Merge version_7_1782950985190 into main #6

Merged
bender merged 1 commits from version_7_1782950985190 into main 2026-07-02 00:13:38 +00:00

View File

@@ -1,57 +1,129 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "packages" section.
/* eslint-disable */
// @ts-nocheck — generated by catalog-eject; runtime-correct but TS strict-mode false-positives on inlined catalog body
import { Check } from "lucide-react";
import Button from "@/components/ui/Button";
import TextAnimation from "@/components/ui/TextAnimation";
import ImageOrVideo from "@/components/ui/ImageOrVideo";
import ScrollReveal from "@/components/ui/ScrollReveal";
import React from 'react';
import PricingMediaCards from '@/components/sections/pricing/PricingMediaCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
const plans = [
{
tag: "WEB X PRO",
price: "$14,900",
period: "MXN",
features: [
"10 pages",
"On-page SEO",
"Forms & WhatsApp",
"GMB Premium",
"1 month support"
],
primaryButton: {
text: "Get Pro",
href: "#contact"
},
imageSrc: "http://img.b2bpic.net/free-psd/start-up-landing-page-template_23-2148819558.jpg"
},
{
tag: "WEB X DOMINATOR",
price: "$24,900",
period: "MXN",
features: [
"Everything in Pro",
"Campaign Landing Page",
"Google Analytics",
"Traffic Report",
"3 months support"
],
primaryButton: {
text: "Get Dominator",
href: "#contact"
},
imageSrc: "http://img.b2bpic.net/free-psd/business-corporation-template_23-2151402198.jpg"
}
];
export default function PackagesSection(): React.JSX.Element {
return (
<div id="packages" data-section="packages">
<SectionErrorBoundary name="packages">
<PricingMediaCards
tag="PACKAGES"
title="CHOOSE YOUR [X] LEVEL"
description="Transparent pricing for complete solutions."
plans={[
{
tag: "WEB X PRO",
price: "$14,900",
period: "MXN",
features: [
"10 pages",
"On-page SEO",
"Forms & WhatsApp",
"GMB Premium",
"1 month support",
],
primaryButton: {
text: "Get Pro",
href: "#contact",
},
imageSrc: "http://img.b2bpic.net/free-psd/start-up-landing-page-template_23-2148819558.jpg",
},
{
tag: "WEB X DOMINATOR",
price: "$24,900",
period: "MXN",
features: [
"Everything in Pro",
"Campaign Landing Page",
"Google Analytics",
"Traffic Report",
"3 months support",
],
primaryButton: {
text: "Get Dominator",
href: "#contact",
},
imageSrc: "http://img.b2bpic.net/free-psd/business-corporation-template_23-2151402198.jpg",
},
]}
textAnimation="fade-blur"
type PricingPlan = {
tag: string;
price: string;
period: string;
features: string[];
primaryButton: { text: string; href: string };
} & ({ imageSrc: string; videoSrc?: never } | { videoSrc: string; imageSrc?: never });
const PackagesInline = () => (
<section aria-label="Pricing section" className="py-20">
<div className="flex flex-col gap-8 md:gap-10">
<div className="flex flex-col items-center gap-2 w-content-width mx-auto">
<div className="px-3 py-1 mb-1 text-sm card rounded w-fit">
<p>{"PACKAGES"}</p>
</div>
<TextAnimation
text={"CHOOSE YOUR [X] LEVEL"}
variant={"fade-blur"}
gradientText={true}
tag="h2"
className="md:max-w-8/10 text-6xl 2xl:text-7xl leading-[1.15] font-semibold text-center text-balance"
/>
</SectionErrorBoundary>
<TextAnimation
text={"Transparent pricing for complete solutions."}
variant={"fade-blur"}
gradientText={false}
tag="p"
className="md:max-w-7/10 text-lg md:text-xl leading-snug text-center text-balance"
/>
{(undefined || undefined) && (
<div className="flex flex-wrap justify-center gap-3 mt-2 md:mt-3">
{undefined && <Button text={undefined.text} href={undefined.href} variant="primary"/>}
{undefined && <Button text={undefined.text} href={undefined.href} variant="secondary"animationDelay={0.1} />}
</div>
)}
</div>
<div className="flex flex-col gap-5 w-content-width mx-auto">
{plans.map((plan) => (
<ScrollReveal
variant="slide-up"
key={plan.tag}
className="flex flex-col md:flex-row gap-6 md:gap-10 p-6 md:p-10 card rounded"
>
<div className="w-full md:w-1/2 aspect-square md:aspect-4/3 rounded overflow-hidden">
<ImageOrVideo imageSrc={plan.imageSrc} videoSrc={plan.videoSrc} />
</div>
<div className="flex flex-col justify-center gap-2 w-full md:w-1/2">
<div className="px-3 py-1 mb-1 w-fit text-sm card rounded">
<p>{plan.price}{plan.period}</p>
</div>
<h3 className="text-4xl md:text-5xl font-semibold leading-[1.15] text-balance">{plan.tag}</h3>
<div className="flex flex-col gap-3 mt-1">
{plan.features.map((feature) => (
<div key={feature} className="flex items-start gap-3">
<div className="flex items-center justify-center shrink-0 size-6 primary-button rounded">
<Check className="size-3 text-primary-cta-text" strokeWidth={2} />
</div>
<span className="text-base leading-snug">{feature}</span>
</div>
))}
</div>
<Button text={plan.primaryButton.text} href={plan.primaryButton.href} variant="primary" className="w-fit mt-2 md:mt-3" />
</div>
</ScrollReveal>
))}
</div>
</div>
</section>
);
export default function PackagesSection() {
return (
<div data-webild-section="packages" id="packages">
<PackagesInline />
</div>
);
}