@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.
Files changed (633) hide show
  1. package/dist/PageRenderer.d.ts +8 -0
  2. package/dist/PageRenderer.d.ts.map +1 -0
  3. package/dist/PageRenderer.js +116 -0
  4. package/dist/PageRenderer.js.map +1 -0
  5. package/dist/SectionSkeleton.d.ts +2 -0
  6. package/dist/SectionSkeleton.d.ts.map +1 -0
  7. package/dist/SectionSkeleton.js +5 -0
  8. package/dist/SectionSkeleton.js.map +1 -0
  9. package/dist/ThemeContext.d.ts +11 -0
  10. package/dist/ThemeContext.d.ts.map +1 -0
  11. package/dist/ThemeContext.js +13 -0
  12. package/dist/ThemeContext.js.map +1 -0
  13. package/dist/ThemeProvider.d.ts +9 -0
  14. package/dist/ThemeProvider.d.ts.map +1 -0
  15. package/dist/ThemeProvider.js +227 -0
  16. package/dist/ThemeProvider.js.map +1 -0
  17. package/dist/ThemeToggle.d.ts +6 -0
  18. package/dist/ThemeToggle.d.ts.map +1 -0
  19. package/dist/ThemeToggle.js +26 -0
  20. package/dist/ThemeToggle.js.map +1 -0
  21. package/dist/animations/advanced-hooks.d.ts +36 -0
  22. package/dist/animations/advanced-hooks.d.ts.map +1 -0
  23. package/dist/animations/advanced-hooks.js +106 -0
  24. package/dist/animations/advanced-hooks.js.map +1 -0
  25. package/dist/animations/canvas-utils.d.ts +41 -0
  26. package/dist/animations/canvas-utils.d.ts.map +1 -0
  27. package/dist/animations/canvas-utils.js +115 -0
  28. package/dist/animations/canvas-utils.js.map +1 -0
  29. package/dist/animations/hooks.d.ts +48 -0
  30. package/dist/animations/hooks.d.ts.map +1 -0
  31. package/dist/animations/hooks.js +50 -0
  32. package/dist/animations/hooks.js.map +1 -0
  33. package/dist/animations/index.d.ts +4 -0
  34. package/dist/animations/index.d.ts.map +1 -0
  35. package/dist/animations/index.js +4 -0
  36. package/dist/animations/index.js.map +1 -0
  37. package/dist/animations/presets.d.ts +43 -0
  38. package/dist/animations/presets.d.ts.map +1 -0
  39. package/dist/animations/presets.js +278 -0
  40. package/dist/animations/presets.js.map +1 -0
  41. package/dist/animations/variants.d.ts +15 -0
  42. package/dist/animations/variants.d.ts.map +1 -0
  43. package/dist/animations/variants.js +90 -0
  44. package/dist/animations/variants.js.map +1 -0
  45. package/dist/backgrounds/BackgroundSection.d.ts +3 -0
  46. package/dist/backgrounds/BackgroundSection.d.ts.map +1 -0
  47. package/dist/backgrounds/BackgroundSection.js +205 -0
  48. package/dist/backgrounds/BackgroundSection.js.map +1 -0
  49. package/dist/buttons/ButtonSection.d.ts +3 -0
  50. package/dist/buttons/ButtonSection.d.ts.map +1 -0
  51. package/dist/buttons/ButtonSection.js +150 -0
  52. package/dist/buttons/ButtonSection.js.map +1 -0
  53. package/dist/cards/CardStack.d.ts +3 -0
  54. package/dist/cards/CardStack.d.ts.map +1 -0
  55. package/dist/cards/CardStack.js +140 -0
  56. package/dist/cards/CardStack.js.map +1 -0
  57. package/dist/cards/FeatureCard.d.ts +3 -0
  58. package/dist/cards/FeatureCard.d.ts.map +1 -0
  59. package/dist/cards/FeatureCard.js +100 -0
  60. package/dist/cards/FeatureCard.js.map +1 -0
  61. package/dist/cards/FeaturedCard.d.ts +3 -0
  62. package/dist/cards/FeaturedCard.d.ts.map +1 -0
  63. package/dist/cards/FeaturedCard.js +66 -0
  64. package/dist/cards/FeaturedCard.js.map +1 -0
  65. package/dist/cards/TerminalCard.d.ts +3 -0
  66. package/dist/cards/TerminalCard.d.ts.map +1 -0
  67. package/dist/cards/TerminalCard.js +73 -0
  68. package/dist/cards/TerminalCard.js.map +1 -0
  69. package/dist/cards/TestimonialCard.d.ts +3 -0
  70. package/dist/cards/TestimonialCard.d.ts.map +1 -0
  71. package/dist/cards/TestimonialCard.js +50 -0
  72. package/dist/cards/TestimonialCard.js.map +1 -0
  73. package/dist/cards/index.d.ts +2 -0
  74. package/dist/cards/index.d.ts.map +1 -0
  75. package/dist/cards/index.js +2 -0
  76. package/dist/cards/index.js.map +1 -0
  77. package/dist/cart/CartCheckoutBar.d.ts +3 -0
  78. package/dist/cart/CartCheckoutBar.d.ts.map +1 -0
  79. package/dist/cart/CartCheckoutBar.js +258 -0
  80. package/dist/cart/CartCheckoutBar.js.map +1 -0
  81. package/dist/cart/CartDiscount.d.ts +3 -0
  82. package/dist/cart/CartDiscount.d.ts.map +1 -0
  83. package/dist/cart/CartDiscount.js +78 -0
  84. package/dist/cart/CartDiscount.js.map +1 -0
  85. package/dist/cart/CartDrawer.d.ts +3 -0
  86. package/dist/cart/CartDrawer.d.ts.map +1 -0
  87. package/dist/cart/CartDrawer.js +141 -0
  88. package/dist/cart/CartDrawer.js.map +1 -0
  89. package/dist/cart/CartLines.d.ts +3 -0
  90. package/dist/cart/CartLines.d.ts.map +1 -0
  91. package/dist/cart/CartLines.js +227 -0
  92. package/dist/cart/CartLines.js.map +1 -0
  93. package/dist/cart/CartPage.d.ts +3 -0
  94. package/dist/cart/CartPage.d.ts.map +1 -0
  95. package/dist/cart/CartPage.js +128 -0
  96. package/dist/cart/CartPage.js.map +1 -0
  97. package/dist/cart/CartSummary.d.ts +3 -0
  98. package/dist/cart/CartSummary.d.ts.map +1 -0
  99. package/dist/cart/CartSummary.js +155 -0
  100. package/dist/cart/CartSummary.js.map +1 -0
  101. package/dist/cart/CartTrigger.d.ts +3 -0
  102. package/dist/cart/CartTrigger.d.ts.map +1 -0
  103. package/dist/cart/CartTrigger.js +45 -0
  104. package/dist/cart/CartTrigger.js.map +1 -0
  105. package/dist/cart/GuaranteeBanner.d.ts +3 -0
  106. package/dist/cart/GuaranteeBanner.d.ts.map +1 -0
  107. package/dist/cart/GuaranteeBanner.js +15 -0
  108. package/dist/cart/GuaranteeBanner.js.map +1 -0
  109. package/dist/cart/index.d.ts +8 -0
  110. package/dist/cart/index.d.ts.map +1 -0
  111. package/dist/cart/index.js +8 -0
  112. package/dist/cart/index.js.map +1 -0
  113. package/dist/content/BeforeAfterSlider.d.ts +3 -0
  114. package/dist/content/BeforeAfterSlider.d.ts.map +1 -0
  115. package/dist/content/BeforeAfterSlider.js +61 -0
  116. package/dist/content/BeforeAfterSlider.js.map +1 -0
  117. package/dist/content/ImageTextSplit.d.ts +3 -0
  118. package/dist/content/ImageTextSplit.d.ts.map +1 -0
  119. package/dist/content/ImageTextSplit.js +33 -0
  120. package/dist/content/ImageTextSplit.js.map +1 -0
  121. package/dist/content/LookbookGrid.d.ts +3 -0
  122. package/dist/content/LookbookGrid.d.ts.map +1 -0
  123. package/dist/content/LookbookGrid.js +183 -0
  124. package/dist/content/LookbookGrid.js.map +1 -0
  125. package/dist/content/ParallaxSection.d.ts +3 -0
  126. package/dist/content/ParallaxSection.d.ts.map +1 -0
  127. package/dist/content/ParallaxSection.js +66 -0
  128. package/dist/content/ParallaxSection.js.map +1 -0
  129. package/dist/content/RichText.d.ts +3 -0
  130. package/dist/content/RichText.d.ts.map +1 -0
  131. package/dist/content/RichText.js +21 -0
  132. package/dist/content/RichText.js.map +1 -0
  133. package/dist/content/index.d.ts +5 -0
  134. package/dist/content/index.d.ts.map +1 -0
  135. package/dist/content/index.js +5 -0
  136. package/dist/content/index.js.map +1 -0
  137. package/dist/content-types.d.ts +637 -0
  138. package/dist/content-types.d.ts.map +1 -0
  139. package/dist/content-types.js +2 -0
  140. package/dist/content-types.js.map +1 -0
  141. package/dist/context/LxCartContext.d.ts +71 -0
  142. package/dist/context/LxCartContext.d.ts.map +1 -0
  143. package/dist/context/LxCartContext.js +491 -0
  144. package/dist/context/LxCartContext.js.map +1 -0
  145. package/dist/context/LxEditorContext.d.ts +8 -0
  146. package/dist/context/LxEditorContext.d.ts.map +1 -0
  147. package/dist/context/LxEditorContext.js +10 -0
  148. package/dist/context/LxEditorContext.js.map +1 -0
  149. package/dist/context/LxPDPContext.d.ts +39 -0
  150. package/dist/context/LxPDPContext.d.ts.map +1 -0
  151. package/dist/context/LxPDPContext.js +52 -0
  152. package/dist/context/LxPDPContext.js.map +1 -0
  153. package/dist/cta/CtaFullWidth.d.ts +3 -0
  154. package/dist/cta/CtaFullWidth.d.ts.map +1 -0
  155. package/dist/cta/CtaFullWidth.js +30 -0
  156. package/dist/cta/CtaFullWidth.js.map +1 -0
  157. package/dist/cta/CtaStickyBottom.d.ts +3 -0
  158. package/dist/cta/CtaStickyBottom.d.ts.map +1 -0
  159. package/dist/cta/CtaStickyBottom.js +43 -0
  160. package/dist/cta/CtaStickyBottom.js.map +1 -0
  161. package/dist/cta/GuaranteeCta.d.ts +3 -0
  162. package/dist/cta/GuaranteeCta.d.ts.map +1 -0
  163. package/dist/cta/GuaranteeCta.js +27 -0
  164. package/dist/cta/GuaranteeCta.js.map +1 -0
  165. package/dist/cta/NewsletterSignup.d.ts +3 -0
  166. package/dist/cta/NewsletterSignup.d.ts.map +1 -0
  167. package/dist/cta/NewsletterSignup.js +35 -0
  168. package/dist/cta/NewsletterSignup.js.map +1 -0
  169. package/dist/cta/Popup.d.ts +3 -0
  170. package/dist/cta/Popup.d.ts.map +1 -0
  171. package/dist/cta/Popup.js +208 -0
  172. package/dist/cta/Popup.js.map +1 -0
  173. package/dist/cta/UrgencyCta.d.ts +3 -0
  174. package/dist/cta/UrgencyCta.d.ts.map +1 -0
  175. package/dist/cta/UrgencyCta.js +85 -0
  176. package/dist/cta/UrgencyCta.js.map +1 -0
  177. package/dist/cta/WaitlistCta.d.ts +3 -0
  178. package/dist/cta/WaitlistCta.d.ts.map +1 -0
  179. package/dist/cta/WaitlistCta.js +62 -0
  180. package/dist/cta/WaitlistCta.js.map +1 -0
  181. package/dist/cta/index.d.ts +3 -0
  182. package/dist/cta/index.d.ts.map +1 -0
  183. package/dist/cta/index.js +3 -0
  184. package/dist/cta/index.js.map +1 -0
  185. package/dist/effects/AnimatedBackground.d.ts +22 -0
  186. package/dist/effects/AnimatedBackground.d.ts.map +1 -0
  187. package/dist/effects/AnimatedBackground.js +313 -0
  188. package/dist/effects/AnimatedBackground.js.map +1 -0
  189. package/dist/effects/CanvasReveal.d.ts +5 -0
  190. package/dist/effects/CanvasReveal.d.ts.map +1 -0
  191. package/dist/effects/CanvasReveal.js +104 -0
  192. package/dist/effects/CanvasReveal.js.map +1 -0
  193. package/dist/effects/DecorativeOverlay.d.ts +10 -0
  194. package/dist/effects/DecorativeOverlay.d.ts.map +1 -0
  195. package/dist/effects/DecorativeOverlay.js +76 -0
  196. package/dist/effects/DecorativeOverlay.js.map +1 -0
  197. package/dist/effects/ScrollLinked.d.ts +3 -0
  198. package/dist/effects/ScrollLinked.d.ts.map +1 -0
  199. package/dist/effects/ScrollLinked.js +57 -0
  200. package/dist/effects/ScrollLinked.js.map +1 -0
  201. package/dist/effects/svg-library.d.ts +3 -0
  202. package/dist/effects/svg-library.d.ts.map +1 -0
  203. package/dist/effects/svg-library.js +105 -0
  204. package/dist/effects/svg-library.js.map +1 -0
  205. package/dist/faq/FaqAccordion.d.ts +3 -0
  206. package/dist/faq/FaqAccordion.d.ts.map +1 -0
  207. package/dist/faq/FaqAccordion.js +39 -0
  208. package/dist/faq/FaqAccordion.js.map +1 -0
  209. package/dist/faq/FaqTwoColumn.d.ts +3 -0
  210. package/dist/faq/FaqTwoColumn.d.ts.map +1 -0
  211. package/dist/faq/FaqTwoColumn.js +38 -0
  212. package/dist/faq/FaqTwoColumn.js.map +1 -0
  213. package/dist/faq/index.d.ts +3 -0
  214. package/dist/faq/index.d.ts.map +1 -0
  215. package/dist/faq/index.js +3 -0
  216. package/dist/faq/index.js.map +1 -0
  217. package/dist/features/BentoGrid.d.ts +3 -0
  218. package/dist/features/BentoGrid.d.ts.map +1 -0
  219. package/dist/features/BentoGrid.js +62 -0
  220. package/dist/features/BentoGrid.js.map +1 -0
  221. package/dist/features/FeatureGrid.d.ts +3 -0
  222. package/dist/features/FeatureGrid.d.ts.map +1 -0
  223. package/dist/features/FeatureGrid.js +89 -0
  224. package/dist/features/FeatureGrid.js.map +1 -0
  225. package/dist/features/FeatureTabs.d.ts +3 -0
  226. package/dist/features/FeatureTabs.d.ts.map +1 -0
  227. package/dist/features/FeatureTabs.js +64 -0
  228. package/dist/features/FeatureTabs.js.map +1 -0
  229. package/dist/features/ProcessSteps.d.ts +3 -0
  230. package/dist/features/ProcessSteps.d.ts.map +1 -0
  231. package/dist/features/ProcessSteps.js +74 -0
  232. package/dist/features/ProcessSteps.js.map +1 -0
  233. package/dist/heroes/HeroActivity.d.ts +3 -0
  234. package/dist/heroes/HeroActivity.d.ts.map +1 -0
  235. package/dist/heroes/HeroActivity.js +54 -0
  236. package/dist/heroes/HeroActivity.js.map +1 -0
  237. package/dist/heroes/HeroAnimated.d.ts +3 -0
  238. package/dist/heroes/HeroAnimated.d.ts.map +1 -0
  239. package/dist/heroes/HeroAnimated.js +101 -0
  240. package/dist/heroes/HeroAnimated.js.map +1 -0
  241. package/dist/heroes/HeroAurora.d.ts +3 -0
  242. package/dist/heroes/HeroAurora.d.ts.map +1 -0
  243. package/dist/heroes/HeroAurora.js +53 -0
  244. package/dist/heroes/HeroAurora.js.map +1 -0
  245. package/dist/heroes/HeroCarousel.d.ts +3 -0
  246. package/dist/heroes/HeroCarousel.d.ts.map +1 -0
  247. package/dist/heroes/HeroCarousel.js +187 -0
  248. package/dist/heroes/HeroCarousel.js.map +1 -0
  249. package/dist/heroes/HeroCentered.d.ts +3 -0
  250. package/dist/heroes/HeroCentered.d.ts.map +1 -0
  251. package/dist/heroes/HeroCentered.js +62 -0
  252. package/dist/heroes/HeroCentered.js.map +1 -0
  253. package/dist/heroes/HeroCinematicFullbleed.d.ts +3 -0
  254. package/dist/heroes/HeroCinematicFullbleed.d.ts.map +1 -0
  255. package/dist/heroes/HeroCinematicFullbleed.js +44 -0
  256. package/dist/heroes/HeroCinematicFullbleed.js.map +1 -0
  257. package/dist/heroes/HeroCountdown.d.ts +3 -0
  258. package/dist/heroes/HeroCountdown.d.ts.map +1 -0
  259. package/dist/heroes/HeroCountdown.js +64 -0
  260. package/dist/heroes/HeroCountdown.js.map +1 -0
  261. package/dist/heroes/HeroDarkSplitSticker.d.ts +3 -0
  262. package/dist/heroes/HeroDarkSplitSticker.d.ts.map +1 -0
  263. package/dist/heroes/HeroDarkSplitSticker.js +39 -0
  264. package/dist/heroes/HeroDarkSplitSticker.js.map +1 -0
  265. package/dist/heroes/HeroEditorial.d.ts +3 -0
  266. package/dist/heroes/HeroEditorial.d.ts.map +1 -0
  267. package/dist/heroes/HeroEditorial.js +30 -0
  268. package/dist/heroes/HeroEditorial.js.map +1 -0
  269. package/dist/heroes/HeroEditorialMinimal.d.ts +3 -0
  270. package/dist/heroes/HeroEditorialMinimal.d.ts.map +1 -0
  271. package/dist/heroes/HeroEditorialMinimal.js +47 -0
  272. package/dist/heroes/HeroEditorialMinimal.js.map +1 -0
  273. package/dist/heroes/HeroFullBleed.d.ts +3 -0
  274. package/dist/heroes/HeroFullBleed.d.ts.map +1 -0
  275. package/dist/heroes/HeroFullBleed.js +136 -0
  276. package/dist/heroes/HeroFullBleed.js.map +1 -0
  277. package/dist/heroes/HeroMini.d.ts +3 -0
  278. package/dist/heroes/HeroMini.d.ts.map +1 -0
  279. package/dist/heroes/HeroMini.js +25 -0
  280. package/dist/heroes/HeroMini.js.map +1 -0
  281. package/dist/heroes/HeroParallax.d.ts +3 -0
  282. package/dist/heroes/HeroParallax.d.ts.map +1 -0
  283. package/dist/heroes/HeroParallax.js +71 -0
  284. package/dist/heroes/HeroParallax.js.map +1 -0
  285. package/dist/heroes/HeroRetroCentered.d.ts +3 -0
  286. package/dist/heroes/HeroRetroCentered.d.ts.map +1 -0
  287. package/dist/heroes/HeroRetroCentered.js +49 -0
  288. package/dist/heroes/HeroRetroCentered.js.map +1 -0
  289. package/dist/heroes/HeroSplit.d.ts +3 -0
  290. package/dist/heroes/HeroSplit.d.ts.map +1 -0
  291. package/dist/heroes/HeroSplit.js +81 -0
  292. package/dist/heroes/HeroSplit.js.map +1 -0
  293. package/dist/heroes/HeroSpotlight.d.ts +3 -0
  294. package/dist/heroes/HeroSpotlight.d.ts.map +1 -0
  295. package/dist/heroes/HeroSpotlight.js +60 -0
  296. package/dist/heroes/HeroSpotlight.js.map +1 -0
  297. package/dist/heroes/HeroTrustSplit.d.ts +3 -0
  298. package/dist/heroes/HeroTrustSplit.d.ts.map +1 -0
  299. package/dist/heroes/HeroTrustSplit.js +53 -0
  300. package/dist/heroes/HeroTrustSplit.js.map +1 -0
  301. package/dist/heroes/HeroTypewriter.d.ts +3 -0
  302. package/dist/heroes/HeroTypewriter.d.ts.map +1 -0
  303. package/dist/heroes/HeroTypewriter.js +80 -0
  304. package/dist/heroes/HeroTypewriter.js.map +1 -0
  305. package/dist/heroes/index.d.ts +12 -0
  306. package/dist/heroes/index.d.ts.map +1 -0
  307. package/dist/heroes/index.js +12 -0
  308. package/dist/heroes/index.js.map +1 -0
  309. package/dist/index.d.ts +37 -0
  310. package/dist/index.d.ts.map +1 -0
  311. package/dist/index.js +49 -0
  312. package/dist/index.js.map +1 -0
  313. package/dist/layout/Footer.d.ts +3 -0
  314. package/dist/layout/Footer.d.ts.map +1 -0
  315. package/dist/layout/Footer.js +75 -0
  316. package/dist/layout/Footer.js.map +1 -0
  317. package/dist/layout/Navbar.d.ts +3 -0
  318. package/dist/layout/Navbar.d.ts.map +1 -0
  319. package/dist/layout/Navbar.js +81 -0
  320. package/dist/layout/Navbar.js.map +1 -0
  321. package/dist/layout/PromoTopBar.d.ts +3 -0
  322. package/dist/layout/PromoTopBar.d.ts.map +1 -0
  323. package/dist/layout/PromoTopBar.js +201 -0
  324. package/dist/layout/PromoTopBar.js.map +1 -0
  325. package/dist/layout/SectionDivider.d.ts +3 -0
  326. package/dist/layout/SectionDivider.d.ts.map +1 -0
  327. package/dist/layout/SectionDivider.js +13 -0
  328. package/dist/layout/SectionDivider.js.map +1 -0
  329. package/dist/layout/SectionTransition.d.ts +3 -0
  330. package/dist/layout/SectionTransition.d.ts.map +1 -0
  331. package/dist/layout/SectionTransition.js +60 -0
  332. package/dist/layout/SectionTransition.js.map +1 -0
  333. package/dist/layout/Ticker.d.ts +3 -0
  334. package/dist/layout/Ticker.d.ts.map +1 -0
  335. package/dist/layout/Ticker.js +32 -0
  336. package/dist/layout/Ticker.js.map +1 -0
  337. package/dist/layout/index.d.ts +6 -0
  338. package/dist/layout/index.d.ts.map +1 -0
  339. package/dist/layout/index.js +6 -0
  340. package/dist/layout/index.js.map +1 -0
  341. package/dist/personalization/CartRecovery.d.ts +3 -0
  342. package/dist/personalization/CartRecovery.d.ts.map +1 -0
  343. package/dist/personalization/CartRecovery.js +224 -0
  344. package/dist/personalization/CartRecovery.js.map +1 -0
  345. package/dist/personalization/CohortTrustStack.d.ts +3 -0
  346. package/dist/personalization/CohortTrustStack.d.ts.map +1 -0
  347. package/dist/personalization/CohortTrustStack.js +101 -0
  348. package/dist/personalization/CohortTrustStack.js.map +1 -0
  349. package/dist/personalization/LiveActivityTicker.d.ts +3 -0
  350. package/dist/personalization/LiveActivityTicker.d.ts.map +1 -0
  351. package/dist/personalization/LiveActivityTicker.js +137 -0
  352. package/dist/personalization/LiveActivityTicker.js.map +1 -0
  353. package/dist/personalization/LoyaltyStatus.d.ts +3 -0
  354. package/dist/personalization/LoyaltyStatus.d.ts.map +1 -0
  355. package/dist/personalization/LoyaltyStatus.js +185 -0
  356. package/dist/personalization/LoyaltyStatus.js.map +1 -0
  357. package/dist/personalization/PersonalizedGreeting.d.ts +3 -0
  358. package/dist/personalization/PersonalizedGreeting.d.ts.map +1 -0
  359. package/dist/personalization/PersonalizedGreeting.js +176 -0
  360. package/dist/personalization/PersonalizedGreeting.js.map +1 -0
  361. package/dist/personalization/PersonalizedRecommendations.d.ts +3 -0
  362. package/dist/personalization/PersonalizedRecommendations.d.ts.map +1 -0
  363. package/dist/personalization/PersonalizedRecommendations.js +156 -0
  364. package/dist/personalization/PersonalizedRecommendations.js.map +1 -0
  365. package/dist/personalization/ProgressMilestone.d.ts +3 -0
  366. package/dist/personalization/ProgressMilestone.d.ts.map +1 -0
  367. package/dist/personalization/ProgressMilestone.js +127 -0
  368. package/dist/personalization/ProgressMilestone.js.map +1 -0
  369. package/dist/personalization/ReengagementBanner.d.ts +3 -0
  370. package/dist/personalization/ReengagementBanner.d.ts.map +1 -0
  371. package/dist/personalization/ReengagementBanner.js +185 -0
  372. package/dist/personalization/ReengagementBanner.js.map +1 -0
  373. package/dist/personalization/ScarcityIndicator.d.ts +3 -0
  374. package/dist/personalization/ScarcityIndicator.d.ts.map +1 -0
  375. package/dist/personalization/ScarcityIndicator.js +264 -0
  376. package/dist/personalization/ScarcityIndicator.js.map +1 -0
  377. package/dist/personalization/VipGate.d.ts +3 -0
  378. package/dist/personalization/VipGate.d.ts.map +1 -0
  379. package/dist/personalization/VipGate.js +309 -0
  380. package/dist/personalization/VipGate.js.map +1 -0
  381. package/dist/placeholder/UnknownComponent.d.ts +6 -0
  382. package/dist/placeholder/UnknownComponent.d.ts.map +1 -0
  383. package/dist/placeholder/UnknownComponent.js +5 -0
  384. package/dist/placeholder/UnknownComponent.js.map +1 -0
  385. package/dist/pricing/PricingCards.d.ts +3 -0
  386. package/dist/pricing/PricingCards.d.ts.map +1 -0
  387. package/dist/pricing/PricingCards.js +143 -0
  388. package/dist/pricing/PricingCards.js.map +1 -0
  389. package/dist/primitives/AspectBox.d.ts +12 -0
  390. package/dist/primitives/AspectBox.d.ts.map +1 -0
  391. package/dist/primitives/AspectBox.js +15 -0
  392. package/dist/primitives/AspectBox.js.map +1 -0
  393. package/dist/primitives/CursorSpotlight.d.ts +11 -0
  394. package/dist/primitives/CursorSpotlight.d.ts.map +1 -0
  395. package/dist/primitives/CursorSpotlight.js +21 -0
  396. package/dist/primitives/CursorSpotlight.js.map +1 -0
  397. package/dist/primitives/HeadlineEffect.d.ts +16 -0
  398. package/dist/primitives/HeadlineEffect.d.ts.map +1 -0
  399. package/dist/primitives/HeadlineEffect.js +187 -0
  400. package/dist/primitives/HeadlineEffect.js.map +1 -0
  401. package/dist/primitives/Marquee.d.ts +11 -0
  402. package/dist/primitives/Marquee.d.ts.map +1 -0
  403. package/dist/primitives/Marquee.js +22 -0
  404. package/dist/primitives/Marquee.js.map +1 -0
  405. package/dist/primitives/MediaFlip.d.ts +16 -0
  406. package/dist/primitives/MediaFlip.d.ts.map +1 -0
  407. package/dist/primitives/MediaFlip.js +118 -0
  408. package/dist/primitives/MediaFlip.js.map +1 -0
  409. package/dist/primitives/MediaLoop.d.ts +15 -0
  410. package/dist/primitives/MediaLoop.d.ts.map +1 -0
  411. package/dist/primitives/MediaLoop.js +31 -0
  412. package/dist/primitives/MediaLoop.js.map +1 -0
  413. package/dist/primitives/PDPGallery.d.ts +24 -0
  414. package/dist/primitives/PDPGallery.d.ts.map +1 -0
  415. package/dist/primitives/PDPGallery.js +128 -0
  416. package/dist/primitives/PDPGallery.js.map +1 -0
  417. package/dist/primitives/TiltCard.d.ts +12 -0
  418. package/dist/primitives/TiltCard.d.ts.map +1 -0
  419. package/dist/primitives/TiltCard.js +41 -0
  420. package/dist/primitives/TiltCard.js.map +1 -0
  421. package/dist/product/BundleBuilder.d.ts +3 -0
  422. package/dist/product/BundleBuilder.d.ts.map +1 -0
  423. package/dist/product/BundleBuilder.js +34 -0
  424. package/dist/product/BundleBuilder.js.map +1 -0
  425. package/dist/product/BuyBox.d.ts +3 -0
  426. package/dist/product/BuyBox.d.ts.map +1 -0
  427. package/dist/product/BuyBox.js +398 -0
  428. package/dist/product/BuyBox.js.map +1 -0
  429. package/dist/product/ComparisonTable.d.ts +3 -0
  430. package/dist/product/ComparisonTable.d.ts.map +1 -0
  431. package/dist/product/ComparisonTable.js +59 -0
  432. package/dist/product/ComparisonTable.js.map +1 -0
  433. package/dist/product/FormatGrid.d.ts +3 -0
  434. package/dist/product/FormatGrid.d.ts.map +1 -0
  435. package/dist/product/FormatGrid.js +28 -0
  436. package/dist/product/FormatGrid.js.map +1 -0
  437. package/dist/product/PDPVariants.d.ts +3 -0
  438. package/dist/product/PDPVariants.d.ts.map +1 -0
  439. package/dist/product/PDPVariants.js +284 -0
  440. package/dist/product/PDPVariants.js.map +1 -0
  441. package/dist/product/PillNav.d.ts +3 -0
  442. package/dist/product/PillNav.d.ts.map +1 -0
  443. package/dist/product/PillNav.js +35 -0
  444. package/dist/product/PillNav.js.map +1 -0
  445. package/dist/product/ProductAccordion.d.ts +3 -0
  446. package/dist/product/ProductAccordion.d.ts.map +1 -0
  447. package/dist/product/ProductAccordion.js +46 -0
  448. package/dist/product/ProductAccordion.js.map +1 -0
  449. package/dist/product/ProductCard.d.ts +62 -0
  450. package/dist/product/ProductCard.d.ts.map +1 -0
  451. package/dist/product/ProductCard.js +442 -0
  452. package/dist/product/ProductCard.js.map +1 -0
  453. package/dist/product/ProductCarousel.d.ts +3 -0
  454. package/dist/product/ProductCarousel.d.ts.map +1 -0
  455. package/dist/product/ProductCarousel.js +123 -0
  456. package/dist/product/ProductCarousel.js.map +1 -0
  457. package/dist/product/ProductCenteredStack.d.ts +3 -0
  458. package/dist/product/ProductCenteredStack.d.ts.map +1 -0
  459. package/dist/product/ProductCenteredStack.js +28 -0
  460. package/dist/product/ProductCenteredStack.js.map +1 -0
  461. package/dist/product/ProductGallery.d.ts +3 -0
  462. package/dist/product/ProductGallery.d.ts.map +1 -0
  463. package/dist/product/ProductGallery.js +80 -0
  464. package/dist/product/ProductGallery.js.map +1 -0
  465. package/dist/product/ProductGrid.d.ts +3 -0
  466. package/dist/product/ProductGrid.d.ts.map +1 -0
  467. package/dist/product/ProductGrid.js +58 -0
  468. package/dist/product/ProductGrid.js.map +1 -0
  469. package/dist/product/ProductHighlightLeft.d.ts +3 -0
  470. package/dist/product/ProductHighlightLeft.d.ts.map +1 -0
  471. package/dist/product/ProductHighlightLeft.js +37 -0
  472. package/dist/product/ProductHighlightLeft.js.map +1 -0
  473. package/dist/product/ProductHighlightRight.d.ts +3 -0
  474. package/dist/product/ProductHighlightRight.d.ts.map +1 -0
  475. package/dist/product/ProductHighlightRight.js +23 -0
  476. package/dist/product/ProductHighlightRight.js.map +1 -0
  477. package/dist/product/ProductPage.d.ts +3 -0
  478. package/dist/product/ProductPage.d.ts.map +1 -0
  479. package/dist/product/ProductPage.js +105 -0
  480. package/dist/product/ProductPage.js.map +1 -0
  481. package/dist/product/SubscriptionToggle.d.ts +3 -0
  482. package/dist/product/SubscriptionToggle.d.ts.map +1 -0
  483. package/dist/product/SubscriptionToggle.js +38 -0
  484. package/dist/product/SubscriptionToggle.js.map +1 -0
  485. package/dist/product/Upsell.d.ts +3 -0
  486. package/dist/product/Upsell.d.ts.map +1 -0
  487. package/dist/product/Upsell.js +59 -0
  488. package/dist/product/Upsell.js.map +1 -0
  489. package/dist/product/VideoCarousel.d.ts +3 -0
  490. package/dist/product/VideoCarousel.d.ts.map +1 -0
  491. package/dist/product/VideoCarousel.js +188 -0
  492. package/dist/product/VideoCarousel.js.map +1 -0
  493. package/dist/product/index.d.ts +8 -0
  494. package/dist/product/index.d.ts.map +1 -0
  495. package/dist/product/index.js +8 -0
  496. package/dist/product/index.js.map +1 -0
  497. package/dist/registry-field-schemas.d.ts +66 -0
  498. package/dist/registry-field-schemas.d.ts.map +1 -0
  499. package/dist/registry-field-schemas.js +745 -0
  500. package/dist/registry-field-schemas.js.map +1 -0
  501. package/dist/registry-metadata.d.ts +10 -0
  502. package/dist/registry-metadata.d.ts.map +1 -0
  503. package/dist/registry-metadata.js +2 -0
  504. package/dist/registry-metadata.js.map +1 -0
  505. package/dist/registry.d.ts +20 -0
  506. package/dist/registry.d.ts.map +1 -0
  507. package/dist/registry.js +2317 -0
  508. package/dist/registry.js.map +1 -0
  509. package/dist/renderText.d.ts +6 -0
  510. package/dist/renderText.d.ts.map +1 -0
  511. package/dist/renderText.js +23 -0
  512. package/dist/renderText.js.map +1 -0
  513. package/dist/reviews/ReviewCarousel.d.ts +3 -0
  514. package/dist/reviews/ReviewCarousel.d.ts.map +1 -0
  515. package/dist/reviews/ReviewCarousel.js +24 -0
  516. package/dist/reviews/ReviewCarousel.js.map +1 -0
  517. package/dist/reviews/ReviewMasonry.d.ts +3 -0
  518. package/dist/reviews/ReviewMasonry.d.ts.map +1 -0
  519. package/dist/reviews/ReviewMasonry.js +25 -0
  520. package/dist/reviews/ReviewMasonry.js.map +1 -0
  521. package/dist/reviews/ReviewSpotlight.d.ts +3 -0
  522. package/dist/reviews/ReviewSpotlight.d.ts.map +1 -0
  523. package/dist/reviews/ReviewSpotlight.js +13 -0
  524. package/dist/reviews/ReviewSpotlight.js.map +1 -0
  525. package/dist/reviews/VideoTestimonials.d.ts +3 -0
  526. package/dist/reviews/VideoTestimonials.d.ts.map +1 -0
  527. package/dist/reviews/VideoTestimonials.js +35 -0
  528. package/dist/reviews/VideoTestimonials.js.map +1 -0
  529. package/dist/reviews/index.d.ts +4 -0
  530. package/dist/reviews/index.d.ts.map +1 -0
  531. package/dist/reviews/index.js +4 -0
  532. package/dist/reviews/index.js.map +1 -0
  533. package/dist/schemas/content.d.ts +125 -0
  534. package/dist/schemas/content.d.ts.map +1 -0
  535. package/dist/schemas/content.js +2 -0
  536. package/dist/schemas/content.js.map +1 -0
  537. package/dist/schemas/index.d.ts +3 -0
  538. package/dist/schemas/index.d.ts.map +1 -0
  539. package/dist/schemas/index.js +2 -0
  540. package/dist/schemas/index.js.map +1 -0
  541. package/dist/schemas/settings.d.ts +23 -0
  542. package/dist/schemas/settings.d.ts.map +1 -0
  543. package/dist/schemas/settings.js +321 -0
  544. package/dist/schemas/settings.js.map +1 -0
  545. package/dist/social-proof/AvatarGroup.d.ts +3 -0
  546. package/dist/social-proof/AvatarGroup.d.ts.map +1 -0
  547. package/dist/social-proof/AvatarGroup.js +58 -0
  548. package/dist/social-proof/AvatarGroup.js.map +1 -0
  549. package/dist/social-proof/LogoCarousel.d.ts +3 -0
  550. package/dist/social-proof/LogoCarousel.d.ts.map +1 -0
  551. package/dist/social-proof/LogoCarousel.js +49 -0
  552. package/dist/social-proof/LogoCarousel.js.map +1 -0
  553. package/dist/social-proof/LogoStrip.d.ts +3 -0
  554. package/dist/social-proof/LogoStrip.d.ts.map +1 -0
  555. package/dist/social-proof/LogoStrip.js +35 -0
  556. package/dist/social-proof/LogoStrip.js.map +1 -0
  557. package/dist/social-proof/PressMentions.d.ts +3 -0
  558. package/dist/social-proof/PressMentions.d.ts.map +1 -0
  559. package/dist/social-proof/PressMentions.js +40 -0
  560. package/dist/social-proof/PressMentions.js.map +1 -0
  561. package/dist/social-proof/StatsGrid.d.ts +3 -0
  562. package/dist/social-proof/StatsGrid.d.ts.map +1 -0
  563. package/dist/social-proof/StatsGrid.js +39 -0
  564. package/dist/social-proof/StatsGrid.js.map +1 -0
  565. package/dist/social-proof/TrustBadges.d.ts +3 -0
  566. package/dist/social-proof/TrustBadges.d.ts.map +1 -0
  567. package/dist/social-proof/TrustBadges.js +18 -0
  568. package/dist/social-proof/TrustBadges.js.map +1 -0
  569. package/dist/social-proof/index.d.ts +4 -0
  570. package/dist/social-proof/index.d.ts.map +1 -0
  571. package/dist/social-proof/index.js +4 -0
  572. package/dist/social-proof/index.js.map +1 -0
  573. package/dist/text-effects/TextEffect.d.ts +3 -0
  574. package/dist/text-effects/TextEffect.d.ts.map +1 -0
  575. package/dist/text-effects/TextEffect.js +277 -0
  576. package/dist/text-effects/TextEffect.js.map +1 -0
  577. package/dist/theme/resolve.d.ts +12 -0
  578. package/dist/theme/resolve.d.ts.map +1 -0
  579. package/dist/theme/resolve.js +26 -0
  580. package/dist/theme/resolve.js.map +1 -0
  581. package/dist/theme/tokens.d.ts +147 -0
  582. package/dist/theme/tokens.d.ts.map +1 -0
  583. package/dist/theme/tokens.js +113 -0
  584. package/dist/theme/tokens.js.map +1 -0
  585. package/dist/types.d.ts +154 -0
  586. package/dist/types.d.ts.map +1 -0
  587. package/dist/types.js +2 -0
  588. package/dist/types.js.map +1 -0
  589. package/dist/utils/elementStyles.d.ts +4 -0
  590. package/dist/utils/elementStyles.d.ts.map +1 -0
  591. package/dist/utils/elementStyles.js +6 -0
  592. package/dist/utils/elementStyles.js.map +1 -0
  593. package/dist/utils/icon-map.d.ts +128 -0
  594. package/dist/utils/icon-map.d.ts.map +1 -0
  595. package/dist/utils/icon-map.js +199 -0
  596. package/dist/utils/icon-map.js.map +1 -0
  597. package/dist/utils/imageStyle.d.ts +4 -0
  598. package/dist/utils/imageStyle.d.ts.map +1 -0
  599. package/dist/utils/imageStyle.js +23 -0
  600. package/dist/utils/imageStyle.js.map +1 -0
  601. package/dist/utils/renderIcon.d.ts +32 -0
  602. package/dist/utils/renderIcon.d.ts.map +1 -0
  603. package/dist/utils/renderIcon.js +188 -0
  604. package/dist/utils/renderIcon.js.map +1 -0
  605. package/dist/utils/schemaUtils.d.ts +9 -0
  606. package/dist/utils/schemaUtils.d.ts.map +1 -0
  607. package/dist/utils/schemaUtils.js +10 -0
  608. package/dist/utils/schemaUtils.js.map +1 -0
  609. package/dist/value-props/HowItWorks.d.ts +3 -0
  610. package/dist/value-props/HowItWorks.d.ts.map +1 -0
  611. package/dist/value-props/HowItWorks.js +23 -0
  612. package/dist/value-props/HowItWorks.js.map +1 -0
  613. package/dist/value-props/NumberedList.d.ts +3 -0
  614. package/dist/value-props/NumberedList.d.ts.map +1 -0
  615. package/dist/value-props/NumberedList.js +22 -0
  616. package/dist/value-props/NumberedList.js.map +1 -0
  617. package/dist/value-props/ValuePropsAlternating.d.ts +3 -0
  618. package/dist/value-props/ValuePropsAlternating.d.ts.map +1 -0
  619. package/dist/value-props/ValuePropsAlternating.js +22 -0
  620. package/dist/value-props/ValuePropsAlternating.js.map +1 -0
  621. package/dist/value-props/ValuePropsGrid.d.ts +3 -0
  622. package/dist/value-props/ValuePropsGrid.d.ts.map +1 -0
  623. package/dist/value-props/ValuePropsGrid.js +23 -0
  624. package/dist/value-props/ValuePropsGrid.js.map +1 -0
  625. package/dist/value-props/ValuePropsIconStrip.d.ts +3 -0
  626. package/dist/value-props/ValuePropsIconStrip.d.ts.map +1 -0
  627. package/dist/value-props/ValuePropsIconStrip.js +11 -0
  628. package/dist/value-props/ValuePropsIconStrip.js.map +1 -0
  629. package/dist/value-props/index.d.ts +6 -0
  630. package/dist/value-props/index.d.ts.map +1 -0
  631. package/dist/value-props/index.js +6 -0
  632. package/dist/value-props/index.js.map +1 -0
  633. 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"}