Merge version_2_1781557767341 into main #1

Merged
bender merged 1 commits from version_2_1781557767341 into main 2026-06-15 21:11:35 +00:00
10 changed files with 377 additions and 220 deletions

View File

@@ -57,28 +57,28 @@ export default function Layout() {
brand="Restoran Barrel"
columns={[
{
title: "Navigation",
title: "Navigacija",
items: [
{
label: "About",
label: "O nama",
href: "#about",
},
{
label: "Menu",
label: "Jelovnik",
href: "#menu",
},
{
label: "Contact",
label: "Kontakt",
href: "#contact",
},
],
},
{
title: "Socials",
title: "Društvene mreže",
items: [
{
label: "Instagram",
href: "#",
href: "https://www.instagram.com/restoran_barrel/",
},
{
label: "Facebook",
@@ -87,27 +87,27 @@ export default function Layout() {
],
},
{
title: "Legal",
title: "Kontakt",
items: [
{
label: "Privacy Policy",
href: "#",
label: "info@restoran-barrel.hr",
href: "mailto:info@restoran-barrel.hr",
},
{
label: "Terms of Use",
href: "#",
label: "+385 1 2043 419",
href: "tel:+38512043419",
},
],
},
]}
copyright="© 2024 Restoran Barrel. All rights reserved."
copyright="© 2024 Restoran Barrel. Sva prava pridržana."
links={[
{
label: "Privacy Policy",
label: "Politika privatnosti",
href: "#",
},
{
label: "Terms",
label: "Uvjeti korištenja",
href: "#",
},
]}

View File

@@ -1,217 +1,35 @@
import AboutMediaOverlay from '@/components/sections/about/AboutMediaOverlay';
import ContactCta from '@/components/sections/contact/ContactCta';
import FaqTwoColumn from '@/components/sections/faq/FaqTwoColumn';
import FeaturesDetailedCards from '@/components/sections/features/FeaturesDetailedCards';
import FeaturesImageBento from '@/components/sections/features/FeaturesImageBento';
import HeroSplit from '@/components/sections/hero/HeroSplit';
import TestimonialMarqueeCards from '@/components/sections/testimonial/TestimonialMarqueeCards';
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 FeaturesSection from './HomePage/sections/Features';
import MenuSection from './HomePage/sections/Menu';
import TestimonialSection from './HomePage/sections/Testimonial';
import FaqSection from './HomePage/sections/Faq';
import ContactSection from './HomePage/sections/Contact';
import GallerySection from './HomePage/sections/Gallery';export default function HomePage(): React.JSX.Element {
return (
<>
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroSplit
tag="Since 2010"
title="Restoran Barrel Soblinec"
description="Where tradition meets culinary perfection. Experience the authentic taste of the region in a warm, sophisticated setting."
primaryButton={{
text: "Explore Menu",
href: "#menu",
}}
secondaryButton={{
text: "Book a Table",
href: "#contact",
}}
imageSrc="http://img.b2bpic.net/free-photo/top-view-radish-meal-with-meat-inside-white-plate-table-food-meal-dinner-restaurant_140725-28248.jpg"
/>
</SectionErrorBoundary>
</div>
<>
<HeroSection />
<GallerySection />
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutMediaOverlay
tag="Our Story"
title="A Passion for Excellence"
description="Restoran Barrel was born out of a desire to create a space that combines culinary craftsmanship with a warm, inviting atmosphere. We source only the finest local ingredients to serve you memorable meals."
imageSrc="http://img.b2bpic.net/free-photo/table-set-dinning-table_1339-3439.jpg"
/>
</SectionErrorBoundary>
</div>
<AboutSection />
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesDetailedCards
tag="Our Standards"
title="Excellence in Every Detail"
description="We believe in transparency and quality in everything we prepare."
items={[
{
title: "Fresh Local Produce",
description: "We partner with local farms to ensure every vegetable and fruit is fresh.",
tags: [
"Organic",
"Farm-to-Table",
],
imageSrc: "http://img.b2bpic.net/free-photo/top-view-fresh-red-tomatoes-with-greens-grey-surface_140725-90517.jpg",
},
{
title: "Crafted Beverages",
description: "Our extensive wine list features carefully selected vintages from top vineyards.",
tags: [
"Wine",
"Cocktails",
],
imageSrc: "http://img.b2bpic.net/free-photo/high-angle-smiley-man-cheese_23-2149428778.jpg",
},
{
title: "Authentic Recipes",
description: "Time-honored family recipes passed through generations, modernized for excellence.",
tags: [
"Authentic",
"Tradition",
],
imageSrc: "http://img.b2bpic.net/free-photo/wine-bottle-ice-bucket-with-couple-toasting-wine-glasses_23-2147891234.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<FeaturesSection />
<div id="menu" data-section="menu">
<SectionErrorBoundary name="menu">
<FeaturesImageBento
tag="Signature Menu"
title="Culinary Delights"
description="Discover our signature dishes prepared with love and precision."
items={[
{
title: "Signature Steak",
description: "Dry-aged for 45 days, perfectly seared.",
imageSrc: "http://img.b2bpic.net/free-photo/local-food-meal-assortment_23-2148833773.jpg",
},
{
title: "Seafood Special",
description: "Fresh daily catch from local sources.",
imageSrc: "http://img.b2bpic.net/free-photo/fried-shrimps-with-green-sauce-table_140725-2118.jpg",
},
{
title: "Artisan Pasta",
description: "Homemade pasta with rich herb sauce.",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-dough-pasta-cooked-tasty-salted-inside-round-blue-plate-with-glasses-wine-flowers-inside-jug-designed-carpet-dark-desk-italian-meal-cuisine_140725-24369.jpg",
},
{
title: "Roasted Vegetables",
description: "Seasonal harvest, lightly drizzled.",
imageSrc: "http://img.b2bpic.net/free-photo/artistic-presentation-gourmet-ice-cream-dessert-stylish-bowl-with-floral-garnishes_23-2151973726.jpg",
},
{
title: "Chef's Dessert",
description: "The perfect sweet finish to your meal.",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-sliced-vegetable-meal-delicious-beans-meal-with-olive-oil-blue-background_140725-58379.jpg",
},
{
title: "Rich Soup",
description: "Hearty seasonal bowl of comfort.",
imageSrc: "http://img.b2bpic.net/free-photo/delicious-creamy-melted-cheese_23-2149332835.jpg",
},
{
title: "Barrel Platter",
description: "A mix of our finest appetizers.",
imageSrc: "http://img.b2bpic.net/free-photo/fried-piece-meat-potatoes-fried-tomato_140725-6649.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<MenuSection />
<div id="testimonial" data-section="testimonial">
<SectionErrorBoundary name="testimonial">
<TestimonialMarqueeCards
tag="Reviews"
title="Stories from Our Guests"
description="What our visitors say about their experience at Barrel."
testimonials={[
{
name: "Marko I.",
role: "Food Critic",
quote: "The absolute highlight of Soblinec. Incredible atmosphere and even better food.",
imageSrc: "http://img.b2bpic.net/free-photo/attractive-happy-young-bearded-man-trendy-hat-texting-messages-via-social-networks-browsing-internet-using-free-wifi-his-electronic-device-coffee-break-restaurant_273609-1934.jpg",
},
{
name: "Ana S.",
role: "Regular Guest",
quote: "I love the warm ambiance and the fresh seafood. A true classic.",
imageSrc: "http://img.b2bpic.net/free-photo/front-view-woman-having-lunch-restaurant_23-2150491815.jpg",
},
{
name: "Ivan D.",
role: "Traveler",
quote: "A hidden gem. The service was impeccable and the menu is outstanding.",
imageSrc: "http://img.b2bpic.net/free-photo/happy-woman-enjoying-dining-table-while-communicating-with-her-husband_637285-3516.jpg",
},
{
name: "Petra L.",
role: "Blogger",
quote: "One of the few places that delivers on both taste and aesthetic.",
imageSrc: "http://img.b2bpic.net/free-photo/one-companions_1098-13516.jpg",
},
{
name: "Tomislav B.",
role: "Local",
quote: "Best place for family gatherings. Consistent quality every single time.",
imageSrc: "http://img.b2bpic.net/free-photo/photo-overjoyed-dark-skinned-girl-has-bushy-hair-laughs-looks-aside-uses-cell-phone-online-communication-messaging-with-friends-drinks-smoothie-cozy-cafeteria_273609-29417.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<TestimonialSection />
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqTwoColumn
tag="Common Questions"
title="Need Information?"
description="Here is what our guests often ask."
items={[
{
question: "Do I need a reservation?",
answer: "Reservations are recommended, especially on weekends and evenings.",
},
{
question: "Do you accommodate dietary restrictions?",
answer: "Yes, please inform us when making a booking so we can accommodate you.",
},
{
question: "Are pets allowed?",
answer: "Pets are welcome on our outdoor terrace.",
},
{
question: "Do you offer catering services?",
answer: "Yes, we handle special events and private gatherings.",
},
]}
/>
</SectionErrorBoundary>
</div>
<FaqSection />
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Visit Us"
text="Join us at Restoran Barrel for an unforgettable dining experience in Soblinec. We are ready to serve you."
primaryButton={{
text: "Book a Table",
href: "tel:+38511234567",
}}
secondaryButton={{
text: "Contact Us",
href: "mailto:info@barrel-soblinec.hr",
}}
/>
</SectionErrorBoundary>
</div>
<ContactSection />
</>
);
}

View File

@@ -0,0 +1,21 @@
// 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 AboutMediaOverlay from '@/components/sections/about/AboutMediaOverlay';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function AboutSection(): React.JSX.Element {
return (
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutMediaOverlay
tag="Our Story"
title="A Passion for Excellence"
description="Restoran Barrel was born out of a desire to create a space that combines culinary craftsmanship with a warm, inviting atmosphere. We source only the finest local ingredients to serve you memorable meals."
imageSrc="http://img.b2bpic.net/free-photo/table-set-dinning-table_1339-3439.jpg"
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,21 @@
// 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="Posjetite nas"
text="Pridružite nam se u Restoranu Barrel na nezaboravnom gastronomskom iskustvu u Soblincu. Spremni smo vas ugostiti."
primaryButton={{"href":"tel:+38512043419","text":"Nazovite nas"}}
secondaryButton={{"href":"mailto:info@restoran-barrel.hr","text":"Pošaljite e-mail"}}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,38 @@
// 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 FaqTwoColumn from '@/components/sections/faq/FaqTwoColumn';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FaqSection(): React.JSX.Element {
return (
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqTwoColumn
tag="Common Questions"
title="Need Information?"
description="Here is what our guests often ask."
items={[
{
question: "Do I need a reservation?",
answer: "Reservations are recommended, especially on weekends and evenings.",
},
{
question: "Do you accommodate dietary restrictions?",
answer: "Yes, please inform us when making a booking so we can accommodate you.",
},
{
question: "Are pets allowed?",
answer: "Pets are welcome on our outdoor terrace.",
},
{
question: "Do you offer catering services?",
answer: "Yes, we handle special events and private gatherings.",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,49 @@
// 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 FeaturesDetailedCards from '@/components/sections/features/FeaturesDetailedCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FeaturesSection(): React.JSX.Element {
return (
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesDetailedCards
tag="Our Standards"
title="Excellence in Every Detail"
description="We believe in transparency and quality in everything we prepare."
items={[
{
title: "Fresh Local Produce",
description: "We partner with local farms to ensure every vegetable and fruit is fresh.",
tags: [
"Organic",
"Farm-to-Table",
],
imageSrc: "http://img.b2bpic.net/free-photo/top-view-fresh-red-tomatoes-with-greens-grey-surface_140725-90517.jpg",
},
{
title: "Crafted Beverages",
description: "Our extensive wine list features carefully selected vintages from top vineyards.",
tags: [
"Wine",
"Cocktails",
],
imageSrc: "http://img.b2bpic.net/free-photo/high-angle-smiley-man-cheese_23-2149428778.jpg",
},
{
title: "Authentic Recipes",
description: "Time-honored family recipes passed through generations, modernized for excellence.",
tags: [
"Authentic",
"Tradition",
],
imageSrc: "http://img.b2bpic.net/free-photo/wine-bottle-ice-bucket-with-couple-toasting-wine-glasses_23-2147891234.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,78 @@
import { motion } from "motion/react"
import TextAnimation from "@/components/ui/TextAnimation"
import ScrollReveal from "@/components/ui/ScrollReveal"
import ImageOrVideo from "@/components/ui/ImageOrVideo"
import Tag from "@/components/ui/Tag"
import Button from "@/components/ui/Button"
export default function GallerySection() {
const items = [
{
title: "Odrezak",
description: "Naš prepoznatljivi odrezak, savršeno pečen.",
imageSrc: "https://images.unsplash.com/photo-1544025162-d76694265947?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&q=80"
},
{
title: "Salata",
description: "Svježa i ukusna salata s lokalnim sastojcima.",
imageSrc: "https://images.unsplash.com/photo-1512621776951-a57141f2eefd?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&q=80"
},
{
title: "Ambijent",
description: "Naš ugodan i topao interijer.",
imageSrc: "https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&q=80"
},
{
title: "Terasa",
description: "Uživajte u obroku na našoj prostranoj terasi.",
imageSrc: "https://images.unsplash.com/photo-1555396273-367ea4eb4db5?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&q=80"
}
];
return (
<section data-webild-section="gallery" id="gallery" className="relative w-full py-24 bg-background">
<div className="w-content-width mx-auto px-6">
<div className="flex flex-col items-center text-center mb-16">
<ScrollReveal variant="fade">
<Tag text="Galerija" className="mb-4" />
</ScrollReveal>
<TextAnimation
text="Naš prostor i hrana"
variant="slide-up"
gradientText={false}
tag="h2"
className="text-4xl md:text-5xl font-bold text-foreground mb-4"
/>
<ScrollReveal variant="fade" delay={0.1}>
<p className="text-lg text-muted-foreground max-w-2xl mx-auto">
Pogledajte naš prekrasan ambijent i neka od naših najpopularnijih jela.
</p>
</ScrollReveal>
</div>
<div className="grid grid-cols-1 md:grid-cols-2 gap-6 mb-12">
{items.map((item, index) => (
<ScrollReveal variant="fade" key={index} delay={index * 0.1}>
<div className="group relative overflow-hidden rounded-theme card h-80">
<ImageOrVideo
imageSrc={item.imageSrc}
className="w-full h-full object-cover transition-transform duration-500 group-hover:scale-105"
/>
<div className="absolute inset-0 bg-gradient-to-t from-black/80 via-black/20 to-transparent opacity-0 group-hover:opacity-100 transition-opacity duration-300 flex flex-col justify-end p-6">
<h3 className="text-xl font-bold text-white mb-2">{item.title}</h3>
<p className="text-white/80 text-sm">{item.description}</p>
</div>
</div>
</ScrollReveal>
))}
</div>
<div className="flex justify-center">
<ScrollReveal variant="fade" delay={0.4}>
<Button text="Pogledajte cijeli jelovnik" href="#menu" variant="primary" />
</ScrollReveal>
</div>
</div>
</section>
);
}

View File

@@ -0,0 +1,23 @@
// 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 HeroSplit from '@/components/sections/hero/HeroSplit';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function HeroSection(): React.JSX.Element {
return (
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroSplit
tag="Od 2010."
title="Restoran Barrel Soblinec"
description="Gdje se tradicija susreće s kulinarskim savršenstvom. Doživite autentičan okus regije u toplom, sofisticiranom okruženju."
primaryButton={{"href":"#menu","text":"Istražite jelovnik"}}
secondaryButton={{"href":"#contact","text":"Rezervirajte stol"}}
imageSrc="http://img.b2bpic.net/free-photo/top-view-radish-meal-with-meat-inside-white-plate-table-food-meal-dinner-restaurant_140725-28248.jpg"
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,57 @@
// 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 FeaturesImageBento from '@/components/sections/features/FeaturesImageBento';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function MenuSection(): React.JSX.Element {
return (
<div id="menu" data-section="menu">
<SectionErrorBoundary name="menu">
<FeaturesImageBento
tag="Signature Menu"
title="Culinary Delights"
description="Discover our signature dishes prepared with love and precision."
items={[
{
title: "Signature Steak",
description: "Dry-aged for 45 days, perfectly seared.",
imageSrc: "http://img.b2bpic.net/free-photo/local-food-meal-assortment_23-2148833773.jpg",
},
{
title: "Seafood Special",
description: "Fresh daily catch from local sources.",
imageSrc: "http://img.b2bpic.net/free-photo/fried-shrimps-with-green-sauce-table_140725-2118.jpg",
},
{
title: "Artisan Pasta",
description: "Homemade pasta with rich herb sauce.",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-dough-pasta-cooked-tasty-salted-inside-round-blue-plate-with-glasses-wine-flowers-inside-jug-designed-carpet-dark-desk-italian-meal-cuisine_140725-24369.jpg",
},
{
title: "Roasted Vegetables",
description: "Seasonal harvest, lightly drizzled.",
imageSrc: "http://img.b2bpic.net/free-photo/artistic-presentation-gourmet-ice-cream-dessert-stylish-bowl-with-floral-garnishes_23-2151973726.jpg",
},
{
title: "Chef's Dessert",
description: "The perfect sweet finish to your meal.",
imageSrc: "http://img.b2bpic.net/free-photo/top-view-sliced-vegetable-meal-delicious-beans-meal-with-olive-oil-blue-background_140725-58379.jpg",
},
{
title: "Rich Soup",
description: "Hearty seasonal bowl of comfort.",
imageSrc: "http://img.b2bpic.net/free-photo/delicious-creamy-melted-cheese_23-2149332835.jpg",
},
{
title: "Barrel Platter",
description: "A mix of our finest appetizers.",
imageSrc: "http://img.b2bpic.net/free-photo/fried-piece-meat-potatoes-fried-tomato_140725-6649.jpg",
},
]}
/>
</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 "testimonial" section.
import React from 'react';
import TestimonialMarqueeCards from '@/components/sections/testimonial/TestimonialMarqueeCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function TestimonialSection(): React.JSX.Element {
return (
<div id="testimonial" data-section="testimonial">
<SectionErrorBoundary name="testimonial">
<TestimonialMarqueeCards
tag="Reviews"
title="Stories from Our Guests"
description="What our visitors say about their experience at Barrel."
testimonials={[
{
name: "Marko I.",
role: "Food Critic",
quote: "The absolute highlight of Soblinec. Incredible atmosphere and even better food.",
imageSrc: "http://img.b2bpic.net/free-photo/attractive-happy-young-bearded-man-trendy-hat-texting-messages-via-social-networks-browsing-internet-using-free-wifi-his-electronic-device-coffee-break-restaurant_273609-1934.jpg",
},
{
name: "Ana S.",
role: "Regular Guest",
quote: "I love the warm ambiance and the fresh seafood. A true classic.",
imageSrc: "http://img.b2bpic.net/free-photo/front-view-woman-having-lunch-restaurant_23-2150491815.jpg",
},
{
name: "Ivan D.",
role: "Traveler",
quote: "A hidden gem. The service was impeccable and the menu is outstanding.",
imageSrc: "http://img.b2bpic.net/free-photo/happy-woman-enjoying-dining-table-while-communicating-with-her-husband_637285-3516.jpg",
},
{
name: "Petra L.",
role: "Blogger",
quote: "One of the few places that delivers on both taste and aesthetic.",
imageSrc: "http://img.b2bpic.net/free-photo/one-companions_1098-13516.jpg",
},
{
name: "Tomislav B.",
role: "Local",
quote: "Best place for family gatherings. Consistent quality every single time.",
imageSrc: "http://img.b2bpic.net/free-photo/photo-overjoyed-dark-skinned-girl-has-bushy-hair-laughs-looks-aside-uses-cell-phone-online-communication-messaging-with-friends-drinks-smoothie-cozy-cafeteria_273609-29417.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}