12 Commits

Author SHA1 Message Date
f07e573927 Merge version_11_1782044722457 into main
Merge version_11_1782044722457 into main
2026-06-21 12:26:33 +00:00
kudinDmitriyUp
3ba4dc59e9 Bob AI: Update navbar CTA link to Telegram 2026-06-21 12:25:49 +00:00
432b25a048 Merge version_10_1782043750641 into main
Merge version_10_1782043750641 into main
2026-06-21 12:09:23 +00:00
f153592fba Update src/pages/HomePage.tsx 2026-06-21 12:09:19 +00:00
3338ee42ce Merge version_9_1782043581203 into main
Merge version_9_1782043581203 into main
2026-06-21 12:06:36 +00:00
ad6f587094 Update src/pages/HomePage.tsx 2026-06-21 12:06:30 +00:00
c33cd5f1d1 Merge version_8_1782043562019 into main
Merge version_8_1782043562019 into main
2026-06-21 12:06:14 +00:00
27c8a9501e Update src/pages/HomePage.tsx 2026-06-21 12:06:11 +00:00
57891aef22 Merge version_7_1782043040214 into main
Merge version_7_1782043040214 into main
2026-06-21 11:57:31 +00:00
7ef3d3b9f1 Update src/pages/HomePage.tsx 2026-06-21 11:57:28 +00:00
824d95ed1f Merge version_6_1782039519228 into main
Merge version_6_1782039519228 into main
2026-06-21 10:58:51 +00:00
1be673d2f5 Merge version_5_1782039452196 into main
Merge version_5_1782039452196 into main
2026-06-21 10:57:54 +00:00
10 changed files with 339 additions and 237 deletions

View File

