Bob AI: Update navbar to floating style without image logo
This commit is contained in:
@@ -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} />
|
||||
|
||||
@@ -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 />
|
||||
</>
|
||||
);
|
||||
}
|
||||
|
||||
22
src/pages/HomePage/sections/About.tsx
Normal file
22
src/pages/HomePage/sections/About.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
27
src/pages/HomePage/sections/Contact.tsx
Normal file
27
src/pages/HomePage/sections/Contact.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
64
src/pages/HomePage/sections/Gallery.tsx
Normal file
64
src/pages/HomePage/sections/Gallery.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
118
src/pages/HomePage/sections/Hero.tsx
Normal file
118
src/pages/HomePage/sections/Hero.tsx
Normal file
@@ -0,0 +1,118 @@
|
||||
/* eslint-disable */
|
||||
// @ts-nocheck — generated by catalog-eject; runtime-correct but TS strict-mode false-positives on inlined catalog body
|
||||
import { Star, Users, Sparkles } from 'lucide-react';
|
||||
import type { LucideIcon } from "lucide-react";
|
||||
|
||||
import Button from "@/components/ui/Button";
|
||||
import HeroBackgroundSlot from "@/components/ui/HeroBackgroundSlot";
|
||||
import TextAnimation from "@/components/ui/TextAnimation";
|
||||
import ImageOrVideo from "@/components/ui/ImageOrVideo";
|
||||
import AvatarGroup from "@/components/ui/AvatarGroup";
|
||||
|
||||
const primaryButton = {
|
||||
text: "Umów wizytę",
|
||||
href: "#"
|
||||
};
|
||||
const secondaryButton = {
|
||||
text: "Zadzwoń: 884 307 703",
|
||||
href: "tel:884307703"
|
||||
};
|
||||
const items = [
|
||||
{
|
||||
text: "4,7★ (124 opinie)",
|
||||
icon: Star
|
||||
},
|
||||
{
|
||||
text: "Indywidualne doradztwo",
|
||||
icon: Users
|
||||
},
|
||||
{
|
||||
text: "Specjalizacja Blond",
|
||||
icon: Sparkles
|
||||
}
|
||||
];
|
||||
|
||||
type HeroOverlayMarqueeProps = {
|
||||
tag: string;
|
||||
title: string;
|
||||
description: string;
|
||||
primaryButton: { text: string; href: string };
|
||||
secondaryButton: { text: string; href: string };
|
||||
avatarsSrc?: string[];
|
||||
avatarsLabel?: string;
|
||||
items: { text: string; icon: LucideIcon }[];
|
||||
} & ({ imageSrc: string; videoSrc?: never } | { videoSrc: string; imageSrc?: never });
|
||||
|
||||
const HeroInline = () => {
|
||||
return (
|
||||
<section
|
||||
aria-label="Hero section"
|
||||
className="relative overflow-hidden flex flex-col justify-between mb-20 w-full h-svh"
|
||||
>
|
||||
<HeroBackgroundSlot />
|
||||
<ImageOrVideo
|
||||
imageSrc={"http://img.b2bpic.net/free-photo/view-child-hair-salon_23-2150462476.jpg"}
|
||||
className="absolute inset-0 object-cover w-full h-full rounded-none"
|
||||
/>
|
||||
|
||||
<div
|
||||
className="absolute z-10 left-0 top-0 w-[150vw] h-[150vw] -translate-x-1/2 -translate-y-1/2 backdrop-blur mask-[radial-gradient(circle,black_20%,transparent_70%)]"
|
||||
aria-hidden="true"
|
||||
/>
|
||||
|
||||
<div className="relative z-10 mx-auto pt-35 w-content-width">
|
||||
<div className="flex flex-col gap-3 w-full md:w-6/10 lg:w-1/2 xl:w-45/100 2xl:w-4/10">
|
||||
<div className="mb-1 px-3 py-1 w-fit text-sm card rounded">
|
||||
<p>{"Poznań, Os. Przyjaźni"}</p>
|
||||
</div>
|
||||
|
||||
<TextAnimation
|
||||
text={"Fryzura w dobrym nastroju"}
|
||||
variant="fade"
|
||||
gradientText={true}
|
||||
tag="h1"
|
||||
className="text-7xl 2xl:text-8xl leading-[1.15] font-semibold text-balance text-white"
|
||||
/>
|
||||
|
||||
<TextAnimation
|
||||
text={"Profesjonalne strzyżenie, koloryzacja blond i indywidualne podejście do Twoich włosów w sercu Poznania. Zaufaj naszemu doświadczeniu."}
|
||||
variant="fade"
|
||||
gradientText={false}
|
||||
tag="p"
|
||||
className="text-lg md:text-xl leading-snug text-balance text-white"
|
||||
/>
|
||||
|
||||
<div className="flex flex-wrap gap-3 mt-2 md:mt-3">
|
||||
<Button text={primaryButton.text} href={primaryButton.href} variant="primary" />
|
||||
<Button text={secondaryButton.text} href={secondaryButton.href} variant="secondary" animationDelay={0.1} />
|
||||
</div>
|
||||
|
||||
{undefined && undefined.length > 0 && (
|
||||
<div className="mt-3 md:mt-4">
|
||||
<AvatarGroup size="lg" labelClassName="text-primary-cta-text" />
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="relative z-10 overflow-hidden mx-auto pb-8 w-content-width mask-fade-x">
|
||||
<div className="flex w-max animate-marquee-horizontal" style={{ animationDuration: "30s" }}>
|
||||
{[...items, ...items, ...items, ...items].map((item, index) => (
|
||||
<div key={index} className="flex items-center shrink-0 gap-1 mx-3 pl-2 pr-4 py-2 card rounded">
|
||||
<item.icon className="h-(--text-base) text-foreground" />
|
||||
<span className="whitespace-nowrap text-base font-medium text-foreground">{item.text}</span>
|
||||
</div>
|
||||
))}
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
);
|
||||
};
|
||||
|
||||
export default function HeroSection() {
|
||||
return (
|
||||
<div data-webild-section="hero" id="hero">
|
||||
<HeroInline />
|
||||
</div>
|
||||
);
|
||||
}
|
||||
38
src/pages/HomePage/sections/Pricing.tsx
Normal file
38
src/pages/HomePage/sections/Pricing.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 "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>
|
||||
);
|
||||
}
|
||||
37
src/pages/HomePage/sections/Services.tsx
Normal file
37
src/pages/HomePage/sections/Services.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
37
src/pages/HomePage/sections/Stylist.tsx
Normal file
37
src/pages/HomePage/sections/Stylist.tsx
Normal 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>
|
||||
);
|
||||
}
|
||||
57
src/pages/HomePage/sections/Testimonials.tsx
Normal file
57
src/pages/HomePage/sections/Testimonials.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 "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>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user