Compare commits
10 Commits
version_5_
...
version_7_
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1db56f4ab4 | ||
| eb32401008 | |||
| 455800f1d3 | |||
| 82db7b004f | |||
| 9bfa52f890 | |||
| f43bf40293 | |||
| 0b08aefae5 | |||
| 4a3594cd66 | |||
| f89c1736f6 | |||
| 6e5b68a3a8 |
@@ -1,4 +1,4 @@
|
||||
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap');
|
||||
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Montserrat:wght@400;500;600;700&display=swap');
|
||||
@import "tailwindcss";
|
||||
@import "./styles/masks.css";
|
||||
@import "./styles/animations.css";
|
||||
@@ -88,7 +88,7 @@
|
||||
--color-background-accent: var(--background-accent);
|
||||
|
||||
/* Fonts */
|
||||
--font-sans: 'Roboto', sans-serif;
|
||||
--font-sans: 'Inter', sans-serif;
|
||||
--font-tight: "Inter Tight", sans-serif;
|
||||
--font-mono: monospace;
|
||||
|
||||
@@ -137,7 +137,7 @@ body {
|
||||
margin: 0;
|
||||
background-color: var(--background);
|
||||
color: var(--foreground);
|
||||
font-family: 'Roboto', sans-serif;
|
||||
font-family: 'Inter', sans-serif;
|
||||
position: relative;
|
||||
min-height: 100vh;
|
||||
overscroll-behavior: none;
|
||||
@@ -150,7 +150,7 @@ h3,
|
||||
h4,
|
||||
h5,
|
||||
h6 {
|
||||
font-family: 'Roboto', sans-serif;
|
||||
font-family: 'Montserrat', sans-serif;
|
||||
}
|
||||
|
||||
/* Default card/button styles. Template theme.css imports come after this file
|
||||
|
||||
@@ -1,193 +1,36 @@
|
||||
import AboutFeaturesSplit from '@/components/sections/about/AboutFeaturesSplit';
|
||||
import ContactCta from '@/components/sections/contact/ContactCta';
|
||||
import FaqTabbedAccordion from '@/components/sections/faq/FaqTabbedAccordion';
|
||||
import FeaturesBento from '@/components/sections/features/FeaturesBento';
|
||||
import HeroBillboardBrand from '@/components/sections/hero/HeroBillboardBrand';
|
||||
import MetricsIconCards from '@/components/sections/metrics/MetricsIconCards';
|
||||
import PricingCenteredCards from '@/components/sections/pricing/PricingCenteredCards';
|
||||
import TestimonialColumnMarqueeCards from '@/components/sections/testimonial/TestimonialColumnMarqueeCards';
|
||||
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 MetricsSection from './HomePage/sections/Metrics';
|
||||
import PricingSection from './HomePage/sections/Pricing';
|
||||
import TestimonialsSection from './HomePage/sections/Testimonials';
|
||||
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">
|
||||
<HeroBillboardBrand
|
||||
brand="Ваша идеальная улыбка — наша цель"
|
||||
description="Профессиональная ортодонтия для всей семьи. Современные технологии и бережный подход к здоровью ваших зубов."
|
||||
primaryButton={{
|
||||
text: "Записаться на прием", href: "#contact"}}
|
||||
secondaryButton={{
|
||||
text: "Узнать о нас", href: "#about"}}
|
||||
imageSrc="http://img.b2bpic.net/free-photo/full-equiped-medical-cabinet_1303-23918.jpg"
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<>
|
||||
<HeroSection />
|
||||
|
||||
<div id="about" data-section="about">
|
||||
<SectionErrorBoundary name="about">
|
||||
<AboutFeaturesSplit
|
||||
tag="О нас"
|
||||
title="Современная ортодонтия"
|
||||
description="Мы используем передовые методы лечения, чтобы сделать вашу улыбку красивой и здоровой. Комфорт пациентов — наш приоритет."
|
||||
items={[
|
||||
{
|
||||
icon: "CheckCircle", title: "Опытные врачи", description: "Специалисты с более чем 10-летним стажем."},
|
||||
{
|
||||
icon: "Shield", title: "Гарантия результата", description: "Контроль на всех этапах лечения."},
|
||||
{
|
||||
icon: "Zap", title: "Современное оборудование", description: "Цифровая диагностика и планирование."},
|
||||
]}
|
||||
imageSrc="http://img.b2bpic.net/free-photo/cheerful-medic-standing-with-arms-crossed_23-2147767252.jpg"
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<AboutSection />
|
||||
|
||||
<div id="features" data-section="features">
|
||||
<SectionErrorBoundary name="features">
|
||||
<FeaturesBento
|
||||
tag="Услуги"
|
||||
title="Что мы предлагаем"
|
||||
description="Комплексный подход к исправлению прикуса."
|
||||
features={[
|
||||
{
|
||||
title: "Брекет-системы", description: "Эффективные решения для любых случаев.", bentoComponent: "media-stack", mediaItems: [
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/side-view-man-posing-with-dental-gems_23-2151212425.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dental-equipment-placed-table_1150-19616.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/glasses-dentist-dental-office_627829-9495.jpg"},
|
||||
],
|
||||
},
|
||||
{
|
||||
title: "Элайнеры", description: "Незаметное исправление прикуса.", bentoComponent: "media-stack", mediaItems: [
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dentist-examining-man-teeth-with-dental-explorer-dental-mirror_651396-2613.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/closeup-snapshot-man-s-face-dentist-s-hands-putting-rubber-bands-brackets_651396-3132.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/happy-girl-is-smiling-with-braces-ray-laser-it_633478-32.jpg"},
|
||||
],
|
||||
},
|
||||
{
|
||||
title: "Цифровая диагностика", description: "Точность планирования лечения.", bentoComponent: "media-stack", mediaItems: [
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dentistry-team-analyzing-teeth-x-ray-green-screen-monitor-dentist-office-specialist-man-nurse-working-with-isolated-mockup-template-radiography-teethcare_482257-38493.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dentist-showing-tablet-teeth-x-ray-reviewing-it-with-patient-doctor-nurse-working-together-modern-stomatological-clinic-explaining-old-woman-radiography-tooth-using-notebook-display_482257-13065.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/orthodontist-using-horizontal-green-screen-tablet-oral-care-dentistry-woman-working-as-dentist-with-chroma-key-isolated-mockup-template-while-looking-teeth-scan_482257-29381.jpg"},
|
||||
],
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<FeaturesSection />
|
||||
|
||||
<div id="metrics" data-section="metrics">
|
||||
<SectionErrorBoundary name="metrics">
|
||||
<MetricsIconCards
|
||||
tag="Статистика"
|
||||
title="Результаты клиники"
|
||||
description="Наш опыт в цифрах."
|
||||
metrics={[
|
||||
{
|
||||
icon: "Users", title: "Счастливых пациентов", value: "2500+"},
|
||||
{
|
||||
icon: "Award", title: "Лет практики", value: "12"},
|
||||
{
|
||||
icon: "Smile", title: "Успешных кейсов", value: "100%"},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<MetricsSection />
|
||||
|
||||
<div id="pricing" data-section="pricing">
|
||||
<SectionErrorBoundary name="pricing">
|
||||
<PricingCenteredCards
|
||||
tag="Цены"
|
||||
title="Стоимость лечения"
|
||||
description="Прозрачное ценообразование без скрытых платежей."
|
||||
plans={[
|
||||
{
|
||||
tag: "Базовый", price: "от 50 000 ₽", description: "Классические металлические брекеты.", features: [
|
||||
"Диагностика", "Установка", "Гарантия"],
|
||||
primaryButton: {
|
||||
text: "Выбрать", href: "#contact"},
|
||||
},
|
||||
{
|
||||
tag: "Комфорт", price: "от 120 000 ₽", description: "Керамические брекеты для эстетики.", features: [
|
||||
"Все преимущества базового", "Меньше визитов", "Эстетичность"],
|
||||
primaryButton: {
|
||||
text: "Выбрать", href: "#contact"},
|
||||
},
|
||||
{
|
||||
tag: "Премиум", price: "от 250 000 ₽", description: "Прозрачные элайнеры.", features: [
|
||||
"Индивидуальный план", "Незаметно", "Макс. комфорт"],
|
||||
primaryButton: {
|
||||
text: "Выбрать", href: "#contact"},
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<PricingSection />
|
||||
|
||||
<div id="testimonials" data-section="testimonials">
|
||||
<SectionErrorBoundary name="testimonials">
|
||||
<TestimonialColumnMarqueeCards
|
||||
tag="Отзывы"
|
||||
title="Что говорят наши пациенты"
|
||||
description="Нам доверяют сотни улыбок."
|
||||
testimonials={[
|
||||
{
|
||||
name: "Анна С.", role: "Пациент", quote: "Очень довольна результатом! Улыбка теперь идеальная.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-face-portrait-smiling-happy-woman-hold-hands-face-looking-camera-with-satisfied-cheerful-face-watch-something-interesting-white-background_176420-54393.jpg"},
|
||||
{
|
||||
name: "Игорь В.", role: "Пациент", quote: "Профессиональный подход и вежливый персонал.", imageSrc: "http://img.b2bpic.net/free-photo/closeup-portrait-young-beautiful-smiling-female-trendy-summer-clothes-sexy-carefree-woman-posing-near-blue-wall-studio-positive-blond-model-having-fun-going-crazy-cheerful-happy_158538-20490.jpg"},
|
||||
{
|
||||
name: "Мария П.", role: "Пациент", quote: "Все объяснили доступно, лечение прошло комфортно.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-young-fit-person-jogging-by-sea_329181-16763.jpg"},
|
||||
{
|
||||
name: "Дмитрий К.", role: "Пациент", quote: "Рекомендую клинику всем знакомым!", imageSrc: "http://img.b2bpic.net/free-photo/female-patient-looking-mirror-dentist-s-office_23-2148985783.jpg"},
|
||||
{
|
||||
name: "Елена М.", role: "Пациент", quote: "Результат превзошел все мои ожидания.", imageSrc: "http://img.b2bpic.net/free-photo/happy-mature-woman-talking-her-doctor-medical-clinic_637285-9073.jpg"},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<TestimonialsSection />
|
||||
|
||||
<div id="faq" data-section="faq">
|
||||
<SectionErrorBoundary name="faq">
|
||||
<FaqTabbedAccordion
|
||||
tag="FAQ"
|
||||
title="Часто задаваемые вопросы"
|
||||
description="Ответы на популярные вопросы."
|
||||
categories={[
|
||||
{
|
||||
name: "Лечение", items: [
|
||||
{
|
||||
question: "Больно ли ставить брекеты?", answer: "Нет, процесс установки абсолютно безболезненный."},
|
||||
{
|
||||
question: "Сколько длится лечение?", answer: "Зависит от сложности, в среднем от 12 до 24 месяцев."},
|
||||
],
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<FaqSection />
|
||||
|
||||
<div id="contact" data-section="contact">
|
||||
<SectionErrorBoundary name="contact">
|
||||
<ContactCta
|
||||
tag="Запись"
|
||||
text="Готовы сделать шаг к идеальной улыбке?"
|
||||
primaryButton={{
|
||||
text: "Записаться онлайн", href: "#"}}
|
||||
secondaryButton={{
|
||||
text: "Позвонить нам", href: "tel:+78000000000"}}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
<ContactSection />
|
||||
</>
|
||||
);
|
||||
}
|
||||
|
||||
29
src/pages/HomePage/sections/About.tsx
Normal file
29
src/pages/HomePage/sections/About.tsx
Normal file
@@ -0,0 +1,29 @@
|
||||
// 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 AboutFeaturesSplit from '@/components/sections/about/AboutFeaturesSplit';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function AboutSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="about" data-section="about">
|
||||
<SectionErrorBoundary name="about">
|
||||
<AboutFeaturesSplit
|
||||
tag="О нас"
|
||||
title="Современная ортодонтия"
|
||||
description="Мы используем передовые методы лечения, чтобы сделать вашу улыбку красивой и здоровой. Комфорт пациентов — наш приоритет."
|
||||
items={[
|
||||
{
|
||||
icon: "CheckCircle", title: "Опытные врачи", description: "Специалисты с более чем 10-летним стажем."},
|
||||
{
|
||||
icon: "Shield", title: "Гарантия результата", description: "Контроль на всех этапах лечения."},
|
||||
{
|
||||
icon: "Zap", title: "Современное оборудование", description: "Цифровая диагностика и планирование."},
|
||||
]}
|
||||
imageSrc="http://img.b2bpic.net/free-photo/cheerful-medic-standing-with-arms-crossed_23-2147767252.jpg"
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
23
src/pages/HomePage/sections/Contact.tsx
Normal file
23
src/pages/HomePage/sections/Contact.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 "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="Запись"
|
||||
text="Готовы сделать шаг к идеальной улыбке?"
|
||||
primaryButton={{
|
||||
text: "Записаться онлайн", href: "#"}}
|
||||
secondaryButton={{
|
||||
text: "Позвонить нам", href: "tel:+78000000000"}}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
30
src/pages/HomePage/sections/Faq.tsx
Normal file
30
src/pages/HomePage/sections/Faq.tsx
Normal file
@@ -0,0 +1,30 @@
|
||||
// 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 FaqTabbedAccordion from '@/components/sections/faq/FaqTabbedAccordion';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function FaqSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="faq" data-section="faq">
|
||||
<SectionErrorBoundary name="faq">
|
||||
<FaqTabbedAccordion
|
||||
tag="FAQ"
|
||||
title="Часто задаваемые вопросы"
|
||||
description="Ответы на популярные вопросы."
|
||||
categories={[
|
||||
{
|
||||
name: "Лечение", items: [
|
||||
{
|
||||
question: "Больно ли ставить брекеты?", answer: "Нет, процесс установки абсолютно безболезненный."},
|
||||
{
|
||||
question: "Сколько длится лечение?", answer: "Зависит от сложности, в среднем от 12 до 24 месяцев."},
|
||||
],
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
52
src/pages/HomePage/sections/Features.tsx
Normal file
52
src/pages/HomePage/sections/Features.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 "features" section.
|
||||
|
||||
import React from 'react';
|
||||
import FeaturesBento from '@/components/sections/features/FeaturesBento';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function FeaturesSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="features" data-section="features">
|
||||
<SectionErrorBoundary name="features">
|
||||
<FeaturesBento
|
||||
tag="Услуги"
|
||||
title="Что мы предлагаем"
|
||||
description="Комплексный подход к исправлению прикуса."
|
||||
features={[
|
||||
{
|
||||
title: "Брекет-системы", description: "Эффективные решения для любых случаев.", bentoComponent: "media-stack", mediaItems: [
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/side-view-man-posing-with-dental-gems_23-2151212425.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dental-equipment-placed-table_1150-19616.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/glasses-dentist-dental-office_627829-9495.jpg"},
|
||||
],
|
||||
},
|
||||
{
|
||||
title: "Элайнеры", description: "Незаметное исправление прикуса.", bentoComponent: "media-stack", mediaItems: [
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dentist-examining-man-teeth-with-dental-explorer-dental-mirror_651396-2613.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/closeup-snapshot-man-s-face-dentist-s-hands-putting-rubber-bands-brackets_651396-3132.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/happy-girl-is-smiling-with-braces-ray-laser-it_633478-32.jpg"},
|
||||
],
|
||||
},
|
||||
{
|
||||
title: "Цифровая диагностика", description: "Точность планирования лечения.", bentoComponent: "media-stack", mediaItems: [
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dentistry-team-analyzing-teeth-x-ray-green-screen-monitor-dentist-office-specialist-man-nurse-working-with-isolated-mockup-template-radiography-teethcare_482257-38493.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/dentist-showing-tablet-teeth-x-ray-reviewing-it-with-patient-doctor-nurse-working-together-modern-stomatological-clinic-explaining-old-woman-radiography-tooth-using-notebook-display_482257-13065.jpg"},
|
||||
{
|
||||
imageSrc: "http://img.b2bpic.net/free-photo/orthodontist-using-horizontal-green-screen-tablet-oral-care-dentistry-woman-working-as-dentist-with-chroma-key-isolated-mockup-template-while-looking-teeth-scan_482257-29381.jpg"},
|
||||
],
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
19
src/pages/HomePage/sections/Hero.tsx
Normal file
19
src/pages/HomePage/sections/Hero.tsx
Normal 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
|
||||
primaryButton={{"href":"#contact","text":"Записаться на прием"}}
|
||||
title="Пронтеева Виктория Александровна"
|
||||
imageSrc="https://images.unsplash.com/photo-1559839734-2b71ea197ec2?q=80&w=2070&auto=format&fit=crop"
|
||||
secondaryButton={{"href":"#about","text":"Узнать больше"}}
|
||||
tag="Врач-ортодонт"
|
||||
description="Индивидуальный подход к созданию вашей идеальной улыбки. Современные методы лечения и бережное отношение к здоровью ваших зубов."
|
||||
/>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
28
src/pages/HomePage/sections/Metrics.tsx
Normal file
28
src/pages/HomePage/sections/Metrics.tsx
Normal file
@@ -0,0 +1,28 @@
|
||||
// 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 MetricsIconCards from '@/components/sections/metrics/MetricsIconCards';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function MetricsSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="metrics" data-section="metrics">
|
||||
<SectionErrorBoundary name="metrics">
|
||||
<MetricsIconCards
|
||||
tag="Статистика"
|
||||
title="Результаты клиники"
|
||||
description="Наш опыт в цифрах."
|
||||
metrics={[
|
||||
{
|
||||
icon: "Users", title: "Счастливых пациентов", value: "2500+"},
|
||||
{
|
||||
icon: "Award", title: "Лет практики", value: "12"},
|
||||
{
|
||||
icon: "Smile", title: "Успешных кейсов", value: "100%"},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
40
src/pages/HomePage/sections/Pricing.tsx
Normal file
40
src/pages/HomePage/sections/Pricing.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 "pricing" section.
|
||||
|
||||
import React from 'react';
|
||||
import PricingCenteredCards from '@/components/sections/pricing/PricingCenteredCards';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function PricingSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="pricing" data-section="pricing">
|
||||
<SectionErrorBoundary name="pricing">
|
||||
<PricingCenteredCards
|
||||
tag="Цены"
|
||||
title="Стоимость лечения"
|
||||
description="Прозрачное ценообразование без скрытых платежей."
|
||||
plans={[
|
||||
{
|
||||
tag: "Базовый", price: "от 50 000 ₽", description: "Классические металлические брекеты.", features: [
|
||||
"Диагностика", "Установка", "Гарантия"],
|
||||
primaryButton: {
|
||||
text: "Выбрать", href: "#contact"},
|
||||
},
|
||||
{
|
||||
tag: "Комфорт", price: "от 120 000 ₽", description: "Керамические брекеты для эстетики.", features: [
|
||||
"Все преимущества базового", "Меньше визитов", "Эстетичность"],
|
||||
primaryButton: {
|
||||
text: "Выбрать", href: "#contact"},
|
||||
},
|
||||
{
|
||||
tag: "Премиум", price: "от 250 000 ₽", description: "Прозрачные элайнеры.", features: [
|
||||
"Индивидуальный план", "Незаметно", "Макс. комфорт"],
|
||||
primaryButton: {
|
||||
text: "Выбрать", href: "#contact"},
|
||||
},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
32
src/pages/HomePage/sections/Testimonials.tsx
Normal file
32
src/pages/HomePage/sections/Testimonials.tsx
Normal file
@@ -0,0 +1,32 @@
|
||||
// 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 TestimonialColumnMarqueeCards from '@/components/sections/testimonial/TestimonialColumnMarqueeCards';
|
||||
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
|
||||
|
||||
export default function TestimonialsSection(): React.JSX.Element {
|
||||
return (
|
||||
<div id="testimonials" data-section="testimonials">
|
||||
<SectionErrorBoundary name="testimonials">
|
||||
<TestimonialColumnMarqueeCards
|
||||
tag="Отзывы"
|
||||
title="Что говорят наши пациенты"
|
||||
description="Нам доверяют сотни улыбок."
|
||||
testimonials={[
|
||||
{
|
||||
name: "Анна С.", role: "Пациент", quote: "Очень довольна результатом! Улыбка теперь идеальная.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-face-portrait-smiling-happy-woman-hold-hands-face-looking-camera-with-satisfied-cheerful-face-watch-something-interesting-white-background_176420-54393.jpg"},
|
||||
{
|
||||
name: "Игорь В.", role: "Пациент", quote: "Профессиональный подход и вежливый персонал.", imageSrc: "http://img.b2bpic.net/free-photo/closeup-portrait-young-beautiful-smiling-female-trendy-summer-clothes-sexy-carefree-woman-posing-near-blue-wall-studio-positive-blond-model-having-fun-going-crazy-cheerful-happy_158538-20490.jpg"},
|
||||
{
|
||||
name: "Мария П.", role: "Пациент", quote: "Все объяснили доступно, лечение прошло комфортно.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-young-fit-person-jogging-by-sea_329181-16763.jpg"},
|
||||
{
|
||||
name: "Дмитрий К.", role: "Пациент", quote: "Рекомендую клинику всем знакомым!", imageSrc: "http://img.b2bpic.net/free-photo/female-patient-looking-mirror-dentist-s-office_23-2148985783.jpg"},
|
||||
{
|
||||
name: "Елена М.", role: "Пациент", quote: "Результат превзошел все мои ожидания.", imageSrc: "http://img.b2bpic.net/free-photo/happy-mature-woman-talking-her-doctor-medical-clinic_637285-9073.jpg"},
|
||||
]}
|
||||
/>
|
||||
</SectionErrorBoundary>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user