Merge version_2_1781453113226 into main

Merge version_2_1781453113226 into main
This commit was merged in pull request #2.
This commit is contained in:
2026-06-14 16:07:43 +00:00
10 changed files with 328 additions and 253 deletions

View File

@@ -1,5 +1,5 @@
import FooterSimpleCard from '@/components/sections/footer/FooterSimpleCard';
import NavbarFloatingLogo from '@/components/ui/NavbarFloatingLogo';
import NavbarFloating from '@/components/ui/NavbarFloating';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
import SiteBackgroundSlot from "@/components/ui/SiteBackgroundSlot";
import { Outlet } from 'react-router-dom';
@@ -34,9 +34,8 @@ export default function Layout() {
<StyleProvider buttonVariant="bounce" siteBackground="floatingGradient" heroBackground="gradientBars">
<SiteBackgroundSlot />
<SectionErrorBoundary name="navbar">
<NavbarFloatingLogo
logo="Fryzjer Dobre Nastroje"
logoImageSrc="https://storage.googleapis.com/webild/default/no-image.jpg?id=01bdrv"
<NavbarFloating
logo="Dobre Nastroje"
ctaButton={{
text: "Umów wizytę", href: "#"}}
navItems={navItems} />

View File

@@ -1,261 +1,36 @@
import AboutTextSplit from '@/components/sections/about/AboutTextSplit';
import ContactCta from '@/components/sections/contact/ContactCta';
import FeaturesMediaCards from '@/components/sections/features/FeaturesMediaCards';
import FeaturesRevealCardsBento from '@/components/sections/features/FeaturesRevealCardsBento';
import HeroOverlayMarquee from '@/components/sections/hero/HeroOverlayMarquee';
import PricingSplitCards from '@/components/sections/pricing/PricingSplitCards';
import TeamOverlayCards from '@/components/sections/team/TeamOverlayCards';
import TestimonialMarqueeOverlayCards from '@/components/sections/testimonial/TestimonialMarqueeOverlayCards';
import { Sparkles, Star, Users } from "lucide-react";
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 ServicesSection from './HomePage/sections/Services';
import StylistSection from './HomePage/sections/Stylist';
import PricingSection from './HomePage/sections/Pricing';
import GallerySection from './HomePage/sections/Gallery';
import TestimonialsSection from './HomePage/sections/Testimonials';
import ContactSection from './HomePage/sections/Contact';
export default function HomePage(): React.JSX.Element {
return (
<>
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroOverlayMarquee
tag="Poznań, Os. Przyjaźni"
title="Fryzura w dobrym nastroju"
description="Profesjonalne strzyżenie, koloryzacja blond i indywidualne podejście do Twoich włosów w sercu Poznania. Zaufaj naszemu doświadczeniu."
primaryButton={{
text: "Umów wizytę",
href: "#",
}}
secondaryButton={{
text: "Zadzwoń: 884 307 703",
href: "tel:884307703",
}}
items={[
{
text: "4,7★ (124 opinie)",
icon: Star,
},
{
text: "Indywidualne doradztwo",
icon: Users,
},
{
text: "Specjalizacja Blond",
icon: Sparkles,
},
]}
imageSrc="http://img.b2bpic.net/free-photo/view-child-hair-salon_23-2150462476.jpg"
/>
</SectionErrorBoundary>
</div>
<>
<HeroSection />
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutTextSplit
title="O nas Twoje włosy w dobrych rękach"
descriptions={[
"Jesteśmy kameralnym salonem fryzjerskim na poznańskim osiedlu Przyjaźni. Naszą misją jest zapewnienie każdej klientce i klientowi nie tylko profesjonalnej fryzury, ale także chwili relaksu w miłej atmosferze.",
"Wierzymy, że kluczem do piękna jest uważność na potrzeby Twoich włosów. Przed przystąpieniem do zabiegu zawsze przeprowadzamy dokładną konsultację, aby efekt końcowy idealnie współgrał z Twoim typem urody i kondycją włosów.",
]}
/>
</SectionErrorBoundary>
</div>
<AboutSection />
<div id="services" data-section="services">
<SectionErrorBoundary name="services">
<FeaturesMediaCards
tag="Oferta"
title="Nasze usługi"
description="Zadbamy o Twój wygląd, niezależnie od tego, czy marzysz o klasycznym strzyżeniu, czy odważnej zmianie koloru."
items={[
{
title: "Strzyżenie damskie i męskie",
description: "Precyzyjne strzyżenie dopasowane do kształtu Twojej twarzy i stylu życia.",
imageSrc: "http://img.b2bpic.net/free-photo/child-getting-their-hair-blown-salon_23-2150462467.jpg",
},
{
title: "Koloryzacja blond",
description: "Mistrzowskie rozjaśnianie i koloryzacja Twoje włosy będą lśnić zdrowym blaskiem.",
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-girl-walks-lush-garden-dressed-wreath_1153-8093.jpg",
},
{
title: "Pielęgnacja i styling",
description: "Regeneracja zniszczonych włosów, odżywcze zabiegi oraz profesjonalne modelowanie.",
imageSrc: "http://img.b2bpic.net/free-photo/charming-lady-has-nice-hairdo_8353-7608.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<ServicesSection />
<div id="stylist" data-section="stylist">
<SectionErrorBoundary name="stylist">
<TeamOverlayCards
tag="Nasz Zespół"
title="Poznaj Panią Ewę"
description="Nasza główna stylistka, specjalistka od perfekcyjnych blondów i koloryzacji, która zawsze wysłucha Twoich oczekiwań."
members={[
{
name: "Ewa",
role: "Główna Stylistka",
imageSrc: "http://img.b2bpic.net/free-photo/portrait-young-female-dentist-dentistry-concept-dental-treatment_169016-67053.jpg",
},
{
name: "Zespół",
role: "Stylista fryzur",
imageSrc: "http://img.b2bpic.net/free-photo/pleased-young-female-barber-wearing-uniform-glasses-headband-looking-camera-showing-thumb-up-isolated-red-background_141793-137078.jpg",
},
{
name: "Zespół",
role: "Specjalista pielęgnacji",
imageSrc: "http://img.b2bpic.net/free-photo/brunette-woman-with-cup-coffee-smiling-white-wall_114579-65337.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<StylistSection />
<div id="pricing" data-section="pricing">
<SectionErrorBoundary name="pricing">
<PricingSplitCards
tag="Cennik"
title="Przejrzysta oferta"
description="Zapraszamy do kontaktu w celu wyceny lub sprawdzenia szczegółowego cennika w naszym systemie rezerwacji."
plans={[
{
tag: "Wizyta",
price: "Sprawdź online",
period: "Booksy",
description: "Aktualny cennik wszystkich zabiegów dostępny w naszym systemie rezerwacji online.",
primaryButton: {
text: "Sprawdź w Booksy",
href: "#",
},
featuresTitle: "Co oferujemy:",
features: [
"Konsultacja fryzjerska",
"Mycie i masaż głowy",
"Profesjonalna pielęgnacja",
],
},
]}
/>
</SectionErrorBoundary>
</div>
<PricingSection />
<div id="gallery" data-section="gallery">
<SectionErrorBoundary name="gallery">
<FeaturesRevealCardsBento
tag="Galeria"
title="Nasze metamorfozy"
description="Zaufaj naszym umiejętnościom oto efekty pracy naszego zespołu."
items={[
{
title: "Blond",
description: "Piękny odcień blond",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/red-hair-woman-with-red-lips-posing-camera_613910-63.jpg",
},
{
title: "Stylizacja",
description: "Nowoczesne upięcia",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/smiley-bride-before-wedding-medium-shot_23-2149860834.jpg",
},
{
title: "Strzyżenie",
description: "Klasyczne cięcie",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/child-getting-haircut-salon_23-2150462510.jpg",
},
{
title: "Kolor",
description: "Odważny kolor",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/back-view-woman-hair-salon_23-2150668444.jpg",
},
{
title: "Blask",
description: "Zdrowe włosy",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/portrait-beautiful-young-woman-with-red-lips-unusual-hair-style-gray_158538-2318.jpg",
},
{
title: "Elegancja",
description: "Wizytowa fryzura",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/medium-shot-trans-model-posing_23-2148905626.jpg",
},
{
title: "Pasja",
description: "Nasza praca",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-girl-with-colorful-hair-black-apron-white-t-shirt-holding-paint-brush-hand-dreamily-looking-camera-modern-pottery-studio_574295-960.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<GallerySection />
<div id="testimonials" data-section="testimonials">
<SectionErrorBoundary name="testimonials">
<TestimonialMarqueeOverlayCards
tag="Opinie"
title="Co mówią nasze klientki?"
description="Dziękujemy za każde zaufanie i miłe słowa w opiniach Google."
testimonials={[
{
name: "Anna",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-woman-getting-her-hair-dyed-by-hairdresser-home_23-2148817234.jpg",
},
{
name: "Katarzyna",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/woman-getting-treatment-hairdresser-shop_23-2149229812.jpg",
},
{
name: "Marta",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/best-friends-smiling-each-other_23-2148238236.jpg",
},
{
name: "Magdalena",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/pretty-girl-waiting-hair-coloring_23-2147769779.jpg",
},
{
name: "Julia",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/young-happy-woman-paying-with-credit-card-cafe_637285-8126.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<TestimonialsSection />
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Kontakt"
text="Gotowa na zmianę? Umów się na wizytę już dziś i poczuj dobry nastrój!"
primaryButton={{
text: "Umów przez Booksy",
href: "#",
}}
secondaryButton={{
text: "Zadzwoń do nas",
href: "tel:884307703",
}}
/>
</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 AboutTextSplit from '@/components/sections/about/AboutTextSplit';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function AboutSection(): React.JSX.Element {
return (
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutTextSplit
title="O nas Twoje włosy w dobrych rękach"
descriptions={[
"Jesteśmy kameralnym salonem fryzjerskim na poznańskim osiedlu Przyjaźni. Naszą misją jest zapewnienie każdej klientce i klientowi nie tylko profesjonalnej fryzury, ale także chwili relaksu w miłej atmosferze.",
"Wierzymy, że kluczem do piękna jest uważność na potrzeby Twoich włosów. Przed przystąpieniem do zabiegu zawsze przeprowadzamy dokładną konsultację, aby efekt końcowy idealnie współgrał z Twoim typem urody i kondycją włosów.",
]}
/>
</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="Kontakt"
text="Gotowa na zmianę? Umów się na wizytę już dziś i poczuj dobry nastrój!"
primaryButton={{
text: "Umów przez Booksy",
href: "#",
}}
secondaryButton={{
text: "Zadzwoń do nas",
href: "tel:884307703",
}}
/>
</SectionErrorBoundary>
</div>
);
}

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 "gallery" section.
import React from 'react';
import FeaturesRevealCardsBento from '@/components/sections/features/FeaturesRevealCardsBento';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function GallerySection(): React.JSX.Element {
return (
<div id="gallery" data-section="gallery">
<SectionErrorBoundary name="gallery">
<FeaturesRevealCardsBento
tag="Galeria"
title="Nasze metamorfozy"
description="Zaufaj naszym umiejętnościom oto efekty pracy naszego zespołu."
items={[
{
title: "Blond",
description: "Piękny odcień blond",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/red-hair-woman-with-red-lips-posing-camera_613910-63.jpg",
},
{
title: "Stylizacja",
description: "Nowoczesne upięcia",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/smiley-bride-before-wedding-medium-shot_23-2149860834.jpg",
},
{
title: "Strzyżenie",
description: "Klasyczne cięcie",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/child-getting-haircut-salon_23-2150462510.jpg",
},
{
title: "Kolor",
description: "Odważny kolor",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/back-view-woman-hair-salon_23-2150668444.jpg",
},
{
title: "Blask",
description: "Zdrowe włosy",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/portrait-beautiful-young-woman-with-red-lips-unusual-hair-style-gray_158538-2318.jpg",
},
{
title: "Elegancja",
description: "Wizytowa fryzura",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/medium-shot-trans-model-posing_23-2148905626.jpg",
},
{
title: "Pasja",
description: "Nasza praca",
href: "#",
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-girl-with-colorful-hair-black-apron-white-t-shirt-holding-paint-brush-hand-dreamily-looking-camera-modern-pottery-studio_574295-960.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,19 @@
// Created by add_section_from_catalog (HeroSplit).
import React from 'react';
import HeroSplit from '@/components/sections/hero/HeroSplit';
export default function HeroSection(): React.JSX.Element {
return (
<div data-webild-section="hero" id="hero">
<HeroSplit
secondaryButton={{"href":"tel:884307703","text":"Zadzwoń: 884 307 703"}}
description="Profesjonalne strzyżenie, koloryzacja blond i indywidualne podejście do Twoich włosów w sercu Poznania. Zaufaj naszemu doświadczeniu."
tag="Poznań, Os. Przyjaźni"
title="Fryzura w dobrym nastroju"
primaryButton={{"text":"Umów wizytę","href":"#"}}
imageSrc="https://picsum.photos/seed/1905341894/1200/800"
/>
</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 "pricing" section.
import React from 'react';
import PricingSplitCards from '@/components/sections/pricing/PricingSplitCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function PricingSection(): React.JSX.Element {
return (
<div id="pricing" data-section="pricing">
<SectionErrorBoundary name="pricing">
<PricingSplitCards
tag="Cennik"
title="Przejrzysta oferta"
description="Zapraszamy do kontaktu w celu wyceny lub sprawdzenia szczegółowego cennika w naszym systemie rezerwacji."
plans={[
{
tag: "Wizyta",
price: "Sprawdź online",
period: "Booksy",
description: "Aktualny cennik wszystkich zabiegów dostępny w naszym systemie rezerwacji online.",
primaryButton: {
text: "Sprawdź w Booksy",
href: "#",
},
featuresTitle: "Co oferujemy:",
features: [
"Konsultacja fryzjerska",
"Mycie i masaż głowy",
"Profesjonalna pielęgnacja",
],
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,37 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "services" section.
import React from 'react';
import FeaturesMediaCards from '@/components/sections/features/FeaturesMediaCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function ServicesSection(): React.JSX.Element {
return (
<div id="services" data-section="services">
<SectionErrorBoundary name="services">
<FeaturesMediaCards
tag="Oferta"
title="Nasze usługi"
description="Zadbamy o Twój wygląd, niezależnie od tego, czy marzysz o klasycznym strzyżeniu, czy odważnej zmianie koloru."
items={[
{
title: "Strzyżenie damskie i męskie",
description: "Precyzyjne strzyżenie dopasowane do kształtu Twojej twarzy i stylu życia.",
imageSrc: "http://img.b2bpic.net/free-photo/child-getting-their-hair-blown-salon_23-2150462467.jpg",
},
{
title: "Koloryzacja blond",
description: "Mistrzowskie rozjaśnianie i koloryzacja Twoje włosy będą lśnić zdrowym blaskiem.",
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-girl-walks-lush-garden-dressed-wreath_1153-8093.jpg",
},
{
title: "Pielęgnacja i styling",
description: "Regeneracja zniszczonych włosów, odżywcze zabiegi oraz profesjonalne modelowanie.",
imageSrc: "http://img.b2bpic.net/free-photo/charming-lady-has-nice-hairdo_8353-7608.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,37 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "stylist" section.
import React from 'react';
import TeamOverlayCards from '@/components/sections/team/TeamOverlayCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function StylistSection(): React.JSX.Element {
return (
<div id="stylist" data-section="stylist">
<SectionErrorBoundary name="stylist">
<TeamOverlayCards
tag="Nasz Zespół"
title="Poznaj Panią Ewę"
description="Nasza główna stylistka, specjalistka od perfekcyjnych blondów i koloryzacji, która zawsze wysłucha Twoich oczekiwań."
members={[
{
name: "Ewa",
role: "Główna Stylistka",
imageSrc: "http://img.b2bpic.net/free-photo/portrait-young-female-dentist-dentistry-concept-dental-treatment_169016-67053.jpg",
},
{
name: "Zespół",
role: "Stylista fryzur",
imageSrc: "http://img.b2bpic.net/free-photo/pleased-young-female-barber-wearing-uniform-glasses-headband-looking-camera-showing-thumb-up-isolated-red-background_141793-137078.jpg",
},
{
name: "Zespół",
role: "Specjalista pielęgnacji",
imageSrc: "http://img.b2bpic.net/free-photo/brunette-woman-with-cup-coffee-smiling-white-wall_114579-65337.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 "testimonials" section.
import React from 'react';
import TestimonialMarqueeOverlayCards from '@/components/sections/testimonial/TestimonialMarqueeOverlayCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function TestimonialsSection(): React.JSX.Element {
return (
<div id="testimonials" data-section="testimonials">
<SectionErrorBoundary name="testimonials">
<TestimonialMarqueeOverlayCards
tag="Opinie"
title="Co mówią nasze klientki?"
description="Dziękujemy za każde zaufanie i miłe słowa w opiniach Google."
testimonials={[
{
name: "Anna",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/beautiful-woman-getting-her-hair-dyed-by-hairdresser-home_23-2148817234.jpg",
},
{
name: "Katarzyna",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/woman-getting-treatment-hairdresser-shop_23-2149229812.jpg",
},
{
name: "Marta",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/best-friends-smiling-each-other_23-2148238236.jpg",
},
{
name: "Magdalena",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/pretty-girl-waiting-hair-coloring_23-2147769779.jpg",
},
{
name: "Julia",
role: "Klientka",
company: "Poznań",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/young-happy-woman-paying-with-credit-card-cafe_637285-8126.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}