Honeymoon
-- Join table for booking add-ons CREATE TABLE booking_addons ( booking_id UUID REFERENCES honeymoon_bookings(id), addon_id UUID REFERENCES honeymoon_addons(id), quantity INT DEFAULT 1 ); POST /api/honeymoon/profile Create or update honeymoon profile.
const toggleAddon = (addon) => { const exists = selected.find(a => a.id === addon.id); const updated = exists ? selected.filter(a => a.id !== addon.id) : [...selected, addon]; setSelected(updated); onTotalChange(updated.reduce((sum, a) => sum + a.price, 0)); };
-- Romantic add-ons (e.g., candlelight dinner, couple massage) CREATE TABLE honeymoon_addons ( id UUID PRIMARY KEY DEFAULT gen_random_uuid(), name VARCHAR(255), price DECIMAL(10,2), location_specific BOOLEAN DEFAULT FALSE, location_id UUID REFERENCES locations(id) ); honeymoon
profileId
const handleSubmit = async () => { await fetch("/api/honeymoon/profile", { method: "POST", body: JSON.stringify({ userId, ...profile }), headers: { "Content-Type": "application/json" } }); setStep(step + 1); }; -- Join table for booking add-ons CREATE TABLE
useEffect(() => { const interval = setInterval(() => { const diff = new Date(weddingDate) - new Date(); setDaysLeft(Math.ceil(diff / (1000 * 60 * 60 * 24))); }, 1000); return () => clearInterval(interval); }, [weddingDate]);
{ "userId": "uuid", "weddingDate": "2025-06-15", "preferredTravelStart": "2025-06-20", "preferredTravelEnd": "2025-06-30", "totalBudget": 5000, "vibe": "relaxing", "dietaryRestrictions": "vegetarian" } 201 Created with profile object. GET /api/honeymoon/recommendations Get AI-curated honeymoon packages based on profile. setStep] = useState(1)
{ "profileId": "prof_abc", "packageId": "pkg_123", "checkIn": "2025-06-20", "checkOut": "2025-06-27", "addOnIds": ["addon_spa", "addon_dinner"] } Booking confirmation + total price. GET /api/honeymoon/booking/:bookingId Fetch booking details with itinerary and romantic tips. 4. Frontend UI Components (React + TailwindCSS) HoneymoonWizard.jsx – Step-by-step setup import { useState } from "react"; export default function HoneymoonWizard({ userId }) { const [step, setStep] = useState(1); const [profile, setProfile] = useState({ weddingDate: "", totalBudget: "", vibe: "relaxing" });
