Merge version_2_1781367107057 into main #1
@@ -1,246 +1,36 @@
|
||||
import AboutTextSplit from '@/components/sections/about/AboutTextSplit';
|
||||
import ContactCta from '@/components/sections/contact/ContactCta';
|
||||
import FaqTwoColumn from '@/components/sections/faq/FaqTwoColumn';
|
||||
import FeaturesImageBento from '@/components/sections/features/FeaturesImageBento';
|
||||
import FeaturesTaggedCards from '@/components/sections/features/FeaturesTaggedCards';
|
||||
import HeroOverlay from '@/components/sections/hero/HeroOverlay';
|
||||
import MetricsMediaCards from '@/components/sections/metrics/MetricsMediaCards';
|
||||
import TestimonialTrustCard from '@/components/sections/testimonial/TestimonialTrustCard';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
// AUTO-GENERATED shell by per-section-migrate.
|
||||
// Section bodies live in ./<PageBase>/sections/<X>.tsx. Edit the section
|
||||
// files directly. Non-block content (wrappers, non-inlinable sections) is
|
||||
// preserved inline; extracted section blocks become <XSection/> refs.
|
||||
|
||||
export default function HomePage() {
|
||||
import React from 'react';
|
||||
import HeroSection from './HomePage/sections/Hero';
|
||||
import AboutSection from './HomePage/sections/About';
|
||||
import ServicesSection from './HomePage/sections/Services';
|
||||
import GallerySection from './HomePage/sections/Gallery';
|
||||
import MetricsSection from './HomePage/sections/Metrics';
|
||||
import ReviewsSection from './HomePage/sections/Reviews';
|
||||
import FaqSection from './HomePage/sections/Faq';
|
||||
import ContactSection from './HomePage/sections/Contact';
|
||||
|
||||
export default function HomePage(): React.JSX.Element {
|
||||
return (
|
||||
<>
|
||||
<div id="hero" data-section="hero">
|
||||
<SectionErrorBoundary name="hero">
|
||||
<HeroOverlay
|
||||
tag="Mobile Luxury Detailing"
|
||||
title="Your Vehicle Deserves Deluxe Treatment"
|
||||
description="Professional mobile auto detailing that brings showroom shine directly to your doorstep. Fast, reliable, affordable."
|
||||
primaryButton={{
|
||||
text: "Book Your Detail Today",
|
||||
href: "#booking",
|
||||
}}
|
||||
secondaryButton={{
|
||||
text: "Get A Free Quote",
|
||||
href: "#contact",
|
||||
}}
|
||||
imageSrc="http://img.b2bpic.net/free-photo/close-up-car-care-process_23-2149193572.jpg"
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<>
|
||||
<HeroSection />
|
||||
|
||||
<div id="about" data-section="about">
|
||||
<SectionErrorBoundary name="about">
|
||||
<AboutTextSplit
|
||||
title="Why Choose Deluxe Detail Mobile Services?"
|
||||
descriptions={[
|
||||
"At Deluxe Detail Mobile Services, we take pride in transforming vehicles inside and out. Whether you need a quick refresh or a complete showroom-quality detail, our mission is simple: deliver exceptional results with unmatched customer service.",
|
||||
"We bring professional detailing directly to your location, saving you time while restoring your vehicle's appearance, shine, and freshness.",
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<AboutSection />
|
||||
|
||||
<div id="services" data-section="services">
|
||||
<SectionErrorBoundary name="services">
|
||||
<FeaturesTaggedCards
|
||||
tag="Our Services"
|
||||
title="Professional Care for Your Vehicle"
|
||||
description="Comprehensive detailing packages tailored to perfection."
|
||||
items={[
|
||||
{
|
||||
tag: "Exterior",
|
||||
title: "Exterior Detailing",
|
||||
description: "Hand wash, clay bar, wax protection, tire shine, and bug & tar removal for a perfect finish.",
|
||||
primaryButton: {
|
||||
text: "Learn More",
|
||||
href: "#",
|
||||
},
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/young-man-washing-car-carwash-station-outdoor_651396-2004.jpg",
|
||||
},
|
||||
{
|
||||
tag: "Interior",
|
||||
title: "Interior Detailing",
|
||||
description: "Deep vacuuming, carpet cleaning, stain removal, and dashboard restoration for a fresh interior.",
|
||||
primaryButton: {
|
||||
text: "Learn More",
|
||||
href: "#",
|
||||
},
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-person-cleaning-car-interior_23-2148194086.jpg",
|
||||
},
|
||||
{
|
||||
tag: "Premium",
|
||||
title: "Premium Packages",
|
||||
description: "Engine bay detailing, paint enhancement, and ceramic protection for long-lasting luxury results.",
|
||||
primaryButton: {
|
||||
text: "Learn More",
|
||||
href: "#",
|
||||
},
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/front-left-wheel-bordeaux-sedan-car_114579-4065.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<ServicesSection />
|
||||
|
||||
<div id="gallery" data-section="gallery">
|
||||
<SectionErrorBoundary name="gallery">
|
||||
<FeaturesImageBento
|
||||
tag="Before & After"
|
||||
title="See The Difference"
|
||||
description="Every vehicle tells a story. Our job is to make it look brand new again."
|
||||
items={[
|
||||
{
|
||||
title: "Engine Bay",
|
||||
description: "Precision cleaning",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/top-view-open-car-service_23-2150171254.jpg",
|
||||
},
|
||||
{
|
||||
title: "Paint Finish",
|
||||
description: "Ceramic shine",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/man-working-car-detailing-coating-car_1303-30600.jpg",
|
||||
},
|
||||
{
|
||||
title: "Headlights",
|
||||
description: "Crystal clear",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/stylish-headlight-white-auto_23-2147963050.jpg",
|
||||
},
|
||||
{
|
||||
title: "Interior Deep Clean",
|
||||
description: "Upholstery restore",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/man-gaming-with-headphones-better-immerse-himself_482257-124713.jpg",
|
||||
},
|
||||
{
|
||||
title: "Exterior Shine",
|
||||
description: "Showroom quality",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/woman-with-gloves-cleaning-gym-equipment_23-2148766022.jpg",
|
||||
},
|
||||
{
|
||||
title: "Dashboard",
|
||||
description: "Like new",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/hand-with-microfiber-cloth-cleaning-car_93675-128696.jpg",
|
||||
},
|
||||
{
|
||||
title: "Alloys",
|
||||
description: "Tire shine",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-car-care-process_23-2149193557.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<GallerySection />
|
||||
|
||||
<div id="metrics" data-section="metrics">
|
||||
<SectionErrorBoundary name="metrics">
|
||||
<MetricsMediaCards
|
||||
tag="Our Impact"
|
||||
title="Excellence in Detailing"
|
||||
description="Results that speak for themselves."
|
||||
metrics={[
|
||||
{
|
||||
value: "500+",
|
||||
title: "Vehicles Detailed",
|
||||
description: "Serving satisfied clients across the region.",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dark-blue-water-with-big-bubbles_23-2147933821.jpg",
|
||||
},
|
||||
{
|
||||
value: "100+",
|
||||
title: "5-Star Reviews",
|
||||
description: "Our customers love the results.",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/closeup-shot-engine-start-buttons-inside-modern-sport-car_181624-33132.jpg",
|
||||
},
|
||||
{
|
||||
value: "100%",
|
||||
title: "Mobile Convenience",
|
||||
description: "We come directly to you.",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-man-cleaning-car-rims_23-2148194113.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<MetricsSection />
|
||||
|
||||
<div id="reviews" data-section="reviews">
|
||||
<SectionErrorBoundary name="reviews">
|
||||
<TestimonialTrustCard
|
||||
quote="My truck looks and smells brand new. The attention to detail was outstanding—from the spotless interior to the shining exterior."
|
||||
rating={5}
|
||||
author="Asia Dawson"
|
||||
avatars={[
|
||||
{
|
||||
name: "Asia Dawson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/front-view-young-businessman-office-clothing_23-2148763859.jpg",
|
||||
},
|
||||
{
|
||||
name: "Nikki Elliott",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/young-beautiful-african-woman-student-resting-relaxing-sitting-cafe-smiling-drinking-coffee_176420-12323.jpg",
|
||||
},
|
||||
{
|
||||
name: "Bertha Jackson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-positive-executive-work_1098-519.jpg",
|
||||
},
|
||||
{
|
||||
name: "Freddie Johnson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-manager_1098-15671.jpg",
|
||||
},
|
||||
{
|
||||
name: "Regina Dawson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-employees-looking-laptop-laughing_74855-4007.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<ReviewsSection />
|
||||
|
||||
<div id="faq" data-section="faq">
|
||||
<SectionErrorBoundary name="faq">
|
||||
<FaqTwoColumn
|
||||
tag="Common Questions"
|
||||
title="Frequently Asked Questions"
|
||||
description="Everything you need to know about our mobile service."
|
||||
items={[
|
||||
{
|
||||
question: "How long does a detail take?",
|
||||
answer: "Most details take between 2-4 hours depending on the package and vehicle size.",
|
||||
},
|
||||
{
|
||||
question: "Do you come to my location?",
|
||||
answer: "Yes, we are a 100% mobile service and bring everything needed directly to your home or office.",
|
||||
},
|
||||
{
|
||||
question: "What payment methods do you accept?",
|
||||
answer: "We accept cash, credit cards, and contactless payments.",
|
||||
},
|
||||
{
|
||||
question: "How often should I detail my vehicle?",
|
||||
answer: "We recommend a professional detail every 3-6 months to maintain your vehicle's value.",
|
||||
},
|
||||
{
|
||||
question: "Do you remove odors and stains?",
|
||||
answer: "Yes, our deep cleaning process is highly effective at removing most odors and stains.",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<FaqSection />
|
||||
|
||||
<div id="contact" data-section="contact">
|
||||
<SectionErrorBoundary name="contact">
|
||||
<ContactCta
|
||||
tag="Booking"
|
||||
text="Ready for that new car feeling again? Experience professional detailing today."
|
||||
primaryButton={{
|
||||
text: "Schedule Your Appointment",
|
||||
href: "#",
|
||||
}}
|
||||
secondaryButton={{
|
||||
text: "Get A Free Quote",
|
||||
href: "#",
|
||||
}}
|
||||
/>
|
||||
</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="Why Choose Deluxe Detail Mobile Services?"
|
||||
descriptions={[
|
||||
"At Deluxe Detail Mobile Services, we take pride in transforming vehicles inside and out. Whether you need a quick refresh or a complete showroom-quality detail, our mission is simple: deliver exceptional results with unmatched customer service.",
|
||||
"We bring professional detailing directly to your location, saving you time while restoring your vehicle's appearance, shine, and freshness.",
|
||||
]}
|
||||
/>
|
||||
</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="Booking"
|
||||
text="Ready for that new car feeling again? Experience professional detailing today."
|
||||
primaryButton={{
|
||||
text: "Schedule Your Appointment",
|
||||
href: "#",
|
||||
}}
|
||||
secondaryButton={{
|
||||
text: "Get A Free Quote",
|
||||
href: "#",
|
||||
}}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
42
src/pages/HomePage/sections/Faq.tsx
Normal file
42
src/pages/HomePage/sections/Faq.tsx
Normal file
@@ -0,0 +1,42 @@
|
||||
// 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="Frequently Asked Questions"
|
||||
description="Everything you need to know about our mobile service."
|
||||
items={[
|
||||
{
|
||||
question: "How long does a detail take?",
|
||||
answer: "Most details take between 2-4 hours depending on the package and vehicle size.",
|
||||
},
|
||||
{
|
||||
question: "Do you come to my location?",
|
||||
answer: "Yes, we are a 100% mobile service and bring everything needed directly to your home or office.",
|
||||
},
|
||||
{
|
||||
question: "What payment methods do you accept?",
|
||||
answer: "We accept cash, credit cards, and contactless payments.",
|
||||
},
|
||||
{
|
||||
question: "How often should I detail my vehicle?",
|
||||
answer: "We recommend a professional detail every 3-6 months to maintain your vehicle's value.",
|
||||
},
|
||||
{
|
||||
question: "Do you remove odors and stains?",
|
||||
answer: "Yes, our deep cleaning process is highly effective at removing most odors and stains.",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
57
src/pages/HomePage/sections/Gallery.tsx
Normal file
57
src/pages/HomePage/sections/Gallery.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 "gallery" section.
|
||||
|
||||
import React from 'react';
|
||||
import FeaturesImageBento from '@/components/sections/features/FeaturesImageBento';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function GallerySection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="gallery" data-section="gallery">
|
||||
<SectionErrorBoundary name="gallery">
|
||||
<FeaturesImageBento
|
||||
tag="Before & After"
|
||||
title="See The Difference"
|
||||
description="Every vehicle tells a story. Our job is to make it look brand new again."
|
||||
items={[
|
||||
{
|
||||
title: "Engine Bay",
|
||||
description: "Precision cleaning",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/top-view-open-car-service_23-2150171254.jpg",
|
||||
},
|
||||
{
|
||||
title: "Paint Finish",
|
||||
description: "Ceramic shine",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/man-working-car-detailing-coating-car_1303-30600.jpg",
|
||||
},
|
||||
{
|
||||
title: "Headlights",
|
||||
description: "Crystal clear",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/stylish-headlight-white-auto_23-2147963050.jpg",
|
||||
},
|
||||
{
|
||||
title: "Interior Deep Clean",
|
||||
description: "Upholstery restore",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/man-gaming-with-headphones-better-immerse-himself_482257-124713.jpg",
|
||||
},
|
||||
{
|
||||
title: "Exterior Shine",
|
||||
description: "Showroom quality",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/woman-with-gloves-cleaning-gym-equipment_23-2148766022.jpg",
|
||||
},
|
||||
{
|
||||
title: "Dashboard",
|
||||
description: "Like new",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/hand-with-microfiber-cloth-cleaning-car_93675-128696.jpg",
|
||||
},
|
||||
{
|
||||
title: "Alloys",
|
||||
description: "Tire shine",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-car-care-process_23-2149193557.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
89
src/pages/HomePage/sections/Hero.tsx
Normal file
89
src/pages/HomePage/sections/Hero.tsx
Normal file
@@ -0,0 +1,89 @@
|
||||
/* eslint-disable */
|
||||
// @ts-nocheck — generated by catalog-eject; runtime-correct but TS strict-mode false-positives on inlined catalog body
|
||||
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: "Book Your Detail Today",
|
||||
href: "#booking"
|
||||
};
|
||||
const secondaryButton = {
|
||||
text: "Get A Free Quote",
|
||||
href: "#contact"
|
||||
};
|
||||
|
||||
type HeroOverlayProps = {
|
||||
tag: string;
|
||||
title: string;
|
||||
description: string;
|
||||
primaryButton: { text: string; href: string };
|
||||
secondaryButton: { text: string; href: string };
|
||||
avatarsSrc?: string[];
|
||||
avatarsLabel?: string;
|
||||
} & ({ imageSrc: string; videoSrc?: never } | { videoSrc: string; imageSrc?: never });
|
||||
|
||||
const HeroInline = () => {
|
||||
return (
|
||||
<section
|
||||
aria-label="Hero section"
|
||||
className="relative w-full h-svh overflow-hidden flex flex-col justify-end mb-20"
|
||||
>
|
||||
<HeroBackgroundSlot />
|
||||
<ImageOrVideo
|
||||
imageSrc={"https://images.unsplash.com/photo-1601362840469-51e4d8d58785?auto=format&fit=crop&q=80"}
|
||||
className="absolute inset-0 w-full h-full object-cover rounded-none"
|
||||
/>
|
||||
|
||||
<div
|
||||
className="absolute z-10 w-[150vw] h-[150vw] left-0 bottom-0 -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 w-content-width mx-auto pb-10 md:pb-25">
|
||||
<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="w-fit px-3 py-1 mb-1 text-sm card rounded">
|
||||
<p>{"Mobile Luxury Detailing"}</p>
|
||||
</div>
|
||||
|
||||
<div className="relative inline-block">
|
||||
<div className="absolute -inset-4 bg-gradient-to-r from-card to-transparent rounded-xl -z-10 border-l-4 border-accent opacity-80"></div>
|
||||
<h1 className="text-7xl 2xl:text-8xl leading-[1.15] font-extrabold text-white text-balance">
|
||||
Deluxe Detail<br />
|
||||
<span className="text-accent">Mobile Services</span>
|
||||
</h1>
|
||||
</div>
|
||||
|
||||
<TextAnimation
|
||||
text={"Professional mobile auto detailing that brings showroom shine directly to your doorstep. Fast, reliable, affordable."}
|
||||
variant="fade-blur"
|
||||
gradientText={false}
|
||||
tag="p"
|
||||
className="text-lg md:text-xl text-white leading-snug text-balance"
|
||||
/>
|
||||
|
||||
<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>
|
||||
</section>
|
||||
);
|
||||
};
|
||||
|
||||
export default function HeroSection() {
|
||||
return (
|
||||
<div data-webild-section="hero" id="hero">
|
||||
<HeroInline />
|
||||
</div>
|
||||
);
|
||||
}
|
||||
40
src/pages/HomePage/sections/Metrics.tsx
Normal file
40
src/pages/HomePage/sections/Metrics.tsx
Normal file
@@ -0,0 +1,40 @@
|
||||
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
|
||||
// file as the canonical source for the "metrics" section.
|
||||
|
||||
import React from 'react';
|
||||
import MetricsMediaCards from '@/components/sections/metrics/MetricsMediaCards';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function MetricsSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="metrics" data-section="metrics">
|
||||
<SectionErrorBoundary name="metrics">
|
||||
<MetricsMediaCards
|
||||
tag="Our Impact"
|
||||
title="Excellence in Detailing"
|
||||
description="Results that speak for themselves."
|
||||
metrics={[
|
||||
{
|
||||
value: "500+",
|
||||
title: "Vehicles Detailed",
|
||||
description: "Serving satisfied clients across the region.",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dark-blue-water-with-big-bubbles_23-2147933821.jpg",
|
||||
},
|
||||
{
|
||||
value: "100+",
|
||||
title: "5-Star Reviews",
|
||||
description: "Our customers love the results.",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/closeup-shot-engine-start-buttons-inside-modern-sport-car_181624-33132.jpg",
|
||||
},
|
||||
{
|
||||
value: "100%",
|
||||
title: "Mobile Convenience",
|
||||
description: "We come directly to you.",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-man-cleaning-car-rims_23-2148194113.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
42
src/pages/HomePage/sections/Reviews.tsx
Normal file
42
src/pages/HomePage/sections/Reviews.tsx
Normal file
@@ -0,0 +1,42 @@
|
||||
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
|
||||
// file as the canonical source for the "reviews" section.
|
||||
|
||||
import React from 'react';
|
||||
import TestimonialTrustCard from '@/components/sections/testimonial/TestimonialTrustCard';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function ReviewsSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="reviews" data-section="reviews">
|
||||
<SectionErrorBoundary name="reviews">
|
||||
<TestimonialTrustCard
|
||||
quote="My truck looks and smells brand new. The attention to detail was outstanding—from the spotless interior to the shining exterior."
|
||||
rating={5}
|
||||
author="Asia Dawson"
|
||||
avatars={[
|
||||
{
|
||||
name: "Asia Dawson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/front-view-young-businessman-office-clothing_23-2148763859.jpg",
|
||||
},
|
||||
{
|
||||
name: "Nikki Elliott",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/young-beautiful-african-woman-student-resting-relaxing-sitting-cafe-smiling-drinking-coffee_176420-12323.jpg",
|
||||
},
|
||||
{
|
||||
name: "Bertha Jackson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-positive-executive-work_1098-519.jpg",
|
||||
},
|
||||
{
|
||||
name: "Freddie Johnson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-manager_1098-15671.jpg",
|
||||
},
|
||||
{
|
||||
name: "Regina Dawson",
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-employees-looking-laptop-laughing_74855-4007.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
52
src/pages/HomePage/sections/Services.tsx
Normal file
52
src/pages/HomePage/sections/Services.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 "services" section.
|
||||
|
||||
import React from 'react';
|
||||
import FeaturesTaggedCards from '@/components/sections/features/FeaturesTaggedCards';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function ServicesSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="services" data-section="services">
|
||||
<SectionErrorBoundary name="services">
|
||||
<FeaturesTaggedCards
|
||||
tag="Our Services"
|
||||
title="Professional Care for Your Vehicle"
|
||||
description="Comprehensive detailing packages tailored to perfection."
|
||||
items={[
|
||||
{
|
||||
tag: "Exterior",
|
||||
title: "Exterior Detailing",
|
||||
description: "Hand wash, clay bar, wax protection, tire shine, and bug & tar removal for a perfect finish.",
|
||||
primaryButton: {
|
||||
text: "Learn More",
|
||||
href: "#",
|
||||
},
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/young-man-washing-car-carwash-station-outdoor_651396-2004.jpg",
|
||||
},
|
||||
{
|
||||
tag: "Interior",
|
||||
title: "Interior Detailing",
|
||||
description: "Deep vacuuming, carpet cleaning, stain removal, and dashboard restoration for a fresh interior.",
|
||||
primaryButton: {
|
||||
text: "Learn More",
|
||||
href: "#",
|
||||
},
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/close-up-person-cleaning-car-interior_23-2148194086.jpg",
|
||||
},
|
||||
{
|
||||
tag: "Premium",
|
||||
title: "Premium Packages",
|
||||
description: "Engine bay detailing, paint enhancement, and ceramic protection for long-lasting luxury results.",
|
||||
primaryButton: {
|
||||
text: "Learn More",
|
||||
href: "#",
|
||||
},
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/front-left-wheel-bordeaux-sedan-car_114579-4065.jpg",
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user