@@ -45,7 +45,7 @@ export default function Layout() {
logo="Tary"
ctaButton={{
text: "Тапсырыс беру",
href: "#contact",
href: "https://t.me/thenu1da",
}}
navItems={navItems} />
</SectionErrorBoundary>

View File

@@ -1,248 +1,36 @@
import AboutTestimonial from '@/components/sections/about/AboutTestimonial';
import ContactCta from '@/components/sections/contact/ContactCta';
import FaqTabbedAccordion from '@/components/sections/faq/FaqTabbedAccordion';
import FeaturesBorderGlow from '@/components/sections/features/FeaturesBorderGlow';
import FeaturesImageBento from '@/components/sections/features/FeaturesImageBento';
import HeroBrand from '@/components/sections/hero/HeroBrand';
import MetricsIconCards from '@/components/sections/metrics/MetricsIconCards';
import TestimonialRatingCards from '@/components/sections/testimonial/TestimonialRatingCards';
import { Coffee, Flame, MapPin, ShieldCheck, 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 ProductsSection from './HomePage/sections/Products';
import FeaturesSection from './HomePage/sections/Features';
import MetricsSection from './HomePage/sections/Metrics';
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">
<HeroBrand
brand="Tary Coffee"
description="Қазақ даласының дәмі, сапалы кофе дәндері. Тary — нағыз талғампаздарға арналған кофе."
primaryButton={{
text: "Тапсырыс беру",
href: "#contact",
}}
secondaryButton={{
text: "Толығырақ",
href: "#about",
}}
imageSrc="http://img.b2bpic.net/free-photo/hand-holding-wooden-spoon-with-coffee-beans_114579-77300.jpg?_wi=1"
/>
</SectionErrorBoundary>
</div>
<>
<HeroSection />
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutTestimonial
tag="Біз туралы"
quote="Tary — тек кофе емес, бұл біздің мәдениетіміздің, қонақжайлылығымыздың көрінісі. Әрбір дән — тари"
author="Tary негізін қалаушы"
role="Coffee Artisan"
imageSrc="http://img.b2bpic.net/free-photo/woman-looking-man-washing-dishes_23-2147742318.jpg"
/>
</SectionErrorBoundary>
</div>
<AboutSection />
<div id="products" data-section="products">
<SectionErrorBoundary name="products">
<FeaturesImageBento
tag="Өнімдер"
title="Біздің таңдаулы кофелер"
description="Ең сапалы дәндерді таңдап, арнайы технологиямен қуырамыз."
items={[
{
title: "Ethiopian Heirloom",
description: "Гүлді және жеміс ноталары",
imageSrc: "http://img.b2bpic.net/free-photo/white-stand-up-pouch-mockup_23-2151965902.jpg",
},
{
title: "Brazil Santos",
description: "Шоколадты және жаңғақты дәм",
imageSrc: "http://img.b2bpic.net/free-photo/close-up-coffee-beans-grinder_53876-95410.jpg",
},
{
title: "Kenya AA",
description: "Ашық және қышқылтым дәм",
imageSrc: "http://img.b2bpic.net/free-photo/front-view-man-making-coffee_23-2150354575.jpg",
},
{
title: "Colombia Supremo",
description: "Балдай тәттілік",
imageSrc: "http://img.b2bpic.net/free-photo/delicious-bubble-tea-drink-high-angle_23-2149870675.jpg",
},
{
title: "Guatemala Antigua",
description: "Дәмдеуіштер мен какао",
imageSrc: "http://img.b2bpic.net/free-photo/scarf-books-near-tea-snacks_23-2147943444.jpg",
},
{
title: "Sumatra Mandheling",
description: "Топырақ және орман ноталары",
imageSrc: "http://img.b2bpic.net/free-photo/wooden-board-with-coffee-beans-marble-background-high-quality-photo_114579-67932.jpg",
},
{
title: "Tary Blend",
description: "Біздің фирмалық қоспамыз",
imageSrc: "http://img.b2bpic.net/free-photo/coffee-automatic-from-machine-with-ground-coffee_1220-6141.jpg",
},
]}
/>
</SectionErrorBoundary>
</div>
<ProductsSection />
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesBorderGlow
tag="Артықшылықтар"
title="Неге бізді таңдайды?"
description="Біздің кофе өндірісіміздегі ерекшеліктер."
features={[
{
icon: Coffee,
title: "Тікелей жеткізу",
description: "Әлемнің үздік плантацияларынан.",
},
{
icon: Flame,
title: "Жаңа қуырылған",
description: "Тапсырыс бойынша қуырамыз.",
},
{
icon: ShieldCheck,
title: "Сапа кепілдігі",
description: "Әрбір дән бақылауда.",
},
]}
/>
</SectionErrorBoundary>
</div>
<FeaturesSection />
<div id="metrics" data-section="metrics">
<SectionErrorBoundary name="metrics">
<MetricsIconCards
tag="Статистика"
title="Tary цифрларда"
metrics={[
{
icon: Coffee,
title: "Жеткізілген кеселер",
value: "50,000+",
},
{
icon: Users,
title: "Бақытты тұтынушылар",
value: "10,000+",
},
{
icon: MapPin,
title: "Серіктестер",
value: "150+",
},
]}
description="Біздің жетістіктеріміз сандармен"
/>
</SectionErrorBoundary>
</div>
<MetricsSection />
<div id="testimonials" data-section="testimonials">
<SectionErrorBoundary name="testimonials">
<TestimonialRatingCards
tag="Пікірлер"
title="Клиенттеріміз не дейді?"
testimonials={[
{
name: "Айдар Е.",
role: "Кофе сүйер",
quote: "Tary кофесі менің таңертеңгі күнімді жарқын етеді.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/young-hispanic-sporty-woman-smiling-happy-using-headphones-dancing-city_839833-15444.jpg",
},
{
name: "Динара С.",
role: "Бизнесмен",
quote: "Тамаша сапа және жылдам жеткізу.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/woman-scanning-qr-code-restaurant_23-2149357868.jpg",
},
{
name: "Ерлан М.",
role: "Студент",
quote: "Бұл мен ішкен ең дәмді кофе.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/front-view-woman-holding-coffee-cup_23-2149647826.jpg",
},
{
name: "Гүлнар А.",
role: "Үй шаруасындағы әйел",
quote: "Иісі үйге жайылып тұрады, өте ұнады.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/women-together-coffee-shop_23-2148263265.jpg",
},
{
name: "Марат Ж.",
role: "Жоба менеджері",
quote: "Керемет сервис пен кофе.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/close-up-indoor-photo-smiling-happy-woman-with-dark-hair-looking-window-while-drinking-coffee_291650-134.jpg",
},
]}
description="Сапамыз бен қызметіміз жайлы шыншыл пікірлер"
/>
</SectionErrorBoundary>
</div>
<TestimonialsSection />
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqTabbedAccordion
tag="Сұрақ-жауап"
title="Жиі қойылатын сұрақтар"
categories={[
{
name: "Жеткізу",
items: [
{
question: "Қалай тапсырыс беремін?",
answer: "Біздің сайт немесе WhatsApp арқылы тапсырыс бере аласыз.",
},
{
question: "Қанша уақытта жетеді?",
answer: "Қала ішінде 2 сағат ішінде жеткіземіз.",
},
{
question: "Жеткізу ақысы қандай?",
answer: "Белгілі бір сомадан асқан тапсырыстар тегін жеткізіледі.",
},
{
question: "Басқа қалаларға жібересіздер ме?",
answer: "Иә, Қазақстанның кез келген қаласына жеткізу бар.",
},
{
question: "Төлемді қалай жүргіземін?",
answer: "Kaspi аударым немесе сайт арқылы төлеуге болады.",
},
],
},
]}
description="Біз жайлы не білгіңіз келеді?"
/>
</SectionErrorBoundary>
</div>
<FaqSection />
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Байланыс"
text="Кофе туралы сұрақтарыңыз бар ма? Бізбен байланысыңыз."
primaryButton={{
text: "WhatsApp-қа жазу",
href: "",
}}
secondaryButton={{
text: "Қоңырау шалу",
href: "",
}}
/>
</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 AboutTestimonial from '@/components/sections/about/AboutTestimonial';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function AboutSection(): React.JSX.Element {
return (
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutTestimonial
tag="Біз туралы"
quote="Tary — тек кофе емес, бұл біздің мәдениетіміздің, қонақжайлылығымыздың көрінісі. Әрбір дән — тари"
author="Tary негізін қалаушы"
role="Coffee Artisan"
imageSrc="http://img.b2bpic.net/free-photo/woman-looking-man-washing-dishes_23-2147742318.jpg"
/>
</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="Байланыс"
text="Кофе туралы сұрақтарыңыз бар ма? Бізбен байланысыңыз."
primaryButton={{
text: "WhatsApp-қа  жазу",
href: "",
}}
secondaryButton={{
text: "Қоңырау шалу",
href: "",
}}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,47 @@
// 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="Сұрақ-жауап"
title="Жиі қойылатын сұрақтар"
categories={[
{
name: "Жеткізу",
items: [
{
question: "Қалай тапсырыс беремін?",
answer: "Біздің сайт немесе WhatsApp арқылы тапсырыс бере аласыз.",
},
{
question: "Қанша уақытта жетеді?",
answer: "Қала ішінде 2 сағат ішінде жеткіземіз.",
},
{
question: "Жеткізу ақысы қандай?",
answer: "Белгілі бір сомадан асқан тапсырыстар тегін жеткізіледі.",
},
{
question: "Басқа қалаларға жібересіздер ме?",
answer: "Иә, Қазақстанның кез келген қаласына жеткізу бар.",
},
{
question: "Төлемді қалай жүргіземін?",
answer: "Kaspi аударым немесе сайт арқылы төлеуге болады.",
},
],
},
]}
description="Біз жайлы не білгіңіз келеді?"
/>
</SectionErrorBoundary>
</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 "features" section.
import React from 'react';
import FeaturesBorderGlow from '@/components/sections/features/FeaturesBorderGlow';
import { Coffee, Flame, MapPin, ShieldCheck, Users } from "lucide-react";
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FeaturesSection(): React.JSX.Element {
return (
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesBorderGlow
tag="Артықшылықтар"
title="Неге бізді таңдайды?"
description="Біздің кофе өндірісіміздегі ерекшеліктер."
features={[
{
icon: Coffee,
title: "Тікелей жеткізу",
description: "Әлемнің үздік плантацияларынан.",
},
{
icon: Flame,
title: "Жаңа қуырылған",
description: "Тапсырыс бойынша қуырамыз.",
},
{
icon: ShieldCheck,
title: "Сапа кепілдігі",
description: "Әрбір дән бақылауда.",
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,28 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "hero" section.
import React from 'react';
import HeroBrand from '@/components/sections/hero/HeroBrand';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function HeroSection(): React.JSX.Element {
return (
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroBrand
brand="Tary Coffee"
description="Қазақ даласының дәмі, сапалы кофе дәндері. Тary — нағыз талғампаздарға арналған кофе."
primaryButton={{
text: "Тапсырыс беру",
href: "",
}}
secondaryButton={{
text: "Толығырақ",
href: "#about",
}}
imageSrc="http://img.b2bpic.net/free-photo/hand-holding-wooden-spoon-with-coffee-beans_114579-77300.jpg?_wi=1"
/>
</SectionErrorBoundary>
</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 "metrics" section.
import React from 'react';
import MetricsIconCards from '@/components/sections/metrics/MetricsIconCards';
import { Coffee, Flame, MapPin, ShieldCheck, Users } from "lucide-react";
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="Tary цифрларда"
metrics={[
{
icon: Coffee,
title: "Жеткізілген кеселер",
value: "50,000+",
},
{
icon: Users,
title: "Бақытты тұтынушылар",
value: "10,000+",
},
{
icon: MapPin,
title: "Серіктестер",
value: "150+",
},
]}
description="Біздің жетістіктеріміз сандармен"
/>
</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 "products" section.
import React from 'react';
import FeaturesImageBento from '@/components/sections/features/FeaturesImageBento';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function ProductsSection(): React.JSX.Element {
return (
<div id="products" data-section="products">
<SectionErrorBoundary name="products">
<FeaturesImageBento
tag="Өнімдер"
title="Біздің таңдаулы кофе"
description="Ең сапалы дәндерді таңдап, арнайы технологиямен қуырамыз."
items={[
{
title: "Ethiopian Heirloom",
description: "Гүлді және жеміс ноталары",
imageSrc: "http://img.b2bpic.net/free-photo/white-stand-up-pouch-mockup_23-2151965902.jpg",
},
{
title: "Brazil Santos",
description: "Шоколадты және жаңғақты дәм",
imageSrc: "http://img.b2bpic.net/free-photo/close-up-coffee-beans-grinder_53876-95410.jpg",
},
{
title: "Kenya AA",
description: "Ашық және қышқылтым дәм",
imageSrc: "http://img.b2bpic.net/free-photo/front-view-man-making-coffee_23-2150354575.jpg",
},
{
title: "Colombia Supremo",
description: "Балдай тәттілік",
imageSrc: "http://img.b2bpic.net/free-photo/delicious-bubble-tea-drink-high-angle_23-2149870675.jpg",
},
{
title: "Guatemala Antigua",
description: "Дәмдеуіштер мен какао",
imageSrc: "http://img.b2bpic.net/free-photo/scarf-books-near-tea-snacks_23-2147943444.jpg",
},
{
title: "Sumatra Mandheling",
description: "Топырақ және орман ноталары",
imageSrc: "http://img.b2bpic.net/free-photo/wooden-board-with-coffee-beans-marble-background-high-quality-photo_114579-67932.jpg",
},
{
title: "Tary Blend",
description: "Біздің фирмалық қоспамыз",
imageSrc: "http://img.b2bpic.net/free-photo/coffee-automatic-from-machine-with-ground-coffee_1220-6141.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 TestimonialRatingCards from '@/components/sections/testimonial/TestimonialRatingCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function TestimonialsSection(): React.JSX.Element {
return (
<div id="testimonials" data-section="testimonials">
<SectionErrorBoundary name="testimonials">
<TestimonialRatingCards
tag="Пікірлер"
title="Клиенттеріміз не дейді?"
testimonials={[
{
name: "Айдар Е.",
role: "Кофе сүйер",
quote: "Tary кофесі менің таңертеңгі күнімді жарқын етеді.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/young-hispanic-sporty-woman-smiling-happy-using-headphones-dancing-city_839833-15444.jpg",
},
{
name: "Динара С.",
role: "Бизнесмен",
quote: "Тамаша сапа және жылдам жеткізу.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/woman-scanning-qr-code-restaurant_23-2149357868.jpg",
},
{
name: "Ерлан М.",
role: "Студент",
quote: "Бұл мен ішкен ең дәмді кофе.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/front-view-woman-holding-coffee-cup_23-2149647826.jpg",
},
{
name: "Гүлнар А.",
role: "Үй шаруасындағы әйел",
quote: "Иісі үйге жайылып тұрады, өте ұнады.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/women-together-coffee-shop_23-2148263265.jpg",
},
{
name: "Марат Ж.",
role: "Жоба менеджері",
quote: "Керемет сервис пен кофе.",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/close-up-indoor-photo-smiling-happy-woman-with-dark-hair-looking-window-while-drinking-coffee_291650-134.jpg",
},
]}
description="Сапамыз бен қызметіміз жайлы шыншыл пікірлер"
/>
</SectionErrorBoundary>
</div>
);
}