return ( <div className="grid grid-cols-1 md:grid-cols-3 gap-4 mt-4"> {addons.map(addon => ( <div key={addon.id} onClick={() => toggleAddon(addon)} className={ border p-4 rounded-lg cursor-pointer transition ${selected.find(a => a.id === addon.id) ? "bg-rose-50 border-rose-400" : "bg-white"} }> <h3 className="font-semibold">{addon.name}</h3> <p className="text-gray-600">${addon.price}</p> </div> ))} </div> ); } import { useEffect, useState } from "react"; export default function HoneymoonCountdown({ weddingDate }) { const [daysLeft, setDaysLeft] = useState(0);
const handleSubmit = async () => { await fetch("/api/honeymoon/profile", { method: "POST", body: JSON.stringify({ userId, ...profile }), headers: { "Content-Type": "application/json" } }); setStep(step + 1); }; honeymoon
-- User's booked honeymoon CREATE TABLE honeymoon_bookings ( id UUID PRIMARY KEY DEFAULT gen_random_uuid(), profile_id UUID REFERENCES honeymoon_profiles(id), package_id UUID REFERENCES honeymoon_packages(id), booking_date TIMESTAMP DEFAULT NOW(), check_in DATE, check_out DATE, total_price DECIMAL(10,2), status VARCHAR(20) DEFAULT 'confirmed' ); return ( <
-- 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) ); div key={addon.id} onClick={() =>