Merge version_3 into main #2

Merged
bender merged 6 commits from version_3 into main 2026-02-28 06:46:13 +00:00
6 changed files with 226 additions and 45 deletions

View File

@@ -29,7 +29,7 @@ export default function BlogPage() {
brandName="Baan Mu"
navItems={[
{ name: "Home", id: "/" },
{ name: "Menu", id: "products" },
{ name: "Menu", id: "/menu" },
{ name: "About", id: "about" },
{ name: "Reviews", id: "testimonial" },
{ name: "Contact", id: "contact" }
@@ -67,4 +67,4 @@ export default function BlogPage() {
</ReactLenis>
</ThemeProvider>
);
}
}

View File

@@ -1,53 +1,24 @@
import type { Metadata } from "next";
import { Montserrat } from "next/font/google";
import { Inter } from "next/font/google";
import "./globals.css";
import { ServiceWrapper } from "@/components/ServiceWrapper";
import Tag from "@/tag/Tag";
const montserrat = Montserrat({
variable: "--font-montserrat", subsets: ["latin"],
});
import "./styles/variables.css";
import "./styles/base.css";
const inter = Inter({
variable: "--font-inter", subsets: ["latin"],
});
export const metadata: Metadata = {
title: "Baan Mu - Authentic Thai Restaurant in San Francisco", description: "Discover authentic Thai cuisine at Baan Mu in San Francisco. Fresh ingredients, traditional recipes, and warm hospitality. Reserve your table today.", keywords: "thai restaurant San Francisco, authentic thai food, pad thai, green curry, thai cuisine, fine dining", metadataBase: new URL("https://baanmu.com"),
alternates: {
canonical: "https://baanmu.com"
},
openGraph: {
title: "Baan Mu - Authentic Thai Restaurant in San Francisco", description: "Experience bold flavors and warm hospitality at Baan Mu. The best Thai restaurant in San Francisco with traditional recipes and fresh ingredients.", url: "https://baanmu.com", siteName: "Baan Mu", type: "website", images: [
{
url: "http://img.b2bpic.net/free-photo/medium-fried-pieces-meat-fried-onions_140725-3560.jpg", alt: "Baan Mu Restaurant"
}
]
},
twitter: {
card: "summary_large_image", title: "Baan Mu - Authentic Thai Restaurant in San Francisco", description: "Experience authentic Thai cuisine in the heart of San Francisco. Discover our signature dishes and warm hospitality.", images: ["http://img.b2bpic.net/free-photo/medium-fried-pieces-meat-fried-onions_140725-3560.jpg"]
},
robots: {
index: true,
follow: true
}
};
title: "Baan Mu - Authentic Thai Cuisine", description: "Experience authentic Thai cuisine at Baan Mu in San Francisco"};
export default function RootLayout({
children,
}: Readonly<{
}: {
children: React.ReactNode;
}>) {
}) {
return (
<html lang="en" suppressHydrationWarning>
<ServiceWrapper>
<body
className={`${montserrat.variable} ${inter.variable} antialiased`}
>
<Tag />
{children}
<html lang="en">
<body className={inter.variable}>{children}
<script
dangerouslySetInnerHTML={{
__html: `
@@ -1415,7 +1386,6 @@ export default function RootLayout({
}}
/>
</body>
</ServiceWrapper>
</html>
);
}
}

205
src/app/menu/page.tsx Normal file
View File

@@ -0,0 +1,205 @@
"use client"
import NavbarLayoutFloatingInline from '@/components/navbar/NavbarLayoutFloatingInline';
import HeroBillboard from '@/components/sections/hero/HeroBillboard';
import TextAbout from '@/components/sections/about/TextAbout';
import ProductCardOne from '@/components/sections/product/ProductCardOne';
import MetricCardFourteen from '@/components/sections/metrics/MetricCardFourteen';
import SocialProofOne from '@/components/sections/socialProof/SocialProofOne';
import TestimonialCardTen from '@/components/sections/testimonial/TestimonialCardTen';
import FeatureCardSixteen from '@/components/sections/feature/FeatureCardSixteen';
import ContactText from '@/components/sections/contact/ContactText';
import FooterLogoReveal from '@/components/sections/footer/FooterLogoReveal';
import { ThemeProvider } from "@/providers/themeProvider/ThemeProvider";
import { Sparkles, Heart, ChefHat } from "lucide-react";
export default function MenuPage() {
return (
<ThemeProvider
defaultButtonVariant="icon-arrow"
defaultTextAnimation="background-highlight"
borderRadius="soft"
contentWidth="medium"
sizing="mediumLarge"
background="floatingGradient"
cardStyle="glass-elevated"
primaryButtonStyle="shadow"
secondaryButtonStyle="layered"
headingFontWeight="semibold"
>
<div id="nav" data-section="nav">
<NavbarLayoutFloatingInline
brandName="Baan Mu"
navItems={[
{ name: "Home", id: "/" },
{ name: "Menu", id: "/menu" },
{ name: "About", id: "about" },
{ name: "Reviews", id: "testimonial" },
{ name: "Contact", id: "contact" }
]}
button={{
text: "Reserve Now", href: "https://www.opentable.com"
}}
/>
</div>
<div id="hero" data-section="hero">
<HeroBillboard
title="Our Complete Menu"
description="Explore the full range of authentic Thai dishes we offer. Each item is carefully crafted using traditional recipes and the finest ingredients."
background={{ variant: "sparkles-gradient" }}
tag="Since 2019"
tagIcon={Sparkles}
tagAnimation="slide-up"
imageSrc="http://img.b2bpic.net/free-photo/medium-fried-pieces-meat-fried-onions_140725-3560.jpg"
imageAlt="Baan Mu Menu"
mediaAnimation="blur-reveal"
buttons={[
{ text: "Reserve a Table", href: "https://www.opentable.com" },
{ text: "Back Home", href: "/" }
]}
buttonAnimation="slide-up"
/>
</div>
<div id="about" data-section="about">
<TextAbout
tag="Menu Philosophy"
tagIcon={Heart}
tagAnimation="slide-up"
title="Our menu celebrates the diversity and authenticity of Thai cuisine. Every dish represents centuries of culinary tradition, from street food favorites to royal Thai preparations."
useInvertedBackground={false}
buttons={[
{ text: "Learn More", href: "#" }
]}
buttonAnimation="slide-up"
/>
</div>
<div id="products" data-section="products">
<ProductCardOne
title="Signature Dishes"
description="Explore our carefully curated selection of authentic Thai favorites, each prepared with fresh ingredients and traditional techniques."
tag="Chef's Selection"
tagIcon={ChefHat}
tagAnimation="slide-up"
textboxLayout="default"
useInvertedBackground={false}
products={[
{
id: "1", name: "Pad Thai", price: "$16.95", imageSrc: "http://img.b2bpic.net/free-photo/stir-noodles-fry-green-chinese_1203-5877.jpg", imageAlt: "Pad Thai - Stir-fried noodles"
},
{
id: "2", name: "Green Curry", price: "$18.95", imageSrc: "http://img.b2bpic.net/free-photo/curry-pork-spicy_1388-222.jpg", imageAlt: "Green Curry with chicken"
},
{
id: "3", name: "Tom Yum Soup", price: "$14.95", imageSrc: "http://img.b2bpic.net/free-photo/tom-yum-kung-thai-hot-spicy-soup-shrimp-with-lemon-grass-lemon-galangal-chilli-wooden-table-thailand-food_1150-21062.jpg", imageAlt: "Tom Yum - Hot and sour soup"
}
]}
gridVariant="three-columns-all-equal-width"
animationType="slide-up"
buttons={[
{ text: "View Full Menu", href: "#" }
]}
buttonAnimation="slide-up"
/>
</div>
<div id="metrics" data-section="metrics">
<MetricCardFourteen
title="Menu Highlights"
tag="Baan Mu Menu"
tagAnimation="slide-up"
metrics={[
{
id: "1", value: "40+", description: "Signature dishes on our complete menu"
},
{
id: "2", value: "100%", description: "Made fresh to order with premium ingredients"
}
]}
metricsAnimation="slide-up"
useInvertedBackground={false}
/>
</div>
<div id="socialproof" data-section="socialproof">
<SocialProofOne
title="Loved by Food Enthusiasts"
description="Join thousands of satisfied diners who've discovered their favorite Thai dishes at Baan Mu"
names={[
"Food Critics Choice", "Best Thai 2024", "5-Star Rated", "Local Favorite", "Award Winner"
]}
textboxLayout="default"
useInvertedBackground={false}
showCard={true}
speed={40}
/>
</div>
<div id="testimonial" data-section="testimonial">
<TestimonialCardTen
title="Guest Stories"
description="Hear from our valued guests about their Baan Mu experience"
textboxLayout="default"
useInvertedBackground={false}
testimonials={[
{
id: "1", title: "Authentic Thai in San Francisco", quote: "The flavors are incredible and transport you straight to Bangkok. Every dish is prepared with such care and authenticity. This is now our favorite Thai restaurant in the city.", name: "Sarah Chen", role: "Food Blogger", imageSrc: "http://img.b2bpic.net/free-photo/closeup-young-female-professional-making-eye-contact-against-colored-background_662251-651.jpg", imageAlt: "Sarah Chen"
},
{
id: "2", title: "Outstanding Service & Atmosphere", quote: "From the warm welcome at the door to the final dessert course, everything about Baan Mu is exceptional. The staff really knows their dishes and makes great recommendations.", name: "Michael Torres", role: "Restaurant Critic", imageSrc: "http://img.b2bpic.net/free-photo/pensive-person-alone-corridor-serious_1262-1042.jpg", imageAlt: "Michael Torres"
},
{
id: "3", title: "Perfect for Special Occasions", quote: "We celebrated our anniversary at Baan Mu and it was absolutely perfect. The intimate setting, incredible food, and attentive service made it a night we'll never forget.", name: "Emma Rodriguez", role: "Event Planner", imageSrc: "http://img.b2bpic.net/free-photo/headshot-charismatic-pleasant-friendly-european-woman-short-chestnut-haircut-smiling-positive-feeling-happy-upbeat-enjoying-lifes-casually-talking-friends-amused-cheerful-standing-white-background_176420-34680.jpg", imageAlt: "Emma Rodriguez"
},
{
id: "4", title: "Best Curry in the Bay Area", quote: "The curries here are genuinely some of the best I've had anywhere. The balance of flavors, the heat level, the creamy coconut base - everything is perfectly executed.", name: "James Park", role: "Culinary Chef", imageSrc: "http://img.b2bpic.net/free-photo/smiling-young-handsome-guy-wearing-green-shirt_141793-122624.jpg", imageAlt: "James Park"
}
]}
/>
</div>
<div id="features" data-section="features">
<FeatureCardSixteen
title="Why Choose Baan Mu"
description="Experience the difference of authentic Thai cuisine combined with modern hospitality"
textboxLayout="default"
useInvertedBackground={false}
animationType="slide-up"
negativeCard={{
items: [
"Mass-produced frozen ingredients", "One-size-fits-all menu", "Impersonal dining experience", "Limited customization options"
]
}}
positiveCard={{
items: [
"Fresh, locally-sourced ingredients", "Authentic recipes from Thai masters", "Personalized service and attention", "Customizable spice levels and preferences"
]
}}
/>
</div>
<div id="contact" data-section="contact">
<ContactText
text="Ready to experience authentic Thai cuisine? Reserve your table at Baan Mu today and discover why San Francisco's food lovers choose us."
animationType="background-highlight"
background={{ variant: "plain" }}
useInvertedBackground={false}
buttons={[
{ text: "Make a Reservation", href: "https://www.opentable.com" },
{ text: "Order Online", href: "https://www.doordash.com" }
]}
/>
</div>
<div id="footer" data-section="footer">
<FooterLogoReveal
logoText="Baan Mu"
leftLink={{ text: "Privacy Policy", href: "#" }}
rightLink={{ text: "Contact Us", href: "mailto:hello@baanmu.com" }}
/>
</div>
</ThemeProvider>
);
}

View File

@@ -34,7 +34,8 @@ export default function LandingPage() {
{ name: "Menu", id: "products" },
{ name: "About", id: "about" },
{ name: "Reviews", id: "testimonial" },
{ name: "Contact", id: "contact" }
{ name: "Contact", id: "contact" },
{ name: "Menu Page", id: "/menu" }
]}
button={{
text: "Reserve Now", href: "https://www.opentable.com"
@@ -98,7 +99,7 @@ export default function LandingPage() {
gridVariant="three-columns-all-equal-width"
animationType="slide-up"
buttons={[
{ text: "View Full Menu", href: "#" }
{ text: "View Full Menu", href: "/menu" }
]}
buttonAnimation="slide-up"
/>
@@ -201,4 +202,4 @@ export default function LandingPage() {
</div>
</ThemeProvider>
);
}
}

View File

@@ -94,6 +94,7 @@ function ProductPageContent({ params }: ProductPageProps) {
brandName="Baan Mu"
navItems={[
{"name":"Home","id":"/"},
{"name":"Menu","id":"/menu"},
{"name":"Shop","id":"/shop"}
]}
button={{ text: "Cart", onClick: () => setCartOpen(true) }}
@@ -134,6 +135,7 @@ function ProductPageContent({ params }: ProductPageProps) {
brandName="Baan Mu"
navItems={[
{"name":"Home","id":"/"},
{"name":"Menu","id":"/menu"},
{"name":"Shop","id":"/shop"}
]}
button={{ text: "Cart", onClick: () => setCartOpen(true) }}
@@ -181,6 +183,7 @@ function ProductPageContent({ params }: ProductPageProps) {
brandName="Baan Mu"
navItems={[
{"name":"Home","id":"/"},
{"name":"Menu","id":"/menu"},
{"name":"Shop","id":"/shop"}
]}
button={{ text: "Cart", onClick: () => setCartOpen(true) }}
@@ -232,4 +235,4 @@ function ProductPageContent({ params }: ProductPageProps) {
</ReactLenis>
</ThemeProvider>
);
}
}

View File

@@ -37,6 +37,7 @@ function ShopPageContent() {
brandName="Baan Mu"
navItems={[
{"name":"Home","id":"/"},
{"name":"Menu","id":"/menu"},
{"name":"Shop","id":"/shop"}
]}
button={{ text: "Cart", onClick: () => console.log("cart") }}
@@ -76,6 +77,7 @@ function ShopPageContent() {
brandName="Baan Mu"
navItems={[
{"name":"Home","id":"/"},
{"name":"Menu","id":"/menu"},
{"name":"Shop","id":"/shop"}
]}
button={{ text: "Cart", onClick: () => console.log("cart") }}
@@ -110,4 +112,4 @@ export default function ShopPage() {
<ShopPageContent />
</Suspense>
);
}
}