@lexsis/storefront-components 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/PageRenderer.d.ts +8 -0
- package/dist/PageRenderer.d.ts.map +1 -0
- package/dist/PageRenderer.js +116 -0
- package/dist/PageRenderer.js.map +1 -0
- package/dist/SectionSkeleton.d.ts +2 -0
- package/dist/SectionSkeleton.d.ts.map +1 -0
- package/dist/SectionSkeleton.js +5 -0
- package/dist/SectionSkeleton.js.map +1 -0
- package/dist/ThemeContext.d.ts +11 -0
- package/dist/ThemeContext.d.ts.map +1 -0
- package/dist/ThemeContext.js +13 -0
- package/dist/ThemeContext.js.map +1 -0
- package/dist/ThemeProvider.d.ts +9 -0
- package/dist/ThemeProvider.d.ts.map +1 -0
- package/dist/ThemeProvider.js +227 -0
- package/dist/ThemeProvider.js.map +1 -0
- package/dist/ThemeToggle.d.ts +6 -0
- package/dist/ThemeToggle.d.ts.map +1 -0
- package/dist/ThemeToggle.js +26 -0
- package/dist/ThemeToggle.js.map +1 -0
- package/dist/animations/advanced-hooks.d.ts +36 -0
- package/dist/animations/advanced-hooks.d.ts.map +1 -0
- package/dist/animations/advanced-hooks.js +106 -0
- package/dist/animations/advanced-hooks.js.map +1 -0
- package/dist/animations/canvas-utils.d.ts +41 -0
- package/dist/animations/canvas-utils.d.ts.map +1 -0
- package/dist/animations/canvas-utils.js +115 -0
- package/dist/animations/canvas-utils.js.map +1 -0
- package/dist/animations/hooks.d.ts +48 -0
- package/dist/animations/hooks.d.ts.map +1 -0
- package/dist/animations/hooks.js +50 -0
- package/dist/animations/hooks.js.map +1 -0
- package/dist/animations/index.d.ts +4 -0
- package/dist/animations/index.d.ts.map +1 -0
- package/dist/animations/index.js +4 -0
- package/dist/animations/index.js.map +1 -0
- package/dist/animations/presets.d.ts +43 -0
- package/dist/animations/presets.d.ts.map +1 -0
- package/dist/animations/presets.js +278 -0
- package/dist/animations/presets.js.map +1 -0
- package/dist/animations/variants.d.ts +15 -0
- package/dist/animations/variants.d.ts.map +1 -0
- package/dist/animations/variants.js +90 -0
- package/dist/animations/variants.js.map +1 -0
- package/dist/backgrounds/BackgroundSection.d.ts +3 -0
- package/dist/backgrounds/BackgroundSection.d.ts.map +1 -0
- package/dist/backgrounds/BackgroundSection.js +205 -0
- package/dist/backgrounds/BackgroundSection.js.map +1 -0
- package/dist/buttons/ButtonSection.d.ts +3 -0
- package/dist/buttons/ButtonSection.d.ts.map +1 -0
- package/dist/buttons/ButtonSection.js +150 -0
- package/dist/buttons/ButtonSection.js.map +1 -0
- package/dist/cards/CardStack.d.ts +3 -0
- package/dist/cards/CardStack.d.ts.map +1 -0
- package/dist/cards/CardStack.js +140 -0
- package/dist/cards/CardStack.js.map +1 -0
- package/dist/cards/FeatureCard.d.ts +3 -0
- package/dist/cards/FeatureCard.d.ts.map +1 -0
- package/dist/cards/FeatureCard.js +100 -0
- package/dist/cards/FeatureCard.js.map +1 -0
- package/dist/cards/FeaturedCard.d.ts +3 -0
- package/dist/cards/FeaturedCard.d.ts.map +1 -0
- package/dist/cards/FeaturedCard.js +66 -0
- package/dist/cards/FeaturedCard.js.map +1 -0
- package/dist/cards/TerminalCard.d.ts +3 -0
- package/dist/cards/TerminalCard.d.ts.map +1 -0
- package/dist/cards/TerminalCard.js +73 -0
- package/dist/cards/TerminalCard.js.map +1 -0
- package/dist/cards/TestimonialCard.d.ts +3 -0
- package/dist/cards/TestimonialCard.d.ts.map +1 -0
- package/dist/cards/TestimonialCard.js +50 -0
- package/dist/cards/TestimonialCard.js.map +1 -0
- package/dist/cards/index.d.ts +2 -0
- package/dist/cards/index.d.ts.map +1 -0
- package/dist/cards/index.js +2 -0
- package/dist/cards/index.js.map +1 -0
- package/dist/cart/CartCheckoutBar.d.ts +3 -0
- package/dist/cart/CartCheckoutBar.d.ts.map +1 -0
- package/dist/cart/CartCheckoutBar.js +258 -0
- package/dist/cart/CartCheckoutBar.js.map +1 -0
- package/dist/cart/CartDiscount.d.ts +3 -0
- package/dist/cart/CartDiscount.d.ts.map +1 -0
- package/dist/cart/CartDiscount.js +78 -0
- package/dist/cart/CartDiscount.js.map +1 -0
- package/dist/cart/CartDrawer.d.ts +3 -0
- package/dist/cart/CartDrawer.d.ts.map +1 -0
- package/dist/cart/CartDrawer.js +141 -0
- package/dist/cart/CartDrawer.js.map +1 -0
- package/dist/cart/CartLines.d.ts +3 -0
- package/dist/cart/CartLines.d.ts.map +1 -0
- package/dist/cart/CartLines.js +227 -0
- package/dist/cart/CartLines.js.map +1 -0
- package/dist/cart/CartPage.d.ts +3 -0
- package/dist/cart/CartPage.d.ts.map +1 -0
- package/dist/cart/CartPage.js +128 -0
- package/dist/cart/CartPage.js.map +1 -0
- package/dist/cart/CartSummary.d.ts +3 -0
- package/dist/cart/CartSummary.d.ts.map +1 -0
- package/dist/cart/CartSummary.js +155 -0
- package/dist/cart/CartSummary.js.map +1 -0
- package/dist/cart/CartTrigger.d.ts +3 -0
- package/dist/cart/CartTrigger.d.ts.map +1 -0
- package/dist/cart/CartTrigger.js +45 -0
- package/dist/cart/CartTrigger.js.map +1 -0
- package/dist/cart/GuaranteeBanner.d.ts +3 -0
- package/dist/cart/GuaranteeBanner.d.ts.map +1 -0
- package/dist/cart/GuaranteeBanner.js +15 -0
- package/dist/cart/GuaranteeBanner.js.map +1 -0
- package/dist/cart/index.d.ts +8 -0
- package/dist/cart/index.d.ts.map +1 -0
- package/dist/cart/index.js +8 -0
- package/dist/cart/index.js.map +1 -0
- package/dist/content/BeforeAfterSlider.d.ts +3 -0
- package/dist/content/BeforeAfterSlider.d.ts.map +1 -0
- package/dist/content/BeforeAfterSlider.js +61 -0
- package/dist/content/BeforeAfterSlider.js.map +1 -0
- package/dist/content/ImageTextSplit.d.ts +3 -0
- package/dist/content/ImageTextSplit.d.ts.map +1 -0
- package/dist/content/ImageTextSplit.js +33 -0
- package/dist/content/ImageTextSplit.js.map +1 -0
- package/dist/content/LookbookGrid.d.ts +3 -0
- package/dist/content/LookbookGrid.d.ts.map +1 -0
- package/dist/content/LookbookGrid.js +183 -0
- package/dist/content/LookbookGrid.js.map +1 -0
- package/dist/content/ParallaxSection.d.ts +3 -0
- package/dist/content/ParallaxSection.d.ts.map +1 -0
- package/dist/content/ParallaxSection.js +66 -0
- package/dist/content/ParallaxSection.js.map +1 -0
- package/dist/content/RichText.d.ts +3 -0
- package/dist/content/RichText.d.ts.map +1 -0
- package/dist/content/RichText.js +21 -0
- package/dist/content/RichText.js.map +1 -0
- package/dist/content/index.d.ts +5 -0
- package/dist/content/index.d.ts.map +1 -0
- package/dist/content/index.js +5 -0
- package/dist/content/index.js.map +1 -0
- package/dist/content-types.d.ts +637 -0
- package/dist/content-types.d.ts.map +1 -0
- package/dist/content-types.js +2 -0
- package/dist/content-types.js.map +1 -0
- package/dist/context/LxCartContext.d.ts +71 -0
- package/dist/context/LxCartContext.d.ts.map +1 -0
- package/dist/context/LxCartContext.js +491 -0
- package/dist/context/LxCartContext.js.map +1 -0
- package/dist/context/LxEditorContext.d.ts +8 -0
- package/dist/context/LxEditorContext.d.ts.map +1 -0
- package/dist/context/LxEditorContext.js +10 -0
- package/dist/context/LxEditorContext.js.map +1 -0
- package/dist/context/LxPDPContext.d.ts +39 -0
- package/dist/context/LxPDPContext.d.ts.map +1 -0
- package/dist/context/LxPDPContext.js +52 -0
- package/dist/context/LxPDPContext.js.map +1 -0
- package/dist/cta/CtaFullWidth.d.ts +3 -0
- package/dist/cta/CtaFullWidth.d.ts.map +1 -0
- package/dist/cta/CtaFullWidth.js +30 -0
- package/dist/cta/CtaFullWidth.js.map +1 -0
- package/dist/cta/CtaStickyBottom.d.ts +3 -0
- package/dist/cta/CtaStickyBottom.d.ts.map +1 -0
- package/dist/cta/CtaStickyBottom.js +43 -0
- package/dist/cta/CtaStickyBottom.js.map +1 -0
- package/dist/cta/GuaranteeCta.d.ts +3 -0
- package/dist/cta/GuaranteeCta.d.ts.map +1 -0
- package/dist/cta/GuaranteeCta.js +27 -0
- package/dist/cta/GuaranteeCta.js.map +1 -0
- package/dist/cta/NewsletterSignup.d.ts +3 -0
- package/dist/cta/NewsletterSignup.d.ts.map +1 -0
- package/dist/cta/NewsletterSignup.js +35 -0
- package/dist/cta/NewsletterSignup.js.map +1 -0
- package/dist/cta/Popup.d.ts +3 -0
- package/dist/cta/Popup.d.ts.map +1 -0
- package/dist/cta/Popup.js +208 -0
- package/dist/cta/Popup.js.map +1 -0
- package/dist/cta/UrgencyCta.d.ts +3 -0
- package/dist/cta/UrgencyCta.d.ts.map +1 -0
- package/dist/cta/UrgencyCta.js +85 -0
- package/dist/cta/UrgencyCta.js.map +1 -0
- package/dist/cta/WaitlistCta.d.ts +3 -0
- package/dist/cta/WaitlistCta.d.ts.map +1 -0
- package/dist/cta/WaitlistCta.js +62 -0
- package/dist/cta/WaitlistCta.js.map +1 -0
- package/dist/cta/index.d.ts +3 -0
- package/dist/cta/index.d.ts.map +1 -0
- package/dist/cta/index.js +3 -0
- package/dist/cta/index.js.map +1 -0
- package/dist/effects/AnimatedBackground.d.ts +22 -0
- package/dist/effects/AnimatedBackground.d.ts.map +1 -0
- package/dist/effects/AnimatedBackground.js +313 -0
- package/dist/effects/AnimatedBackground.js.map +1 -0
- package/dist/effects/CanvasReveal.d.ts +5 -0
- package/dist/effects/CanvasReveal.d.ts.map +1 -0
- package/dist/effects/CanvasReveal.js +104 -0
- package/dist/effects/CanvasReveal.js.map +1 -0
- package/dist/effects/DecorativeOverlay.d.ts +10 -0
- package/dist/effects/DecorativeOverlay.d.ts.map +1 -0
- package/dist/effects/DecorativeOverlay.js +76 -0
- package/dist/effects/DecorativeOverlay.js.map +1 -0
- package/dist/effects/ScrollLinked.d.ts +3 -0
- package/dist/effects/ScrollLinked.d.ts.map +1 -0
- package/dist/effects/ScrollLinked.js +57 -0
- package/dist/effects/ScrollLinked.js.map +1 -0
- package/dist/effects/svg-library.d.ts +3 -0
- package/dist/effects/svg-library.d.ts.map +1 -0
- package/dist/effects/svg-library.js +105 -0
- package/dist/effects/svg-library.js.map +1 -0
- package/dist/faq/FaqAccordion.d.ts +3 -0
- package/dist/faq/FaqAccordion.d.ts.map +1 -0
- package/dist/faq/FaqAccordion.js +39 -0
- package/dist/faq/FaqAccordion.js.map +1 -0
- package/dist/faq/FaqTwoColumn.d.ts +3 -0
- package/dist/faq/FaqTwoColumn.d.ts.map +1 -0
- package/dist/faq/FaqTwoColumn.js +38 -0
- package/dist/faq/FaqTwoColumn.js.map +1 -0
- package/dist/faq/index.d.ts +3 -0
- package/dist/faq/index.d.ts.map +1 -0
- package/dist/faq/index.js +3 -0
- package/dist/faq/index.js.map +1 -0
- package/dist/features/BentoGrid.d.ts +3 -0
- package/dist/features/BentoGrid.d.ts.map +1 -0
- package/dist/features/BentoGrid.js +62 -0
- package/dist/features/BentoGrid.js.map +1 -0
- package/dist/features/FeatureGrid.d.ts +3 -0
- package/dist/features/FeatureGrid.d.ts.map +1 -0
- package/dist/features/FeatureGrid.js +89 -0
- package/dist/features/FeatureGrid.js.map +1 -0
- package/dist/features/FeatureTabs.d.ts +3 -0
- package/dist/features/FeatureTabs.d.ts.map +1 -0
- package/dist/features/FeatureTabs.js +64 -0
- package/dist/features/FeatureTabs.js.map +1 -0
- package/dist/features/ProcessSteps.d.ts +3 -0
- package/dist/features/ProcessSteps.d.ts.map +1 -0
- package/dist/features/ProcessSteps.js +74 -0
- package/dist/features/ProcessSteps.js.map +1 -0
- package/dist/heroes/HeroActivity.d.ts +3 -0
- package/dist/heroes/HeroActivity.d.ts.map +1 -0
- package/dist/heroes/HeroActivity.js +54 -0
- package/dist/heroes/HeroActivity.js.map +1 -0
- package/dist/heroes/HeroAnimated.d.ts +3 -0
- package/dist/heroes/HeroAnimated.d.ts.map +1 -0
- package/dist/heroes/HeroAnimated.js +101 -0
- package/dist/heroes/HeroAnimated.js.map +1 -0
- package/dist/heroes/HeroAurora.d.ts +3 -0
- package/dist/heroes/HeroAurora.d.ts.map +1 -0
- package/dist/heroes/HeroAurora.js +53 -0
- package/dist/heroes/HeroAurora.js.map +1 -0
- package/dist/heroes/HeroCarousel.d.ts +3 -0
- package/dist/heroes/HeroCarousel.d.ts.map +1 -0
- package/dist/heroes/HeroCarousel.js +187 -0
- package/dist/heroes/HeroCarousel.js.map +1 -0
- package/dist/heroes/HeroCentered.d.ts +3 -0
- package/dist/heroes/HeroCentered.d.ts.map +1 -0
- package/dist/heroes/HeroCentered.js +62 -0
- package/dist/heroes/HeroCentered.js.map +1 -0
- package/dist/heroes/HeroCinematicFullbleed.d.ts +3 -0
- package/dist/heroes/HeroCinematicFullbleed.d.ts.map +1 -0
- package/dist/heroes/HeroCinematicFullbleed.js +44 -0
- package/dist/heroes/HeroCinematicFullbleed.js.map +1 -0
- package/dist/heroes/HeroCountdown.d.ts +3 -0
- package/dist/heroes/HeroCountdown.d.ts.map +1 -0
- package/dist/heroes/HeroCountdown.js +64 -0
- package/dist/heroes/HeroCountdown.js.map +1 -0
- package/dist/heroes/HeroDarkSplitSticker.d.ts +3 -0
- package/dist/heroes/HeroDarkSplitSticker.d.ts.map +1 -0
- package/dist/heroes/HeroDarkSplitSticker.js +39 -0
- package/dist/heroes/HeroDarkSplitSticker.js.map +1 -0
- package/dist/heroes/HeroEditorial.d.ts +3 -0
- package/dist/heroes/HeroEditorial.d.ts.map +1 -0
- package/dist/heroes/HeroEditorial.js +30 -0
- package/dist/heroes/HeroEditorial.js.map +1 -0
- package/dist/heroes/HeroEditorialMinimal.d.ts +3 -0
- package/dist/heroes/HeroEditorialMinimal.d.ts.map +1 -0
- package/dist/heroes/HeroEditorialMinimal.js +47 -0
- package/dist/heroes/HeroEditorialMinimal.js.map +1 -0
- package/dist/heroes/HeroFullBleed.d.ts +3 -0
- package/dist/heroes/HeroFullBleed.d.ts.map +1 -0
- package/dist/heroes/HeroFullBleed.js +136 -0
- package/dist/heroes/HeroFullBleed.js.map +1 -0
- package/dist/heroes/HeroMini.d.ts +3 -0
- package/dist/heroes/HeroMini.d.ts.map +1 -0
- package/dist/heroes/HeroMini.js +25 -0
- package/dist/heroes/HeroMini.js.map +1 -0
- package/dist/heroes/HeroParallax.d.ts +3 -0
- package/dist/heroes/HeroParallax.d.ts.map +1 -0
- package/dist/heroes/HeroParallax.js +71 -0
- package/dist/heroes/HeroParallax.js.map +1 -0
- package/dist/heroes/HeroRetroCentered.d.ts +3 -0
- package/dist/heroes/HeroRetroCentered.d.ts.map +1 -0
- package/dist/heroes/HeroRetroCentered.js +49 -0
- package/dist/heroes/HeroRetroCentered.js.map +1 -0
- package/dist/heroes/HeroSplit.d.ts +3 -0
- package/dist/heroes/HeroSplit.d.ts.map +1 -0
- package/dist/heroes/HeroSplit.js +81 -0
- package/dist/heroes/HeroSplit.js.map +1 -0
- package/dist/heroes/HeroSpotlight.d.ts +3 -0
- package/dist/heroes/HeroSpotlight.d.ts.map +1 -0
- package/dist/heroes/HeroSpotlight.js +60 -0
- package/dist/heroes/HeroSpotlight.js.map +1 -0
- package/dist/heroes/HeroTrustSplit.d.ts +3 -0
- package/dist/heroes/HeroTrustSplit.d.ts.map +1 -0
- package/dist/heroes/HeroTrustSplit.js +53 -0
- package/dist/heroes/HeroTrustSplit.js.map +1 -0
- package/dist/heroes/HeroTypewriter.d.ts +3 -0
- package/dist/heroes/HeroTypewriter.d.ts.map +1 -0
- package/dist/heroes/HeroTypewriter.js +80 -0
- package/dist/heroes/HeroTypewriter.js.map +1 -0
- package/dist/heroes/index.d.ts +12 -0
- package/dist/heroes/index.d.ts.map +1 -0
- package/dist/heroes/index.js +12 -0
- package/dist/heroes/index.js.map +1 -0
- package/dist/index.d.ts +37 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +49 -0
- package/dist/index.js.map +1 -0
- package/dist/layout/Footer.d.ts +3 -0
- package/dist/layout/Footer.d.ts.map +1 -0
- package/dist/layout/Footer.js +75 -0
- package/dist/layout/Footer.js.map +1 -0
- package/dist/layout/Navbar.d.ts +3 -0
- package/dist/layout/Navbar.d.ts.map +1 -0
- package/dist/layout/Navbar.js +81 -0
- package/dist/layout/Navbar.js.map +1 -0
- package/dist/layout/PromoTopBar.d.ts +3 -0
- package/dist/layout/PromoTopBar.d.ts.map +1 -0
- package/dist/layout/PromoTopBar.js +201 -0
- package/dist/layout/PromoTopBar.js.map +1 -0
- package/dist/layout/SectionDivider.d.ts +3 -0
- package/dist/layout/SectionDivider.d.ts.map +1 -0
- package/dist/layout/SectionDivider.js +13 -0
- package/dist/layout/SectionDivider.js.map +1 -0
- package/dist/layout/SectionTransition.d.ts +3 -0
- package/dist/layout/SectionTransition.d.ts.map +1 -0
- package/dist/layout/SectionTransition.js +60 -0
- package/dist/layout/SectionTransition.js.map +1 -0
- package/dist/layout/Ticker.d.ts +3 -0
- package/dist/layout/Ticker.d.ts.map +1 -0
- package/dist/layout/Ticker.js +32 -0
- package/dist/layout/Ticker.js.map +1 -0
- package/dist/layout/index.d.ts +6 -0
- package/dist/layout/index.d.ts.map +1 -0
- package/dist/layout/index.js +6 -0
- package/dist/layout/index.js.map +1 -0
- package/dist/personalization/CartRecovery.d.ts +3 -0
- package/dist/personalization/CartRecovery.d.ts.map +1 -0
- package/dist/personalization/CartRecovery.js +224 -0
- package/dist/personalization/CartRecovery.js.map +1 -0
- package/dist/personalization/CohortTrustStack.d.ts +3 -0
- package/dist/personalization/CohortTrustStack.d.ts.map +1 -0
- package/dist/personalization/CohortTrustStack.js +101 -0
- package/dist/personalization/CohortTrustStack.js.map +1 -0
- package/dist/personalization/LiveActivityTicker.d.ts +3 -0
- package/dist/personalization/LiveActivityTicker.d.ts.map +1 -0
- package/dist/personalization/LiveActivityTicker.js +137 -0
- package/dist/personalization/LiveActivityTicker.js.map +1 -0
- package/dist/personalization/LoyaltyStatus.d.ts +3 -0
- package/dist/personalization/LoyaltyStatus.d.ts.map +1 -0
- package/dist/personalization/LoyaltyStatus.js +185 -0
- package/dist/personalization/LoyaltyStatus.js.map +1 -0
- package/dist/personalization/PersonalizedGreeting.d.ts +3 -0
- package/dist/personalization/PersonalizedGreeting.d.ts.map +1 -0
- package/dist/personalization/PersonalizedGreeting.js +176 -0
- package/dist/personalization/PersonalizedGreeting.js.map +1 -0
- package/dist/personalization/PersonalizedRecommendations.d.ts +3 -0
- package/dist/personalization/PersonalizedRecommendations.d.ts.map +1 -0
- package/dist/personalization/PersonalizedRecommendations.js +156 -0
- package/dist/personalization/PersonalizedRecommendations.js.map +1 -0
- package/dist/personalization/ProgressMilestone.d.ts +3 -0
- package/dist/personalization/ProgressMilestone.d.ts.map +1 -0
- package/dist/personalization/ProgressMilestone.js +127 -0
- package/dist/personalization/ProgressMilestone.js.map +1 -0
- package/dist/personalization/ReengagementBanner.d.ts +3 -0
- package/dist/personalization/ReengagementBanner.d.ts.map +1 -0
- package/dist/personalization/ReengagementBanner.js +185 -0
- package/dist/personalization/ReengagementBanner.js.map +1 -0
- package/dist/personalization/ScarcityIndicator.d.ts +3 -0
- package/dist/personalization/ScarcityIndicator.d.ts.map +1 -0
- package/dist/personalization/ScarcityIndicator.js +264 -0
- package/dist/personalization/ScarcityIndicator.js.map +1 -0
- package/dist/personalization/VipGate.d.ts +3 -0
- package/dist/personalization/VipGate.d.ts.map +1 -0
- package/dist/personalization/VipGate.js +309 -0
- package/dist/personalization/VipGate.js.map +1 -0
- package/dist/placeholder/UnknownComponent.d.ts +6 -0
- package/dist/placeholder/UnknownComponent.d.ts.map +1 -0
- package/dist/placeholder/UnknownComponent.js +5 -0
- package/dist/placeholder/UnknownComponent.js.map +1 -0
- package/dist/pricing/PricingCards.d.ts +3 -0
- package/dist/pricing/PricingCards.d.ts.map +1 -0
- package/dist/pricing/PricingCards.js +143 -0
- package/dist/pricing/PricingCards.js.map +1 -0
- package/dist/primitives/AspectBox.d.ts +12 -0
- package/dist/primitives/AspectBox.d.ts.map +1 -0
- package/dist/primitives/AspectBox.js +15 -0
- package/dist/primitives/AspectBox.js.map +1 -0
- package/dist/primitives/CursorSpotlight.d.ts +11 -0
- package/dist/primitives/CursorSpotlight.d.ts.map +1 -0
- package/dist/primitives/CursorSpotlight.js +21 -0
- package/dist/primitives/CursorSpotlight.js.map +1 -0
- package/dist/primitives/HeadlineEffect.d.ts +16 -0
- package/dist/primitives/HeadlineEffect.d.ts.map +1 -0
- package/dist/primitives/HeadlineEffect.js +187 -0
- package/dist/primitives/HeadlineEffect.js.map +1 -0
- package/dist/primitives/Marquee.d.ts +11 -0
- package/dist/primitives/Marquee.d.ts.map +1 -0
- package/dist/primitives/Marquee.js +22 -0
- package/dist/primitives/Marquee.js.map +1 -0
- package/dist/primitives/MediaFlip.d.ts +16 -0
- package/dist/primitives/MediaFlip.d.ts.map +1 -0
- package/dist/primitives/MediaFlip.js +118 -0
- package/dist/primitives/MediaFlip.js.map +1 -0
- package/dist/primitives/MediaLoop.d.ts +15 -0
- package/dist/primitives/MediaLoop.d.ts.map +1 -0
- package/dist/primitives/MediaLoop.js +31 -0
- package/dist/primitives/MediaLoop.js.map +1 -0
- package/dist/primitives/PDPGallery.d.ts +24 -0
- package/dist/primitives/PDPGallery.d.ts.map +1 -0
- package/dist/primitives/PDPGallery.js +128 -0
- package/dist/primitives/PDPGallery.js.map +1 -0
- package/dist/primitives/TiltCard.d.ts +12 -0
- package/dist/primitives/TiltCard.d.ts.map +1 -0
- package/dist/primitives/TiltCard.js +41 -0
- package/dist/primitives/TiltCard.js.map +1 -0
- package/dist/product/BundleBuilder.d.ts +3 -0
- package/dist/product/BundleBuilder.d.ts.map +1 -0
- package/dist/product/BundleBuilder.js +34 -0
- package/dist/product/BundleBuilder.js.map +1 -0
- package/dist/product/BuyBox.d.ts +3 -0
- package/dist/product/BuyBox.d.ts.map +1 -0
- package/dist/product/BuyBox.js +398 -0
- package/dist/product/BuyBox.js.map +1 -0
- package/dist/product/ComparisonTable.d.ts +3 -0
- package/dist/product/ComparisonTable.d.ts.map +1 -0
- package/dist/product/ComparisonTable.js +59 -0
- package/dist/product/ComparisonTable.js.map +1 -0
- package/dist/product/FormatGrid.d.ts +3 -0
- package/dist/product/FormatGrid.d.ts.map +1 -0
- package/dist/product/FormatGrid.js +28 -0
- package/dist/product/FormatGrid.js.map +1 -0
- package/dist/product/PDPVariants.d.ts +3 -0
- package/dist/product/PDPVariants.d.ts.map +1 -0
- package/dist/product/PDPVariants.js +284 -0
- package/dist/product/PDPVariants.js.map +1 -0
- package/dist/product/PillNav.d.ts +3 -0
- package/dist/product/PillNav.d.ts.map +1 -0
- package/dist/product/PillNav.js +35 -0
- package/dist/product/PillNav.js.map +1 -0
- package/dist/product/ProductAccordion.d.ts +3 -0
- package/dist/product/ProductAccordion.d.ts.map +1 -0
- package/dist/product/ProductAccordion.js +46 -0
- package/dist/product/ProductAccordion.js.map +1 -0
- package/dist/product/ProductCard.d.ts +62 -0
- package/dist/product/ProductCard.d.ts.map +1 -0
- package/dist/product/ProductCard.js +442 -0
- package/dist/product/ProductCard.js.map +1 -0
- package/dist/product/ProductCarousel.d.ts +3 -0
- package/dist/product/ProductCarousel.d.ts.map +1 -0
- package/dist/product/ProductCarousel.js +123 -0
- package/dist/product/ProductCarousel.js.map +1 -0
- package/dist/product/ProductCenteredStack.d.ts +3 -0
- package/dist/product/ProductCenteredStack.d.ts.map +1 -0
- package/dist/product/ProductCenteredStack.js +28 -0
- package/dist/product/ProductCenteredStack.js.map +1 -0
- package/dist/product/ProductGallery.d.ts +3 -0
- package/dist/product/ProductGallery.d.ts.map +1 -0
- package/dist/product/ProductGallery.js +80 -0
- package/dist/product/ProductGallery.js.map +1 -0
- package/dist/product/ProductGrid.d.ts +3 -0
- package/dist/product/ProductGrid.d.ts.map +1 -0
- package/dist/product/ProductGrid.js +58 -0
- package/dist/product/ProductGrid.js.map +1 -0
- package/dist/product/ProductHighlightLeft.d.ts +3 -0
- package/dist/product/ProductHighlightLeft.d.ts.map +1 -0
- package/dist/product/ProductHighlightLeft.js +37 -0
- package/dist/product/ProductHighlightLeft.js.map +1 -0
- package/dist/product/ProductHighlightRight.d.ts +3 -0
- package/dist/product/ProductHighlightRight.d.ts.map +1 -0
- package/dist/product/ProductHighlightRight.js +23 -0
- package/dist/product/ProductHighlightRight.js.map +1 -0
- package/dist/product/ProductPage.d.ts +3 -0
- package/dist/product/ProductPage.d.ts.map +1 -0
- package/dist/product/ProductPage.js +105 -0
- package/dist/product/ProductPage.js.map +1 -0
- package/dist/product/SubscriptionToggle.d.ts +3 -0
- package/dist/product/SubscriptionToggle.d.ts.map +1 -0
- package/dist/product/SubscriptionToggle.js +38 -0
- package/dist/product/SubscriptionToggle.js.map +1 -0
- package/dist/product/Upsell.d.ts +3 -0
- package/dist/product/Upsell.d.ts.map +1 -0
- package/dist/product/Upsell.js +59 -0
- package/dist/product/Upsell.js.map +1 -0
- package/dist/product/VideoCarousel.d.ts +3 -0
- package/dist/product/VideoCarousel.d.ts.map +1 -0
- package/dist/product/VideoCarousel.js +188 -0
- package/dist/product/VideoCarousel.js.map +1 -0
- package/dist/product/index.d.ts +8 -0
- package/dist/product/index.d.ts.map +1 -0
- package/dist/product/index.js +8 -0
- package/dist/product/index.js.map +1 -0
- package/dist/registry-field-schemas.d.ts +66 -0
- package/dist/registry-field-schemas.d.ts.map +1 -0
- package/dist/registry-field-schemas.js +745 -0
- package/dist/registry-field-schemas.js.map +1 -0
- package/dist/registry-metadata.d.ts +10 -0
- package/dist/registry-metadata.d.ts.map +1 -0
- package/dist/registry-metadata.js +2 -0
- package/dist/registry-metadata.js.map +1 -0
- package/dist/registry.d.ts +20 -0
- package/dist/registry.d.ts.map +1 -0
- package/dist/registry.js +2317 -0
- package/dist/registry.js.map +1 -0
- package/dist/renderText.d.ts +6 -0
- package/dist/renderText.d.ts.map +1 -0
- package/dist/renderText.js +23 -0
- package/dist/renderText.js.map +1 -0
- package/dist/reviews/ReviewCarousel.d.ts +3 -0
- package/dist/reviews/ReviewCarousel.d.ts.map +1 -0
- package/dist/reviews/ReviewCarousel.js +24 -0
- package/dist/reviews/ReviewCarousel.js.map +1 -0
- package/dist/reviews/ReviewMasonry.d.ts +3 -0
- package/dist/reviews/ReviewMasonry.d.ts.map +1 -0
- package/dist/reviews/ReviewMasonry.js +25 -0
- package/dist/reviews/ReviewMasonry.js.map +1 -0
- package/dist/reviews/ReviewSpotlight.d.ts +3 -0
- package/dist/reviews/ReviewSpotlight.d.ts.map +1 -0
- package/dist/reviews/ReviewSpotlight.js +13 -0
- package/dist/reviews/ReviewSpotlight.js.map +1 -0
- package/dist/reviews/VideoTestimonials.d.ts +3 -0
- package/dist/reviews/VideoTestimonials.d.ts.map +1 -0
- package/dist/reviews/VideoTestimonials.js +35 -0
- package/dist/reviews/VideoTestimonials.js.map +1 -0
- package/dist/reviews/index.d.ts +4 -0
- package/dist/reviews/index.d.ts.map +1 -0
- package/dist/reviews/index.js +4 -0
- package/dist/reviews/index.js.map +1 -0
- package/dist/schemas/content.d.ts +125 -0
- package/dist/schemas/content.d.ts.map +1 -0
- package/dist/schemas/content.js +2 -0
- package/dist/schemas/content.js.map +1 -0
- package/dist/schemas/index.d.ts +3 -0
- package/dist/schemas/index.d.ts.map +1 -0
- package/dist/schemas/index.js +2 -0
- package/dist/schemas/index.js.map +1 -0
- package/dist/schemas/settings.d.ts +23 -0
- package/dist/schemas/settings.d.ts.map +1 -0
- package/dist/schemas/settings.js +321 -0
- package/dist/schemas/settings.js.map +1 -0
- package/dist/social-proof/AvatarGroup.d.ts +3 -0
- package/dist/social-proof/AvatarGroup.d.ts.map +1 -0
- package/dist/social-proof/AvatarGroup.js +58 -0
- package/dist/social-proof/AvatarGroup.js.map +1 -0
- package/dist/social-proof/LogoCarousel.d.ts +3 -0
- package/dist/social-proof/LogoCarousel.d.ts.map +1 -0
- package/dist/social-proof/LogoCarousel.js +49 -0
- package/dist/social-proof/LogoCarousel.js.map +1 -0
- package/dist/social-proof/LogoStrip.d.ts +3 -0
- package/dist/social-proof/LogoStrip.d.ts.map +1 -0
- package/dist/social-proof/LogoStrip.js +35 -0
- package/dist/social-proof/LogoStrip.js.map +1 -0
- package/dist/social-proof/PressMentions.d.ts +3 -0
- package/dist/social-proof/PressMentions.d.ts.map +1 -0
- package/dist/social-proof/PressMentions.js +40 -0
- package/dist/social-proof/PressMentions.js.map +1 -0
- package/dist/social-proof/StatsGrid.d.ts +3 -0
- package/dist/social-proof/StatsGrid.d.ts.map +1 -0
- package/dist/social-proof/StatsGrid.js +39 -0
- package/dist/social-proof/StatsGrid.js.map +1 -0
- package/dist/social-proof/TrustBadges.d.ts +3 -0
- package/dist/social-proof/TrustBadges.d.ts.map +1 -0
- package/dist/social-proof/TrustBadges.js +18 -0
- package/dist/social-proof/TrustBadges.js.map +1 -0
- package/dist/social-proof/index.d.ts +4 -0
- package/dist/social-proof/index.d.ts.map +1 -0
- package/dist/social-proof/index.js +4 -0
- package/dist/social-proof/index.js.map +1 -0
- package/dist/text-effects/TextEffect.d.ts +3 -0
- package/dist/text-effects/TextEffect.d.ts.map +1 -0
- package/dist/text-effects/TextEffect.js +277 -0
- package/dist/text-effects/TextEffect.js.map +1 -0
- package/dist/theme/resolve.d.ts +12 -0
- package/dist/theme/resolve.d.ts.map +1 -0
- package/dist/theme/resolve.js +26 -0
- package/dist/theme/resolve.js.map +1 -0
- package/dist/theme/tokens.d.ts +147 -0
- package/dist/theme/tokens.d.ts.map +1 -0
- package/dist/theme/tokens.js +113 -0
- package/dist/theme/tokens.js.map +1 -0
- package/dist/types.d.ts +154 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/elementStyles.d.ts +4 -0
- package/dist/utils/elementStyles.d.ts.map +1 -0
- package/dist/utils/elementStyles.js +6 -0
- package/dist/utils/elementStyles.js.map +1 -0
- package/dist/utils/icon-map.d.ts +128 -0
- package/dist/utils/icon-map.d.ts.map +1 -0
- package/dist/utils/icon-map.js +199 -0
- package/dist/utils/icon-map.js.map +1 -0
- package/dist/utils/imageStyle.d.ts +4 -0
- package/dist/utils/imageStyle.d.ts.map +1 -0
- package/dist/utils/imageStyle.js +23 -0
- package/dist/utils/imageStyle.js.map +1 -0
- package/dist/utils/renderIcon.d.ts +32 -0
- package/dist/utils/renderIcon.d.ts.map +1 -0
- package/dist/utils/renderIcon.js +188 -0
- package/dist/utils/renderIcon.js.map +1 -0
- package/dist/utils/schemaUtils.d.ts +9 -0
- package/dist/utils/schemaUtils.d.ts.map +1 -0
- package/dist/utils/schemaUtils.js +10 -0
- package/dist/utils/schemaUtils.js.map +1 -0
- package/dist/value-props/HowItWorks.d.ts +3 -0
- package/dist/value-props/HowItWorks.d.ts.map +1 -0
- package/dist/value-props/HowItWorks.js +23 -0
- package/dist/value-props/HowItWorks.js.map +1 -0
- package/dist/value-props/NumberedList.d.ts +3 -0
- package/dist/value-props/NumberedList.d.ts.map +1 -0
- package/dist/value-props/NumberedList.js +22 -0
- package/dist/value-props/NumberedList.js.map +1 -0
- package/dist/value-props/ValuePropsAlternating.d.ts +3 -0
- package/dist/value-props/ValuePropsAlternating.d.ts.map +1 -0
- package/dist/value-props/ValuePropsAlternating.js +22 -0
- package/dist/value-props/ValuePropsAlternating.js.map +1 -0
- package/dist/value-props/ValuePropsGrid.d.ts +3 -0
- package/dist/value-props/ValuePropsGrid.d.ts.map +1 -0
- package/dist/value-props/ValuePropsGrid.js +23 -0
- package/dist/value-props/ValuePropsGrid.js.map +1 -0
- package/dist/value-props/ValuePropsIconStrip.d.ts +3 -0
- package/dist/value-props/ValuePropsIconStrip.d.ts.map +1 -0
- package/dist/value-props/ValuePropsIconStrip.js +11 -0
- package/dist/value-props/ValuePropsIconStrip.js.map +1 -0
- package/dist/value-props/index.d.ts +6 -0
- package/dist/value-props/index.d.ts.map +1 -0
- package/dist/value-props/index.js +6 -0
- package/dist/value-props/index.js.map +1 -0
- package/package.json +46 -0
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useState } from "react";
|
|
3
|
+
import { AnimatePresence, motion } from "framer-motion";
|
|
4
|
+
function getInitials(name) {
|
|
5
|
+
return name
|
|
6
|
+
.split(" ")
|
|
7
|
+
.map((w) => w[0])
|
|
8
|
+
.join("")
|
|
9
|
+
.toUpperCase()
|
|
10
|
+
.slice(0, 2);
|
|
11
|
+
}
|
|
12
|
+
const PILL_STYLE = (surface, border) => ({
|
|
13
|
+
display: "inline-flex",
|
|
14
|
+
alignItems: "center",
|
|
15
|
+
gap: "0.5rem",
|
|
16
|
+
padding: "0.35rem 0.85rem",
|
|
17
|
+
borderRadius: "9999px",
|
|
18
|
+
background: surface,
|
|
19
|
+
border: `1px solid ${border}`,
|
|
20
|
+
backdropFilter: "blur(8px)",
|
|
21
|
+
WebkitBackdropFilter: "blur(8px)",
|
|
22
|
+
boxShadow: "0 2px 8px rgba(0,0,0,0.08)",
|
|
23
|
+
maxWidth: "100%",
|
|
24
|
+
overflow: "hidden",
|
|
25
|
+
});
|
|
26
|
+
const DEFAULT_ITEMS = [
|
|
27
|
+
{ name: "Priya S.", city: "Delhi", product_name: "Vitamin C Serum", time_ago: "2 mins ago" },
|
|
28
|
+
{ name: "Anika M.", city: "Mumbai", product_name: "Retinol Night Cream", time_ago: "4 mins ago" },
|
|
29
|
+
{ name: "Rahul K.", city: "Bangalore", product_name: "SPF 50 Sunscreen", time_ago: "6 mins ago" },
|
|
30
|
+
{ name: "Sneha R.", city: "Chennai", product_name: "Hyaluronic Toner", time_ago: "9 mins ago" },
|
|
31
|
+
];
|
|
32
|
+
export default function LiveActivityTicker({ content, variant, theme }) {
|
|
33
|
+
const surface = theme.palette.surface || "rgba(255,255,255,0.85)";
|
|
34
|
+
const textColor = theme.palette.text;
|
|
35
|
+
const accent = theme.palette.accent;
|
|
36
|
+
const border = theme.palette.border || "rgba(0,0,0,0.1)";
|
|
37
|
+
const bodyFont = theme.fonts.body;
|
|
38
|
+
const rawItems = Array.isArray(content.activity_items)
|
|
39
|
+
? content.activity_items
|
|
40
|
+
: Array.isArray(content.mock_items)
|
|
41
|
+
? content.mock_items
|
|
42
|
+
: DEFAULT_ITEMS;
|
|
43
|
+
switch (variant) {
|
|
44
|
+
case "visitor_count":
|
|
45
|
+
return _jsx(VisitorCount, { content: content, surface: surface, textColor: textColor, accent: accent, border: border, bodyFont: bodyFont });
|
|
46
|
+
case "combined":
|
|
47
|
+
return _jsx(Combined, { content: content, rawItems: rawItems, surface: surface, textColor: textColor, accent: accent, border: border, bodyFont: bodyFont });
|
|
48
|
+
case "local_proof":
|
|
49
|
+
return _jsx(LocalProof, { content: content, surface: surface, textColor: textColor, accent: accent, border: border, bodyFont: bodyFont });
|
|
50
|
+
default:
|
|
51
|
+
return _jsx(RecentPurchases, { rawItems: rawItems, surface: surface, textColor: textColor, accent: accent, border: border, bodyFont: bodyFont });
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
// ─── Variant 1: recent_purchases ────────────────────────────────────────────
|
|
55
|
+
function RecentPurchases({ rawItems, surface, textColor, accent, border, bodyFont, }) {
|
|
56
|
+
const [idx, setIdx] = useState(0);
|
|
57
|
+
useEffect(() => {
|
|
58
|
+
if (rawItems.length < 2)
|
|
59
|
+
return;
|
|
60
|
+
const id = setInterval(() => setIdx((i) => (i + 1) % rawItems.length), 4000);
|
|
61
|
+
return () => clearInterval(id);
|
|
62
|
+
}, [rawItems.length]);
|
|
63
|
+
const item = rawItems[idx];
|
|
64
|
+
return (_jsx("div", { style: { display: "inline-flex", fontFamily: bodyFont, fontSize: "0.8rem" }, children: _jsx("div", { style: PILL_STYLE(surface, border), children: _jsx(AnimatePresence, { mode: "wait", children: _jsxs(motion.div, { initial: { opacity: 0, y: 8 }, animate: { opacity: 1, y: 0 }, exit: { opacity: 0, y: -8 }, transition: { duration: 0.3 }, style: { display: "flex", alignItems: "center", gap: "0.5rem" }, children: [_jsx("span", { style: {
|
|
65
|
+
width: "1.6rem",
|
|
66
|
+
height: "1.6rem",
|
|
67
|
+
borderRadius: "50%",
|
|
68
|
+
backgroundColor: item.avatar_color || accent,
|
|
69
|
+
display: "flex",
|
|
70
|
+
alignItems: "center",
|
|
71
|
+
justifyContent: "center",
|
|
72
|
+
color: "#fff",
|
|
73
|
+
fontWeight: 700,
|
|
74
|
+
fontSize: "0.65rem",
|
|
75
|
+
flexShrink: 0,
|
|
76
|
+
}, children: getInitials(item.name) }), _jsxs("span", { style: { color: textColor, whiteSpace: "nowrap", overflow: "hidden", textOverflow: "ellipsis", maxWidth: "22ch" }, children: [_jsx("strong", { children: item.name }), item.city ? ` from ${item.city}` : "", " bought", " ", _jsx("strong", { children: item.product_name }), " · ", _jsx("span", { style: { opacity: 0.55 }, children: item.time_ago })] })] }, idx) }) }) }));
|
|
77
|
+
}
|
|
78
|
+
// ─── Variant 2: visitor_count ────────────────────────────────────────────────
|
|
79
|
+
function VisitorCount({ content, surface, textColor, accent, border, bodyFont, }) {
|
|
80
|
+
const base = content.visitor_count || 142;
|
|
81
|
+
const [count, setCount] = useState(base);
|
|
82
|
+
useEffect(() => {
|
|
83
|
+
const id = setInterval(() => {
|
|
84
|
+
setCount((n) => {
|
|
85
|
+
const drift = Math.round(base * 0.05);
|
|
86
|
+
const delta = Math.floor(Math.random() * (drift * 2 + 1)) - drift;
|
|
87
|
+
return Math.max(1, n + delta);
|
|
88
|
+
});
|
|
89
|
+
}, 3500);
|
|
90
|
+
return () => clearInterval(id);
|
|
91
|
+
}, [base]);
|
|
92
|
+
return (_jsxs("div", { style: { display: "inline-flex", justifyContent: "center", fontFamily: bodyFont, fontSize: "0.8rem" }, children: [_jsxs("div", { style: PILL_STYLE(surface, border), children: [_jsxs("span", { style: { position: "relative", display: "inline-flex", width: "0.55rem", height: "0.55rem", flexShrink: 0 }, children: [_jsx("span", { style: {
|
|
93
|
+
position: "absolute",
|
|
94
|
+
inset: 0,
|
|
95
|
+
borderRadius: "50%",
|
|
96
|
+
backgroundColor: "#22c55e",
|
|
97
|
+
opacity: 0.7,
|
|
98
|
+
animation: "ping 1.2s cubic-bezier(0,0,0.2,1) infinite",
|
|
99
|
+
} }), _jsx("span", { style: {
|
|
100
|
+
position: "relative",
|
|
101
|
+
width: "0.55rem",
|
|
102
|
+
height: "0.55rem",
|
|
103
|
+
borderRadius: "50%",
|
|
104
|
+
backgroundColor: "#22c55e",
|
|
105
|
+
display: "inline-flex",
|
|
106
|
+
} })] }), _jsxs("span", { style: { color: textColor }, children: [_jsx(AnimatePresence, { mode: "wait", children: _jsx(motion.strong, { initial: { opacity: 0, y: 6 }, animate: { opacity: 1, y: 0 }, exit: { opacity: 0, y: -6 }, transition: { duration: 0.25 }, style: { color: accent, display: "inline-block" }, children: count.toLocaleString() }, count) }), " ", "\uD83D\uDC41 people viewing this right now"] })] }), _jsx("style", { children: `@keyframes ping{75%,100%{transform:scale(2);opacity:0}}` })] }));
|
|
107
|
+
}
|
|
108
|
+
// ─── Variant 3: combined ─────────────────────────────────────────────────────
|
|
109
|
+
function Combined({ content, rawItems, surface, textColor, accent, border, bodyFont, }) {
|
|
110
|
+
const base = content.visitor_count || 142;
|
|
111
|
+
const [visitorCount, setVisitorCount] = useState(base);
|
|
112
|
+
const [phase, setPhase] = useState("purchase");
|
|
113
|
+
const [purchaseIdx, setPurchaseIdx] = useState(0);
|
|
114
|
+
useEffect(() => {
|
|
115
|
+
const id = setInterval(() => {
|
|
116
|
+
setPhase((p) => {
|
|
117
|
+
if (p === "purchase") {
|
|
118
|
+
setPurchaseIdx((i) => (i + 1) % rawItems.length);
|
|
119
|
+
return "count";
|
|
120
|
+
}
|
|
121
|
+
setVisitorCount((n) => Math.max(1, n + Math.floor(Math.random() * 7) - 3));
|
|
122
|
+
return "purchase";
|
|
123
|
+
});
|
|
124
|
+
}, 3000);
|
|
125
|
+
return () => clearInterval(id);
|
|
126
|
+
}, [rawItems.length]);
|
|
127
|
+
const item = rawItems[purchaseIdx];
|
|
128
|
+
return (_jsx("div", { style: { display: "inline-flex", fontFamily: bodyFont, fontSize: "0.8rem" }, children: _jsx("div", { style: PILL_STYLE(surface, border), children: _jsx(AnimatePresence, { mode: "wait", children: phase === "purchase" ? (_jsxs(motion.span, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, transition: { duration: 0.4 }, style: { color: textColor, whiteSpace: "nowrap", overflow: "hidden", textOverflow: "ellipsis", maxWidth: "28ch" }, children: ["\uD83D\uDED2 ", _jsx("strong", { children: item.name }), " just bought ", _jsx("strong", { children: item.product_name })] }, "purchase")) : (_jsxs(motion.span, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, transition: { duration: 0.4 }, style: { color: textColor }, children: ["\uD83D\uDC41", " ", _jsx("strong", { style: { color: accent }, children: visitorCount.toLocaleString() }), " ", "people are viewing this right now"] }, "count")) }) }) }));
|
|
129
|
+
}
|
|
130
|
+
// ─── Variant 4: local_proof ──────────────────────────────────────────────────
|
|
131
|
+
function LocalProof({ content, surface, textColor, border, bodyFont, }) {
|
|
132
|
+
const locationName = content.location_name || "your area";
|
|
133
|
+
const locationPurchases = content.location_purchases || 38;
|
|
134
|
+
const locationEmoji = content.location_emoji || "📍";
|
|
135
|
+
return (_jsx("div", { style: { display: "inline-flex", fontFamily: bodyFont, fontSize: "0.8rem" }, children: _jsx("div", { style: PILL_STYLE(surface, border), children: _jsxs("span", { style: { color: textColor }, children: [locationEmoji, " Popular with people in ", _jsx("strong", { children: locationName }), " · ", _jsx("strong", { children: locationPurchases }), " purchases today"] }) }) }));
|
|
136
|
+
}
|
|
137
|
+
//# sourceMappingURL=LiveActivityTicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LiveActivityTicker.js","sourceRoot":"","sources":["../../src/personalization/LiveActivityTicker.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoyaltyStatus.d.ts","sourceRoot":"","sources":["../../src/personalization/LoyaltyStatus.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AA+Z/C,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,eAAe,EAAE,aAAa,EAAE,QAAQ,EAAE,EAAE,cAAc,2CAM/H"}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect, useRef } from "react";
|
|
3
|
+
import { renderText } from "../renderText";
|
|
4
|
+
import { renderIcon } from "../utils/renderIcon";
|
|
5
|
+
import { motion, AnimatePresence } from "framer-motion";
|
|
6
|
+
import { containerStagger, itemFadeUp } from "../animations/variants";
|
|
7
|
+
// ─── Helpers ───────────────────────────────────────────────────────────────────
|
|
8
|
+
function resolvePoints(content) {
|
|
9
|
+
const c = content;
|
|
10
|
+
const val = c._dynamic_customer_points ?? c.customer_points;
|
|
11
|
+
return typeof val === "number" ? val : 0;
|
|
12
|
+
}
|
|
13
|
+
function resolveTierName(content) {
|
|
14
|
+
const c = content;
|
|
15
|
+
return renderText(c._dynamic_tier_name ?? c.tier_name ?? "");
|
|
16
|
+
}
|
|
17
|
+
function formatCountdown(seconds) {
|
|
18
|
+
const h = Math.floor(seconds / 3600);
|
|
19
|
+
const m = Math.floor((seconds % 3600) / 60);
|
|
20
|
+
const s = seconds % 60;
|
|
21
|
+
return [h, m, s].map((v) => String(v).padStart(2, "0")).join(":");
|
|
22
|
+
}
|
|
23
|
+
// ─── Variant 1: points_balance_card ──────────────────────────────────────────
|
|
24
|
+
function PointsBalanceCard({ content, theme }) {
|
|
25
|
+
const c = content;
|
|
26
|
+
const points = resolvePoints(content);
|
|
27
|
+
const rate = typeof c.redemption_rate === "number" ? c.redemption_rate : 0.01;
|
|
28
|
+
const dollarValue = (points * rate).toFixed(2);
|
|
29
|
+
const multiplier = typeof c.bonus_multiplier_active === "number" ? c.bonus_multiplier_active : 1;
|
|
30
|
+
const hasBonus = multiplier > 1;
|
|
31
|
+
const currency = renderText(c.currency_symbol) || "₹";
|
|
32
|
+
const accent = theme.palette.accent;
|
|
33
|
+
const surface = theme.palette.surface;
|
|
34
|
+
const text = theme.palette.text;
|
|
35
|
+
const success = theme.palette.success || "#16a34a";
|
|
36
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
37
|
+
// Count-up animation
|
|
38
|
+
const [displayed, setDisplayed] = useState(0);
|
|
39
|
+
const rafRef = useRef(null);
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
if (points === 0) {
|
|
42
|
+
setDisplayed(0);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const duration = 1200;
|
|
46
|
+
const start = performance.now();
|
|
47
|
+
function tick(now) {
|
|
48
|
+
const elapsed = now - start;
|
|
49
|
+
const progress = Math.min(elapsed / duration, 1);
|
|
50
|
+
// ease-out cubic
|
|
51
|
+
const eased = 1 - Math.pow(1 - progress, 3);
|
|
52
|
+
setDisplayed(Math.round(eased * points));
|
|
53
|
+
if (progress < 1) {
|
|
54
|
+
rafRef.current = requestAnimationFrame(tick);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
rafRef.current = requestAnimationFrame(tick);
|
|
58
|
+
return () => { if (rafRef.current != null)
|
|
59
|
+
cancelAnimationFrame(rafRef.current); };
|
|
60
|
+
}, [points]);
|
|
61
|
+
if (points === 0) {
|
|
62
|
+
return (_jsx("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", padding: "32px 24px", textAlign: "center", display: "flex", flexDirection: "column", alignItems: "center", gap: "12px" }, children: _jsx("p", { style: { fontSize: "1rem", color: text, opacity: 0.5 }, children: "Earn points on your next order" }) }));
|
|
63
|
+
}
|
|
64
|
+
return (_jsxs("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", padding: "36px 28px", textAlign: "center", display: "flex", flexDirection: "column", alignItems: "center", gap: "12px", position: "relative" }, children: [hasBonus && (_jsxs("div", { style: { position: "absolute", top: "16px", right: "16px", backgroundColor: "#f59e0b", color: "#fff", fontSize: "0.72rem", fontWeight: 700, padding: "4px 10px", borderRadius: "999px", display: "flex", alignItems: "center", gap: "4px" }, children: [_jsx("span", { children: "\uD83C\uDF89" }), _jsxs("span", { children: [multiplier, "x Bonus Active"] })] })), _jsx("p", { style: { fontSize: "0.7rem", fontWeight: 700, textTransform: "uppercase", letterSpacing: "0.15em", color: text, opacity: 0.45, margin: 0 }, children: "Your Points" }), _jsx("p", { style: { fontFamily: `${theme.fonts.display}, serif`, fontSize: "clamp(3.5rem, 8vw, 5rem)", fontWeight: 800, lineHeight: 1, color: text, margin: 0 }, children: displayed.toLocaleString() }), _jsxs("p", { style: { fontSize: "0.9rem", color: text, opacity: 0.65, margin: 0 }, children: ["= ", _jsxs("strong", { style: { color: success }, children: [currency, dollarValue] }), " off your next order"] }), _jsx("a", { href: "#redeem", style: { marginTop: "8px", display: "inline-flex", alignItems: "center", gap: "6px", backgroundColor: accent, color: "#fff", fontWeight: 700, fontSize: "0.9rem", padding: "12px 28px", borderRadius: "var(--lx-button-radius, 9999px)", textDecoration: "none", cursor: "pointer" }, children: "Redeem Now \u2192" })] }));
|
|
65
|
+
}
|
|
66
|
+
// ─── Variant 2: tier_progress_bar ─────────────────────────────────────────────
|
|
67
|
+
function TierProgressBar({ content, theme }) {
|
|
68
|
+
const c = content;
|
|
69
|
+
const tierName = resolveTierName(content);
|
|
70
|
+
const nextTierName = renderText(c.next_tier_name ?? "");
|
|
71
|
+
const pointsToNext = typeof c.points_to_next_tier === "number" ? c.points_to_next_tier : 0;
|
|
72
|
+
const tierTotal = typeof c.tier_points_total === "number" ? c.tier_points_total : 0;
|
|
73
|
+
const isTopTier = !nextTierName;
|
|
74
|
+
const earned = tierTotal - pointsToNext;
|
|
75
|
+
const pct = tierTotal > 0 ? Math.max(0, Math.min(100, (earned / tierTotal) * 100)) : 0;
|
|
76
|
+
const accent = theme.palette.accent;
|
|
77
|
+
const surface = theme.palette.surface;
|
|
78
|
+
const text = theme.palette.text;
|
|
79
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
80
|
+
return (_jsxs("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", padding: "28px 24px", display: "flex", flexDirection: "column", gap: "14px" }, children: [_jsxs("div", { style: { display: "flex", justifyContent: "space-between", alignItems: "center" }, children: [_jsx("span", { style: { fontSize: "0.8rem", fontWeight: 700, color: accent }, children: tierName || "Current Tier" }), !isTopTier && (_jsx("span", { style: { fontSize: "0.8rem", fontWeight: 600, color: text, opacity: 0.45 }, children: nextTierName }))] }), _jsx("div", { style: { height: "10px", backgroundColor: border, borderRadius: "999px", overflow: "hidden" }, children: _jsx(motion.div, { initial: { width: 0 }, animate: { width: `${pct}%` }, transition: { duration: 1, ease: [0.25, 0.46, 0.45, 0.94] }, style: { height: "100%", backgroundColor: accent, borderRadius: "999px" } }) }), isTopTier ? (_jsx("p", { style: { fontSize: "0.82rem", color: text, opacity: 0.65, margin: 0 }, children: "You've reached the highest tier \uD83C\uDF89" })) : (_jsxs("p", { style: { fontSize: "0.82rem", color: text, opacity: 0.65, margin: 0 }, children: [_jsx("strong", { style: { color: text }, children: pointsToNext.toLocaleString() }), " points to ", _jsx("strong", { style: { color: text }, children: nextTierName })] }))] }));
|
|
81
|
+
}
|
|
82
|
+
// ─── Variant 3: next_milestone ────────────────────────────────────────────────
|
|
83
|
+
function NextMilestone({ content, theme }) {
|
|
84
|
+
const c = content;
|
|
85
|
+
const nextTierName = renderText(c.next_tier_name ?? "");
|
|
86
|
+
const pointsToNext = typeof c.points_to_next_tier === "number" ? c.points_to_next_tier : null;
|
|
87
|
+
const benefits = Array.isArray(c.tier_benefits) ? c.tier_benefits : [];
|
|
88
|
+
const accent = theme.palette.accent;
|
|
89
|
+
const surface = theme.palette.surface;
|
|
90
|
+
const text = theme.palette.text;
|
|
91
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
92
|
+
const success = theme.palette.success || "#16a34a";
|
|
93
|
+
const hasData = pointsToNext !== null && nextTierName;
|
|
94
|
+
if (!hasData) {
|
|
95
|
+
return (_jsx("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", padding: "28px 24px", textAlign: "center" }, children: _jsx("p", { style: { fontSize: "1rem", color: text, opacity: 0.5 }, children: "Earn points on your next order" }) }));
|
|
96
|
+
}
|
|
97
|
+
return (_jsxs("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", padding: "28px 24px", display: "flex", flexDirection: "column", gap: "20px" }, children: [_jsxs("div", { style: { textAlign: "center" }, children: [_jsxs("p", { style: { fontFamily: `${theme.fonts.display}, serif`, fontSize: "clamp(2.5rem, 6vw, 3.5rem)", fontWeight: 800, lineHeight: 1, color: text, margin: 0 }, children: [pointsToNext.toLocaleString(), " more"] }), _jsxs("p", { style: { fontSize: "1rem", color: text, opacity: 0.6, marginTop: "6px" }, children: ["purchases to ", _jsx("strong", { style: { color: accent }, children: nextTierName })] })] }), benefits.length > 0 && (_jsxs(_Fragment, { children: [_jsx("p", { style: { fontSize: "0.72rem", fontWeight: 700, textTransform: "uppercase", letterSpacing: "0.12em", color: text, opacity: 0.4, margin: 0 }, children: "Unlock:" }), _jsx(motion.ul, { variants: containerStagger, initial: "hidden", animate: "visible", style: { listStyle: "none", padding: 0, margin: 0, display: "flex", flexDirection: "column", gap: "10px" }, children: benefits.map((b, i) => (_jsxs(motion.li, { variants: itemFadeUp, style: { display: "flex", alignItems: "center", gap: "10px" }, children: [_jsx("span", { style: { flexShrink: 0, color: success }, children: renderIcon("lucide:check", { size: 16, color: success }) }), _jsx("span", { style: { fontSize: "0.875rem", color: text }, children: b })] }, i))) })] })), _jsx("a", { href: "#earn", style: { display: "inline-flex", alignItems: "center", justifyContent: "center", gap: "6px", backgroundColor: accent, color: "#fff", fontWeight: 700, fontSize: "0.9rem", padding: "13px 28px", borderRadius: "var(--lx-button-radius, 9999px)", textDecoration: "none", cursor: "pointer" }, children: "Start earning \u2192" })] }));
|
|
98
|
+
}
|
|
99
|
+
// ─── Variant 4: perks_comparison ─────────────────────────────────────────────
|
|
100
|
+
function PerksComparison({ content, theme }) {
|
|
101
|
+
const c = content;
|
|
102
|
+
const allTiers = Array.isArray(c.all_tiers) ? c.all_tiers : [];
|
|
103
|
+
const accent = theme.palette.accent;
|
|
104
|
+
const surface = theme.palette.surface;
|
|
105
|
+
const text = theme.palette.text;
|
|
106
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
107
|
+
const bg = theme.palette.bg;
|
|
108
|
+
const success = theme.palette.success || "#16a34a";
|
|
109
|
+
if (allTiers.length === 0) {
|
|
110
|
+
return (_jsx("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", padding: "28px 24px", textAlign: "center" }, children: _jsx("p", { style: { fontSize: "1rem", color: text, opacity: 0.5 }, children: "Earn points on your next order" }) }));
|
|
111
|
+
}
|
|
112
|
+
// Collect all unique benefits across tiers
|
|
113
|
+
const allBenefits = Array.from(new Set(allTiers.flatMap((t) => t.benefits)));
|
|
114
|
+
const currentTier = allTiers.find((t) => t.is_current);
|
|
115
|
+
return (_jsxs("div", { style: { backgroundColor: surface, border: `1px solid ${border}`, borderRadius: "16px", overflow: "hidden" }, children: [_jsxs("div", { style: { display: "grid", gridTemplateColumns: `1.5fr ${allTiers.map(() => "1fr").join(" ")}`, borderBottom: `1px solid ${border}` }, children: [_jsx("div", { style: { padding: "14px 16px", backgroundColor: bg } }), allTiers.map((tier, i) => (_jsxs("div", { style: {
|
|
116
|
+
padding: "14px 12px", textAlign: "center",
|
|
117
|
+
backgroundColor: tier.is_current ? accent + "14" : bg,
|
|
118
|
+
borderLeft: `1px solid ${border}`,
|
|
119
|
+
}, children: [_jsx("p", { style: { fontSize: "0.75rem", fontWeight: 700, textTransform: "uppercase", letterSpacing: "0.1em", color: tier.is_current ? accent : text, margin: 0 }, children: tier.name }), tier.is_current && (_jsx("p", { style: { fontSize: "0.65rem", color: accent, opacity: 0.8, margin: "2px 0 0" }, children: "Current" }))] }, i)))] }), allBenefits.map((benefit, ri) => (_jsxs("div", { style: { display: "grid", gridTemplateColumns: `1.5fr ${allTiers.map(() => "1fr").join(" ")}`, borderBottom: ri < allBenefits.length - 1 ? `1px solid ${border}` : "none" }, children: [_jsx("div", { style: { padding: "12px 16px", fontSize: "0.82rem", color: text, display: "flex", alignItems: "center" }, children: benefit }), allTiers.map((tier, ci) => {
|
|
120
|
+
const hasBenefit = tier.benefits.includes(benefit);
|
|
121
|
+
const isCurrentCol = tier.is_current;
|
|
122
|
+
const currentHas = currentTier ? currentTier.benefits.includes(benefit) : false;
|
|
123
|
+
const locked = !hasBenefit || (!currentHas && !isCurrentCol);
|
|
124
|
+
const showCheck = hasBenefit;
|
|
125
|
+
return (_jsx("div", { style: {
|
|
126
|
+
padding: "12px 12px",
|
|
127
|
+
textAlign: "center",
|
|
128
|
+
backgroundColor: isCurrentCol ? accent + "08" : "transparent",
|
|
129
|
+
borderLeft: `1px solid ${border}`,
|
|
130
|
+
display: "flex", alignItems: "center", justifyContent: "center",
|
|
131
|
+
}, children: showCheck ? (_jsx("span", { style: { opacity: !currentHas && !isCurrentCol ? 0.4 : 1 }, children: !currentHas && !isCurrentCol
|
|
132
|
+
? renderIcon("lucide:lock", { size: 15, color: text, strokeWidth: 2 })
|
|
133
|
+
: renderIcon("lucide:check", { size: 16, color: isCurrentCol ? accent : success, strokeWidth: 2.5 }) })) : (_jsx("span", { style: { color: text, opacity: 0.2, fontSize: "0.75rem" }, children: "\u2014" })) }, ci));
|
|
134
|
+
})] }, ri)))] }));
|
|
135
|
+
}
|
|
136
|
+
// ─── Variant 5: redemption_offer ─────────────────────────────────────────────
|
|
137
|
+
function RedemptionOffer({ content, theme }) {
|
|
138
|
+
const c = content;
|
|
139
|
+
const points = resolvePoints(content);
|
|
140
|
+
const rate = typeof c.redemption_rate === "number" ? c.redemption_rate : 0.01;
|
|
141
|
+
const multiplier = typeof c.bonus_multiplier_active === "number" ? c.bonus_multiplier_active : 1;
|
|
142
|
+
const hasBonus = multiplier > 1;
|
|
143
|
+
const dollarValue = (points * rate).toFixed(2);
|
|
144
|
+
const boostedValue = (points * rate * multiplier).toFixed(2);
|
|
145
|
+
const expiresAt = typeof c.bonus_expires_at === "string" ? c.bonus_expires_at : null;
|
|
146
|
+
const currency = renderText(c.currency_symbol) || "₹";
|
|
147
|
+
const accent = theme.palette.accent;
|
|
148
|
+
const text = theme.palette.text;
|
|
149
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
150
|
+
// Countdown state
|
|
151
|
+
const [secondsLeft, setSecondsLeft] = useState(null);
|
|
152
|
+
useEffect(() => {
|
|
153
|
+
if (!expiresAt)
|
|
154
|
+
return;
|
|
155
|
+
function calcRemaining() {
|
|
156
|
+
const diff = Math.max(0, Math.floor((new Date(expiresAt).getTime() - Date.now()) / 1000));
|
|
157
|
+
return diff;
|
|
158
|
+
}
|
|
159
|
+
setSecondsLeft(calcRemaining());
|
|
160
|
+
const id = setInterval(() => {
|
|
161
|
+
const remaining = calcRemaining();
|
|
162
|
+
setSecondsLeft(remaining);
|
|
163
|
+
if (remaining <= 0)
|
|
164
|
+
clearInterval(id);
|
|
165
|
+
}, 1000);
|
|
166
|
+
return () => clearInterval(id);
|
|
167
|
+
}, [expiresAt]);
|
|
168
|
+
if (points === 0) {
|
|
169
|
+
return (_jsx("div", { style: { backgroundColor: "#fef9c3", border: `1px solid #fde68a`, borderRadius: "16px", padding: "28px 24px", textAlign: "center" }, children: _jsx("p", { style: { fontSize: "1rem", color: "#92400e", opacity: 0.7 }, children: "Earn points on your next order" }) }));
|
|
170
|
+
}
|
|
171
|
+
return (_jsxs("div", { style: { background: `linear-gradient(135deg, ${accent}18 0%, #fef9c3 100%)`, border: `1.5px solid ${accent}40`, borderRadius: "16px", padding: "32px 28px", display: "flex", flexDirection: "column", gap: "16px", alignItems: "center", textAlign: "center" }, children: [_jsxs("p", { style: { fontFamily: `${theme.fonts.display}, serif`, fontSize: "clamp(1.6rem, 4vw, 2.2rem)", fontWeight: 800, color: text, margin: 0, lineHeight: 1.2 }, children: [points.toLocaleString(), " points = ", _jsxs("span", { style: { color: accent }, children: [currency, dollarValue] })] }), _jsx(AnimatePresence, { children: hasBonus && (_jsxs(motion.p, { initial: { opacity: 0, y: -8 }, animate: { opacity: 1, y: 0 }, exit: { opacity: 0, y: -8 }, style: { fontSize: "0.9rem", color: text, opacity: 0.75, margin: 0 }, children: ["Using today's ", _jsxs("strong", { style: { color: accent }, children: [multiplier, "x bonus"] }), " = ", _jsxs("strong", { style: { color: accent }, children: [currency, boostedValue] })] })) }), expiresAt && secondsLeft !== null && secondsLeft > 0 && (_jsxs("div", { style: { display: "flex", alignItems: "center", gap: "8px", backgroundColor: "#fff8", backdropFilter: "blur(6px)", border: `1px solid ${border}`, borderRadius: "10px", padding: "10px 18px" }, children: [renderIcon("lucide:clock", { size: 15, color: accent }), _jsx("span", { style: { fontFamily: "monospace", fontSize: "1rem", fontWeight: 700, color: accent, letterSpacing: "0.08em" }, children: formatCountdown(secondsLeft) }), _jsx("span", { style: { fontSize: "0.75rem", color: text, opacity: 0.55 }, children: "until bonus expires" })] })), _jsxs("button", { type: "button", "data-lx-redeem": true, style: { marginTop: "4px", backgroundColor: accent, color: "#fff", fontWeight: 700, fontSize: "1rem", padding: "15px 36px", borderRadius: "var(--lx-button-radius, 9999px)", border: "none", cursor: "pointer", letterSpacing: "0.02em", transition: "opacity 0.15s" }, children: ["Redeem ", points.toLocaleString(), " Points"] })] }));
|
|
172
|
+
}
|
|
173
|
+
// ─── Main export ──────────────────────────────────────────────────────────────
|
|
174
|
+
export default function LoyaltyStatus({ content, variant, theme, kit, generatedAssets, elementStyles, settings }) {
|
|
175
|
+
if (variant === "tier_progress_bar")
|
|
176
|
+
return _jsx(TierProgressBar, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
177
|
+
if (variant === "next_milestone")
|
|
178
|
+
return _jsx(NextMilestone, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
179
|
+
if (variant === "perks_comparison")
|
|
180
|
+
return _jsx(PerksComparison, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
181
|
+
if (variant === "redemption_offer")
|
|
182
|
+
return _jsx(RedemptionOffer, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
183
|
+
return _jsx(PointsBalanceCard, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
184
|
+
}
|
|
185
|
+
//# sourceMappingURL=LoyaltyStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoyaltyStatus.js","sourceRoot":"","sources":["../../src/personalization/LoyaltyStatus.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { ComponentProps } from "../types";
|
|
2
|
+
export default function PersonalizedGreeting({ content, variant, theme, kit, generatedAssets, elementStyles, settings }: ComponentProps): import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
//# sourceMappingURL=PersonalizedGreeting.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PersonalizedGreeting.d.ts","sourceRoot":"","sources":["../../src/personalization/PersonalizedGreeting.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAoT/C,MAAM,CAAC,OAAO,UAAU,oBAAoB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,eAAe,EAAE,aAAa,EAAE,QAAQ,EAAE,EAAE,cAAc,2CAKtI"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { motion } from "framer-motion";
|
|
3
|
+
import { renderText } from "../renderText";
|
|
4
|
+
import { AspectBox } from "../primitives/AspectBox";
|
|
5
|
+
import { MediaLoop } from "../primitives/MediaLoop";
|
|
6
|
+
// ─── Helpers ──────────────────────────────────────────────────────────────────
|
|
7
|
+
function resolveName(content) {
|
|
8
|
+
const c = content;
|
|
9
|
+
return renderText(c._dynamic_customer_name || c.customer_first_name || "");
|
|
10
|
+
}
|
|
11
|
+
function resolvePurchaseName(content) {
|
|
12
|
+
const c = content;
|
|
13
|
+
return renderText(c._dynamic_last_purchase_name || c.last_purchase_name || "");
|
|
14
|
+
}
|
|
15
|
+
function resolvePurchaseDate(content) {
|
|
16
|
+
const c = content;
|
|
17
|
+
return renderText(c._dynamic_last_purchase_date || c.last_purchase_date || "");
|
|
18
|
+
}
|
|
19
|
+
function resolvePurchaseCount(content) {
|
|
20
|
+
const c = content;
|
|
21
|
+
const val = c._dynamic_purchase_count ?? c.purchase_count;
|
|
22
|
+
return typeof val === "number" ? val : 0;
|
|
23
|
+
}
|
|
24
|
+
function formatDate(dateStr) {
|
|
25
|
+
try {
|
|
26
|
+
const d = new Date(dateStr);
|
|
27
|
+
if (isNaN(d.getTime()))
|
|
28
|
+
return dateStr;
|
|
29
|
+
const now = new Date();
|
|
30
|
+
const opts = d.getFullYear() === now.getFullYear()
|
|
31
|
+
? { month: "long", day: "numeric" }
|
|
32
|
+
: { month: "long", day: "numeric", year: "numeric" };
|
|
33
|
+
return d.toLocaleDateString("en-US", opts);
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
return dateStr;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function purchaseStatus(days) {
|
|
40
|
+
if (days <= 7)
|
|
41
|
+
return "arrived";
|
|
42
|
+
if (days <= 14)
|
|
43
|
+
return "shipped";
|
|
44
|
+
return "ordered";
|
|
45
|
+
}
|
|
46
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
47
|
+
// Variant 1: name_welcome
|
|
48
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
49
|
+
function NameWelcome({ content, theme }) {
|
|
50
|
+
const name = resolveName(content);
|
|
51
|
+
if (!name)
|
|
52
|
+
return null;
|
|
53
|
+
return (_jsx(motion.div, { initial: { opacity: 0, y: -8 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.45, ease: "easeOut" }, style: { padding: "12px 20px" }, children: _jsxs("p", { style: {
|
|
54
|
+
fontFamily: `${theme.fonts.display}, serif`,
|
|
55
|
+
fontWeight: Number(theme.fonts.displayWeight) || 700,
|
|
56
|
+
fontSize: "clamp(1.5rem, 3.5vw, 2.25rem)",
|
|
57
|
+
color: theme.palette.text,
|
|
58
|
+
margin: 0,
|
|
59
|
+
lineHeight: 1.2,
|
|
60
|
+
}, children: ["Hi ", name, ","] }) }));
|
|
61
|
+
}
|
|
62
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
63
|
+
// Variant 2: purchase_context
|
|
64
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
65
|
+
function PurchaseContext({ content, theme }) {
|
|
66
|
+
const c = content;
|
|
67
|
+
const name = resolveName(content);
|
|
68
|
+
const productName = resolvePurchaseName(content);
|
|
69
|
+
const days = typeof c.days_since_purchase === "number" ? c.days_since_purchase : null;
|
|
70
|
+
const status = days !== null ? purchaseStatus(days) : null;
|
|
71
|
+
const image = c.last_purchase_image;
|
|
72
|
+
const surface = theme.palette.surface;
|
|
73
|
+
const text = theme.palette.text;
|
|
74
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
75
|
+
return (_jsx("div", { style: { padding: "10px 20px" }, children: _jsxs("div", { style: {
|
|
76
|
+
backgroundColor: surface,
|
|
77
|
+
border: `1px solid ${border}`,
|
|
78
|
+
borderRadius: "var(--lx-card-radius, 12px)",
|
|
79
|
+
padding: "12px 16px",
|
|
80
|
+
display: "flex",
|
|
81
|
+
alignItems: "center",
|
|
82
|
+
gap: "14px",
|
|
83
|
+
maxWidth: "560px",
|
|
84
|
+
}, children: [image && (_jsx("div", { style: { flexShrink: 0, width: "48px", height: "48px", borderRadius: "8px", overflow: "hidden" }, children: _jsx(AspectBox, { aspect: "1:1", fit: "cover", style: { width: "48px", height: "48px" }, children: _jsx(MediaLoop, { src: image, alt: productName || "Product", fit: "cover" }) }) })), _jsxs("p", { style: { fontSize: "0.875rem", color: text, margin: 0, lineHeight: 1.5 }, children: ["Welcome back", name ? `, ${name}` : "", ".", productName && status && days !== null && (_jsxs(_Fragment, { children: [" Your ", _jsx("strong", { children: productName }), " ", status, " ", days, " day", days === 1 ? "" : "s", " ago."] })), productName && !status && (_jsxs(_Fragment, { children: [" Your ", _jsx("strong", { children: productName }), " is on its way."] }))] })] }) }));
|
|
85
|
+
}
|
|
86
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
87
|
+
// Variant 3: status_milestone
|
|
88
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
89
|
+
const CONFETTI_COLORS = ["#f59e0b", "#10b981", "#3b82f6", "#ec4899"];
|
|
90
|
+
function StatusMilestone({ content, theme }) {
|
|
91
|
+
const c = content;
|
|
92
|
+
const name = resolveName(content);
|
|
93
|
+
const count = resolvePurchaseCount(content);
|
|
94
|
+
const reward = c.milestone_reward;
|
|
95
|
+
const accent = theme.palette.accent;
|
|
96
|
+
const surface = theme.palette.surface;
|
|
97
|
+
const text = theme.palette.text;
|
|
98
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
99
|
+
const confettiColors = [accent, ...CONFETTI_COLORS];
|
|
100
|
+
// Deterministic offsets for 5 confetti dots
|
|
101
|
+
const confettiTargets = [
|
|
102
|
+
{ x: -90, y: -55 },
|
|
103
|
+
{ x: 80, y: -70 },
|
|
104
|
+
{ x: -65, y: 50 },
|
|
105
|
+
{ x: 100, y: 40 },
|
|
106
|
+
{ x: 20, y: -80 },
|
|
107
|
+
];
|
|
108
|
+
return (_jsx("div", { style: { padding: "10px 20px" }, children: _jsxs("div", { style: {
|
|
109
|
+
backgroundColor: surface,
|
|
110
|
+
border: `1px solid ${border}`,
|
|
111
|
+
borderRadius: "var(--lx-card-radius, 12px)",
|
|
112
|
+
padding: "16px 20px",
|
|
113
|
+
maxWidth: "560px",
|
|
114
|
+
position: "relative",
|
|
115
|
+
overflow: "hidden",
|
|
116
|
+
}, children: [confettiTargets.map((target, i) => (_jsx(motion.div, { initial: { x: 0, y: 0, opacity: 1, scale: 1 }, animate: { x: target.x, y: target.y, opacity: 0, scale: 0.5 }, transition: { duration: 0.7, delay: i * 0.06, ease: "easeOut" }, style: {
|
|
117
|
+
position: "absolute",
|
|
118
|
+
top: "50%",
|
|
119
|
+
left: "50%",
|
|
120
|
+
width: "10px",
|
|
121
|
+
height: "10px",
|
|
122
|
+
borderRadius: "50%",
|
|
123
|
+
backgroundColor: confettiColors[i % confettiColors.length],
|
|
124
|
+
pointerEvents: "none",
|
|
125
|
+
zIndex: 0,
|
|
126
|
+
} }, i))), _jsxs("div", { style: { position: "relative", zIndex: 1 }, children: [_jsxs("p", { style: { fontSize: "0.95rem", fontWeight: 600, color: text, margin: "0 0 4px" }, children: ["\uD83C\uDF89 ", name ? `${name} — you've` : "You've", " made ", _jsx("strong", { children: count }), " purchase", count === 1 ? "" : "s", " with us!"] }), reward && (_jsxs(_Fragment, { children: [_jsx("p", { style: { fontSize: "0.8rem", color: text, opacity: 0.65, margin: "8px 0 10px" }, children: "Here's your reward:" }), _jsx("button", { type: "button", "data-lx-milestone-reward": reward, style: {
|
|
127
|
+
padding: "9px 22px",
|
|
128
|
+
fontSize: "0.82rem",
|
|
129
|
+
fontWeight: 700,
|
|
130
|
+
backgroundColor: accent,
|
|
131
|
+
color: "#ffffff",
|
|
132
|
+
border: "none",
|
|
133
|
+
borderRadius: "var(--lx-button-radius, 9999px)",
|
|
134
|
+
cursor: "pointer",
|
|
135
|
+
transition: "opacity 0.15s",
|
|
136
|
+
}, children: reward })] }))] })] }) }));
|
|
137
|
+
}
|
|
138
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
139
|
+
// Variant 4: reengagement_personal
|
|
140
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
141
|
+
function ReengagementPersonal({ content, theme }) {
|
|
142
|
+
const c = content;
|
|
143
|
+
const name = resolveName(content);
|
|
144
|
+
if (!name)
|
|
145
|
+
return null;
|
|
146
|
+
const dateStr = resolvePurchaseDate(content);
|
|
147
|
+
const formattedDate = dateStr ? formatDate(dateStr) : null;
|
|
148
|
+
const newProducts = Array.isArray(c.new_products) ? c.new_products.slice(0, 3) : [];
|
|
149
|
+
const highlight = theme.palette.highlight;
|
|
150
|
+
const text = theme.palette.text;
|
|
151
|
+
const border = theme.palette.border || "#e5e7eb";
|
|
152
|
+
return (_jsx("div", { style: { padding: "10px 20px" }, children: _jsxs("div", { style: {
|
|
153
|
+
backgroundColor: highlight,
|
|
154
|
+
borderRadius: "var(--lx-card-radius, 12px)",
|
|
155
|
+
padding: "14px 18px",
|
|
156
|
+
maxWidth: "640px",
|
|
157
|
+
}, children: [_jsxs("p", { style: { fontSize: "0.9rem", fontWeight: 600, color: text, margin: "0 0 6px" }, children: [name, formattedDate ? `, we haven't seen you since ${formattedDate}.` : ", we've missed you!"] }), _jsx("p", { style: { fontSize: "0.8rem", color: text, opacity: 0.7, margin: "0 0 10px" }, children: "Here's what's new since then:" }), newProducts.length > 0 && (_jsx("div", { style: { display: "flex", gap: "10px", overflowX: "auto" }, children: newProducts.map((p, i) => (_jsxs("div", { style: {
|
|
158
|
+
flexShrink: 0,
|
|
159
|
+
width: "100px",
|
|
160
|
+
border: `1px solid ${border}`,
|
|
161
|
+
borderRadius: "var(--lx-card-radius, 10px)",
|
|
162
|
+
overflow: "hidden",
|
|
163
|
+
backgroundColor: theme.palette.bg,
|
|
164
|
+
}, children: [_jsx(AspectBox, { aspect: "1:1", fit: "cover", children: p.image_url && _jsx(MediaLoop, { src: p.image_url, alt: p.name, fit: "cover" }) }), _jsxs("div", { style: { padding: "6px 8px" }, children: [_jsx("p", { style: { fontSize: "0.7rem", fontWeight: 600, color: text, margin: "0 0 2px", lineHeight: 1.3, whiteSpace: "nowrap", overflow: "hidden", textOverflow: "ellipsis" }, children: p.name }), _jsx("p", { style: { fontSize: "0.68rem", color: text, opacity: 0.6, margin: 0 }, children: p.price })] })] }, i))) }))] }) }));
|
|
165
|
+
}
|
|
166
|
+
// ─── Main export ──────────────────────────────────────────────────────────────
|
|
167
|
+
export default function PersonalizedGreeting({ content, variant, theme, kit, generatedAssets, elementStyles, settings }) {
|
|
168
|
+
if (variant === "purchase_context")
|
|
169
|
+
return _jsx(PurchaseContext, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
170
|
+
if (variant === "status_milestone")
|
|
171
|
+
return _jsx(StatusMilestone, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
172
|
+
if (variant === "reengagement_personal")
|
|
173
|
+
return _jsx(ReengagementPersonal, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
174
|
+
return _jsx(NameWelcome, { content: content, variant: variant, theme: theme, kit: kit, generatedAssets: generatedAssets, elementStyles: elementStyles, settings: settings });
|
|
175
|
+
}
|
|
176
|
+
//# sourceMappingURL=PersonalizedGreeting.js.map
|