Merge version_2_1781437956637 into main

Merge version_2_1781437956637 into main
This commit was merged in pull request #1.
This commit is contained in:
2026-06-14 11:53:49 +00:00
10 changed files with 431 additions and 246 deletions

View File

@@ -1,258 +1,41 @@
import AboutText from '@/components/sections/about/AboutText';
import ContactCta from '@/components/sections/contact/ContactCta';
import FaqSimple from '@/components/sections/faq/FaqSimple';
import FeaturesRevealCardsBento from '@/components/sections/features/FeaturesRevealCardsBento';
import FeaturesTaggedCards from '@/components/sections/features/FeaturesTaggedCards';
import HeroBillboardTiltedCarousel from '@/components/sections/hero/HeroBillboardTiltedCarousel';
import MetricsSimpleCards from '@/components/sections/metrics/MetricsSimpleCards';
import TestimonialTrustCard from '@/components/sections/testimonial/TestimonialTrustCard';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
// AUTO-GENERATED shell by per-section-migrate.
// Section bodies live in ./<PageBase>/sections/<X>.tsx. Edit the section
// files directly. Non-block content (wrappers, non-inlinable sections) is
// preserved inline; extracted section blocks become <XSection/> refs.
export default function HomePage() {
import React from 'react';
import HeroSection from './HomePage/sections/Hero';
import AboutSection from './HomePage/sections/About';
import MenuSection from './HomePage/sections/Menu';
import FeaturesSection from './HomePage/sections/Features';
import TestimonialSection from './HomePage/sections/Testimonial';
import MetricsSection from './HomePage/sections/Metrics';
import FaqSection from './HomePage/sections/Faq';
import ContactSection from './HomePage/sections/Contact';
{/* webild-stub @2026-06-14T11:53:44.531Z: Add a location or map section to improve trust and local discovery, as visitors need to know where the restaurant is located to convert. */}
import LocationSection from './HomePage/sections/Location';export default function HomePage(): React.JSX.Element {
return (
<>
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroBillboardTiltedCarousel
tag="Authentic Experience"
title="The Soul of Poland, Served Daily"
description="Indulge in traditional Polish recipes, crafted with love and fresh, local ingredients in a warm, rustic atmosphere."
primaryButton={{
text: "View Menu",
href: "#menu",
}}
secondaryButton={{
text: "Book a Table",
href: "#contact",
}}
items={[
{
imageSrc: "http://img.b2bpic.net/free-photo/raviolli-with-tomato-table_140725-825.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/top-close-view-plate-spices-plate-potatoes-with-mushrooms-wooden-cutting-board_140725-99215.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-thanksgiving-meal-concept_23-2148629583.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/top-view-wooden-table-with-soup-slices-bread_23-2148486530.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/caesar-salad_1203-8975.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/top-view-delicious-meat-soup-with-sliced-vegetables-grey-space_140725-75720.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<>
<HeroSection />
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutText
title="A Legacy of Culinary Tradition"
primaryButton={{
text: "Learn Our Story",
href: "#",
}}
/>
</SectionErrorBoundary>
</div>
<AboutSection />
<div id="menu" data-section="menu">
<SectionErrorBoundary name="menu">
<FeaturesRevealCardsBento
tag="Our Specialties"
title="Traditional Polish Cuisine"
description="Explore our curated menu of classic dishes, prepared with authentic recipes passed down through generations."
items={[
{
title: "Handmade Pierogi",
description: "Classic dumplings filled with potatoes, cheese, or wild mushrooms.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-chinese-hot-pot_23-2149529850.jpg",
},
{
title: "Stuffed Cabbage",
description: "Tender cabbage leaves filled with savory meat and rice.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/close-up-photo-homemade-pickle-filled-pepper-white-plate_114579-66288.jpg",
},
{
title: "Borscht Soup",
description: "Rich, earthy beetroot soup with fresh herbs and sour cream.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/creamy-soup-with-herbs-spices_114579-3423.jpg",
},
{
title: "Bigos Stew",
description: "Hearty hunter's stew made with sauerkraut and premium meats.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-cooked-vegetables-sliced-with-sauce-seasonings-dark-background-meal-food-dinner-soup-sauce-vegetable_140725-85743.jpg",
},
{
title: "Potato Pancakes",
description: "Crispy golden potato pancakes served with savory toppings.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/chicken-cutlets-with-apple-mint_2829-14083.jpg",
},
{
title: "Sweet Cheesecake",
description: "Creamy, traditional Polish cheesecake with a buttery crust.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/homemade-newyork-cheesecake-with-frozen-berries-mint-healthy-organic-dessert-top-view_114579-10404.jpg",
},
{
title: "Smoked Sausage",
description: "Authentic Polish sausages served with mustard and bread.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-cooked-bell-peppers-with-fried-sausages-inside-plate-dark-green-surface_140725-61874.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<MenuSection />
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesTaggedCards
tag="Why We Are Different"
title="The Polonia Promise"
description="Every detail reflects our dedication to Polish culinary heritage."
items={[
{
tag: "Fresh",
title: "Locally Sourced",
description: "We partner with local farmers for the freshest seasonal produce.",
primaryButton: {
text: "Learn More",
href: "#",
},
imageSrc: "http://img.b2bpic.net/free-photo/top-view-raw-chicken-meal-with-potatoes-vegetables-saucepan-red-stripped-towel-tomatoes-salt-gray-background_140725-159403.jpg",
},
{
tag: "Ambiance",
title: "Traditional Interior",
description: "Experience the warmth of Poland in our rustic wooden-themed dining space.",
primaryButton: {
text: "See Gallery",
href: "#",
},
imageSrc: "http://img.b2bpic.net/free-photo/top-view-thanksgiving-plate-with-cutlery_23-2148638930.jpg",
},
{
tag: "Craft",
title: "Authentic Methods",
description: "Recipes prepared with traditional techniques for a truly original taste.",
primaryButton: {
text: "Our Methods",
href: "#",
},
imageSrc: "http://img.b2bpic.net/free-photo/top-view-cakes-with-cinnamon-coffee-beans_23-2148368314.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<FeaturesSection />
<div id="testimonial" data-section="testimonial">
<SectionErrorBoundary name="testimonial">
<TestimonialTrustCard
quote="Polonia Bistro transported me straight back to my childhood in Warsaw. The pierogi are exactly how I remember them—authentic, buttery, and perfect."
rating={5}
author="Elena Kowalski"
avatars={[
{
name: "Elena Kowalski",
imageSrc: "http://img.b2bpic.net/free-photo/having-lunch-spacious-restaurant_52683-117480.jpg",
},
{
name: "Mark Miller",
imageSrc: "http://img.b2bpic.net/free-photo/two-female-friends-eating-burgers-restaurant_23-2148666560.jpg",
},
{
name: "Sarah Davis",
imageSrc: "http://img.b2bpic.net/free-photo/ham-slices-with-potatoes_140725-3769.jpg",
},
{
name: "John Smith",
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-redhead-woman-having-fun-while-having-dinner-with-friends-home_637285-3551.jpg",
},
{
name: "Anna Becker",
imageSrc: "http://img.b2bpic.net/free-photo/adults-enjoying-mexican-food_23-2149663830.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<TestimonialSection />
<div id="metrics" data-section="metrics">
<SectionErrorBoundary name="metrics">
<MetricsSimpleCards
tag="Our History"
title="Serving Polish Joy"
description="Celebrating years of culinary excellence and traditional warmth."
metrics={[
{
value: "12+",
description: "Years of Tradition",
},
{
value: "5000+",
description: "Happy Guests Served",
},
{
value: "15+",
description: "Authentic Recipes",
},
]}
/>
</SectionErrorBoundary>
</div>
<MetricsSection />
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqSimple
tag="Common Questions"
title="Helpful Info"
description="Quick answers to common questions about our bistro."
items={[
{
question: "Do you accept reservations?",
answer: "Yes, we recommend booking in advance, especially for weekends.",
},
{
question: "Do you offer vegan options?",
answer: "We have several plant-based dishes, including our wild mushroom pierogi.",
},
{
question: "Is there parking available?",
answer: "Free parking is available behind the restaurant.",
},
]}
/>
</SectionErrorBoundary>
</div>
<FaqSection />
<LocationSection />
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Book Now"
text="Reserve your table and join us for an unforgettable meal."
primaryButton={{
text: "Book a Table",
href: "#",
}}
secondaryButton={{
text: "View Location",
href: "#",
}}
/>
</SectionErrorBoundary>
</div>
<ContactSection />
</>
);
}

View File

@@ -0,0 +1,22 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "about" section.
import React from 'react';
import AboutText from '@/components/sections/about/AboutText';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function AboutSection(): React.JSX.Element {
return (
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutText
title="A Legacy of Culinary Tradition"
primaryButton={{
text: "Learn Our Story",
href: "#",
}}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,27 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "contact" section.
import React from 'react';
import ContactCta from '@/components/sections/contact/ContactCta';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function ContactSection(): React.JSX.Element {
return (
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Book Now"
text="Reserve your table and join us for an unforgettable meal."
primaryButton={{
text: "Book a Table",
href: "#",
}}
secondaryButton={{
text: "View Location",
href: "#",
}}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,34 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "faq" section.
import React from 'react';
import FaqSimple from '@/components/sections/faq/FaqSimple';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FaqSection(): React.JSX.Element {
return (
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqSimple
tag="Common Questions"
title="Helpful Info"
description="Quick answers to common questions about our bistro."
items={[
{
question: "Do you accept reservations?",
answer: "Yes, we recommend booking in advance, especially for weekends.",
},
{
question: "Do you offer vegan options?",
answer: "We have several plant-based dishes, including our wild mushroom pierogi.",
},
{
question: "Is there parking available?",
answer: "Free parking is available behind the restaurant.",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,52 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "features" section.
import React from 'react';
import FeaturesTaggedCards from '@/components/sections/features/FeaturesTaggedCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FeaturesSection(): React.JSX.Element {
return (
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesTaggedCards
tag="Why We Are Different"
title="The Polonia Promise"
description="Every detail reflects our dedication to Polish culinary heritage."
items={[
{
tag: "Fresh",
title: "Locally Sourced",
description: "We partner with local farmers for the freshest seasonal produce.",
primaryButton: {
text: "Learn More",
href: "#",
},
imageSrc: "http://img.b2bpic.net/free-photo/top-view-raw-chicken-meal-with-potatoes-vegetables-saucepan-red-stripped-towel-tomatoes-salt-gray-background_140725-159403.jpg",
},
{
tag: "Ambiance",
title: "Traditional Interior",
description: "Experience the warmth of Poland in our rustic wooden-themed dining space.",
primaryButton: {
text: "See Gallery",
href: "#",
},
imageSrc: "http://img.b2bpic.net/free-photo/top-view-thanksgiving-plate-with-cutlery_23-2148638930.jpg",
},
{
tag: "Craft",
title: "Authentic Methods",
description: "Recipes prepared with traditional techniques for a truly original taste.",
primaryButton: {
text: "Our Methods",
href: "#",
},
imageSrc: "http://img.b2bpic.net/free-photo/top-view-cakes-with-cinnamon-coffee-beans_23-2148368314.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,48 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "hero" section.
import React from 'react';
import HeroBillboardTiltedCarousel from '@/components/sections/hero/HeroBillboardTiltedCarousel';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function HeroSection(): React.JSX.Element {
return (
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroBillboardTiltedCarousel
tag="Authentic Experience"
title="The Soul of Poland, Served Daily"
description="Indulge in traditional Polish recipes, crafted with love and fresh, local ingredients in a warm, rustic atmosphere."
primaryButton={{
text: "View Menu",
href: "#menu",
}}
secondaryButton={{
text: "Book a Table",
href: "#contact",
}}
items={[
{
imageSrc: "http://img.b2bpic.net/free-photo/raviolli-with-tomato-table_140725-825.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/top-close-view-plate-spices-plate-potatoes-with-mushrooms-wooden-cutting-board_140725-99215.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-thanksgiving-meal-concept_23-2148629583.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/top-view-wooden-table-with-soup-slices-bread_23-2148486530.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/caesar-salad_1203-8975.jpg",
},
{
imageSrc: "http://img.b2bpic.net/free-photo/top-view-delicious-meat-soup-with-sliced-vegetables-grey-space_140725-75720.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,79 @@
import ScrollReveal from '@/components/ui/ScrollReveal';
import { MapPin, Clock, Phone } from 'lucide-react';
export default function LocationSection() {
return (
<section className="relative w-full py-24 bg-background" data-webild-section="location" id="location">
<div className="max-w-content-width mx-auto px-6">
<ScrollReveal variant="fade">
<div className="text-center mb-16">
<h2 className="text-4xl md:text-5xl font-bold text-foreground mb-4">Visit Us</h2>
<p className="text-lg text-muted-foreground max-w-2xl mx-auto">
Experience authentic Polish cuisine in a warm, welcoming atmosphere. We are located in the heart of the city.
</p>
</div>
</ScrollReveal>
<div className="grid grid-cols-1 lg:grid-cols-2 gap-12 items-center">
<ScrollReveal variant="slide-up" delay={0.1}>
<div className="space-y-8">
<div className="flex items-start gap-4">
<div className="w-12 h-12 rounded-full bg-card flex items-center justify-center shrink-0">
<MapPin className="w-6 h-6 text-foreground" />
</div>
<div>
<h3 className="text-xl font-semibold text-foreground mb-2">Address</h3>
<p className="text-muted-foreground">
123 Culinary Avenue<br />
Warsaw, Poland 00-001
</p>
</div>
</div>
<div className="flex items-start gap-4">
<div className="w-12 h-12 rounded-full bg-card flex items-center justify-center shrink-0">
<Clock className="w-6 h-6 text-foreground" />
</div>
<div>
<h3 className="text-xl font-semibold text-foreground mb-2">Opening Hours</h3>
<p className="text-muted-foreground">
Monday - Friday: 11:00 AM - 10:00 PM<br />
Saturday - Sunday: 10:00 AM - 11:00 PM
</p>
</div>
</div>
<div className="flex items-start gap-4">
<div className="w-12 h-12 rounded-full bg-card flex items-center justify-center shrink-0">
<Phone className="w-6 h-6 text-foreground" />
</div>
<div>
<h3 className="text-xl font-semibold text-foreground mb-2">Contact</h3>
<p className="text-muted-foreground">
+48 123 456 789<br />
hello@polishrestaurant.com
</p>
</div>
</div>
</div>
</ScrollReveal>
<ScrollReveal variant="slide-up" delay={0.2}>
<div className="w-full h-[400px] rounded-3xl overflow-hidden bg-card border border-border">
<iframe
src="https://www.google.com/maps/embed?pb=!1m18!1m12!1m3!1d78385.33446030911!2d20.95475653556515!3d52.23306532087612!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!3m3!1m2!1s0x471ecc669a869f01%3A0x72f0be2a88ead3fc!2sWarsaw%2C%20Poland!5e0!3m2!1sen!2sus!4v1715000000000!5m2!1sen!2sus"
width="100%"
height="100%"
style={{ border: 0 }}
allowFullScreen={true}
loading="lazy"
referrerPolicy="no-referrer-when-downgrade"
className="grayscale opacity-90 hover:grayscale-0 transition-all duration-500"
></iframe>
</div>
</ScrollReveal>
</div>
</div>
</section>
);
}

View File

@@ -0,0 +1,64 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "menu" section.
import React from 'react';
import FeaturesRevealCardsBento from '@/components/sections/features/FeaturesRevealCardsBento';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function MenuSection(): React.JSX.Element {
return (
<div id="menu" data-section="menu">
<SectionErrorBoundary name="menu">
<FeaturesRevealCardsBento
tag="Our Specialties"
title="Traditional Polish Cuisine"
description="Explore our curated menu of classic dishes, prepared with authentic recipes passed down through generations."
items={[
{
title: "Handmade Pierogi",
description: "Classic dumplings filled with potatoes, cheese, or wild mushrooms.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-chinese-hot-pot_23-2149529850.jpg",
},
{
title: "Stuffed Cabbage",
description: "Tender cabbage leaves filled with savory meat and rice.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/close-up-photo-homemade-pickle-filled-pepper-white-plate_114579-66288.jpg",
},
{
title: "Borscht Soup",
description: "Rich, earthy beetroot soup with fresh herbs and sour cream.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/creamy-soup-with-herbs-spices_114579-3423.jpg",
},
{
title: "Bigos Stew",
description: "Hearty hunter's stew made with sauerkraut and premium meats.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-cooked-vegetables-sliced-with-sauce-seasonings-dark-background-meal-food-dinner-soup-sauce-vegetable_140725-85743.jpg",
},
{
title: "Potato Pancakes",
description: "Crispy golden potato pancakes served with savory toppings.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/chicken-cutlets-with-apple-mint_2829-14083.jpg",
},
{
title: "Sweet Cheesecake",
description: "Creamy, traditional Polish cheesecake with a buttery crust.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/homemade-newyork-cheesecake-with-frozen-berries-mint-healthy-organic-dessert-top-view_114579-10404.jpg",
},
{
title: "Smoked Sausage",
description: "Authentic Polish sausages served with mustard and bread.",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-cooked-bell-peppers-with-fried-sausages-inside-plate-dark-green-surface_140725-61874.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,34 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "metrics" section.
import React from 'react';
import MetricsSimpleCards from '@/components/sections/metrics/MetricsSimpleCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function MetricsSection(): React.JSX.Element {
return (
<div id="metrics" data-section="metrics">
<SectionErrorBoundary name="metrics">
<MetricsSimpleCards
tag="Our History"
title="Serving Polish Joy"
description="Celebrating years of culinary excellence and traditional warmth."
metrics={[
{
value: "12+",
description: "Years of Tradition",
},
{
value: "5000+",
description: "Happy Guests Served",
},
{
value: "15+",
description: "Authentic Recipes",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,42 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "testimonial" section.
import React from 'react';
import TestimonialTrustCard from '@/components/sections/testimonial/TestimonialTrustCard';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function TestimonialSection(): React.JSX.Element {
return (
<div id="testimonial" data-section="testimonial">
<SectionErrorBoundary name="testimonial">
<TestimonialTrustCard
quote="Polonia Bistro transported me straight back to my childhood in Warsaw. The pierogi are exactly how I remember them—authentic, buttery, and perfect."
rating={5}
author="Elena Kowalski"
avatars={[
{
name: "Elena Kowalski",
imageSrc: "http://img.b2bpic.net/free-photo/having-lunch-spacious-restaurant_52683-117480.jpg",
},
{
name: "Mark Miller",
imageSrc: "http://img.b2bpic.net/free-photo/two-female-friends-eating-burgers-restaurant_23-2148666560.jpg",
},
{
name: "Sarah Davis",
imageSrc: "http://img.b2bpic.net/free-photo/ham-slices-with-potatoes_140725-3769.jpg",
},
{
name: "John Smith",
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-redhead-woman-having-fun-while-having-dinner-with-friends-home_637285-3551.jpg",
},
{
name: "Anna Becker",
imageSrc: "http://img.b2bpic.net/free-photo/adults-enjoying-mexican-food_23-2149663830.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}