@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,21 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useRef } from "react";
|
|
3
|
+
export function CursorSpotlight({ radius = 250, color = "rgba(255,255,255,0.18)", children, className = "", style, }) {
|
|
4
|
+
const ref = useRef(null);
|
|
5
|
+
const [pos, setPos] = useState({ x: -9999, y: -9999, visible: false });
|
|
6
|
+
const onMove = (e) => {
|
|
7
|
+
if (!ref.current)
|
|
8
|
+
return;
|
|
9
|
+
const r = ref.current.getBoundingClientRect();
|
|
10
|
+
setPos({ x: e.clientX - r.left, y: e.clientY - r.top, visible: true });
|
|
11
|
+
};
|
|
12
|
+
const onLeave = () => setPos((p) => ({ ...p, visible: false }));
|
|
13
|
+
return (_jsxs("div", { ref: ref, className: `relative ${className}`, style: { overflow: "hidden", ...style }, onMouseMove: onMove, onMouseLeave: onLeave, children: [children, pos.visible && (_jsx("div", { style: {
|
|
14
|
+
position: "absolute",
|
|
15
|
+
inset: 0,
|
|
16
|
+
pointerEvents: "none",
|
|
17
|
+
background: `radial-gradient(circle ${radius}px at ${pos.x}px ${pos.y}px, ${color}, transparent 70%)`,
|
|
18
|
+
zIndex: 1,
|
|
19
|
+
} }))] }));
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=CursorSpotlight.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CursorSpotlight.js","sourceRoot":"","sources":["../../src/primitives/CursorSpotlight.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAWzC,MAAM,UAAU,eAAe,CAAC,EAC9B,MAAM,GAAG,GAAG,EACZ,KAAK,GAAG,wBAAwB,EAChC,QAAQ,EACR,SAAS,GAAG,EAAE,EACd,KAAK,GACgB;IACrB,MAAM,GAAG,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IACzC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IAEvE,MAAM,MAAM,GAAG,CAAC,CAAmC,EAAE,EAAE;QACrD,IAAI,CAAC,GAAG,CAAC,OAAO;YAAE,OAAO;QACzB,MAAM,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;QAC9C,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IACzE,CAAC,CAAC;IAEF,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IAEhE,OAAO,CACL,eACE,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,YAAY,SAAS,EAAE,EAClC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAE,EACvC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,OAAO,aAEpB,QAAQ,EACR,GAAG,CAAC,OAAO,IAAI,CACd,cACE,KAAK,EAAE;oBACL,QAAQ,EAAE,UAAU;oBACpB,KAAK,EAAE,CAAC;oBACR,aAAa,EAAE,MAAM;oBACrB,UAAU,EAAE,0BAA0B,MAAM,SAAS,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,OAAO,KAAK,oBAAoB;oBACrG,MAAM,EAAE,CAAC;iBACV,GACD,CACH,IACG,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export interface HeadlineEffectProps {
|
|
2
|
+
text: string;
|
|
3
|
+
effect?: string;
|
|
4
|
+
accent: string;
|
|
5
|
+
textColor: string;
|
|
6
|
+
prefix?: string;
|
|
7
|
+
words?: string[];
|
|
8
|
+
highlightWords?: string[];
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Drop-in children replacement for any hero <h1>.
|
|
12
|
+
* When effect is undefined/unknown → plain text, zero overhead.
|
|
13
|
+
* Heroes own the <h1> wrapper; this component owns only the animated content inside it.
|
|
14
|
+
*/
|
|
15
|
+
export declare function HeadlineEffect({ text, effect, accent, textColor, prefix, words, highlightWords }: HeadlineEffectProps): import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
//# sourceMappingURL=HeadlineEffect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HeadlineEffect.d.ts","sourceRoot":"","sources":["../../src/primitives/HeadlineEffect.tsx"],"names":[],"mappings":"AAIA,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAElB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IAEjB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;CAC3B;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAU,EAAE,cAAmB,EAAE,EAAE,mBAAmB,2CAY/H"}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect, useRef } from "react";
|
|
3
|
+
const SCRAMBLE_CHARS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!@#$%";
|
|
4
|
+
/**
|
|
5
|
+
* Drop-in children replacement for any hero <h1>.
|
|
6
|
+
* When effect is undefined/unknown → plain text, zero overhead.
|
|
7
|
+
* Heroes own the <h1> wrapper; this component owns only the animated content inside it.
|
|
8
|
+
*/
|
|
9
|
+
export function HeadlineEffect({ text, effect, accent, textColor, prefix, words = [], highlightWords = [] }) {
|
|
10
|
+
switch (effect) {
|
|
11
|
+
case "scramble": return _jsx(Scramble, { text: text, accent: accent });
|
|
12
|
+
case "text_reveal": return _jsx(TextReveal, { text: text, accent: accent });
|
|
13
|
+
case "glitch": return _jsx(Glitch, { text: text, accent: accent });
|
|
14
|
+
case "colourful": return _jsx(Colourful, { text: text, accent: accent });
|
|
15
|
+
case "hero_highlight": return _jsx(HeroHighlight, { text: text, accent: accent, highlightWords: highlightWords });
|
|
16
|
+
case "word_by_word": return _jsx(WordByWord, { text: text });
|
|
17
|
+
case "flip_words": return _jsx(FlipWords, { text: text, accent: accent, prefix: prefix, words: words });
|
|
18
|
+
case "moving_text": return _jsx(MovingText, { text: text, textColor: textColor });
|
|
19
|
+
default: return _jsx(_Fragment, { children: text });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
// ── Scramble ──────────────────────────────────────────────────────────────────
|
|
23
|
+
function Scramble({ text, accent }) {
|
|
24
|
+
const [display, setDisplay] = useState(text);
|
|
25
|
+
const [settled, setSettled] = useState(false);
|
|
26
|
+
const count = useRef(0);
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
count.current = 0;
|
|
29
|
+
setSettled(false);
|
|
30
|
+
const chars = text.split("");
|
|
31
|
+
const id = setInterval(() => {
|
|
32
|
+
count.current += 1;
|
|
33
|
+
const t = count.current;
|
|
34
|
+
setDisplay(chars.map((c, i) => (i < t || c === " ") ? c : SCRAMBLE_CHARS[Math.floor(Math.random() * SCRAMBLE_CHARS.length)]).join(""));
|
|
35
|
+
if (t >= chars.length) {
|
|
36
|
+
clearInterval(id);
|
|
37
|
+
setSettled(true);
|
|
38
|
+
}
|
|
39
|
+
}, 40);
|
|
40
|
+
return () => clearInterval(id);
|
|
41
|
+
}, [text]);
|
|
42
|
+
return (_jsx("span", { style: { fontVariantNumeric: "tabular-nums" }, children: display.split("").map((char, i) => (_jsx("span", { style: { color: !settled && char !== text[i] ? accent : undefined }, children: char }, i))) }));
|
|
43
|
+
}
|
|
44
|
+
// ── TextReveal ────────────────────────────────────────────────────────────────
|
|
45
|
+
function TextReveal({ text }) {
|
|
46
|
+
const [revealed, setRevealed] = useState(false);
|
|
47
|
+
const ref = useRef(null);
|
|
48
|
+
useEffect(() => {
|
|
49
|
+
const el = ref.current;
|
|
50
|
+
if (!el)
|
|
51
|
+
return;
|
|
52
|
+
if (typeof IntersectionObserver === "undefined") {
|
|
53
|
+
setRevealed(true);
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
const obs = new IntersectionObserver(([e]) => { if (e.isIntersecting) {
|
|
57
|
+
setRevealed(true);
|
|
58
|
+
obs.disconnect();
|
|
59
|
+
} }, { threshold: 0.1 });
|
|
60
|
+
obs.observe(el);
|
|
61
|
+
// Fallback: if already in viewport at mount time, trigger immediately
|
|
62
|
+
const rect = el.getBoundingClientRect();
|
|
63
|
+
if (rect.top < window.innerHeight) {
|
|
64
|
+
setRevealed(true);
|
|
65
|
+
obs.disconnect();
|
|
66
|
+
}
|
|
67
|
+
return () => obs.disconnect();
|
|
68
|
+
}, []);
|
|
69
|
+
return (_jsxs("span", { ref: ref, children: [_jsx("style", { children: `@keyframes lx-charReveal { from { clip-path: inset(0 100% 0 0); } to { clip-path: inset(0 0% 0 0); } }` }), text.split("").map((char, i) => (_jsx("span", { style: {
|
|
70
|
+
display: "inline-block",
|
|
71
|
+
clipPath: revealed ? undefined : "inset(0 100% 0 0)",
|
|
72
|
+
animation: revealed ? `lx-charReveal 0.4s ease forwards ${i * 0.025}s` : undefined,
|
|
73
|
+
}, children: char === " " ? " " : char }, i)))] }));
|
|
74
|
+
}
|
|
75
|
+
// ── Glitch ────────────────────────────────────────────────────────────────────
|
|
76
|
+
function Glitch({ text, accent }) {
|
|
77
|
+
return (_jsxs("span", { style: { position: "relative", display: "inline-block" }, children: [_jsx("style", { children: `
|
|
78
|
+
@keyframes lx-glitch1 { 0%,90%,100%{transform:none} 92%{transform:translateX(-3px) skewX(2deg)} 95%{transform:translateX(3px)} }
|
|
79
|
+
@keyframes lx-glitch2 { 0%,90%,100%{transform:none;color:inherit} 91%{transform:translateX(3px) skewX(-2deg);color:${accent}} 94%{transform:translateX(-2px)} }
|
|
80
|
+
` }), _jsx("span", { "aria-hidden": true, style: { position: "absolute", top: 0, left: 0, mixBlendMode: "screen", animation: "lx-glitch1 4s step-end infinite", textShadow: `-2px 0 ${accent}` }, children: text }), _jsx("span", { "aria-hidden": true, style: { position: "absolute", top: 0, left: 0, mixBlendMode: "screen", animation: "lx-glitch2 4s step-end infinite", textShadow: `2px 0 ${accent}88` }, children: text }), text] }));
|
|
81
|
+
}
|
|
82
|
+
// ── Colourful ─────────────────────────────────────────────────────────────────
|
|
83
|
+
function Colourful({ text, accent }) {
|
|
84
|
+
return (_jsxs("span", { children: [_jsx("style", { children: `@keyframes lx-colourShift { from{background-position:0% center} to{background-position:200% center} }` }), _jsx("span", { style: {
|
|
85
|
+
display: "inline-block",
|
|
86
|
+
background: `linear-gradient(90deg, ${accent}, #f59e0b, #a78bfa, ${accent})`,
|
|
87
|
+
backgroundSize: "300% auto",
|
|
88
|
+
WebkitBackgroundClip: "text",
|
|
89
|
+
WebkitTextFillColor: "transparent",
|
|
90
|
+
backgroundClip: "text",
|
|
91
|
+
animation: "lx-colourShift 3s linear infinite",
|
|
92
|
+
}, children: text })] }));
|
|
93
|
+
}
|
|
94
|
+
// ── HeroHighlight ─────────────────────────────────────────────────────────────
|
|
95
|
+
function HeroHighlight({ text, accent, highlightWords }) {
|
|
96
|
+
const [visible, setVisible] = useState(false);
|
|
97
|
+
const ref = useRef(null);
|
|
98
|
+
const hlSet = new Set(highlightWords.map(w => w.toLowerCase()));
|
|
99
|
+
useEffect(() => {
|
|
100
|
+
const el = ref.current;
|
|
101
|
+
if (!el)
|
|
102
|
+
return;
|
|
103
|
+
if (typeof IntersectionObserver === "undefined") {
|
|
104
|
+
setVisible(true);
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
const obs = new IntersectionObserver(([e]) => { if (e.isIntersecting) {
|
|
108
|
+
setVisible(true);
|
|
109
|
+
obs.disconnect();
|
|
110
|
+
} }, { threshold: 0.1 });
|
|
111
|
+
obs.observe(el);
|
|
112
|
+
const rect = el.getBoundingClientRect();
|
|
113
|
+
if (rect.top < window.innerHeight) {
|
|
114
|
+
setVisible(true);
|
|
115
|
+
obs.disconnect();
|
|
116
|
+
}
|
|
117
|
+
return () => obs.disconnect();
|
|
118
|
+
}, []);
|
|
119
|
+
const tokens = text.split(/(\s+)/);
|
|
120
|
+
return (_jsxs("span", { ref: ref, children: [_jsx("style", { children: `@keyframes lx-hlGrow { from{width:0} to{width:100%} }` }), tokens.map((token, i) => {
|
|
121
|
+
const isHL = hlSet.has(token.trim().toLowerCase()) && token.trim().length > 0;
|
|
122
|
+
return isHL ? (_jsxs("span", { style: { position: "relative", display: "inline-block" }, children: [token, _jsx("span", { style: {
|
|
123
|
+
position: "absolute", bottom: 0, left: 0, height: "3px",
|
|
124
|
+
background: accent,
|
|
125
|
+
animation: visible ? `lx-hlGrow 0.6s ease forwards ${i * 0.05}s` : undefined,
|
|
126
|
+
width: visible ? undefined : "0",
|
|
127
|
+
} })] }, i)) : _jsx("span", { children: token }, i);
|
|
128
|
+
})] }));
|
|
129
|
+
}
|
|
130
|
+
// ── WordByWord ────────────────────────────────────────────────────────────────
|
|
131
|
+
function WordByWord({ text }) {
|
|
132
|
+
const [animated, setAnimated] = useState(false);
|
|
133
|
+
const ref = useRef(null);
|
|
134
|
+
useEffect(() => {
|
|
135
|
+
const el = ref.current;
|
|
136
|
+
if (!el)
|
|
137
|
+
return;
|
|
138
|
+
if (typeof IntersectionObserver === "undefined") {
|
|
139
|
+
setAnimated(true);
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
const obs = new IntersectionObserver(([e]) => { if (e.isIntersecting) {
|
|
143
|
+
setAnimated(true);
|
|
144
|
+
obs.disconnect();
|
|
145
|
+
} }, { threshold: 0.1 });
|
|
146
|
+
obs.observe(el);
|
|
147
|
+
const rect = el.getBoundingClientRect();
|
|
148
|
+
if (rect.top < window.innerHeight) {
|
|
149
|
+
setAnimated(true);
|
|
150
|
+
obs.disconnect();
|
|
151
|
+
}
|
|
152
|
+
return () => obs.disconnect();
|
|
153
|
+
}, []);
|
|
154
|
+
return (_jsxs("span", { ref: ref, children: [_jsx("style", { children: `@keyframes lx-wordUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }` }), text.split(" ").map((word, i) => (_jsx("span", { style: {
|
|
155
|
+
display: "inline-block",
|
|
156
|
+
marginRight: "0.3em",
|
|
157
|
+
opacity: animated ? undefined : 0,
|
|
158
|
+
animation: animated ? `lx-wordUp 0.5s ease forwards ${i * 0.12}s` : undefined,
|
|
159
|
+
}, children: word }, i)))] }));
|
|
160
|
+
}
|
|
161
|
+
// ── FlipWords ─────────────────────────────────────────────────────────────────
|
|
162
|
+
function FlipWords({ text, accent, prefix, words }) {
|
|
163
|
+
const [idx, setIdx] = useState(0);
|
|
164
|
+
const active = words.length > 0 ? words[idx] : text;
|
|
165
|
+
useEffect(() => {
|
|
166
|
+
if (words.length < 2)
|
|
167
|
+
return;
|
|
168
|
+
const id = setInterval(() => setIdx(i => (i + 1) % words.length), 2500);
|
|
169
|
+
return () => clearInterval(id);
|
|
170
|
+
}, [words.length]);
|
|
171
|
+
return (_jsxs("span", { style: { perspective: "800px" }, children: [_jsx("style", { children: `@keyframes lx-flipIn { from{transform:rotateX(-90deg);opacity:0} to{transform:rotateX(0deg);opacity:1} }` }), prefix && _jsxs("span", { children: [prefix, " "] }), _jsx("span", { style: { display: "inline-block", color: accent, fontWeight: 700, transformOrigin: "50% 50%", animation: "lx-flipIn 0.4s ease forwards" }, children: active }, idx)] }));
|
|
172
|
+
}
|
|
173
|
+
// ── MovingText ────────────────────────────────────────────────────────────────
|
|
174
|
+
function MovingText({ text, textColor }) {
|
|
175
|
+
const repeated = [text, text, text, text].join(" ");
|
|
176
|
+
return (_jsxs("span", { style: { display: "block", overflow: "hidden" }, children: [_jsx("style", { children: `@keyframes lx-moveText { from{transform:translateX(0)} to{transform:translateX(-25%)} }` }), _jsx("span", { style: {
|
|
177
|
+
display: "inline-block",
|
|
178
|
+
fontSize: "clamp(3rem, 12vw, 9rem)",
|
|
179
|
+
textTransform: "uppercase",
|
|
180
|
+
letterSpacing: "0.05em",
|
|
181
|
+
opacity: 0.1,
|
|
182
|
+
whiteSpace: "nowrap",
|
|
183
|
+
animation: "lx-moveText 8s linear infinite",
|
|
184
|
+
color: textColor,
|
|
185
|
+
}, children: repeated })] }));
|
|
186
|
+
}
|
|
187
|
+
//# sourceMappingURL=HeadlineEffect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HeadlineEffect.js","sourceRoot":"","sources":["../../src/primitives/HeadlineEffect.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ReactNode } from "react";
|
|
2
|
+
interface MarqueeProps {
|
|
3
|
+
speed?: number;
|
|
4
|
+
direction?: "left" | "right";
|
|
5
|
+
pauseOnHover?: boolean;
|
|
6
|
+
gap?: number;
|
|
7
|
+
children: ReactNode;
|
|
8
|
+
}
|
|
9
|
+
export declare function Marquee({ speed, direction, pauseOnHover, gap, children, }: MarqueeProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=Marquee.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Marquee.d.ts","sourceRoot":"","sources":["../../src/primitives/Marquee.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,UAAU,YAAY;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAC7B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,OAAO,CAAC,EACtB,KAAU,EACV,SAAkB,EAClB,YAAmB,EACnB,GAAQ,EACR,QAAQ,GACT,EAAE,YAAY,2CA4Bd"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useId } from "react";
|
|
3
|
+
export function Marquee({ speed = 20, direction = "left", pauseOnHover = true, gap = 24, children, }) {
|
|
4
|
+
const uid = useId().replace(/:/g, "");
|
|
5
|
+
const animId = `lx-marquee-${uid}`;
|
|
6
|
+
const sign = direction === "left" ? "-" : "";
|
|
7
|
+
const css = `
|
|
8
|
+
@keyframes ${animId} {
|
|
9
|
+
0% { transform: translateX(0); }
|
|
10
|
+
100% { transform: translateX(${sign}50%); }
|
|
11
|
+
}
|
|
12
|
+
.${animId}-inner {
|
|
13
|
+
display: flex;
|
|
14
|
+
gap: ${gap}px;
|
|
15
|
+
animation: ${animId} ${speed}s linear infinite;
|
|
16
|
+
width: max-content;
|
|
17
|
+
}
|
|
18
|
+
${pauseOnHover ? `.${animId}-inner:hover { animation-play-state: paused; }` : ""}
|
|
19
|
+
`;
|
|
20
|
+
return (_jsxs("div", { style: { overflow: "hidden", width: "100%" }, children: [_jsx("style", { children: css }), _jsxs("div", { className: `${animId}-inner`, children: [children, children] })] }));
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=Marquee.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Marquee.js","sourceRoot":"","sources":["../../src/primitives/Marquee.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAW9B,MAAM,UAAU,OAAO,CAAC,EACtB,KAAK,GAAG,EAAE,EACV,SAAS,GAAG,MAAM,EAClB,YAAY,GAAG,IAAI,EACnB,GAAG,GAAG,EAAE,EACR,QAAQ,GACK;IACb,MAAM,GAAG,GAAG,KAAK,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,MAAM,GAAG,cAAc,GAAG,EAAE,CAAC;IACnC,MAAM,IAAI,GAAG,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IAE7C,MAAM,GAAG,GAAG;iBACG,MAAM;;qCAEc,IAAI;;OAElC,MAAM;;aAEA,GAAG;mBACG,MAAM,IAAI,KAAK;;;MAG5B,YAAY,CAAC,CAAC,CAAC,IAAI,MAAM,gDAAgD,CAAC,CAAC,CAAC,EAAE;GACjF,CAAC;IAEF,OAAO,CACL,eAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,aAC/C,0BAAQ,GAAG,GAAS,EACpB,eAAK,SAAS,EAAE,GAAG,MAAM,QAAQ,aAC9B,QAAQ,EACR,QAAQ,IACL,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export type HoverEffect = "shimmer" | "tilt" | "spotlight" | "ken_burns" | "blur_reveal" | "desaturate" | "zoom_punch" | "split_reveal";
|
|
2
|
+
interface MediaFlipProps {
|
|
3
|
+
front?: string;
|
|
4
|
+
back?: string;
|
|
5
|
+
images?: string[];
|
|
6
|
+
shimmer?: boolean;
|
|
7
|
+
hoverEffect?: HoverEffect;
|
|
8
|
+
alt?: string;
|
|
9
|
+
aspect?: string;
|
|
10
|
+
fit?: "cover" | "contain";
|
|
11
|
+
speed?: number;
|
|
12
|
+
className?: string;
|
|
13
|
+
}
|
|
14
|
+
export declare function MediaFlip({ front: frontProp, back: backProp, images: imagesProp, shimmer, hoverEffect, alt, aspect, fit, speed, className, }: MediaFlipProps): import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=MediaFlip.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaFlip.d.ts","sourceRoot":"","sources":["../../src/primitives/MediaFlip.tsx"],"names":[],"mappings":"AAIA,MAAM,MAAM,WAAW,GACnB,SAAS,GACT,MAAM,GACN,WAAW,GACX,WAAW,GACX,aAAa,GACb,YAAY,GACZ,YAAY,GACZ,cAAc,CAAC;AAEnB,UAAU,cAAc;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAwBD,wBAAgB,SAAS,CAAC,EACxB,KAAK,EAAE,SAAS,EAChB,IAAI,EAAE,QAAQ,EACd,MAAM,EAAE,UAAU,EAClB,OAAe,EACf,WAAW,EACX,GAAQ,EACR,MAAc,EACd,GAAa,EACb,KAAY,EACZ,SAAc,GACf,EAAE,cAAc,2CA0IhB"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useRef, useState } from "react";
|
|
3
|
+
import { AspectBox } from "./AspectBox";
|
|
4
|
+
const EFFECT_KEYFRAMES = `
|
|
5
|
+
@keyframes lx-shimmer {
|
|
6
|
+
from { transform: translateX(-100%) skewX(-15deg); }
|
|
7
|
+
to { transform: translateX(250%) skewX(-15deg); }
|
|
8
|
+
}
|
|
9
|
+
@keyframes lx-ken-burns {
|
|
10
|
+
0% { transform: scale(1) translate(0, 0); }
|
|
11
|
+
50% { transform: scale(1.08) translate(-1%, -1%); }
|
|
12
|
+
100% { transform: scale(1) translate(0, 0); }
|
|
13
|
+
}
|
|
14
|
+
@keyframes lx-zoom-punch {
|
|
15
|
+
0% { transform: scale(1); }
|
|
16
|
+
40% { transform: scale(1.1); }
|
|
17
|
+
70% { transform: scale(1.04); }
|
|
18
|
+
100% { transform: scale(1.06); }
|
|
19
|
+
}
|
|
20
|
+
@keyframes lx-split-in {
|
|
21
|
+
from { clip-path: inset(0 100% 0 0); }
|
|
22
|
+
to { clip-path: inset(0 0% 0 0); }
|
|
23
|
+
}
|
|
24
|
+
`;
|
|
25
|
+
export function MediaFlip({ front: frontProp, back: backProp, images: imagesProp, shimmer = false, hoverEffect, alt = "", aspect = "1:1", fit = "cover", speed = 1500, className = "", }) {
|
|
26
|
+
// Resolve effective effect — hoverEffect prop wins over shimmer boolean
|
|
27
|
+
const effect = hoverEffect ?? (shimmer ? "shimmer" : undefined);
|
|
28
|
+
// Resolve images
|
|
29
|
+
const images = imagesProp && imagesProp.length > 0
|
|
30
|
+
? imagesProp
|
|
31
|
+
: [frontProp ?? "", ...(backProp ? [backProp] : [])].filter(Boolean);
|
|
32
|
+
const front = images[0] ?? "";
|
|
33
|
+
const back = images[1];
|
|
34
|
+
const hasBack = !!back && back !== front;
|
|
35
|
+
// Hover state
|
|
36
|
+
const [isHovered, setIsHovered] = useState(false);
|
|
37
|
+
const [animKey, setAnimKey] = useState(0); // replays one-shot anims
|
|
38
|
+
// Mouse position for tilt + spotlight
|
|
39
|
+
const wrapRef = useRef(null);
|
|
40
|
+
const [mouse, setMouse] = useState({ x: 0, y: 0, rx: 0, ry: 0 });
|
|
41
|
+
// Image cycling (multi-image)
|
|
42
|
+
const [cycledSrc, setCycledSrc] = useState(back ?? front);
|
|
43
|
+
const timerRef = useRef(null);
|
|
44
|
+
function handleEnter() {
|
|
45
|
+
setIsHovered(true);
|
|
46
|
+
setAnimKey((k) => k + 1);
|
|
47
|
+
if (images.length >= 2)
|
|
48
|
+
setCycledSrc(images[1]);
|
|
49
|
+
if (images.length >= 3 && speed > 0) {
|
|
50
|
+
let cur = 1;
|
|
51
|
+
timerRef.current = setInterval(() => {
|
|
52
|
+
cur = (cur % (images.length - 1)) + 1;
|
|
53
|
+
setCycledSrc(images[cur]);
|
|
54
|
+
}, speed);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function handleLeave() {
|
|
58
|
+
setIsHovered(false);
|
|
59
|
+
setMouse({ x: 0, y: 0, rx: 0, ry: 0 });
|
|
60
|
+
if (timerRef.current) {
|
|
61
|
+
clearInterval(timerRef.current);
|
|
62
|
+
timerRef.current = null;
|
|
63
|
+
}
|
|
64
|
+
setCycledSrc(images[1] ?? images[0]);
|
|
65
|
+
}
|
|
66
|
+
function handleMouseMove(e) {
|
|
67
|
+
if (effect !== "tilt" && effect !== "spotlight")
|
|
68
|
+
return;
|
|
69
|
+
const el = wrapRef.current;
|
|
70
|
+
if (!el)
|
|
71
|
+
return;
|
|
72
|
+
const rect = el.getBoundingClientRect();
|
|
73
|
+
const x = e.clientX - rect.left;
|
|
74
|
+
const y = e.clientY - rect.top;
|
|
75
|
+
const rx = ((y / rect.height) - 0.5) * -16;
|
|
76
|
+
const ry = ((x / rect.width) - 0.5) * 16;
|
|
77
|
+
setMouse({ x, y, rx, ry });
|
|
78
|
+
}
|
|
79
|
+
// ── Base image style ────────────────────────────────────────────────────────
|
|
80
|
+
const baseImg = {
|
|
81
|
+
position: "absolute", inset: 0,
|
|
82
|
+
width: "100%", height: "100%",
|
|
83
|
+
objectFit: fit, display: "block",
|
|
84
|
+
};
|
|
85
|
+
// ── Per-effect front image styles ──────────────────────────────────────────
|
|
86
|
+
function frontStyle() {
|
|
87
|
+
switch (effect) {
|
|
88
|
+
case "blur_reveal":
|
|
89
|
+
return { ...baseImg, filter: isHovered ? "blur(0)" : "blur(7px)", transition: "filter 0.45s ease" };
|
|
90
|
+
case "desaturate":
|
|
91
|
+
return { ...baseImg, filter: isHovered ? "saturate(1)" : "saturate(0)", transition: "filter 0.5s ease" };
|
|
92
|
+
case "ken_burns":
|
|
93
|
+
return { ...baseImg, animation: "lx-ken-burns 8s ease-in-out infinite", animationPlayState: isHovered ? "paused" : "running", transformOrigin: "center" };
|
|
94
|
+
case "zoom_punch":
|
|
95
|
+
return isHovered
|
|
96
|
+
? { ...baseImg, animation: `lx-zoom-punch 0.45s cubic-bezier(0.4,0,0.2,1) forwards`, transformOrigin: "center" }
|
|
97
|
+
: { ...baseImg };
|
|
98
|
+
case "split_reveal":
|
|
99
|
+
case "shimmer":
|
|
100
|
+
return { ...baseImg, opacity: hasBack && isHovered ? 0 : 1, transition: "opacity 0.4s ease" };
|
|
101
|
+
default:
|
|
102
|
+
return { ...baseImg, opacity: hasBack && isHovered ? 0 : 1, transition: "opacity 0.4s ease" };
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
// ── Tilt transform for wrapper ─────────────────────────────────────────────
|
|
106
|
+
const tiltTransform = effect === "tilt" && isHovered
|
|
107
|
+
? { transform: `perspective(800px) rotateX(${mouse.rx}deg) rotateY(${mouse.ry}deg)`, transition: "transform 0.1s ease-out" }
|
|
108
|
+
: effect === "tilt"
|
|
109
|
+
? { transform: "perspective(800px) rotateX(0deg) rotateY(0deg)", transition: "transform 0.4s ease" }
|
|
110
|
+
: {};
|
|
111
|
+
return (_jsxs(AspectBox, { aspect: aspect, className: className, style: { cursor: "pointer", ...tiltTransform }, children: [_jsx("style", { children: EFFECT_KEYFRAMES }), _jsxs("div", { ref: wrapRef, style: { position: "absolute", inset: 0 }, onMouseEnter: handleEnter, onMouseLeave: handleLeave, onMouseMove: handleMouseMove, children: [_jsx("img", { src: front, alt: alt, loading: "lazy", style: frontStyle() }, effect === "zoom_punch" && isHovered ? `punch-${animKey}` : "front"), hasBack && effect !== "split_reveal" && (_jsx("img", { src: cycledSrc, alt: alt, loading: "lazy", style: { ...baseImg, opacity: isHovered ? 1 : 0, transition: "opacity 0.4s ease" } })), hasBack && effect === "split_reveal" && isHovered && (_jsx("img", { src: cycledSrc, alt: alt, loading: "lazy", style: { ...baseImg, animation: "lx-split-in 0.5s cubic-bezier(0.4,0,0.2,1) forwards" } }, `split-${animKey}`)), effect === "shimmer" && isHovered && (_jsx("div", { "aria-hidden": true, style: { position: "absolute", inset: 0, overflow: "hidden", pointerEvents: "none", zIndex: 2 }, children: _jsx("div", { style: { position: "absolute", top: 0, left: 0, width: "40%", height: "100%",
|
|
112
|
+
background: "linear-gradient(105deg, transparent 20%, rgba(255,255,255,0.55) 50%, transparent 80%)",
|
|
113
|
+
animation: "lx-shimmer 0.65s cubic-bezier(0.4,0,0.2,1) forwards" } }) }, `shimmer-${animKey}`)), effect === "spotlight" && isHovered && (_jsx("div", { "aria-hidden": true, style: { position: "absolute", inset: 0, pointerEvents: "none", zIndex: 2,
|
|
114
|
+
background: `radial-gradient(circle 130px at ${mouse.x}px ${mouse.y}px, rgba(255,255,255,0.28), transparent 70%)` } })), effect === "tilt" && isHovered && (_jsx("div", { "aria-hidden": true, style: { position: "absolute", inset: 0, pointerEvents: "none", zIndex: 2,
|
|
115
|
+
background: `radial-gradient(circle at ${(mouse.x / (wrapRef.current?.offsetWidth ?? 1)) * 100}% ${(mouse.y / (wrapRef.current?.offsetHeight ?? 1)) * 100}%, rgba(255,255,255,0.22), transparent 60%)`,
|
|
116
|
+
borderRadius: "inherit" } }))] })] }));
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=MediaFlip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaFlip.js","sourceRoot":"","sources":["../../src/primitives/MediaFlip.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { CSSProperties } from "react";
|
|
2
|
+
interface MediaLoopProps {
|
|
3
|
+
src: string;
|
|
4
|
+
poster?: string;
|
|
5
|
+
alt?: string;
|
|
6
|
+
fit?: "cover" | "contain";
|
|
7
|
+
className?: string;
|
|
8
|
+
style?: CSSProperties;
|
|
9
|
+
playOnHover?: boolean;
|
|
10
|
+
/** When true, applies --lx-image-radius, --lx-image-shadow, --lx-image-opacity from theme */
|
|
11
|
+
applyImageTokens?: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare function MediaLoop({ src, poster, alt, fit, className, style, playOnHover, applyImageTokens, }: MediaLoopProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=MediaLoop.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaLoop.d.ts","sourceRoot":"","sources":["../../src/primitives/MediaLoop.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAI3C,UAAU,cAAc;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,6FAA6F;IAC7F,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED,wBAAgB,SAAS,CAAC,EACxB,GAAG,EACH,MAAM,EACN,GAAQ,EACR,GAAa,EACb,SAAc,EACd,KAAK,EACL,WAAmB,EACnB,gBAAwB,GACzB,EAAE,cAAc,2CAkDhB"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useRef } from "react";
|
|
3
|
+
const VIDEO_EXTS = /\.(mp4|webm|mov|ogg)(\?.*)?$/i;
|
|
4
|
+
export function MediaLoop({ src, poster, alt = "", fit = "cover", className = "", style, playOnHover = false, applyImageTokens = false, }) {
|
|
5
|
+
const isVideo = VIDEO_EXTS.test(src);
|
|
6
|
+
const [hovered, setHovered] = useState(false);
|
|
7
|
+
const videoRef = useRef(null);
|
|
8
|
+
const tokenStyles = applyImageTokens
|
|
9
|
+
? {
|
|
10
|
+
borderRadius: "var(--lx-image-radius)",
|
|
11
|
+
boxShadow: "var(--lx-image-shadow)",
|
|
12
|
+
opacity: "var(--lx-image-opacity)",
|
|
13
|
+
}
|
|
14
|
+
: {};
|
|
15
|
+
const baseStyle = {
|
|
16
|
+
width: "100%",
|
|
17
|
+
height: "100%",
|
|
18
|
+
objectFit: fit,
|
|
19
|
+
objectPosition: "var(--lx-object-position, 50% 50%)",
|
|
20
|
+
display: "block",
|
|
21
|
+
...tokenStyles,
|
|
22
|
+
...style,
|
|
23
|
+
};
|
|
24
|
+
if (!isVideo) {
|
|
25
|
+
return (_jsx("img", { src: src, alt: alt, loading: "lazy", className: className, style: baseStyle }));
|
|
26
|
+
}
|
|
27
|
+
return (_jsx("video", { ref: videoRef, src: src, poster: poster, autoPlay: playOnHover ? hovered : true, muted: true, loop: true, playsInline: true, className: className, style: baseStyle, onMouseEnter: () => { setHovered(true); if (playOnHover)
|
|
28
|
+
videoRef.current?.play(); }, onMouseLeave: () => { setHovered(false); if (playOnHover)
|
|
29
|
+
videoRef.current?.pause(); } }));
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=MediaLoop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaLoop.js","sourceRoot":"","sources":["../../src/primitives/MediaLoop.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAGzC,MAAM,UAAU,GAAG,+BAA+B,CAAC;AAcnD,MAAM,UAAU,SAAS,CAAC,EACxB,GAAG,EACH,MAAM,EACN,GAAG,GAAG,EAAE,EACR,GAAG,GAAG,OAAO,EACb,SAAS,GAAG,EAAE,EACd,KAAK,EACL,WAAW,GAAG,KAAK,EACnB,gBAAgB,GAAG,KAAK,GACT;IACf,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9C,MAAM,QAAQ,GAAG,MAAM,CAAmB,IAAI,CAAC,CAAC;IAEhD,MAAM,WAAW,GAAkB,gBAAgB;QACjD,CAAC,CAAC;YACE,YAAY,EAAE,wBAAwB;YACtC,SAAS,EAAE,wBAAwB;YACnC,OAAO,EAAE,yBAA8C;SACxD;QACH,CAAC,CAAC,EAAE,CAAC;IAEP,MAAM,SAAS,GAAkB;QAC/B,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;QACd,SAAS,EAAE,GAAG;QACd,cAAc,EAAE,oCAA8C;QAC9D,OAAO,EAAE,OAAO;QAChB,GAAG,WAAW;QACd,GAAG,KAAK;KACT,CAAC;IAEF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,CACL,cACE,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,GAAG,EACR,OAAO,EAAC,MAAM,EACd,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,SAAS,GAChB,CACH,CAAC;IACJ,CAAC;IAED,OAAO,CACL,gBACE,GAAG,EAAE,QAAQ,EACb,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EACtC,KAAK,QACL,IAAI,QACJ,WAAW,QACX,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,SAAS,EAChB,YAAY,EAAE,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,WAAW;YAAE,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EACpF,YAAY,EAAE,GAAG,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,WAAW;YAAE,QAAQ,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,GACtF,CACH,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { CSSProperties } from "react";
|
|
2
|
+
export type ThumbPosition = "left" | "right" | "top" | "bottom" | "top-left" | "top-right" | "bottom-left" | "bottom-right";
|
|
3
|
+
export type GalleryAnimationMode = "fade" | "slide" | "zoom" | "flip" | "ken_burns";
|
|
4
|
+
export interface PDPGalleryProps {
|
|
5
|
+
images: string[];
|
|
6
|
+
alt?: string;
|
|
7
|
+
aspect?: string;
|
|
8
|
+
fit?: "cover" | "contain";
|
|
9
|
+
thumbPosition?: ThumbPosition;
|
|
10
|
+
thumbSize?: number;
|
|
11
|
+
autoInterval?: number;
|
|
12
|
+
animationMode?: GalleryAnimationMode;
|
|
13
|
+
accentColor?: string;
|
|
14
|
+
borderColor?: string;
|
|
15
|
+
imageRadius?: string;
|
|
16
|
+
thumbRadius?: string;
|
|
17
|
+
bgColor?: string;
|
|
18
|
+
className?: string;
|
|
19
|
+
style?: CSSProperties;
|
|
20
|
+
activeIndex?: number;
|
|
21
|
+
onSelect?: (index: number) => void;
|
|
22
|
+
}
|
|
23
|
+
export declare function PDPGallery({ images, alt, aspect, fit, thumbPosition, thumbSize, autoInterval, animationMode, accentColor, borderColor, imageRadius, thumbRadius, bgColor, className, style, activeIndex: controlledIndex, onSelect, }: PDPGalleryProps): import("react/jsx-runtime").JSX.Element;
|
|
24
|
+
//# sourceMappingURL=PDPGallery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PDPGallery.d.ts","sourceRoot":"","sources":["../../src/primitives/PDPGallery.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAM3C,MAAM,MAAM,aAAa,GACrB,MAAM,GACN,OAAO,GACP,KAAK,GACL,QAAQ,GACR,UAAU,GACV,WAAW,GACX,aAAa,GACb,cAAc,CAAC;AAEnB,MAAM,MAAM,oBAAoB,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,WAAW,CAAC;AAEpF,MAAM,WAAW,eAAe;IAC9B,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,GAAG,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAC1B,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;IAEtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC;AAwDD,wBAAgB,UAAU,CAAC,EACzB,MAAM,EACN,GAAQ,EACR,MAAc,EACd,GAAe,EACf,aAAsB,EACtB,SAAc,EACd,YAAgB,EAChB,aAAsB,EACtB,WAAuB,EACvB,WAAuB,EACvB,WAA4C,EAC5C,WAAmB,EACnB,OAAmB,EACnB,SAAc,EACd,KAAK,EACL,WAAW,EAAE,eAAe,EAC5B,QAAQ,GACT,EAAE,eAAe,2CA+HjB"}
|