170 lines
7.3 KiB
PHP
170 lines
7.3 KiB
PHP
<?php
|
|
ini_set('display_errors', 1);
|
|
ini_set('display_startup_errors', 1);
|
|
error_reporting(E_ALL);
|
|
|
|
require_once 'includes/pexels.php';
|
|
$query = 'contact';
|
|
$orientation = 'landscape';
|
|
$url = 'https://api.pexels.com/v1/search?query=' . urlencode($query) . '&orientation=' . urlencode($orientation) . '&per_page=1&page=1';
|
|
$data = pexels_get($url);
|
|
$hero_image_url = '';
|
|
if ($data && !empty($data['photos'])) {
|
|
$photo = $data['photos'][0];
|
|
$src = $photo['src']['large2x'] ?? ($photo['src']['large'] ?? $photo['src']['original']);
|
|
$target = __DIR__ . '/assets/images/pexels/' . $photo['id'] . '.jpg';
|
|
download_to($src, $target);
|
|
$hero_image_url = 'assets/images/pexels/' . $photo['id'] . '.jpg';
|
|
}
|
|
|
|
$message = '';
|
|
if ($_SERVER["REQUEST_METHOD"] == "POST") {
|
|
require_once __DIR__ . '/mail/MailService.php';
|
|
$name = filter_var($_POST['name'], FILTER_SANITIZE_STRING);
|
|
$email = filter_var($_POST['email'], FILTER_SANITIZE_EMAIL);
|
|
$body = filter_var($_POST['message'], FILTER_SANITIZE_STRING);
|
|
|
|
$result = MailService::sendContactMessage($name, $email, $body);
|
|
|
|
if (!empty($result['success'])) {
|
|
$message = '<div class="alert alert-success">Thank you for your message. We will get back to you shortly.</div>';
|
|
} else {
|
|
$message = '<div class="alert alert-danger">Sorry, there was an error sending your message. Please try again later.</div>';
|
|
}
|
|
}
|
|
?>
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>Contact Us</title>
|
|
<!-- SEO and Meta Tags -->
|
|
<meta name="description" content="Get in touch with us for any questions or feedback.">
|
|
<meta name="keywords" content="contact, support, feedback, help">
|
|
|
|
<!-- Bootstrap CSS -->
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css">
|
|
|
|
<!-- Custom CSS -->
|
|
<link rel="stylesheet" href="assets/css/custom.css?v=<?php echo time(); ?>">
|
|
|
|
<style>
|
|
.hero-section {
|
|
background-image: url('<?php echo $hero_image_url; ?>');
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
|
|
<!-- Header -->
|
|
<header>
|
|
<nav class="navbar navbar-expand-lg navbar-light fixed-top transparent-nav">
|
|
<div class="container">
|
|
<a class="navbar-brand" href="index.php">👵 Grandma's Getaway</a>
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
<div class="collapse navbar-collapse" id="navbarNav">
|
|
<ul class="navbar-nav ms-auto align-items-center">
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="index.php#how-it-works">How It Works</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="index.php#features">For Parents</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="index.php#features">For Caregivers</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link active" href="contact.php">Contact</a>
|
|
</li>
|
|
<li class="nav-item ms-lg-3">
|
|
<a class="nav-link" href="register.php">Register</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="login.php">Sign In</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
</header>
|
|
|
|
<main>
|
|
<section class="hero-section">
|
|
<div class="container">
|
|
<div class="row">
|
|
<div class="col-md-10 offset-md-1">
|
|
<h1>Get In Touch</h1>
|
|
<p class="lead">We'd love to hear from you. Send us a message and we'll respond as soon as possible.</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="section">
|
|
<div class="container">
|
|
<div class="row">
|
|
<div class="col-md-8 offset-md-2">
|
|
<div class="card p-5 shadow-lg border-0" style="border-radius: 15px;">
|
|
<h2 class="text-center mb-4">Contact Form</h2>
|
|
<?php if ($message) echo $message; ?>
|
|
<form action="contact.php" method="post">
|
|
<div class="mb-3">
|
|
<label for="name" class="form-label">Name</label>
|
|
<input type="text" class="form-control form-control-lg" id="name" name="name" required>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="email" class="form-label">Email address</label>
|
|
<input type="email" class="form-control form-control-lg" id="email" name="email" required>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="message" class="form-label">Message</label>
|
|
<textarea class="form-control form-control-lg" id="message" name="message" rows="5" required></textarea>
|
|
</div>
|
|
<div class="d-grid gap-2 d-md-flex justify-content-md-between">
|
|
<a href="index.php" class="btn btn-secondary btn-lg">Back to Home</a>
|
|
<button type="submit" class="btn btn-primary btn-lg">Submit</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
</main>
|
|
|
|
<!-- Footer -->
|
|
<footer class="footer">
|
|
<div class="container text-center">
|
|
<p>© <?php echo date("Y"); ?> <?php echo htmlspecialchars(getenv('PROJECT_NAME') ?: 'Grandma\'s Getaway'); ?>. All Rights Reserved.</p>
|
|
<p>
|
|
<a href="#">Privacy Policy</a> |
|
|
<a href="#">Terms of Service</a> |
|
|
<a href="contact.php">Contact Us</a>
|
|
p>
|
|
</div>
|
|
</footer>
|
|
|
|
<!-- Bootstrap JS -->
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js"></script>
|
|
|
|
<!-- Custom JS -->
|
|
<script src="assets/js/main.js?v=<?php echo time(); ?>"></script>
|
|
|
|
<script>
|
|
document.addEventListener('scroll', function() {
|
|
const header = document.querySelector('.transparent-nav');
|
|
if (window.scrollY > 50) {
|
|
header.classList.add('scrolled');
|
|
} else {
|
|
header.classList.remove('scrolled');
|
|
}
|
|
});
|
|
</script>
|
|
|
|
</body>
|
|
</html>
|