Merge version_2_1781557767341 into main #1
@@ -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: "#",
|
||||
},
|
||||
]}
|
||||
|
||||
@@ -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 />
|
||||
</>
|
||||
);
|
||||
}
|
||||
|
||||
21
src/pages/HomePage/sections/About.tsx
Normal file
21
src/pages/HomePage/sections/About.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
21
src/pages/HomePage/sections/Contact.tsx
Normal file
21
src/pages/HomePage/sections/Contact.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
38
src/pages/HomePage/sections/Faq.tsx
Normal file
38
src/pages/HomePage/sections/Faq.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
49
src/pages/HomePage/sections/Features.tsx
Normal file
49
src/pages/HomePage/sections/Features.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
78
src/pages/HomePage/sections/Gallery.tsx
Normal file
78
src/pages/HomePage/sections/Gallery.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
23
src/pages/HomePage/sections/Hero.tsx
Normal file
23
src/pages/HomePage/sections/Hero.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
57
src/pages/HomePage/sections/Menu.tsx
Normal file
57
src/pages/HomePage/sections/Menu.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
52
src/pages/HomePage/sections/Testimonial.tsx
Normal file
52
src/pages/HomePage/sections/Testimonial.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user