61 lines
2.3 KiB
PHP
61 lines
2.3 KiB
PHP
<?php
|
|
require_once("env.php");
|
|
require_once("connection.php");
|
|
require_once("functions.php");
|
|
|
|
// Start session to retrieve the logged-in user's ID
|
|
session_start();
|
|
|
|
// Get user ID from session (assuming user is logged in)
|
|
$user_id = isset($_SESSION['user_id']) ? $_SESSION['user_id'] : null;
|
|
|
|
// Check if the form has been submitted
|
|
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
|
|
// Get values from the form
|
|
$from_date = $_POST['from_date'];
|
|
$to_date = $_POST['to_date'];
|
|
$num_vehicles = (int)$_POST['vehicles'];
|
|
$num_adults = (int)$_POST['adults'];
|
|
$num_children = (int)$_POST['children'];
|
|
$add_firewood = isset($_POST['AddExtra']) ? 1 : 0; // Checkbox for extras
|
|
$is_member = isset($_POST['is_member']) ? (int)$_POST['is_member'] : 0; // Hidden member status
|
|
$type = "camping";
|
|
|
|
// Calculate the total number of nights
|
|
$date1 = new DateTime($from_date);
|
|
$date2 = new DateTime($to_date);
|
|
$nights = $date2->diff($date1)->days;
|
|
|
|
// Determine rate per night
|
|
$rate_per_night = ($is_member) ? 0 : 200; // Free for members, R200 for non-members
|
|
|
|
// Calculate the total cost
|
|
$vehicle_cost = $rate_per_night * $num_vehicles * $nights;
|
|
$firewood_cost = $add_firewood ? 50 : 0;
|
|
$total_amount = $vehicle_cost + $firewood_cost;
|
|
|
|
// Calculate discount if the user is a member
|
|
$discount_amount = ($is_member) ? $vehicle_cost : 0;
|
|
|
|
// Insert booking into the database
|
|
$sql = "INSERT INTO bookings (booking_type, user_id, from_date, to_date, num_vehicles, num_adults, num_children, add_firewood, total_amount, discount_amount)
|
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
|
|
|
|
$stmt = $conn->prepare($sql);
|
|
$stmt->bind_param('sissiiiidd', $type, $user_id, $from_date, $to_date, $num_vehicles, $num_adults, $num_children, $add_firewood, $total_amount, $discount_amount);
|
|
|
|
if ($stmt->execute()) {
|
|
// Redirect to success page or display success message
|
|
echo "<script>alert('Booking successfully created!'); window.location.href = 'booking.php';</script>";
|
|
} else {
|
|
// Handle error if insert fails
|
|
echo "<script>alert('Error processing booking. Please try again later.');</script>";
|
|
}
|
|
|
|
$stmt->close();
|
|
$conn->close();
|
|
} else {
|
|
echo "Invalid request.";
|
|
}
|
|
?>
|