@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,2317 @@
1
+ import { lazy } from "react";
2
+ import { HERO_CENTERED_FIELDS, HERO_SPLIT_FIELDS, HERO_FULLBLEED_FIELDS, HERO_CAROUSEL_FIELDS, HERO_EDITORIAL_FIELDS, HERO_COUNTDOWN_FIELDS, HERO_TYPEWRITER_FIELDS, HERO_PARALLAX_FIELDS, HERO_ANIMATED_FIELDS, HERO_SPOTLIGHT_FIELDS, HERO_AURORA_FIELDS, HERO_ACTIVITY_FIELDS, HERO_MINI_FIELDS, HERO_PRODUCT_BREAKOUT_FIELDS, CTA_FULLWIDTH_FIELDS, CTA_STICKY_FIELDS, NEWSLETTER_FIELDS, FAQ_FIELDS, REVIEWS_FIELDS, FEATURE_GRID_FIELDS, VALUE_PROPS_FIELDS, GUARANTEE_FIELDS, TESTIMONIAL_CARD_FIELDS, CONTENT_RICH_FIELDS, CONTENT_IMAGE_TEXT_FIELDS, BEFORE_AFTER_FIELDS, FEATURED_CARD_FIELDS, PRODUCT_CARD_FIELDS, STATS_FIELDS, LOGO_CAROUSEL_FIELDS, POPUP_FIELDS, TRANSITION_FIELDS, TEXT_EFFECT_FIELDS, BUTTON_SECTION_FIELDS, URGENCY_CTA_FIELDS, WAITLIST_FIELDS, AVATAR_GROUP_FIELDS, PARALLAX_FIELDS, PROCESS_STEPS_FIELDS, BACKGROUND_SECTION_FIELDS, CARD_STACK_FIELDS, TERMINAL_FIELDS, FEATURE_TABS_FIELDS, BENTO_FIELDS, LOOKBOOK_GRID_FIELDS, PRICING_FIELDS, NAVBAR_FIELDS, FOOTER_FIELDS, PROMOBAR_FIELDS, PROMOBAR_MULTI_FIELDS, PROMOBAR_ROTATING_FIELDS, PROMOBAR_COUNTDOWN_FIELDS, TICKER_FIELDS, CART_GUARANTEE_FIELDS, HERO_EDITORIAL_MINIMAL_FIELDS, HERO_DARK_STICKER_FIELDS, HERO_RETRO_FIELDS, HERO_TRUST_FIELDS, HERO_CINEMATIC_FIELDS, LIVE_ACTIVITY_TICKER_FIELDS, CART_DRAWER_FIELDS, } from "./registry-field-schemas";
3
+ export const COMPONENT_REGISTRY = {
4
+ // ─── Heroes ───────────────────────────────────────────────────────────
5
+ lx_hero: {
6
+ category: "hero",
7
+ defaultVariant: "centered",
8
+ variants: {
9
+ centered: {
10
+ component: lazy(() => import("./heroes/HeroCentered")),
11
+ requiredContent: ["headline", "cta_text"],
12
+ optionalContent: ["subhead", "eyebrow", "media_url", "rating"],
13
+ fields: HERO_CENTERED_FIELDS,
14
+ supportedSettings: ["min_height", "overlay_strength"],
15
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now" },
16
+ variantGroup: "hero_centered",
17
+ },
18
+ split: {
19
+ component: lazy(() => import("./heroes/HeroSplit")),
20
+ requiredContent: ["headline", "cta_text", "media_url"],
21
+ optionalContent: ["subhead", "eyebrow", "pills"],
22
+ fields: HERO_SPLIT_FIELDS,
23
+ supportedSettings: ["min_height", "image_corner_radius", "overlay_strength"],
24
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
25
+ variantGroup: "hero_split",
26
+ },
27
+ right_text: {
28
+ component: lazy(() => import("./heroes/HeroSplit")),
29
+ requiredContent: ["headline", "cta_text", "media_url"],
30
+ optionalContent: ["subhead", "eyebrow"],
31
+ fields: HERO_SPLIT_FIELDS,
32
+ supportedSettings: ["min_height", "image_corner_radius", "overlay_strength"],
33
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
34
+ variantGroup: "hero_split",
35
+ },
36
+ overlap: {
37
+ component: lazy(() => import("./heroes/HeroSplit")),
38
+ requiredContent: ["headline", "cta_text", "media_url"],
39
+ optionalContent: ["subhead", "eyebrow"],
40
+ fields: HERO_SPLIT_FIELDS,
41
+ supportedSettings: ["min_height", "image_corner_radius"],
42
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
43
+ variantGroup: "hero_split",
44
+ },
45
+ with_pills: {
46
+ component: lazy(() => import("./heroes/HeroSplit")),
47
+ requiredContent: ["headline", "cta_text", "media_url", "pills"],
48
+ optionalContent: ["subhead", "eyebrow"],
49
+ fields: HERO_SPLIT_FIELDS,
50
+ supportedSettings: ["min_height", "image_corner_radius"],
51
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", pills: [] },
52
+ variantGroup: "hero_split",
53
+ },
54
+ full_bleed: {
55
+ component: lazy(() => import("./heroes/HeroFullBleed")),
56
+ requiredContent: ["headline", "cta_text", "bg_media_url"],
57
+ optionalContent: ["subhead"],
58
+ fields: HERO_FULLBLEED_FIELDS,
59
+ supportedSettings: ["min_height", "overlay_strength"],
60
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1522337360788-8b13dee7a37e?w=1600&q=80" },
61
+ variantGroup: "hero_fullbleed",
62
+ },
63
+ editorial: {
64
+ component: lazy(() => import("./heroes/HeroEditorial")),
65
+ requiredContent: ["headline", "cta_text"],
66
+ optionalContent: ["subhead", "category_tag", "byline", "media_url"],
67
+ fields: HERO_EDITORIAL_FIELDS,
68
+ supportedSettings: ["min_height"],
69
+ defaultContent: { headline: "Your headline here", cta_text: "Read More" },
70
+ variantGroup: "hero_editorial",
71
+ },
72
+ mini: {
73
+ component: lazy(() => import("./heroes/HeroMini")),
74
+ requiredContent: ["headline"],
75
+ optionalContent: ["subhead", "cta_text"],
76
+ fields: HERO_MINI_FIELDS,
77
+ supportedSettings: [],
78
+ defaultContent: { headline: "All Products" },
79
+ variantGroup: "hero_mini",
80
+ },
81
+ countdown: {
82
+ component: lazy(() => import("./heroes/HeroCountdown")),
83
+ requiredContent: ["headline", "cta_text", "countdown_end"],
84
+ optionalContent: ["subhead", "eyebrow", "media_url", "urgency_text"],
85
+ fields: HERO_COUNTDOWN_FIELDS,
86
+ supportedSettings: [],
87
+ defaultContent: { headline: "Sale ends soon", cta_text: "Shop Now" },
88
+ variantGroup: "hero_countdown",
89
+ },
90
+ with_urgency: {
91
+ component: lazy(() => import("./heroes/HeroCountdown")),
92
+ requiredContent: ["headline", "cta_text", "countdown_end"],
93
+ optionalContent: ["subhead", "eyebrow", "media_url"],
94
+ fields: HERO_COUNTDOWN_FIELDS,
95
+ supportedSettings: [],
96
+ defaultContent: { headline: "Hurry, offer ends soon", cta_text: "Claim Now" },
97
+ variantGroup: "hero_countdown",
98
+ },
99
+ typewriter: {
100
+ component: lazy(() => import("./heroes/HeroTypewriter")),
101
+ requiredContent: ["headline_prefix", "rotating_words", "cta_text"],
102
+ optionalContent: ["subhead", "eyebrow", "media_url"],
103
+ fields: HERO_TYPEWRITER_FIELDS,
104
+ supportedSettings: [],
105
+ defaultContent: { headline_prefix: "Skin that is", rotating_words: ["Radiant", "Glowing"], cta_text: "Shop Now" },
106
+ variantGroup: "hero_animated",
107
+ },
108
+ // HeroCentered extended variants
109
+ with_rating: {
110
+ component: lazy(() => import("./heroes/HeroCentered")),
111
+ requiredContent: ["headline", "cta_text", "rating"],
112
+ optionalContent: ["subhead", "eyebrow", "media_url", "review_count"],
113
+ fields: HERO_CENTERED_FIELDS,
114
+ supportedSettings: ["min_height", "overlay_strength"],
115
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", rating: 4.9 },
116
+ variantGroup: "hero_centered",
117
+ },
118
+ gradient_overlay: {
119
+ component: lazy(() => import("./heroes/HeroCentered")),
120
+ requiredContent: ["headline", "cta_text"],
121
+ optionalContent: ["subhead", "eyebrow", "media_url"],
122
+ fields: HERO_CENTERED_FIELDS,
123
+ supportedSettings: ["min_height", "overlay_strength"],
124
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now" },
125
+ variantGroup: "hero_centered",
126
+ },
127
+ full_bleed_centered: {
128
+ component: lazy(() => import("./heroes/HeroCentered")),
129
+ requiredContent: ["headline", "cta_text", "media_url"],
130
+ optionalContent: ["subhead", "eyebrow"],
131
+ fields: HERO_CENTERED_FIELDS,
132
+ supportedSettings: ["min_height", "overlay_strength"],
133
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now" },
134
+ variantGroup: "hero_centered",
135
+ },
136
+ bg_carousel: {
137
+ component: lazy(() => import("./heroes/HeroCentered")),
138
+ requiredContent: ["headline", "cta_text", "media_urls"],
139
+ optionalContent: ["subhead", "eyebrow"],
140
+ fields: HERO_CENTERED_FIELDS,
141
+ supportedSettings: ["min_height", "overlay_strength"],
142
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", media_urls: [] },
143
+ variantGroup: "hero_centered",
144
+ },
145
+ // HeroSplit extended variants
146
+ split_video: {
147
+ component: lazy(() => import("./heroes/HeroSplit")),
148
+ requiredContent: ["headline", "cta_text", "media_url"],
149
+ optionalContent: ["subhead", "eyebrow"],
150
+ fields: { ...HERO_SPLIT_FIELDS, media_url: { type: "video", required: true, label: "Video" } },
151
+ supportedSettings: ["min_height"],
152
+ defaultContent: { headline: "Your headline here", cta_text: "Watch Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
153
+ variantGroup: "hero_split",
154
+ },
155
+ parallax_split: {
156
+ component: lazy(() => import("./heroes/HeroSplit")),
157
+ requiredContent: ["headline", "cta_text", "media_url"],
158
+ optionalContent: ["subhead", "eyebrow"],
159
+ fields: HERO_SPLIT_FIELDS,
160
+ supportedSettings: ["min_height", "image_corner_radius"],
161
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
162
+ variantGroup: "hero_split",
163
+ },
164
+ // HeroFullBleed extended variants
165
+ dark_overlay: {
166
+ component: lazy(() => import("./heroes/HeroFullBleed")),
167
+ requiredContent: ["headline", "cta_text", "bg_media_url"],
168
+ optionalContent: ["subhead"],
169
+ fields: HERO_FULLBLEED_FIELDS,
170
+ supportedSettings: ["min_height", "overlay_strength"],
171
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1522337360788-8b13dee7a37e?w=1600&q=80" },
172
+ variantGroup: "hero_fullbleed",
173
+ },
174
+ full_bleed_gradient: {
175
+ component: lazy(() => import("./heroes/HeroFullBleed")),
176
+ requiredContent: ["headline", "cta_text", "bg_media_url"],
177
+ optionalContent: ["subhead"],
178
+ fields: HERO_FULLBLEED_FIELDS,
179
+ supportedSettings: ["min_height", "overlay_strength"],
180
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1522337360788-8b13dee7a37e?w=1600&q=80" },
181
+ variantGroup: "hero_fullbleed",
182
+ },
183
+ // HeroParallax variants
184
+ parallax_scroll: {
185
+ component: lazy(() => import("./heroes/HeroParallax")),
186
+ requiredContent: ["headline", "cta_text", "bg_media_url"],
187
+ optionalContent: ["subhead", "eyebrow"],
188
+ fields: HERO_PARALLAX_FIELDS,
189
+ supportedSettings: ["min_height", "overlay_strength"],
190
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1526045431048-f857369baa09?w=1600&q=80" },
191
+ variantGroup: "hero_fullbleed",
192
+ },
193
+ zoom_on_scroll: {
194
+ component: lazy(() => import("./heroes/HeroParallax")),
195
+ requiredContent: ["headline", "cta_text", "bg_media_url"],
196
+ optionalContent: ["subhead", "eyebrow"],
197
+ fields: HERO_PARALLAX_FIELDS,
198
+ supportedSettings: ["min_height", "overlay_strength"],
199
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1526045431048-f857369baa09?w=1600&q=80" },
200
+ variantGroup: "hero_fullbleed",
201
+ },
202
+ tilt_3d: {
203
+ component: lazy(() => import("./heroes/HeroParallax")),
204
+ requiredContent: ["headline", "cta_text"],
205
+ optionalContent: ["subhead", "eyebrow", "bg_media_url"],
206
+ fields: HERO_PARALLAX_FIELDS,
207
+ supportedSettings: ["min_height"],
208
+ defaultContent: { headline: "Hover to feel the difference", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1526045431048-f857369baa09?w=1600&q=80" },
209
+ variantGroup: "hero_fullbleed",
210
+ },
211
+ layered: {
212
+ component: lazy(() => import("./heroes/HeroParallax")),
213
+ requiredContent: ["headline", "cta_text", "bg_media_url"],
214
+ optionalContent: ["subhead", "eyebrow"],
215
+ fields: HERO_PARALLAX_FIELDS,
216
+ supportedSettings: ["min_height", "overlay_strength"],
217
+ defaultContent: { headline: "Your headline here", cta_text: "Shop Now", bg_media_url: "https://images.unsplash.com/photo-1526045431048-f857369baa09?w=1600&q=80" },
218
+ variantGroup: "hero_fullbleed",
219
+ },
220
+ // HeroAnimated variants
221
+ rotating_text: {
222
+ component: lazy(() => import("./heroes/HeroAnimated")),
223
+ requiredContent: ["rotating_words", "cta_text"],
224
+ optionalContent: ["headline_prefix", "subhead", "eyebrow"],
225
+ fields: HERO_ANIMATED_FIELDS,
226
+ supportedSettings: [],
227
+ defaultContent: { headline_prefix: "Formulated for", rotating_words: ["Dry Skin", "Oily Skin"], cta_text: "Find My Match" },
228
+ variantGroup: "hero_animated",
229
+ },
230
+ glitch: {
231
+ component: lazy(() => import("./heroes/HeroAnimated")),
232
+ requiredContent: ["headline", "cta_text"],
233
+ optionalContent: ["subhead", "eyebrow"],
234
+ fields: HERO_ANIMATED_FIELDS,
235
+ supportedSettings: [],
236
+ defaultContent: { headline: "BREAK THE ROUTINE", cta_text: "Shop Now" },
237
+ variantGroup: "hero_animated",
238
+ },
239
+ flip_words: {
240
+ component: lazy(() => import("./heroes/HeroAnimated")),
241
+ requiredContent: ["rotating_words", "cta_text"],
242
+ optionalContent: ["headline_prefix", "subhead", "eyebrow"],
243
+ fields: HERO_ANIMATED_FIELDS,
244
+ supportedSettings: [],
245
+ defaultContent: { headline_prefix: "Your skin deserves", rotating_words: ["Better", "Clarity"], cta_text: "Shop Now" },
246
+ variantGroup: "hero_animated",
247
+ },
248
+ // HeroSpotlight variants
249
+ spotlight_single: {
250
+ component: lazy(() => import("./heroes/HeroSpotlight")),
251
+ requiredContent: ["headline", "cta_text"],
252
+ optionalContent: ["subhead", "eyebrow", "media_url"],
253
+ fields: HERO_SPOTLIGHT_FIELDS,
254
+ supportedSettings: ["min_height", "image_corner_radius"],
255
+ defaultContent: { headline: "Featured Product", cta_text: "Shop Now" },
256
+ variantGroup: "hero_spotlight",
257
+ },
258
+ spotlight_multi: {
259
+ component: lazy(() => import("./heroes/HeroSpotlight")),
260
+ requiredContent: ["headline", "cta_text"],
261
+ optionalContent: ["subhead", "eyebrow", "media_url", "cards"],
262
+ fields: HERO_SPOTLIGHT_FIELDS,
263
+ supportedSettings: [],
264
+ defaultContent: { headline: "Our bestselling trio", cta_text: "Shop All", cards: [] },
265
+ variantGroup: "hero_spotlight",
266
+ },
267
+ // HeroAurora variants
268
+ aurora_wave: {
269
+ component: lazy(() => import("./heroes/HeroAurora")),
270
+ requiredContent: ["headline", "cta_text"],
271
+ optionalContent: ["subhead", "eyebrow"],
272
+ fields: HERO_AURORA_FIELDS,
273
+ supportedSettings: [],
274
+ defaultContent: { headline: "Aurora-inspired luminosity", cta_text: "Explore" },
275
+ variantGroup: "hero_aurora",
276
+ },
277
+ aurora_static: {
278
+ component: lazy(() => import("./heroes/HeroAurora")),
279
+ requiredContent: ["headline", "cta_text"],
280
+ optionalContent: ["subhead", "eyebrow"],
281
+ fields: HERO_AURORA_FIELDS,
282
+ supportedSettings: [],
283
+ defaultContent: { headline: "Still waters run deep", cta_text: "Shop Sensitive Range" },
284
+ variantGroup: "hero_aurora",
285
+ },
286
+ // HeroActivity variants
287
+ recent_orders: {
288
+ component: lazy(() => import("./heroes/HeroActivity")),
289
+ requiredContent: ["headline", "cta_text"],
290
+ optionalContent: ["subhead", "eyebrow", "media_url", "activity_items"],
291
+ fields: HERO_ACTIVITY_FIELDS,
292
+ supportedSettings: [],
293
+ defaultContent: { headline: "Join the ritual", cta_text: "Shop Bestsellers" },
294
+ variantGroup: "hero_activity",
295
+ },
296
+ live_viewers: {
297
+ component: lazy(() => import("./heroes/HeroActivity")),
298
+ requiredContent: ["headline", "cta_text"],
299
+ optionalContent: ["subhead", "eyebrow", "media_url", "live_count"],
300
+ fields: HERO_ACTIVITY_FIELDS,
301
+ supportedSettings: [],
302
+ defaultContent: { headline: "Everyone's watching this one", cta_text: "Shop Now", live_count: 247 },
303
+ variantGroup: "hero_activity",
304
+ },
305
+ stock_level: {
306
+ component: lazy(() => import("./heroes/HeroActivity")),
307
+ requiredContent: ["headline", "cta_text"],
308
+ optionalContent: ["subhead", "eyebrow", "media_url", "stock_level", "stock_max"],
309
+ fields: HERO_ACTIVITY_FIELDS,
310
+ supportedSettings: [],
311
+ defaultContent: { headline: "Last batch of the season", cta_text: "Secure Mine Now", stock_level: 23, stock_max: 100 },
312
+ variantGroup: "hero_activity",
313
+ },
314
+ // HeroCarousel variants
315
+ slideshow: {
316
+ component: lazy(() => import("./heroes/HeroCarousel")),
317
+ requiredContent: ["slides"],
318
+ optionalContent: ["headline", "cta_text"],
319
+ fields: HERO_CAROUSEL_FIELDS,
320
+ supportedSettings: ["min_height", "overlay_strength"],
321
+ defaultContent: { slides: [] },
322
+ variantGroup: "hero_carousel",
323
+ },
324
+ crossfade: {
325
+ component: lazy(() => import("./heroes/HeroCarousel")),
326
+ requiredContent: ["slides"],
327
+ optionalContent: [],
328
+ fields: HERO_CAROUSEL_FIELDS,
329
+ supportedSettings: ["min_height", "overlay_strength"],
330
+ defaultContent: { slides: [] },
331
+ variantGroup: "hero_carousel",
332
+ },
333
+ split_carousel: {
334
+ component: lazy(() => import("./heroes/HeroCarousel")),
335
+ requiredContent: ["headline", "cta_text", "slides"],
336
+ optionalContent: ["subhead", "eyebrow"],
337
+ fields: HERO_CAROUSEL_FIELDS,
338
+ supportedSettings: ["min_height", "image_corner_radius"],
339
+ defaultContent: { headline: "Our bestselling collection", cta_text: "Shop All", slides: [] },
340
+ variantGroup: "hero_carousel",
341
+ },
342
+ ken_burns: {
343
+ component: lazy(() => import("./heroes/HeroCarousel")),
344
+ requiredContent: ["headline", "cta_text"],
345
+ optionalContent: ["bg_media_url", "media_url", "subhead", "eyebrow"],
346
+ fields: HERO_CAROUSEL_FIELDS,
347
+ supportedSettings: ["min_height"],
348
+ defaultContent: { headline: "Beauty in slow motion", cta_text: "Begin Your Ritual", bg_media_url: "https://images.unsplash.com/photo-1526045431048-f857369baa09?w=1600&q=80" },
349
+ variantGroup: "hero_carousel",
350
+ },
351
+ // Product breakout hero
352
+ product_breakout: {
353
+ component: lazy(() => import("./heroes/HeroFullBleed")),
354
+ requiredContent: ["headline", "product_image_url"],
355
+ optionalContent: ["product_name", "cta_text", "social_proof", "features", "price", "compare_price", "bg_color", "tagline"],
356
+ fields: HERO_PRODUCT_BREAKOUT_FIELDS,
357
+ supportedSettings: [],
358
+ defaultContent: { headline: "The hero product", cta_text: "Shop Now", product_image_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
359
+ variantGroup: "hero_product",
360
+ },
361
+ // ─── Brand-template variants ────────────────────────────────────────────
362
+ editorial_minimal: {
363
+ component: lazy(() => import("./heroes/HeroEditorialMinimal")),
364
+ requiredContent: ["headline", "media_url"],
365
+ optionalContent: ["subhead", "cta_text", "cta_url", "overlay_strength", "italic"],
366
+ fields: HERO_EDITORIAL_MINIMAL_FIELDS,
367
+ supportedSettings: ["min_height"],
368
+ defaultContent: { headline: "Confidence through restraint.", media_url: "https://images.unsplash.com/photo-1522337360788-8b13dee7a37e?w=1600&q=80" },
369
+ variantGroup: "hero_editorial",
370
+ },
371
+ dark_split_sticker: {
372
+ component: lazy(() => import("./heroes/HeroDarkSplitSticker")),
373
+ requiredContent: ["headline", "media_url"],
374
+ optionalContent: ["eyebrow", "subhead", "cta_text", "cta_url", "sticker_url", "bg_color", "accent_color"],
375
+ fields: HERO_DARK_STICKER_FIELDS,
376
+ supportedSettings: ["min_height"],
377
+ defaultContent: { headline: "Murder your thirst.", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80" },
378
+ variantGroup: "hero_dark",
379
+ },
380
+ retro_centered: {
381
+ component: lazy(() => import("./heroes/HeroRetroCentered")),
382
+ requiredContent: ["headline", "media_url"],
383
+ optionalContent: ["subhead", "cta_text", "cta_url", "bg_color", "bg_gradient", "floating_elements"],
384
+ fields: HERO_RETRO_FIELDS,
385
+ supportedSettings: ["min_height"],
386
+ defaultContent: { headline: "The feel-good soda.", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1570194065650-d99fb4d8a609?w=800&q=80", bg_color: "#FDE68A" },
387
+ variantGroup: "hero_retro",
388
+ },
389
+ trust_split: {
390
+ component: lazy(() => import("./heroes/HeroTrustSplit")),
391
+ requiredContent: ["headline", "media_url"],
392
+ optionalContent: ["subhead", "cta_text", "cta_url", "rating", "review_count", "credential_badges"],
393
+ fields: HERO_TRUST_FIELDS,
394
+ supportedSettings: ["min_height"],
395
+ defaultContent: { headline: "Scale up your health routine.", cta_text: "Shop Now", media_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80", rating: 4.8, review_count: "60,000+ verified reviews" },
396
+ variantGroup: "hero_trust",
397
+ },
398
+ cinematic_fullbleed: {
399
+ component: lazy(() => import("./heroes/HeroCinematicFullbleed")),
400
+ requiredContent: ["headline"],
401
+ optionalContent: ["eyebrow", "subhead", "media_url", "video_url", "cta_text", "cta_url", "overlay_strength", "cta_bg_color", "cta_text_color"],
402
+ fields: HERO_CINEMATIC_FIELDS,
403
+ supportedSettings: ["min_height"],
404
+ defaultContent: { headline: "The Hybrid Revolution.", cta_text: "Shop Now", video_url: "/stock-hero.mp4" },
405
+ variantGroup: "hero_cinematic",
406
+ },
407
+ },
408
+ },
409
+ // ─── Reviews ──────────────────────────────────────────────────────────
410
+ lx_reviews: {
411
+ category: "reviews",
412
+ defaultVariant: "masonry",
413
+ variants: {
414
+ masonry: {
415
+ component: lazy(() => import("./reviews/ReviewMasonry")),
416
+ requiredContent: ["reviews", "heading"],
417
+ optionalContent: [],
418
+ fields: REVIEWS_FIELDS,
419
+ variantGroup: "reviews",
420
+ supportedSettings: [],
421
+ defaultContent: { heading: "What our customers say", reviews: [] },
422
+ },
423
+ carousel: {
424
+ component: lazy(() => import("./reviews/ReviewCarousel")),
425
+ requiredContent: ["reviews"],
426
+ optionalContent: ["heading"],
427
+ fields: REVIEWS_FIELDS,
428
+ variantGroup: "reviews",
429
+ supportedSettings: [],
430
+ defaultContent: { heading: "What our customers say", reviews: [] },
431
+ },
432
+ spotlight: {
433
+ component: lazy(() => import("./reviews/ReviewSpotlight")),
434
+ requiredContent: ["featured_review"],
435
+ optionalContent: ["supporting_reviews"],
436
+ fields: REVIEWS_FIELDS,
437
+ variantGroup: "reviews",
438
+ supportedSettings: [],
439
+ defaultContent: { heading: "What our customers say", reviews: [] },
440
+ },
441
+ infinite_scroll: {
442
+ component: lazy(() => import("./reviews/ReviewMasonry")),
443
+ requiredContent: ["reviews", "heading"],
444
+ optionalContent: [],
445
+ fields: REVIEWS_FIELDS,
446
+ variantGroup: "reviews",
447
+ supportedSettings: [],
448
+ defaultContent: { heading: "What our customers say", reviews: [] },
449
+ },
450
+ },
451
+ },
452
+ // ─── Video Testimonials ───────────────────────────────────────────────
453
+ lx_review_video: {
454
+ category: "reviews",
455
+ defaultVariant: "grid",
456
+ variants: {
457
+ grid: {
458
+ component: lazy(() => import("./reviews/VideoTestimonials")),
459
+ requiredContent: ["videos"],
460
+ optionalContent: ["heading", "subhead"],
461
+ fields: REVIEWS_FIELDS,
462
+ variantGroup: "review_video",
463
+ supportedSettings: [],
464
+ defaultContent: { heading: "Hear from our customers", videos: [] },
465
+ },
466
+ carousel: {
467
+ component: lazy(() => import("./reviews/VideoTestimonials")),
468
+ requiredContent: ["videos"],
469
+ optionalContent: ["heading", "subhead"],
470
+ fields: REVIEWS_FIELDS,
471
+ variantGroup: "review_video",
472
+ supportedSettings: [],
473
+ defaultContent: { heading: "Hear from our customers", videos: [] },
474
+ },
475
+ featured: {
476
+ component: lazy(() => import("./reviews/VideoTestimonials")),
477
+ requiredContent: ["videos"],
478
+ optionalContent: ["heading", "subhead"],
479
+ fields: REVIEWS_FIELDS,
480
+ variantGroup: "review_video",
481
+ supportedSettings: [],
482
+ defaultContent: { heading: "Hear from our customers", videos: [] },
483
+ },
484
+ },
485
+ },
486
+ // ─── Social Proof ─────────────────────────────────────────────────────
487
+ lx_social_proof: {
488
+ category: "social-proof",
489
+ defaultVariant: "logo_strip",
490
+ variants: {
491
+ logo_strip: {
492
+ component: lazy(() => import("./social-proof/LogoStrip")),
493
+ requiredContent: ["logos"],
494
+ optionalContent: ["headline"],
495
+ fields: LOGO_CAROUSEL_FIELDS,
496
+ variantGroup: "social_proof_logo",
497
+ supportedSettings: [],
498
+ defaultContent: { logos: [] },
499
+ },
500
+ trust_badges: {
501
+ component: lazy(() => import("./social-proof/TrustBadges")),
502
+ requiredContent: ["badges"],
503
+ optionalContent: [],
504
+ fields: FEATURED_CARD_FIELDS,
505
+ variantGroup: "social_proof_logo",
506
+ supportedSettings: [],
507
+ defaultContent: { title: "", body: "" },
508
+ },
509
+ press_mentions: {
510
+ component: lazy(() => import("./social-proof/PressMentions")),
511
+ requiredContent: ["mentions"],
512
+ optionalContent: ["heading"],
513
+ fields: LOGO_CAROUSEL_FIELDS,
514
+ variantGroup: "social_proof_logo",
515
+ supportedSettings: [],
516
+ defaultContent: { logos: [] },
517
+ },
518
+ },
519
+ },
520
+ // ─── Stats Grid ───────────────────────────────────────────────────────
521
+ lx_stats: {
522
+ category: "social-proof",
523
+ defaultVariant: "3_col",
524
+ variants: {
525
+ "3_col": {
526
+ component: lazy(() => import("./social-proof/StatsGrid")),
527
+ requiredContent: ["stats"],
528
+ optionalContent: ["heading", "subhead"],
529
+ fields: STATS_FIELDS,
530
+ variantGroup: "stats",
531
+ supportedSettings: [],
532
+ defaultContent: { heading: "", stats: [] },
533
+ },
534
+ "4_col": {
535
+ component: lazy(() => import("./social-proof/StatsGrid")),
536
+ requiredContent: ["stats"],
537
+ optionalContent: ["heading", "subhead"],
538
+ fields: STATS_FIELDS,
539
+ variantGroup: "stats",
540
+ supportedSettings: [],
541
+ defaultContent: { heading: "", stats: [] },
542
+ },
543
+ centered: {
544
+ component: lazy(() => import("./social-proof/StatsGrid")),
545
+ requiredContent: ["stats"],
546
+ optionalContent: ["heading", "subhead"],
547
+ fields: STATS_FIELDS,
548
+ variantGroup: "stats",
549
+ supportedSettings: [],
550
+ defaultContent: { heading: "", stats: [] },
551
+ },
552
+ },
553
+ },
554
+ // ─── Logo Carousel ────────────────────────────────────────────────────
555
+ lx_logo_carousel: {
556
+ category: "social-proof",
557
+ defaultVariant: "scroll",
558
+ variants: {
559
+ scroll: {
560
+ component: lazy(() => import("./social-proof/LogoCarousel")),
561
+ requiredContent: ["logos"],
562
+ optionalContent: ["heading", "speed"],
563
+ fields: LOGO_CAROUSEL_FIELDS,
564
+ variantGroup: "logo_carousel",
565
+ supportedSettings: [],
566
+ defaultContent: { heading: "", logos: [] },
567
+ },
568
+ grid: {
569
+ component: lazy(() => import("./social-proof/LogoCarousel")),
570
+ requiredContent: ["logos"],
571
+ optionalContent: ["heading"],
572
+ fields: LOGO_CAROUSEL_FIELDS,
573
+ variantGroup: "logo_carousel",
574
+ supportedSettings: [],
575
+ defaultContent: { heading: "", logos: [] },
576
+ },
577
+ fade: {
578
+ component: lazy(() => import("./social-proof/LogoCarousel")),
579
+ requiredContent: ["logos"],
580
+ optionalContent: ["heading", "interval"],
581
+ fields: LOGO_CAROUSEL_FIELDS,
582
+ variantGroup: "logo_carousel",
583
+ supportedSettings: [],
584
+ defaultContent: { heading: "", logos: [] },
585
+ },
586
+ },
587
+ },
588
+ // Alias for logo_carousel (legacy blueprint compatibility)
589
+ lx_logo_cloud: {
590
+ category: "social-proof",
591
+ defaultVariant: "grid",
592
+ variants: {
593
+ grid: {
594
+ component: lazy(() => import("./social-proof/LogoCarousel")),
595
+ requiredContent: ["logos"],
596
+ optionalContent: ["heading"],
597
+ fields: LOGO_CAROUSEL_FIELDS,
598
+ variantGroup: "logo_carousel",
599
+ supportedSettings: [],
600
+ defaultContent: { heading: "", logos: [] },
601
+ },
602
+ scroll: {
603
+ component: lazy(() => import("./social-proof/LogoCarousel")),
604
+ requiredContent: ["logos"],
605
+ optionalContent: ["heading", "speed"],
606
+ fields: LOGO_CAROUSEL_FIELDS,
607
+ variantGroup: "logo_carousel",
608
+ supportedSettings: [],
609
+ defaultContent: { heading: "", logos: [] },
610
+ },
611
+ fade: {
612
+ component: lazy(() => import("./social-proof/LogoCarousel")),
613
+ requiredContent: ["logos"],
614
+ optionalContent: ["heading", "interval"],
615
+ fields: LOGO_CAROUSEL_FIELDS,
616
+ variantGroup: "logo_carousel",
617
+ supportedSettings: [],
618
+ defaultContent: { heading: "", logos: [] },
619
+ },
620
+ },
621
+ },
622
+ // ─── Value Props ──────────────────────────────────────────────────────
623
+ lx_value_props: {
624
+ category: "value-props",
625
+ defaultVariant: "grid",
626
+ variants: {
627
+ grid: {
628
+ component: lazy(() => import("./value-props/ValuePropsGrid")),
629
+ requiredContent: ["items"],
630
+ optionalContent: ["heading"],
631
+ fields: VALUE_PROPS_FIELDS,
632
+ variantGroup: "value_props",
633
+ supportedSettings: [],
634
+ defaultContent: { heading: "Why choose us", items: [] },
635
+ },
636
+ alternating_rows: {
637
+ component: lazy(() => import("./value-props/ValuePropsAlternating")),
638
+ requiredContent: ["items"],
639
+ optionalContent: ["heading"],
640
+ fields: VALUE_PROPS_FIELDS,
641
+ variantGroup: "value_props",
642
+ supportedSettings: [],
643
+ defaultContent: { heading: "Why choose us", items: [] },
644
+ },
645
+ icon_strip: {
646
+ component: lazy(() => import("./value-props/ValuePropsIconStrip")),
647
+ requiredContent: ["items"],
648
+ optionalContent: [],
649
+ fields: VALUE_PROPS_FIELDS,
650
+ variantGroup: "value_props",
651
+ supportedSettings: [],
652
+ defaultContent: { heading: "Why choose us", items: [] },
653
+ },
654
+ numbered_list: {
655
+ component: lazy(() => import("./value-props/NumberedList")),
656
+ requiredContent: ["items"],
657
+ optionalContent: ["heading"],
658
+ fields: VALUE_PROPS_FIELDS,
659
+ variantGroup: "value_props",
660
+ supportedSettings: [],
661
+ defaultContent: { heading: "Why choose us", items: [] },
662
+ },
663
+ how_it_works: {
664
+ component: lazy(() => import("./value-props/HowItWorks")),
665
+ requiredContent: ["steps"],
666
+ optionalContent: ["heading"],
667
+ fields: VALUE_PROPS_FIELDS,
668
+ variantGroup: "value_props",
669
+ supportedSettings: [],
670
+ defaultContent: { heading: "Why choose us", items: [] },
671
+ },
672
+ },
673
+ },
674
+ // ─── Feature Grid ─────────────────────────────────────────────────────
675
+ lx_feature_grid: {
676
+ category: "features",
677
+ defaultVariant: "3_col",
678
+ variants: {
679
+ "3_col": {
680
+ component: lazy(() => import("./features/FeatureGrid")),
681
+ requiredContent: ["items"],
682
+ optionalContent: ["heading", "subhead"],
683
+ fields: FEATURE_GRID_FIELDS,
684
+ variantGroup: "feature_grid",
685
+ supportedSettings: [],
686
+ defaultContent: { heading: "Features", items: [] },
687
+ },
688
+ "2_col": {
689
+ component: lazy(() => import("./features/FeatureGrid")),
690
+ requiredContent: ["items"],
691
+ optionalContent: ["heading", "subhead"],
692
+ fields: FEATURE_GRID_FIELDS,
693
+ variantGroup: "feature_grid",
694
+ supportedSettings: [],
695
+ defaultContent: { heading: "Features", items: [] },
696
+ },
697
+ "4_col": {
698
+ component: lazy(() => import("./features/FeatureGrid")),
699
+ requiredContent: ["items"],
700
+ optionalContent: ["heading", "subhead"],
701
+ fields: FEATURE_GRID_FIELDS,
702
+ variantGroup: "feature_grid",
703
+ supportedSettings: [],
704
+ defaultContent: { heading: "Features", items: [] },
705
+ },
706
+ icon_cards: {
707
+ component: lazy(() => import("./features/FeatureGrid")),
708
+ requiredContent: ["items"],
709
+ optionalContent: ["heading", "subhead"],
710
+ fields: FEATURE_GRID_FIELDS,
711
+ variantGroup: "feature_grid",
712
+ supportedSettings: [],
713
+ defaultContent: { heading: "Features", items: [] },
714
+ },
715
+ with_images: {
716
+ component: lazy(() => import("./features/FeatureGrid")),
717
+ requiredContent: ["items"],
718
+ optionalContent: ["heading", "subhead"],
719
+ fields: FEATURE_GRID_FIELDS,
720
+ variantGroup: "feature_grid",
721
+ supportedSettings: [],
722
+ defaultContent: { heading: "Features", items: [] },
723
+ },
724
+ },
725
+ },
726
+ // ─── Bento Grid ───────────────────────────────────────────────────────
727
+ lx_bento: {
728
+ category: "features",
729
+ defaultVariant: "2x2",
730
+ variants: {
731
+ "2x2": {
732
+ component: lazy(() => import("./features/BentoGrid")),
733
+ requiredContent: ["items"],
734
+ optionalContent: ["heading"],
735
+ fields: BENTO_FIELDS,
736
+ variantGroup: "bento",
737
+ supportedSettings: [],
738
+ defaultContent: { heading: "", items: [] },
739
+ },
740
+ with_videos: {
741
+ component: lazy(() => import("./features/BentoGrid")),
742
+ requiredContent: ["items"],
743
+ optionalContent: ["heading"],
744
+ fields: BENTO_FIELDS,
745
+ variantGroup: "bento",
746
+ supportedSettings: [],
747
+ defaultContent: { heading: "", items: [] },
748
+ },
749
+ },
750
+ },
751
+ // ─── Lookbook Grid ─────────────────────────────────────────────────────
752
+ lx_lookbook_grid: {
753
+ category: "content",
754
+ defaultVariant: "editorial",
755
+ variants: {
756
+ editorial: {
757
+ component: lazy(() => import("./content/LookbookGrid")),
758
+ requiredContent: ["items"],
759
+ optionalContent: ["heading", "cols", "gap", "animation_style", "stagger_delay"],
760
+ fields: LOOKBOOK_GRID_FIELDS,
761
+ variantGroup: "lookbook_grid",
762
+ supportedSettings: [],
763
+ defaultContent: { items: [], animation_style: "fade_up", stagger_delay: 80, gap: "xs" },
764
+ },
765
+ mosaic: {
766
+ component: lazy(() => import("./content/LookbookGrid")),
767
+ requiredContent: ["items"],
768
+ optionalContent: ["heading", "cols", "gap", "animation_style", "stagger_delay"],
769
+ fields: LOOKBOOK_GRID_FIELDS,
770
+ variantGroup: "lookbook_grid",
771
+ supportedSettings: [],
772
+ defaultContent: { items: [], cols: "3", animation_style: "fade_up", stagger_delay: 80, gap: "xs" },
773
+ },
774
+ uniform: {
775
+ component: lazy(() => import("./content/LookbookGrid")),
776
+ requiredContent: ["items"],
777
+ optionalContent: ["heading", "cols", "gap", "animation_style", "stagger_delay"],
778
+ fields: LOOKBOOK_GRID_FIELDS,
779
+ variantGroup: "lookbook_grid",
780
+ supportedSettings: [],
781
+ defaultContent: { items: [], cols: "3", animation_style: "fade_up", stagger_delay: 80, gap: "xs" },
782
+ },
783
+ custom: {
784
+ component: lazy(() => import("./content/LookbookGrid")),
785
+ requiredContent: ["items"],
786
+ optionalContent: ["heading", "cols", "gap", "animation_style", "stagger_delay"],
787
+ fields: LOOKBOOK_GRID_FIELDS,
788
+ variantGroup: "lookbook_grid",
789
+ supportedSettings: [],
790
+ defaultContent: { items: [], cols: "3", animation_style: "fade_up", stagger_delay: 80, gap: "xs" },
791
+ },
792
+ jumbled: {
793
+ component: lazy(() => import("./content/LookbookGrid")),
794
+ requiredContent: ["items"],
795
+ optionalContent: ["heading", "cols", "gap", "stagger_delay"],
796
+ fields: LOOKBOOK_GRID_FIELDS,
797
+ variantGroup: "lookbook_grid",
798
+ supportedSettings: [],
799
+ defaultContent: { items: [], cols: "3", gap: "xs", stagger_delay: 80 },
800
+ },
801
+ },
802
+ },
803
+ // ─── Feature Tabs ─────────────────────────────────────────────────────
804
+ lx_feature_tabs: {
805
+ category: "features",
806
+ defaultVariant: "horizontal",
807
+ variants: {
808
+ horizontal: {
809
+ component: lazy(() => import("./features/FeatureTabs")),
810
+ requiredContent: ["tabs"],
811
+ optionalContent: ["heading"],
812
+ fields: FEATURE_TABS_FIELDS,
813
+ variantGroup: "feature_tabs",
814
+ supportedSettings: [],
815
+ defaultContent: { heading: "", tabs: [] },
816
+ },
817
+ vertical: {
818
+ component: lazy(() => import("./features/FeatureTabs")),
819
+ requiredContent: ["tabs"],
820
+ optionalContent: ["heading"],
821
+ fields: FEATURE_TABS_FIELDS,
822
+ variantGroup: "feature_tabs",
823
+ supportedSettings: [],
824
+ defaultContent: { heading: "", tabs: [] },
825
+ },
826
+ icon_tabs: {
827
+ component: lazy(() => import("./features/FeatureTabs")),
828
+ requiredContent: ["tabs"],
829
+ optionalContent: ["heading"],
830
+ fields: FEATURE_TABS_FIELDS,
831
+ variantGroup: "feature_tabs",
832
+ supportedSettings: [],
833
+ defaultContent: { heading: "", tabs: [] },
834
+ },
835
+ },
836
+ },
837
+ // ─── Product ──────────────────────────────────────────────────────────
838
+ lx_product: {
839
+ category: "product",
840
+ defaultVariant: "highlight_left",
841
+ variants: {
842
+ highlight_left: {
843
+ component: lazy(() => import("./product/ProductHighlightLeft")),
844
+ requiredContent: ["product_name", "price", "image_url", "cta_text"],
845
+ optionalContent: ["compare_price", "description", "badges"],
846
+ fields: {},
847
+ variantGroup: "product_highlight",
848
+ supportedSettings: [],
849
+ defaultContent: {},
850
+ },
851
+ highlight_right: {
852
+ component: lazy(() => import("./product/ProductHighlightRight")),
853
+ requiredContent: ["product_name", "price", "image_url", "cta_text"],
854
+ optionalContent: ["description", "ingredients"],
855
+ fields: {},
856
+ variantGroup: "product_highlight",
857
+ supportedSettings: [],
858
+ defaultContent: {},
859
+ },
860
+ centered_stack: {
861
+ component: lazy(() => import("./product/ProductCenteredStack")),
862
+ requiredContent: ["product_name", "price", "image_url", "cta_text"],
863
+ optionalContent: ["description", "variants"],
864
+ fields: {},
865
+ variantGroup: "product_highlight",
866
+ supportedSettings: [],
867
+ defaultContent: {},
868
+ },
869
+ comparison_table: {
870
+ component: lazy(() => import("./product/ComparisonTable")),
871
+ requiredContent: ["products", "feature_labels"],
872
+ optionalContent: ["highlighted_index"],
873
+ fields: {},
874
+ variantGroup: "product_comparison",
875
+ supportedSettings: [],
876
+ defaultContent: {},
877
+ },
878
+ bundle_builder: {
879
+ component: lazy(() => import("./product/BundleBuilder")),
880
+ requiredContent: ["products", "bundle_price", "cta_text"],
881
+ optionalContent: ["savings_text"],
882
+ fields: {},
883
+ variantGroup: "product_bundle",
884
+ supportedSettings: [],
885
+ defaultContent: {},
886
+ },
887
+ subscription_toggle: {
888
+ component: lazy(() => import("./product/SubscriptionToggle")),
889
+ requiredContent: ["one_time_price", "subscribe_price", "cta_text"],
890
+ optionalContent: ["savings_percent", "frequency_options"],
891
+ fields: {},
892
+ variantGroup: "product_subscription",
893
+ supportedSettings: [],
894
+ defaultContent: {},
895
+ },
896
+ },
897
+ },
898
+ // ─── Product Gallery ──────────────────────────────────────────────────
899
+ lx_product_gallery: {
900
+ category: "product",
901
+ defaultVariant: "carousel",
902
+ variants: {
903
+ carousel: {
904
+ component: lazy(() => import("./product/ProductGallery")),
905
+ requiredContent: ["images"],
906
+ optionalContent: ["headline", "subhead"],
907
+ fields: {},
908
+ variantGroup: "product_gallery",
909
+ supportedSettings: [],
910
+ defaultContent: { images: [] },
911
+ },
912
+ with_thumbnails: {
913
+ component: lazy(() => import("./product/ProductGallery")),
914
+ requiredContent: ["images"],
915
+ optionalContent: ["headline", "subhead"],
916
+ fields: {},
917
+ variantGroup: "product_gallery",
918
+ supportedSettings: [],
919
+ defaultContent: { images: [] },
920
+ },
921
+ zoom: {
922
+ component: lazy(() => import("./product/ProductGallery")),
923
+ requiredContent: ["images"],
924
+ optionalContent: ["headline", "subhead"],
925
+ fields: {},
926
+ variantGroup: "product_gallery",
927
+ supportedSettings: [],
928
+ defaultContent: { images: [] },
929
+ },
930
+ },
931
+ },
932
+ // ─── Buy Box ─────────────────────────────────────────────────────────
933
+ lx_buy_box: {
934
+ category: "product",
935
+ defaultVariant: "standard",
936
+ variants: {
937
+ standard: {
938
+ component: lazy(() => import("./product/BuyBox")),
939
+ requiredContent: ["variants", "price"],
940
+ optionalContent: ["product_title", "compare_at_price", "trust_badges", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style"],
941
+ fields: {},
942
+ variantGroup: "buy_box",
943
+ supportedSettings: [],
944
+ defaultContent: {},
945
+ },
946
+ with_subscription: {
947
+ component: lazy(() => import("./product/BuyBox")),
948
+ requiredContent: ["price"],
949
+ optionalContent: ["variants", "product_title", "subscribe_price", "subscribe_label", "frequencies", "trust_badges", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style"],
950
+ fields: {},
951
+ variantGroup: "buy_box",
952
+ supportedSettings: [],
953
+ defaultContent: {},
954
+ },
955
+ quantity_breaks: {
956
+ component: lazy(() => import("./product/BuyBox")),
957
+ requiredContent: ["price"],
958
+ optionalContent: ["variants", "product_title", "quantity_breaks", "trust_badges", "rating", "review_count", "features", "secondary_cta", "emi_offers"],
959
+ fields: {},
960
+ variantGroup: "buy_box",
961
+ supportedSettings: [],
962
+ defaultContent: {},
963
+ },
964
+ sticky_bar: {
965
+ component: lazy(() => import("./product/BuyBox")),
966
+ requiredContent: ["price"],
967
+ optionalContent: ["variants", "product_title", "image_url", "compare_at_price"],
968
+ fields: {},
969
+ variantGroup: "buy_box",
970
+ supportedSettings: [],
971
+ defaultContent: {},
972
+ },
973
+ image_map: {
974
+ component: lazy(() => import("./product/BuyBox")),
975
+ requiredContent: ["image_url"],
976
+ optionalContent: ["variants", "product_title", "cta_text", "trust_badges", "rating", "review_count"],
977
+ fields: {},
978
+ variantGroup: "buy_box",
979
+ supportedSettings: [],
980
+ defaultContent: {},
981
+ },
982
+ },
983
+ },
984
+ // ─── Product Accordion ───────────────────────────────────────────────
985
+ lx_product_accordion: {
986
+ category: "product",
987
+ defaultVariant: "default",
988
+ variants: {
989
+ default: {
990
+ component: lazy(() => import("./product/ProductAccordion")),
991
+ requiredContent: ["sections"],
992
+ optionalContent: ["heading"],
993
+ fields: {},
994
+ variantGroup: "product_accordion",
995
+ supportedSettings: [],
996
+ defaultContent: {},
997
+ },
998
+ with_icons: {
999
+ component: lazy(() => import("./product/ProductAccordion")),
1000
+ requiredContent: ["sections"],
1001
+ optionalContent: ["heading"],
1002
+ fields: {},
1003
+ variantGroup: "product_accordion",
1004
+ supportedSettings: [],
1005
+ defaultContent: {},
1006
+ },
1007
+ },
1008
+ },
1009
+ // ─── Upsell ──────────────────────────────────────────────────────────
1010
+ lx_upsell: {
1011
+ category: "product",
1012
+ defaultVariant: "horizontal",
1013
+ variants: {
1014
+ horizontal: {
1015
+ component: lazy(() => import("./product/Upsell")),
1016
+ requiredContent: ["products"],
1017
+ optionalContent: ["headline"],
1018
+ fields: {},
1019
+ variantGroup: "upsell",
1020
+ supportedSettings: [],
1021
+ defaultContent: {},
1022
+ },
1023
+ grid: {
1024
+ component: lazy(() => import("./product/Upsell")),
1025
+ requiredContent: ["products"],
1026
+ optionalContent: ["headline"],
1027
+ fields: {},
1028
+ variantGroup: "upsell",
1029
+ supportedSettings: [],
1030
+ defaultContent: {},
1031
+ },
1032
+ post_purchase: {
1033
+ component: lazy(() => import("./product/Upsell")),
1034
+ requiredContent: ["products"],
1035
+ optionalContent: ["headline", "subhead"],
1036
+ fields: {},
1037
+ variantGroup: "upsell",
1038
+ supportedSettings: [],
1039
+ defaultContent: {},
1040
+ },
1041
+ },
1042
+ },
1043
+ // ─── PDP Full Layout ──────────────────────────────────────────────────
1044
+ lx_pdp: {
1045
+ category: "product",
1046
+ defaultVariant: "split",
1047
+ variants: {
1048
+ split: {
1049
+ component: lazy(() => import("./product/ProductPage")),
1050
+ requiredContent: ["product_name", "price"],
1051
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style"],
1052
+ fields: {},
1053
+ variantGroup: "pdp",
1054
+ supportedSettings: [],
1055
+ defaultContent: {},
1056
+ },
1057
+ centered: {
1058
+ component: lazy(() => import("./product/ProductPage")),
1059
+ requiredContent: ["product_name", "price"],
1060
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style"],
1061
+ fields: {},
1062
+ variantGroup: "pdp",
1063
+ supportedSettings: [],
1064
+ defaultContent: {},
1065
+ },
1066
+ editorial: {
1067
+ component: lazy(() => import("./product/ProductPage")),
1068
+ requiredContent: ["product_name", "price"],
1069
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "eyebrow", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style"],
1070
+ fields: {},
1071
+ variantGroup: "pdp",
1072
+ supportedSettings: [],
1073
+ defaultContent: {},
1074
+ },
1075
+ sticky_gallery: {
1076
+ component: lazy(() => import("./product/PDPVariants")),
1077
+ requiredContent: ["product_name", "price"],
1078
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "eyebrow", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style", "material_callouts", "auto_change_interval", "image_aspect", "image_fit"],
1079
+ fields: {},
1080
+ variantGroup: "pdp",
1081
+ supportedSettings: [],
1082
+ defaultContent: {},
1083
+ },
1084
+ film_strip_ingredients: {
1085
+ component: lazy(() => import("./product/PDPVariants")),
1086
+ requiredContent: ["product_name", "price"],
1087
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "eyebrow", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style", "ingredients", "clinical_results"],
1088
+ fields: {},
1089
+ variantGroup: "pdp",
1090
+ supportedSettings: [],
1091
+ defaultContent: {},
1092
+ },
1093
+ shade_studio: {
1094
+ component: lazy(() => import("./product/PDPVariants")),
1095
+ requiredContent: ["product_name", "price"],
1096
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style", "editorial_link", "auto_change_interval"],
1097
+ fields: {},
1098
+ variantGroup: "pdp",
1099
+ supportedSettings: [],
1100
+ defaultContent: {},
1101
+ },
1102
+ dark_premium: {
1103
+ component: lazy(() => import("./product/PDPVariants")),
1104
+ requiredContent: ["product_name", "price"],
1105
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "subscribe_price", "trust_badges", "compare_at_price", "rating", "review_count", "features", "secondary_cta", "emi_offers", "variant_selector_style", "feature_grid", "endorsement", "guarantee", "auto_change_interval"],
1106
+ fields: {},
1107
+ variantGroup: "pdp",
1108
+ supportedSettings: [],
1109
+ defaultContent: {},
1110
+ },
1111
+ fashion_minimal: {
1112
+ component: lazy(() => import("./product/PDPVariants")),
1113
+ requiredContent: ["product_name", "price"],
1114
+ optionalContent: ["images", "variants", "description", "badges", "cta_text", "trust_badges", "compare_at_price", "rating", "review_count", "variant_selector_style"],
1115
+ fields: {},
1116
+ variantGroup: "pdp",
1117
+ supportedSettings: [],
1118
+ defaultContent: {},
1119
+ },
1120
+ },
1121
+ },
1122
+ // ─── Newsletter Signup ────────────────────────────────────────────────
1123
+ lx_newsletter: {
1124
+ category: "cta",
1125
+ defaultVariant: "inline",
1126
+ variants: {
1127
+ inline: {
1128
+ component: lazy(() => import("./cta/NewsletterSignup")),
1129
+ requiredContent: ["headline", "cta_text"],
1130
+ optionalContent: ["subhead", "placeholder", "disclaimer"],
1131
+ fields: NEWSLETTER_FIELDS,
1132
+ variantGroup: "newsletter",
1133
+ supportedSettings: [],
1134
+ defaultContent: { headline: "Join the ritual", cta_text: "Subscribe" },
1135
+ },
1136
+ modal: {
1137
+ component: lazy(() => import("./cta/NewsletterSignup")),
1138
+ requiredContent: ["headline", "cta_text"],
1139
+ optionalContent: ["subhead", "placeholder", "disclaimer"],
1140
+ fields: NEWSLETTER_FIELDS,
1141
+ variantGroup: "newsletter",
1142
+ supportedSettings: [],
1143
+ defaultContent: { headline: "Join the ritual", cta_text: "Subscribe" },
1144
+ },
1145
+ banner: {
1146
+ component: lazy(() => import("./cta/NewsletterSignup")),
1147
+ requiredContent: ["headline", "cta_text"],
1148
+ optionalContent: ["subhead", "placeholder"],
1149
+ fields: NEWSLETTER_FIELDS,
1150
+ variantGroup: "newsletter",
1151
+ supportedSettings: [],
1152
+ defaultContent: { headline: "Join the ritual", cta_text: "Subscribe" },
1153
+ },
1154
+ with_incentive: {
1155
+ component: lazy(() => import("./cta/NewsletterSignup")),
1156
+ requiredContent: ["headline", "cta_text"],
1157
+ optionalContent: ["subhead", "placeholder", "incentive_text", "disclaimer"],
1158
+ fields: NEWSLETTER_FIELDS,
1159
+ variantGroup: "newsletter",
1160
+ supportedSettings: [],
1161
+ defaultContent: { headline: "Join the ritual", cta_text: "Subscribe" },
1162
+ },
1163
+ },
1164
+ },
1165
+ // ─── Guarantee CTA ────────────────────────────────────────────────────
1166
+ lx_guarantee: {
1167
+ category: "cta",
1168
+ defaultVariant: "badge",
1169
+ variants: {
1170
+ badge: {
1171
+ component: lazy(() => import("./cta/GuaranteeCta")),
1172
+ requiredContent: ["headline", "body"],
1173
+ optionalContent: ["badge_text", "icon", "cta_text", "cta_url"],
1174
+ fields: GUARANTEE_FIELDS,
1175
+ variantGroup: "guarantee",
1176
+ supportedSettings: [],
1177
+ defaultContent: { headline: "30-Day Money Back Guarantee", body: "Try it risk-free.", cta_text: "Shop Now" },
1178
+ },
1179
+ banner: {
1180
+ component: lazy(() => import("./cta/GuaranteeCta")),
1181
+ requiredContent: ["headline", "body"],
1182
+ optionalContent: ["badge_text", "icon", "cta_text", "cta_url"],
1183
+ fields: GUARANTEE_FIELDS,
1184
+ variantGroup: "guarantee",
1185
+ supportedSettings: [],
1186
+ defaultContent: { headline: "30-Day Money Back Guarantee", body: "Try it risk-free.", cta_text: "Shop Now" },
1187
+ },
1188
+ inline: {
1189
+ component: lazy(() => import("./cta/GuaranteeCta")),
1190
+ requiredContent: ["headline", "body"],
1191
+ optionalContent: ["badge_text", "icon", "cta_text", "cta_url"],
1192
+ fields: GUARANTEE_FIELDS,
1193
+ variantGroup: "guarantee",
1194
+ supportedSettings: [],
1195
+ defaultContent: { headline: "30-Day Money Back Guarantee", body: "Try it risk-free.", cta_text: "Shop Now" },
1196
+ },
1197
+ money_back: {
1198
+ component: lazy(() => import("./cta/GuaranteeCta")),
1199
+ requiredContent: ["headline", "body"],
1200
+ optionalContent: ["guarantee_text", "badges", "cta_text", "cta_url"],
1201
+ fields: GUARANTEE_FIELDS,
1202
+ variantGroup: "guarantee",
1203
+ supportedSettings: [],
1204
+ defaultContent: { headline: "30-Day Money Back Guarantee", body: "Try it risk-free.", cta_text: "Shop Now" },
1205
+ },
1206
+ split: {
1207
+ component: lazy(() => import("./cta/GuaranteeCta")),
1208
+ requiredContent: ["headline", "body"],
1209
+ optionalContent: ["badges", "cta_text", "cta_url"],
1210
+ fields: GUARANTEE_FIELDS,
1211
+ variantGroup: "guarantee",
1212
+ supportedSettings: [],
1213
+ defaultContent: { headline: "30-Day Money Back Guarantee", body: "Try it risk-free.", cta_text: "Shop Now" },
1214
+ },
1215
+ },
1216
+ },
1217
+ // ─── FAQ ──────────────────────────────────────────────────────────────
1218
+ lx_faq: {
1219
+ category: "faq",
1220
+ defaultVariant: "accordion",
1221
+ variants: {
1222
+ accordion: {
1223
+ component: lazy(() => import("./faq/FaqAccordion")),
1224
+ requiredContent: ["items"],
1225
+ optionalContent: ["heading"],
1226
+ fields: FAQ_FIELDS,
1227
+ variantGroup: "faq",
1228
+ supportedSettings: [],
1229
+ defaultContent: { heading: "Frequently Asked Questions", items: [] },
1230
+ },
1231
+ two_column: {
1232
+ component: lazy(() => import("./faq/FaqTwoColumn")),
1233
+ requiredContent: ["items"],
1234
+ optionalContent: ["heading"],
1235
+ fields: FAQ_FIELDS,
1236
+ variantGroup: "faq",
1237
+ supportedSettings: [],
1238
+ defaultContent: { heading: "Frequently Asked Questions", items: [] },
1239
+ },
1240
+ },
1241
+ },
1242
+ // ─── CTA ──────────────────────────────────────────────────────────────
1243
+ lx_cta: {
1244
+ category: "cta",
1245
+ defaultVariant: "full_width",
1246
+ variants: {
1247
+ full_width: {
1248
+ component: lazy(() => import("./cta/CtaFullWidth")),
1249
+ requiredContent: ["headline", "cta_text"],
1250
+ optionalContent: ["subhead", "urgency_text"],
1251
+ fields: CTA_FULLWIDTH_FIELDS,
1252
+ variantGroup: "cta_fullwidth",
1253
+ supportedSettings: [],
1254
+ defaultContent: { headline: "Ready to get started?", cta_text: "Shop Now" },
1255
+ },
1256
+ sticky_bottom: {
1257
+ component: lazy(() => import("./cta/CtaStickyBottom")),
1258
+ requiredContent: ["cta_text"],
1259
+ optionalContent: ["product_name", "price", "countdown_end"],
1260
+ fields: CTA_STICKY_FIELDS,
1261
+ variantGroup: "cta_sticky",
1262
+ supportedSettings: [],
1263
+ defaultContent: { cta_text: "Add to Cart" },
1264
+ },
1265
+ },
1266
+ },
1267
+ // ─── Content ──────────────────────────────────────────────────────────
1268
+ lx_content: {
1269
+ category: "content",
1270
+ defaultVariant: "rich_text",
1271
+ variants: {
1272
+ rich_text: {
1273
+ component: lazy(() => import("./content/RichText")),
1274
+ requiredContent: ["body_html"],
1275
+ optionalContent: ["heading"],
1276
+ fields: CONTENT_RICH_FIELDS,
1277
+ variantGroup: "content_rich",
1278
+ supportedSettings: [],
1279
+ defaultContent: { body_html: "<p>Your content here.</p>" },
1280
+ },
1281
+ image_text_split: {
1282
+ component: lazy(() => import("./content/ImageTextSplit")),
1283
+ requiredContent: ["headline", "body", "image_url"],
1284
+ optionalContent: ["cta_text"],
1285
+ fields: CONTENT_IMAGE_TEXT_FIELDS,
1286
+ variantGroup: "content_split",
1287
+ supportedSettings: [],
1288
+ defaultContent: { headline: "Our story", body: "Tell your brand story here.", image_url: "https://images.unsplash.com/photo-1607748851687-ba9a10438621?w=800&q=80" },
1289
+ },
1290
+ before_after_slider: {
1291
+ component: lazy(() => import("./content/BeforeAfterSlider")),
1292
+ requiredContent: ["before_url", "after_url"],
1293
+ optionalContent: ["before_label", "after_label", "heading", "subhead"],
1294
+ fields: BEFORE_AFTER_FIELDS,
1295
+ variantGroup: "before_after",
1296
+ supportedSettings: [],
1297
+ defaultContent: { before_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80", after_url: "https://images.unsplash.com/photo-1570194065650-d99fb4d8a609?w=800&q=80" },
1298
+ },
1299
+ },
1300
+ },
1301
+ // ─── Before/After (standalone) ────────────────────────────────────────
1302
+ lx_before_after: {
1303
+ category: "content",
1304
+ defaultVariant: "drag",
1305
+ variants: {
1306
+ drag: {
1307
+ component: lazy(() => import("./content/BeforeAfterSlider")),
1308
+ requiredContent: ["before_url", "after_url"],
1309
+ optionalContent: ["before_label", "after_label", "heading", "subhead"],
1310
+ fields: BEFORE_AFTER_FIELDS,
1311
+ variantGroup: "before_after",
1312
+ supportedSettings: [],
1313
+ defaultContent: { before_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80", after_url: "https://images.unsplash.com/photo-1570194065650-d99fb4d8a609?w=800&q=80" },
1314
+ },
1315
+ side_by_side: {
1316
+ component: lazy(() => import("./content/BeforeAfterSlider")),
1317
+ requiredContent: ["before_url", "after_url"],
1318
+ optionalContent: ["before_label", "after_label", "heading", "subhead"],
1319
+ fields: BEFORE_AFTER_FIELDS,
1320
+ variantGroup: "before_after",
1321
+ supportedSettings: [],
1322
+ defaultContent: { before_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80", after_url: "https://images.unsplash.com/photo-1570194065650-d99fb4d8a609?w=800&q=80" },
1323
+ },
1324
+ click_toggle: {
1325
+ component: lazy(() => import("./content/BeforeAfterSlider")),
1326
+ requiredContent: ["before_url", "after_url"],
1327
+ optionalContent: ["before_label", "after_label", "heading", "subhead"],
1328
+ fields: BEFORE_AFTER_FIELDS,
1329
+ variantGroup: "before_after",
1330
+ supportedSettings: [],
1331
+ defaultContent: { before_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=800&q=80", after_url: "https://images.unsplash.com/photo-1570194065650-d99fb4d8a609?w=800&q=80" },
1332
+ },
1333
+ },
1334
+ },
1335
+ // ─── Product Card ─────────────────────────────────────────────────────
1336
+ lx_product_card: {
1337
+ category: "cards",
1338
+ defaultVariant: "editorial",
1339
+ variants: {
1340
+ editorial: {
1341
+ component: lazy(() => import("./cards/FeatureCard")),
1342
+ requiredContent: ["image_url", "label"],
1343
+ optionalContent: ["headline", "headline_strike", "tag", "tilt_degree"],
1344
+ fields: PRODUCT_CARD_FIELDS,
1345
+ variantGroup: "product_card",
1346
+ supportedSettings: [],
1347
+ defaultContent: { headline: "HOW TO\nUSE THIS", label: "Product Name", tilt_degree: 4 },
1348
+ },
1349
+ tilt: {
1350
+ component: lazy(() => import("./cards/FeatureCard")),
1351
+ requiredContent: ["image_url", "label"],
1352
+ optionalContent: ["price", "compare_price", "cta_text", "cta_url", "bg_color"],
1353
+ fields: PRODUCT_CARD_FIELDS,
1354
+ variantGroup: "product_card",
1355
+ supportedSettings: [],
1356
+ defaultContent: { label: "Product Name", bg_color: "#111111" },
1357
+ },
1358
+ spotlight: {
1359
+ component: lazy(() => import("./cards/FeatureCard")),
1360
+ requiredContent: ["image_url", "label"],
1361
+ optionalContent: ["cta_text", "cta_url", "bg_color"],
1362
+ fields: PRODUCT_CARD_FIELDS,
1363
+ variantGroup: "product_card",
1364
+ supportedSettings: [],
1365
+ defaultContent: { label: "LIMITED DROP", bg_color: "#0a0a0a" },
1366
+ },
1367
+ desaturate: {
1368
+ component: lazy(() => import("./cards/FeatureCard")),
1369
+ requiredContent: ["image_url", "label"],
1370
+ optionalContent: ["hover_image", "status_badge"],
1371
+ fields: PRODUCT_CARD_FIELDS,
1372
+ variantGroup: "product_card",
1373
+ supportedSettings: [],
1374
+ defaultContent: { label: "Product Name" },
1375
+ },
1376
+ },
1377
+ },
1378
+ // ─── Cards ────────────────────────────────────────────────────────────
1379
+ lx_card: {
1380
+ category: "cards",
1381
+ defaultVariant: "3d_tilt",
1382
+ variants: {
1383
+ "3d_tilt": {
1384
+ component: lazy(() => import("./cards/FeaturedCard")),
1385
+ requiredContent: ["title", "body"],
1386
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1387
+ fields: FEATURED_CARD_FIELDS,
1388
+ variantGroup: "featured_card",
1389
+ supportedSettings: [],
1390
+ defaultContent: { title: "Card title", body: "Card description" },
1391
+ },
1392
+ glare: {
1393
+ component: lazy(() => import("./cards/FeaturedCard")),
1394
+ requiredContent: ["title", "body"],
1395
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1396
+ fields: FEATURED_CARD_FIELDS,
1397
+ variantGroup: "featured_card",
1398
+ supportedSettings: [],
1399
+ defaultContent: { title: "Card title", body: "Card description" },
1400
+ },
1401
+ glow: {
1402
+ component: lazy(() => import("./cards/FeaturedCard")),
1403
+ requiredContent: ["title", "body"],
1404
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1405
+ fields: FEATURED_CARD_FIELDS,
1406
+ variantGroup: "featured_card",
1407
+ supportedSettings: [],
1408
+ defaultContent: { title: "Card title", body: "Card description" },
1409
+ },
1410
+ expandable: {
1411
+ component: lazy(() => import("./cards/FeaturedCard")),
1412
+ requiredContent: ["title", "body"],
1413
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1414
+ fields: FEATURED_CARD_FIELDS,
1415
+ variantGroup: "featured_card",
1416
+ supportedSettings: [],
1417
+ defaultContent: { title: "Card title", body: "Card description" },
1418
+ },
1419
+ },
1420
+ },
1421
+ // ─── Featured Card (standalone) ───────────────────────────────────────
1422
+ lx_featured_card: {
1423
+ category: "cards",
1424
+ defaultVariant: "3d_tilt",
1425
+ variants: {
1426
+ "3d_tilt": {
1427
+ component: lazy(() => import("./cards/FeaturedCard")),
1428
+ requiredContent: ["title", "body"],
1429
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1430
+ fields: FEATURED_CARD_FIELDS,
1431
+ variantGroup: "featured_card",
1432
+ supportedSettings: [],
1433
+ defaultContent: { title: "Card title", body: "Card description" },
1434
+ },
1435
+ glare: {
1436
+ component: lazy(() => import("./cards/FeaturedCard")),
1437
+ requiredContent: ["title", "body"],
1438
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1439
+ fields: FEATURED_CARD_FIELDS,
1440
+ variantGroup: "featured_card",
1441
+ supportedSettings: [],
1442
+ defaultContent: { title: "Card title", body: "Card description" },
1443
+ },
1444
+ glow: {
1445
+ component: lazy(() => import("./cards/FeaturedCard")),
1446
+ requiredContent: ["title", "body"],
1447
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1448
+ fields: FEATURED_CARD_FIELDS,
1449
+ variantGroup: "featured_card",
1450
+ supportedSettings: [],
1451
+ defaultContent: { title: "Card title", body: "Card description" },
1452
+ },
1453
+ expandable: {
1454
+ component: lazy(() => import("./cards/FeaturedCard")),
1455
+ requiredContent: ["title", "body"],
1456
+ optionalContent: ["image_url", "icon", "cta_text", "cta_url", "badge"],
1457
+ fields: FEATURED_CARD_FIELDS,
1458
+ variantGroup: "featured_card",
1459
+ supportedSettings: [],
1460
+ defaultContent: { title: "Card title", body: "Card description" },
1461
+ },
1462
+ },
1463
+ },
1464
+ // ─── Layout ───────────────────────────────────────────────────────────
1465
+ lx_layout: {
1466
+ category: "layout",
1467
+ defaultVariant: "promo_top_bar",
1468
+ variants: {
1469
+ promo_top_bar: {
1470
+ component: lazy(() => import("./layout/PromoTopBar")),
1471
+ requiredContent: ["text"],
1472
+ optionalContent: ["cta_text", "link", "bg_color", "text_color"],
1473
+ fields: PROMOBAR_FIELDS,
1474
+ variantGroup: "layout_promo",
1475
+ supportedSettings: [],
1476
+ defaultContent: { text: "Free shipping on orders over ₹999" },
1477
+ },
1478
+ static: {
1479
+ component: lazy(() => import("./layout/PromoTopBar")),
1480
+ requiredContent: ["text"],
1481
+ optionalContent: ["cta_text", "link", "bg_color", "text_color"],
1482
+ fields: PROMOBAR_FIELDS,
1483
+ variantGroup: "layout_promo",
1484
+ supportedSettings: [],
1485
+ defaultContent: { text: "Free shipping on orders over ₹999" },
1486
+ },
1487
+ scrolling: {
1488
+ component: lazy(() => import("./layout/PromoTopBar")),
1489
+ requiredContent: ["text"],
1490
+ optionalContent: ["bg_color", "text_color"],
1491
+ fields: PROMOBAR_FIELDS,
1492
+ variantGroup: "layout_promo",
1493
+ supportedSettings: [],
1494
+ defaultContent: { text: "Free shipping · No questions returns · Dermatologist tested" },
1495
+ },
1496
+ sticky_marquee: {
1497
+ component: lazy(() => import("./layout/PromoTopBar")),
1498
+ requiredContent: ["items"],
1499
+ optionalContent: ["bg_color", "text_color", "speed", "separator"],
1500
+ fields: PROMOBAR_MULTI_FIELDS,
1501
+ variantGroup: "layout_promo",
1502
+ supportedSettings: [],
1503
+ defaultContent: { items: [{ text: "Free shipping ₹499+" }, { text: "Dermatologist tested" }, { text: "100% vegan" }] },
1504
+ },
1505
+ rotating: {
1506
+ component: lazy(() => import("./layout/PromoTopBar")),
1507
+ requiredContent: ["items"],
1508
+ optionalContent: ["bg_color", "text_color", "interval"],
1509
+ fields: PROMOBAR_ROTATING_FIELDS,
1510
+ variantGroup: "layout_promo",
1511
+ supportedSettings: [],
1512
+ defaultContent: { items: [{ text: "Free shipping on orders over ₹499" }, { text: "30-day hassle-free returns" }], interval: 3000 },
1513
+ },
1514
+ dismissible: {
1515
+ component: lazy(() => import("./layout/PromoTopBar")),
1516
+ requiredContent: ["text"],
1517
+ optionalContent: ["cta_text", "link", "bg_color", "text_color", "storage_key"],
1518
+ fields: PROMOBAR_FIELDS,
1519
+ variantGroup: "layout_promo",
1520
+ supportedSettings: [],
1521
+ defaultContent: { text: "🎉 Limited time: 20% off your first order" },
1522
+ },
1523
+ countdown_bar: {
1524
+ component: lazy(() => import("./layout/PromoTopBar")),
1525
+ requiredContent: ["message", "end_date"],
1526
+ optionalContent: ["cta_text", "cta_url", "bg_color", "text_color"],
1527
+ fields: PROMOBAR_COUNTDOWN_FIELDS,
1528
+ variantGroup: "layout_promo",
1529
+ supportedSettings: [],
1530
+ defaultContent: { message: "Sale ends in", end_date: "2025-12-31T23:59:59Z" },
1531
+ },
1532
+ ticker: {
1533
+ component: lazy(() => import("./layout/Ticker")),
1534
+ requiredContent: ["items"],
1535
+ optionalContent: ["speed"],
1536
+ fields: TICKER_FIELDS,
1537
+ variantGroup: "layout_ticker",
1538
+ supportedSettings: [],
1539
+ defaultContent: { items: ["Free shipping", "Cruelty-free", "Dermatologist tested"] },
1540
+ },
1541
+ divider: {
1542
+ component: lazy(() => import("./layout/SectionDivider")),
1543
+ requiredContent: [],
1544
+ optionalContent: ["style", "label"],
1545
+ fields: {},
1546
+ variantGroup: "layout_divider",
1547
+ supportedSettings: [],
1548
+ defaultContent: {},
1549
+ },
1550
+ navbar: {
1551
+ component: lazy(() => import("./layout/Navbar")),
1552
+ requiredContent: [],
1553
+ optionalContent: ["logo_url", "brand_name", "nav_items", "cta_text", "cta_url", "bg_color", "text_color", "cta_bg_color", "cta_text_color", "initial_text_color"],
1554
+ fields: NAVBAR_FIELDS,
1555
+ variantGroup: "navbar",
1556
+ supportedSettings: [],
1557
+ defaultContent: { brand_name: "My Brand" },
1558
+ },
1559
+ footer: {
1560
+ component: lazy(() => import("./layout/Footer")),
1561
+ requiredContent: [],
1562
+ optionalContent: ["brand_name", "logo_url", "tagline", "columns", "social_links", "newsletter_heading", "newsletter_placeholder", "copyright"],
1563
+ fields: FOOTER_FIELDS,
1564
+ variantGroup: "footer",
1565
+ supportedSettings: [],
1566
+ defaultContent: { brand_name: "My Brand" },
1567
+ },
1568
+ },
1569
+ },
1570
+ // ─── Product Grid ─────────────────────────────────────────────────────
1571
+ lx_product_grid: {
1572
+ category: "product",
1573
+ defaultVariant: "3_col",
1574
+ variants: {
1575
+ "3_col": {
1576
+ component: lazy(() => import("./product/ProductGrid")),
1577
+ requiredContent: ["items"],
1578
+ optionalContent: ["heading", "subhead"],
1579
+ fields: FEATURE_GRID_FIELDS,
1580
+ variantGroup: "product_grid",
1581
+ supportedSettings: [],
1582
+ defaultContent: { heading: "Our Products", items: [] },
1583
+ },
1584
+ "2_col": {
1585
+ component: lazy(() => import("./product/ProductGrid")),
1586
+ requiredContent: ["items"],
1587
+ optionalContent: ["heading", "subhead"],
1588
+ fields: FEATURE_GRID_FIELDS,
1589
+ variantGroup: "product_grid",
1590
+ supportedSettings: [],
1591
+ defaultContent: { heading: "Our Products", items: [] },
1592
+ },
1593
+ "4_col": {
1594
+ component: lazy(() => import("./product/ProductGrid")),
1595
+ requiredContent: ["items"],
1596
+ optionalContent: ["heading", "subhead"],
1597
+ fields: FEATURE_GRID_FIELDS,
1598
+ variantGroup: "product_grid",
1599
+ supportedSettings: [],
1600
+ defaultContent: { heading: "Our Products", items: [] },
1601
+ },
1602
+ masonry: {
1603
+ component: lazy(() => import("./product/ProductGrid")),
1604
+ requiredContent: ["items"],
1605
+ optionalContent: ["heading", "subhead"],
1606
+ fields: FEATURE_GRID_FIELDS,
1607
+ variantGroup: "product_grid",
1608
+ supportedSettings: [],
1609
+ defaultContent: { heading: "Our Products", items: [] },
1610
+ },
1611
+ with_hover_zoom: {
1612
+ component: lazy(() => import("./product/ProductGrid")),
1613
+ requiredContent: ["items"],
1614
+ optionalContent: ["heading", "subhead"],
1615
+ fields: FEATURE_GRID_FIELDS,
1616
+ variantGroup: "product_grid",
1617
+ supportedSettings: [],
1618
+ defaultContent: { heading: "Our Products", items: [] },
1619
+ },
1620
+ quick_add: {
1621
+ component: lazy(() => import("./product/ProductGrid")),
1622
+ requiredContent: ["items"],
1623
+ optionalContent: ["heading", "subhead"],
1624
+ fields: FEATURE_GRID_FIELDS,
1625
+ variantGroup: "product_grid",
1626
+ supportedSettings: [],
1627
+ defaultContent: { heading: "Our Products", items: [] },
1628
+ },
1629
+ },
1630
+ },
1631
+ // ─── Pill Nav ─────────────────────────────────────────────────────────
1632
+ lx_pill_nav: {
1633
+ category: "product",
1634
+ defaultVariant: "centered",
1635
+ variants: {
1636
+ centered: {
1637
+ component: lazy(() => import("./product/PillNav")),
1638
+ requiredContent: ["pills"],
1639
+ optionalContent: ["heading", "subhead", "accent_color"],
1640
+ fields: {
1641
+ pills: { type: "array", required: true, label: "Pills" },
1642
+ heading: { type: "text", required: false, label: "Heading" },
1643
+ subhead: { type: "text", required: false, label: "Subtext" },
1644
+ accent_color: { type: "color", required: false, label: "Accent color" },
1645
+ },
1646
+ variantGroup: "pill_nav",
1647
+ supportedSettings: [],
1648
+ defaultContent: { pills: [] },
1649
+ },
1650
+ scrollable: {
1651
+ component: lazy(() => import("./product/PillNav")),
1652
+ requiredContent: ["pills"],
1653
+ optionalContent: ["heading", "subhead", "accent_color"],
1654
+ fields: {
1655
+ pills: { type: "array", required: true, label: "Pills" },
1656
+ heading: { type: "text", required: false, label: "Heading" },
1657
+ subhead: { type: "text", required: false, label: "Subtext" },
1658
+ accent_color: { type: "color", required: false, label: "Accent color" },
1659
+ },
1660
+ variantGroup: "pill_nav",
1661
+ supportedSettings: [],
1662
+ defaultContent: { pills: [] },
1663
+ },
1664
+ },
1665
+ },
1666
+ // ─── Format Grid ──────────────────────────────────────────────────────
1667
+ lx_format_grid: {
1668
+ category: "product",
1669
+ defaultVariant: "4_col",
1670
+ variants: {
1671
+ "4_col": {
1672
+ component: lazy(() => import("./product/FormatGrid")),
1673
+ requiredContent: ["items"],
1674
+ optionalContent: ["heading", "subhead", "body"],
1675
+ fields: FEATURE_GRID_FIELDS,
1676
+ variantGroup: "format_grid",
1677
+ supportedSettings: [],
1678
+ defaultContent: { heading: "Our Formats", items: [] },
1679
+ },
1680
+ "3_col": {
1681
+ component: lazy(() => import("./product/FormatGrid")),
1682
+ requiredContent: ["items"],
1683
+ optionalContent: ["heading", "subhead", "body"],
1684
+ fields: FEATURE_GRID_FIELDS,
1685
+ variantGroup: "format_grid",
1686
+ supportedSettings: [],
1687
+ defaultContent: { heading: "Our Formats", items: [] },
1688
+ },
1689
+ },
1690
+ },
1691
+ // ─── Product Carousel ─────────────────────────────────────────────────
1692
+ lx_product_carousel: {
1693
+ category: "product",
1694
+ defaultVariant: "arrows",
1695
+ variants: {
1696
+ arrows: {
1697
+ component: lazy(() => import("./product/ProductCarousel")),
1698
+ requiredContent: ["items"],
1699
+ optionalContent: ["heading"],
1700
+ fields: { heading: { type: "text", required: false, label: "Heading" }, items: { type: "array", required: true, label: "Products" } },
1701
+ variantGroup: "product_carousel",
1702
+ supportedSettings: [],
1703
+ defaultContent: { heading: "", items: [] },
1704
+ },
1705
+ dots: {
1706
+ component: lazy(() => import("./product/ProductCarousel")),
1707
+ requiredContent: ["items"],
1708
+ optionalContent: ["heading"],
1709
+ fields: { heading: { type: "text", required: false, label: "Heading" }, items: { type: "array", required: true, label: "Products" } },
1710
+ variantGroup: "product_carousel",
1711
+ supportedSettings: [],
1712
+ defaultContent: { heading: "", items: [] },
1713
+ },
1714
+ auto_scroll: {
1715
+ component: lazy(() => import("./product/ProductCarousel")),
1716
+ requiredContent: ["items"],
1717
+ optionalContent: ["heading"],
1718
+ fields: { heading: { type: "text", required: false, label: "Heading" }, items: { type: "array", required: true, label: "Products" } },
1719
+ variantGroup: "product_carousel",
1720
+ supportedSettings: [],
1721
+ defaultContent: { heading: "", items: [] },
1722
+ },
1723
+ apple_cards: {
1724
+ component: lazy(() => import("./product/ProductCarousel")),
1725
+ requiredContent: ["items"],
1726
+ optionalContent: ["heading"],
1727
+ fields: { heading: { type: "text", required: false, label: "Heading" }, items: { type: "array", required: true, label: "Products" } },
1728
+ variantGroup: "product_carousel",
1729
+ supportedSettings: [],
1730
+ defaultContent: { heading: "", items: [] },
1731
+ },
1732
+ with_quick_add: {
1733
+ component: lazy(() => import("./product/ProductCarousel")),
1734
+ requiredContent: ["items"],
1735
+ optionalContent: ["heading"],
1736
+ fields: { heading: { type: "text", required: false, label: "Heading" }, items: { type: "array", required: true, label: "Products" } },
1737
+ variantGroup: "product_carousel",
1738
+ supportedSettings: [],
1739
+ defaultContent: { heading: "", items: [] },
1740
+ },
1741
+ },
1742
+ },
1743
+ // ─── Pricing ──────────────────────────────────────────────────────────
1744
+ lx_pricing: {
1745
+ category: "pricing",
1746
+ defaultVariant: "three_col",
1747
+ variants: {
1748
+ three_col: {
1749
+ component: lazy(() => import("./pricing/PricingCards")),
1750
+ requiredContent: ["plans"],
1751
+ optionalContent: ["heading", "subhead"],
1752
+ fields: PRICING_FIELDS,
1753
+ variantGroup: "pricing",
1754
+ supportedSettings: [],
1755
+ defaultContent: { heading: "Simple, transparent pricing", plans: [] },
1756
+ },
1757
+ two_col: {
1758
+ component: lazy(() => import("./pricing/PricingCards")),
1759
+ requiredContent: ["plans"],
1760
+ optionalContent: ["heading", "subhead"],
1761
+ fields: PRICING_FIELDS,
1762
+ variantGroup: "pricing",
1763
+ supportedSettings: [],
1764
+ defaultContent: { heading: "Simple, transparent pricing", plans: [] },
1765
+ },
1766
+ with_toggle: {
1767
+ component: lazy(() => import("./pricing/PricingCards")),
1768
+ requiredContent: ["plans"],
1769
+ optionalContent: ["heading", "subhead"],
1770
+ fields: PRICING_FIELDS,
1771
+ variantGroup: "pricing",
1772
+ supportedSettings: [],
1773
+ defaultContent: { heading: "Simple, transparent pricing", plans: [] },
1774
+ },
1775
+ },
1776
+ },
1777
+ // ─── Navbar ───────────────────────────────────────────────────────────
1778
+ lx_navbar: {
1779
+ category: "layout",
1780
+ defaultVariant: "fixed",
1781
+ variants: {
1782
+ fixed: {
1783
+ component: lazy(() => import("./layout/Navbar")),
1784
+ requiredContent: [],
1785
+ optionalContent: ["logo_url", "brand_name", "nav_items", "cta_text", "cta_url", "bg_color", "text_color", "cta_bg_color", "cta_text_color", "initial_text_color"],
1786
+ fields: NAVBAR_FIELDS,
1787
+ variantGroup: "navbar",
1788
+ supportedSettings: [],
1789
+ defaultContent: { brand_name: "Brand" },
1790
+ },
1791
+ transparent_to_solid: {
1792
+ component: lazy(() => import("./layout/Navbar")),
1793
+ requiredContent: [],
1794
+ optionalContent: ["logo_url", "brand_name", "nav_items", "cta_text", "cta_url", "bg_color", "text_color", "cta_bg_color", "cta_text_color", "initial_text_color"],
1795
+ fields: NAVBAR_FIELDS,
1796
+ variantGroup: "navbar",
1797
+ supportedSettings: [],
1798
+ defaultContent: { brand_name: "Brand" },
1799
+ },
1800
+ centered_logo: {
1801
+ component: lazy(() => import("./layout/Navbar")),
1802
+ requiredContent: [],
1803
+ optionalContent: ["logo_url", "brand_name", "nav_items", "cta_text", "cta_url", "bg_color", "text_color", "cta_bg_color", "cta_text_color", "initial_text_color"],
1804
+ fields: NAVBAR_FIELDS,
1805
+ variantGroup: "navbar",
1806
+ supportedSettings: [],
1807
+ defaultContent: { brand_name: "Brand" },
1808
+ },
1809
+ },
1810
+ },
1811
+ // ─── Footer ───────────────────────────────────────────────────────────
1812
+ lx_footer: {
1813
+ category: "layout",
1814
+ defaultVariant: "multi_column",
1815
+ variants: {
1816
+ multi_column: {
1817
+ component: lazy(() => import("./layout/Footer")),
1818
+ requiredContent: [],
1819
+ optionalContent: ["brand_name", "logo_url", "tagline", "columns", "social_links", "copyright"],
1820
+ fields: FOOTER_FIELDS,
1821
+ variantGroup: "footer",
1822
+ supportedSettings: [],
1823
+ defaultContent: { brand_name: "Brand" },
1824
+ },
1825
+ simple: {
1826
+ component: lazy(() => import("./layout/Footer")),
1827
+ requiredContent: [],
1828
+ optionalContent: ["brand_name", "logo_url", "columns", "social_links", "copyright"],
1829
+ fields: FOOTER_FIELDS,
1830
+ variantGroup: "footer",
1831
+ supportedSettings: [],
1832
+ defaultContent: { brand_name: "Brand" },
1833
+ },
1834
+ with_newsletter: {
1835
+ component: lazy(() => import("./layout/Footer")),
1836
+ requiredContent: [],
1837
+ optionalContent: ["brand_name", "logo_url", "tagline", "columns", "social_links", "newsletter_heading", "newsletter_placeholder", "copyright"],
1838
+ fields: FOOTER_FIELDS,
1839
+ variantGroup: "footer",
1840
+ supportedSettings: [],
1841
+ defaultContent: { brand_name: "Brand" },
1842
+ },
1843
+ },
1844
+ },
1845
+ // ─── Cart Drawer ──────────────────────────────────────────────────────
1846
+ lx_cart_drawer: {
1847
+ category: "cart",
1848
+ defaultVariant: "minimal",
1849
+ variants: {
1850
+ minimal: {
1851
+ component: lazy(() => import("./cart/CartDrawer")),
1852
+ requiredContent: [],
1853
+ optionalContent: ["heading", "empty_headline", "empty_cta_text", "empty_cta_url", "checkout_label"],
1854
+ fields: CART_DRAWER_FIELDS,
1855
+ variantGroup: "cart_drawer",
1856
+ supportedSettings: [],
1857
+ defaultContent: { heading: "Cart", empty_headline: "Your cart is empty", empty_cta_text: "Continue Shopping" },
1858
+ },
1859
+ with_upsell: {
1860
+ component: lazy(() => import("./cart/CartDrawer")),
1861
+ requiredContent: [],
1862
+ optionalContent: ["heading", "empty_headline", "empty_cta_text", "empty_cta_url", "upsell_title", "upsell_items", "checkout_label"],
1863
+ fields: CART_DRAWER_FIELDS,
1864
+ variantGroup: "cart_drawer",
1865
+ supportedSettings: [],
1866
+ defaultContent: { heading: "Cart", upsell_title: "Add on", upsell_items: [] },
1867
+ },
1868
+ with_discount: {
1869
+ component: lazy(() => import("./cart/CartDrawer")),
1870
+ requiredContent: [],
1871
+ optionalContent: ["heading", "empty_headline", "empty_cta_text", "empty_cta_url", "checkout_label"],
1872
+ fields: CART_DRAWER_FIELDS,
1873
+ variantGroup: "cart_drawer",
1874
+ supportedSettings: [],
1875
+ defaultContent: { heading: "Cart" },
1876
+ },
1877
+ },
1878
+ },
1879
+ // ─── Cart Trigger ─────────────────────────────────────────────────────
1880
+ lx_cart_trigger: {
1881
+ category: "cart",
1882
+ defaultVariant: "button",
1883
+ variants: {
1884
+ button: {
1885
+ component: lazy(() => import("./cart/CartTrigger")),
1886
+ requiredContent: [],
1887
+ optionalContent: ["label", "subhead"],
1888
+ fields: {},
1889
+ variantGroup: "cart_trigger",
1890
+ supportedSettings: [],
1891
+ defaultContent: { label: "View Cart" },
1892
+ },
1893
+ },
1894
+ },
1895
+ // ─── Cart ─────────────────────────────────────────────────────────────
1896
+ lx_cart: {
1897
+ category: "cart",
1898
+ defaultVariant: "guarantee_banner",
1899
+ variants: {
1900
+ guarantee_banner: {
1901
+ component: lazy(() => import("./cart/GuaranteeBanner")),
1902
+ requiredContent: ["guarantees"],
1903
+ optionalContent: [],
1904
+ fields: CART_GUARANTEE_FIELDS,
1905
+ variantGroup: "cart_guarantee",
1906
+ supportedSettings: [],
1907
+ defaultContent: { guarantees: [] },
1908
+ },
1909
+ },
1910
+ },
1911
+ // ─── Background ──────────────────────────────────────────────────────
1912
+ lx_background: {
1913
+ category: "background",
1914
+ defaultVariant: "gradient",
1915
+ variants: {
1916
+ gradient: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1917
+ aurora: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1918
+ mesh: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1919
+ particles: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1920
+ grid_dots: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1921
+ noise: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1922
+ spotlight: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1923
+ beams: { component: lazy(() => import("./backgrounds/BackgroundSection")), requiredContent: [], optionalContent: ["heading", "subhead", "cta_text", "cta_url", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "background_section", supportedSettings: [], defaultContent: {} },
1924
+ },
1925
+ },
1926
+ // ─── Text Effects ─────────────────────────────────────────────────────
1927
+ lx_text_effect: {
1928
+ category: "text-effect",
1929
+ defaultVariant: "flip_words",
1930
+ variants: {
1931
+ flip_words: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: ["words", "prefix", "suffix"], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1932
+ text_reveal: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: [], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1933
+ glitch: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: [], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1934
+ colourful: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: [], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1935
+ moving_text: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: [], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1936
+ hero_highlight: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: ["highlight_words"], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1937
+ scramble: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: [], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1938
+ word_by_word: { component: lazy(() => import("./text-effects/TextEffect")), requiredContent: ["text"], optionalContent: [], fields: TEXT_EFFECT_FIELDS, variantGroup: "text_effect", supportedSettings: [], defaultContent: { text: "Your text here" } },
1939
+ },
1940
+ },
1941
+ // ─── Buttons ──────────────────────────────────────────────────────────
1942
+ lx_button: {
1943
+ category: "button",
1944
+ defaultVariant: "pulse_cta",
1945
+ variants: {
1946
+ magnetic: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1947
+ moving_border: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1948
+ shimmer: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1949
+ stateful: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1950
+ pulse_cta: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1951
+ glow_cta: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1952
+ primary_secondary: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "secondary_text", "secondary_url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1953
+ icon_arrow: { component: lazy(() => import("./buttons/ButtonSection")), requiredContent: ["text"], optionalContent: ["url", "heading", "subhead"], fields: BUTTON_SECTION_FIELDS, variantGroup: "button_section", supportedSettings: [], defaultContent: { text: "Shop Now" } },
1954
+ },
1955
+ },
1956
+ // ─── Card Stack ───────────────────────────────────────────────────────
1957
+ lx_card_stack: {
1958
+ category: "cards",
1959
+ defaultVariant: "vertical_stack",
1960
+ variants: {
1961
+ vertical_stack: { component: lazy(() => import("./cards/CardStack")), requiredContent: ["cards"], optionalContent: ["heading"], fields: CARD_STACK_FIELDS, variantGroup: "card_stack", supportedSettings: [], defaultContent: { heading: "", cards: [] } },
1962
+ reveal_on_scroll: { component: lazy(() => import("./cards/CardStack")), requiredContent: ["cards"], optionalContent: ["heading"], fields: CARD_STACK_FIELDS, variantGroup: "card_stack", supportedSettings: [], defaultContent: { heading: "", cards: [] } },
1963
+ fan_out: { component: lazy(() => import("./cards/CardStack")), requiredContent: ["cards"], optionalContent: ["heading"], fields: CARD_STACK_FIELDS, variantGroup: "card_stack", supportedSettings: [], defaultContent: { heading: "", cards: [] } },
1964
+ },
1965
+ },
1966
+ // ─── Testimonial Card ─────────────────────────────────────────────────
1967
+ lx_testimonial_card: {
1968
+ category: "cards",
1969
+ defaultVariant: "quote",
1970
+ variants: {
1971
+ quote: { component: lazy(() => import("./cards/TestimonialCard")), requiredContent: ["quote", "author"], optionalContent: ["role", "company", "rating"], fields: TESTIMONIAL_CARD_FIELDS, variantGroup: "testimonial_card", supportedSettings: [], defaultContent: { quote: "This product changed my skin.", author: "Jane D." } },
1972
+ metric: { component: lazy(() => import("./cards/TestimonialCard")), requiredContent: ["quote", "author"], optionalContent: ["metric_value", "metric_label", "role", "company"], fields: TESTIMONIAL_CARD_FIELDS, variantGroup: "testimonial_card", supportedSettings: [], defaultContent: { quote: "This product changed my skin.", author: "Jane D." } },
1973
+ with_photo: { component: lazy(() => import("./cards/TestimonialCard")), requiredContent: ["quote", "author"], optionalContent: ["avatar_url", "role", "company"], fields: TESTIMONIAL_CARD_FIELDS, variantGroup: "testimonial_card", supportedSettings: [], defaultContent: { quote: "This product changed my skin.", author: "Jane D." } },
1974
+ company_logo: { component: lazy(() => import("./cards/TestimonialCard")), requiredContent: ["quote", "author"], optionalContent: ["logo_url", "company", "role"], fields: TESTIMONIAL_CARD_FIELDS, variantGroup: "testimonial_card", supportedSettings: [], defaultContent: { quote: "This product changed my skin.", author: "Jane D." } },
1975
+ },
1976
+ },
1977
+ // ─── Terminal ─────────────────────────────────────────────────────────
1978
+ lx_terminal: {
1979
+ category: "cards",
1980
+ defaultVariant: "static",
1981
+ variants: {
1982
+ static: { component: lazy(() => import("./cards/TerminalCard")), requiredContent: ["lines"], optionalContent: ["title", "prompt"], fields: TERMINAL_FIELDS, variantGroup: "terminal", supportedSettings: [], defaultContent: { lines: ["$ npm install", "✓ Done"] } },
1983
+ typing: { component: lazy(() => import("./cards/TerminalCard")), requiredContent: ["lines"], optionalContent: ["title", "prompt"], fields: TERMINAL_FIELDS, variantGroup: "terminal", supportedSettings: [], defaultContent: { lines: ["$ npm install", "✓ Done"] } },
1984
+ },
1985
+ },
1986
+ // ─── Urgency CTA ──────────────────────────────────────────────────────
1987
+ lx_urgency_cta: {
1988
+ category: "cta",
1989
+ defaultVariant: "countdown_bar",
1990
+ variants: {
1991
+ countdown_bar: { component: lazy(() => import("./cta/UrgencyCta")), requiredContent: [], optionalContent: ["message", "countdown_end", "cta_text", "cta_url"], fields: URGENCY_CTA_FIELDS, variantGroup: "urgency_cta", supportedSettings: [], defaultContent: {} },
1992
+ stock_scarcity: { component: lazy(() => import("./cta/UrgencyCta")), requiredContent: [], optionalContent: ["stock_count", "stock_max", "activity_count", "activity_label"], fields: URGENCY_CTA_FIELDS, variantGroup: "urgency_cta", supportedSettings: [], defaultContent: {} },
1993
+ social_urgency: { component: lazy(() => import("./cta/UrgencyCta")), requiredContent: [], optionalContent: ["activity_count", "activity_label"], fields: URGENCY_CTA_FIELDS, variantGroup: "urgency_cta", supportedSettings: [], defaultContent: {} },
1994
+ },
1995
+ },
1996
+ // ─── Avatar Group ─────────────────────────────────────────────────────
1997
+ lx_avatar_group: {
1998
+ category: "social-proof",
1999
+ defaultVariant: "stacked",
2000
+ variants: {
2001
+ stacked: { component: lazy(() => import("./social-proof/AvatarGroup")), requiredContent: ["avatars"], optionalContent: ["count_label"], fields: AVATAR_GROUP_FIELDS, variantGroup: "avatar_group", supportedSettings: [], defaultContent: { avatars: [] } },
2002
+ with_count: { component: lazy(() => import("./social-proof/AvatarGroup")), requiredContent: ["avatars"], optionalContent: ["count_label", "cta_text", "cta_url"], fields: AVATAR_GROUP_FIELDS, variantGroup: "avatar_group", supportedSettings: [], defaultContent: { avatars: [] } },
2003
+ expanding: { component: lazy(() => import("./social-proof/AvatarGroup")), requiredContent: ["avatars"], optionalContent: ["count_label"], fields: AVATAR_GROUP_FIELDS, variantGroup: "avatar_group", supportedSettings: [], defaultContent: { avatars: [] } },
2004
+ },
2005
+ },
2006
+ // ─── Waitlist ─────────────────────────────────────────────────────────
2007
+ lx_waitlist: {
2008
+ category: "cta",
2009
+ defaultVariant: "simple",
2010
+ variants: {
2011
+ simple: { component: lazy(() => import("./cta/WaitlistCta")), requiredContent: ["heading"], optionalContent: ["subhead", "placeholder", "cta_text"], fields: WAITLIST_FIELDS, variantGroup: "waitlist", supportedSettings: [], defaultContent: { heading: "Join the waitlist" } },
2012
+ with_position: { component: lazy(() => import("./cta/WaitlistCta")), requiredContent: ["heading"], optionalContent: ["subhead", "placeholder", "cta_text", "position_number"], fields: WAITLIST_FIELDS, variantGroup: "waitlist", supportedSettings: [], defaultContent: { heading: "Join the waitlist" } },
2013
+ },
2014
+ },
2015
+ // ─── Parallax ─────────────────────────────────────────────────────────
2016
+ lx_parallax: {
2017
+ category: "content",
2018
+ defaultVariant: "image_scroll",
2019
+ variants: {
2020
+ image_scroll: { component: lazy(() => import("./content/ParallaxSection")), requiredContent: [], optionalContent: ["heading", "subhead", "image_url", "body"], fields: PARALLAX_FIELDS, variantGroup: "parallax", supportedSettings: [], defaultContent: {} },
2021
+ text_layers: { component: lazy(() => import("./content/ParallaxSection")), requiredContent: [], optionalContent: ["heading", "subhead", "body"], fields: PARALLAX_FIELDS, variantGroup: "parallax", supportedSettings: [], defaultContent: {} },
2022
+ zoom_on_scroll: { component: lazy(() => import("./content/ParallaxSection")), requiredContent: [], optionalContent: ["heading", "subhead", "image_url"], fields: PARALLAX_FIELDS, variantGroup: "parallax", supportedSettings: [], defaultContent: {} },
2023
+ },
2024
+ },
2025
+ // ─── Process Steps ────────────────────────────────────────────────────
2026
+ lx_process_steps: {
2027
+ category: "features",
2028
+ defaultVariant: "horizontal",
2029
+ variants: {
2030
+ horizontal: { component: lazy(() => import("./features/ProcessSteps")), requiredContent: ["steps"], optionalContent: ["heading", "subhead"], fields: PROCESS_STEPS_FIELDS, variantGroup: "process_steps", supportedSettings: [], defaultContent: { heading: "How it works", steps: [] } },
2031
+ vertical: { component: lazy(() => import("./features/ProcessSteps")), requiredContent: ["steps"], optionalContent: ["heading", "subhead"], fields: PROCESS_STEPS_FIELDS, variantGroup: "process_steps", supportedSettings: [], defaultContent: { heading: "How it works", steps: [] } },
2032
+ numbered_large: { component: lazy(() => import("./features/ProcessSteps")), requiredContent: ["steps"], optionalContent: ["heading", "subhead"], fields: PROCESS_STEPS_FIELDS, variantGroup: "process_steps", supportedSettings: [], defaultContent: { heading: "How it works", steps: [] } },
2033
+ },
2034
+ },
2035
+ // ─── Section Transitions ─────────────────────────────────────────────────────
2036
+ lx_transition: {
2037
+ category: "layout",
2038
+ defaultVariant: "waves",
2039
+ variants: {
2040
+ waves: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2041
+ waves_opacity: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2042
+ curve: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2043
+ curve_asymmetrical: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2044
+ triangle: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2045
+ triangle_asymmetrical: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2046
+ tilt: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2047
+ arrow: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2048
+ split: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2049
+ book: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2050
+ // legacy aliases
2051
+ wave_down: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2052
+ wave_up: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2053
+ angle_cut: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2054
+ angle_cut_reverse: { component: lazy(() => import("./layout/SectionTransition")), requiredContent: ["color_above", "color_below"], optionalContent: ["height", "flip"], fields: TRANSITION_FIELDS, variantGroup: "transition", supportedSettings: [], defaultContent: { color_above: "#ffffff", color_below: "#f8f8f8" } },
2055
+ },
2056
+ },
2057
+ // ─── Effects ──────────────────────────────────────────────────────────
2058
+ lx_scroll_linked: {
2059
+ category: "effects",
2060
+ defaultVariant: "fade_on_scroll",
2061
+ variants: {
2062
+ fade_on_scroll: { component: lazy(() => import("./effects/ScrollLinked")), requiredContent: [], optionalContent: ["heading", "subhead", "children", "threshold", "once"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "scroll_linked", supportedSettings: [], defaultContent: {} },
2063
+ slide_on_scroll: { component: lazy(() => import("./effects/ScrollLinked")), requiredContent: [], optionalContent: ["heading", "subhead", "children", "threshold", "once"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "scroll_linked", supportedSettings: [], defaultContent: {} },
2064
+ scale_on_scroll: { component: lazy(() => import("./effects/ScrollLinked")), requiredContent: [], optionalContent: ["heading", "subhead", "children", "threshold", "once"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "scroll_linked", supportedSettings: [], defaultContent: {} },
2065
+ rotate_on_scroll: { component: lazy(() => import("./effects/ScrollLinked")), requiredContent: [], optionalContent: ["heading", "subhead", "children", "threshold", "once"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "scroll_linked", supportedSettings: [], defaultContent: {} },
2066
+ stagger_on_scroll: { component: lazy(() => import("./effects/ScrollLinked")), requiredContent: [], optionalContent: ["heading", "subhead", "children", "stagger_delay", "threshold", "once"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "scroll_linked", supportedSettings: [], defaultContent: {} },
2067
+ progress_bar: { component: lazy(() => import("./effects/ScrollLinked")), requiredContent: [], optionalContent: ["heading", "subhead", "children"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "scroll_linked", supportedSettings: [], defaultContent: {} },
2068
+ },
2069
+ },
2070
+ // ─── Popup / Lead Capture ────────────────────────────────────────────
2071
+ lx_popup: {
2072
+ category: "cta",
2073
+ defaultVariant: "split_image",
2074
+ variants: {
2075
+ split_image: {
2076
+ component: lazy(() => import("./cta/Popup")),
2077
+ requiredContent: ["headline", "image_url"],
2078
+ optionalContent: ["subtext", "cta_text", "fine_print", "logo_url", "trigger_delay", "trigger", "discount_badge", "email_placeholder", "phone_placeholder", "success_message"],
2079
+ fields: POPUP_FIELDS,
2080
+ variantGroup: "popup",
2081
+ supportedSettings: [],
2082
+ defaultContent: { headline: "Get 10% off", image_url: "https://images.unsplash.com/photo-1556228720-195a672e8a03?w=600&q=80", cta_text: "Claim Offer" },
2083
+ },
2084
+ email_capture: {
2085
+ component: lazy(() => import("./cta/Popup")),
2086
+ requiredContent: ["headline"],
2087
+ optionalContent: ["subtext", "cta_text", "fine_print", "logo_url", "trigger_delay", "trigger", "discount_badge", "email_placeholder", "success_message"],
2088
+ fields: POPUP_FIELDS,
2089
+ variantGroup: "popup",
2090
+ supportedSettings: [],
2091
+ defaultContent: { headline: "Get exclusive offers", cta_text: "Subscribe" },
2092
+ },
2093
+ phone_capture: {
2094
+ component: lazy(() => import("./cta/Popup")),
2095
+ requiredContent: ["headline"],
2096
+ optionalContent: ["subtext", "cta_text", "fine_print", "logo_url", "trigger_delay", "trigger", "discount_badge", "phone_placeholder", "success_message"],
2097
+ fields: POPUP_FIELDS,
2098
+ variantGroup: "popup",
2099
+ supportedSettings: [],
2100
+ defaultContent: { headline: "Get SMS updates", cta_text: "Sign me up" },
2101
+ },
2102
+ },
2103
+ },
2104
+ // ─── Video Carousel ───────────────────────────────────────────────────
2105
+ lx_video_carousel: {
2106
+ category: "product",
2107
+ defaultVariant: "alternating_heights",
2108
+ variants: {
2109
+ alternating_heights: {
2110
+ component: lazy(() => import("./product/VideoCarousel")),
2111
+ requiredContent: ["items"],
2112
+ optionalContent: ["heading", "subheading"],
2113
+ fields: { heading: { type: "text", required: false, label: "Heading" }, subhead: { type: "text", required: false, label: "Subtext" }, items: { type: "array", required: true, label: "Videos" } },
2114
+ variantGroup: "video_carousel",
2115
+ supportedSettings: [],
2116
+ defaultContent: { heading: "", items: [] },
2117
+ },
2118
+ uniform: {
2119
+ component: lazy(() => import("./product/VideoCarousel")),
2120
+ requiredContent: ["items"],
2121
+ optionalContent: ["heading", "subheading"],
2122
+ fields: { heading: { type: "text", required: false, label: "Heading" }, subhead: { type: "text", required: false, label: "Subtext" }, items: { type: "array", required: true, label: "Videos" } },
2123
+ variantGroup: "video_carousel",
2124
+ supportedSettings: [],
2125
+ defaultContent: { heading: "", items: [] },
2126
+ },
2127
+ },
2128
+ },
2129
+ // ─── Live Activity Ticker ─────────────────────────────────────────────
2130
+ lx_live_activity_ticker: {
2131
+ category: "social-proof",
2132
+ defaultVariant: "recent_purchases",
2133
+ variants: {
2134
+ recent_purchases: {
2135
+ component: lazy(() => import("./personalization/LiveActivityTicker")),
2136
+ requiredContent: [],
2137
+ optionalContent: ["activity_items", "mock_items"],
2138
+ fields: LIVE_ACTIVITY_TICKER_FIELDS,
2139
+ variantGroup: "live_activity_ticker",
2140
+ supportedSettings: [],
2141
+ defaultContent: { mock_items: [] },
2142
+ },
2143
+ visitor_count: {
2144
+ component: lazy(() => import("./personalization/LiveActivityTicker")),
2145
+ requiredContent: [],
2146
+ optionalContent: ["visitor_count"],
2147
+ fields: LIVE_ACTIVITY_TICKER_FIELDS,
2148
+ variantGroup: "live_activity_ticker",
2149
+ supportedSettings: [],
2150
+ defaultContent: { visitor_count: 142 },
2151
+ },
2152
+ combined: {
2153
+ component: lazy(() => import("./personalization/LiveActivityTicker")),
2154
+ requiredContent: [],
2155
+ optionalContent: ["activity_items", "mock_items", "visitor_count"],
2156
+ fields: LIVE_ACTIVITY_TICKER_FIELDS,
2157
+ variantGroup: "live_activity_ticker",
2158
+ supportedSettings: [],
2159
+ defaultContent: { visitor_count: 97 },
2160
+ },
2161
+ local_proof: {
2162
+ component: lazy(() => import("./personalization/LiveActivityTicker")),
2163
+ requiredContent: [],
2164
+ optionalContent: ["location_name", "location_purchases", "location_emoji"],
2165
+ fields: LIVE_ACTIVITY_TICKER_FIELDS,
2166
+ variantGroup: "live_activity_ticker",
2167
+ supportedSettings: [],
2168
+ defaultContent: { location_name: "Mumbai", location_purchases: 38, location_emoji: "🇮🇳" },
2169
+ },
2170
+ },
2171
+ },
2172
+ lx_canvas_reveal: {
2173
+ category: "effects",
2174
+ defaultVariant: "gradient_reveal",
2175
+ variants: {
2176
+ gradient_reveal: { component: lazy(() => import("./effects/CanvasReveal")), requiredContent: [], optionalContent: ["heading", "subhead", "trigger", "duration"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "canvas_reveal", supportedSettings: [], defaultContent: {} },
2177
+ particle_reveal: { component: lazy(() => import("./effects/CanvasReveal")), requiredContent: [], optionalContent: ["heading", "subhead", "trigger", "duration", "particle_count", "colors"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "canvas_reveal", supportedSettings: [], defaultContent: {} },
2178
+ wave_reveal: { component: lazy(() => import("./effects/CanvasReveal")), requiredContent: [], optionalContent: ["heading", "subhead", "trigger", "duration"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "canvas_reveal", supportedSettings: [], defaultContent: {} },
2179
+ morph_reveal: { component: lazy(() => import("./effects/CanvasReveal")), requiredContent: [], optionalContent: ["heading", "subhead", "trigger", "duration"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "canvas_reveal", supportedSettings: [], defaultContent: {} },
2180
+ draw_on_scroll: { component: lazy(() => import("./effects/CanvasReveal")), requiredContent: [], optionalContent: ["heading", "subhead", "duration"], fields: BACKGROUND_SECTION_FIELDS, variantGroup: "canvas_reveal", supportedSettings: [], defaultContent: {} },
2181
+ },
2182
+ },
2183
+ // ─── Personalization Components ───────────────────────────────────────────
2184
+ lx_scarcity_indicator: {
2185
+ category: "personalization",
2186
+ defaultVariant: "stock_bar",
2187
+ variants: {
2188
+ stock_bar: { component: lazy(() => import("./personalization/ScarcityIndicator")), requiredContent: [], optionalContent: ["product_id", "real_stock_level", "show_scarcity_threshold", "scarcity_copy", "activity_count"], fields: {}, variantGroup: "scarcity_indicator", supportedSettings: [], defaultContent: { real_stock_level: 5, show_scarcity_threshold: 10 } },
2189
+ size_availability: { component: lazy(() => import("./personalization/ScarcityIndicator")), requiredContent: [], optionalContent: ["size_inventory", "restock_date"], fields: {}, variantGroup: "scarcity_indicator", supportedSettings: [], defaultContent: {} },
2190
+ restock_countdown: { component: lazy(() => import("./personalization/ScarcityIndicator")), requiredContent: [], optionalContent: ["restock_date", "product_id"], fields: {}, variantGroup: "scarcity_indicator", supportedSettings: [], defaultContent: {} },
2191
+ threshold_alert: { component: lazy(() => import("./personalization/ScarcityIndicator")), requiredContent: [], optionalContent: ["product_id", "real_stock_level", "show_scarcity_threshold", "scarcity_copy"], fields: {}, variantGroup: "scarcity_indicator", supportedSettings: [], defaultContent: { real_stock_level: 3, show_scarcity_threshold: 10 } },
2192
+ },
2193
+ },
2194
+ lx_cart_recovery: {
2195
+ category: "personalization",
2196
+ defaultVariant: "abandoned_carousel",
2197
+ variants: {
2198
+ abandoned_carousel: { component: lazy(() => import("./personalization/CartRecovery")), requiredContent: [], optionalContent: ["abandoned_items", "_dynamic_cart_items"], fields: {}, variantGroup: "cart_recovery", supportedSettings: [], defaultContent: {} },
2199
+ incentive_offer: { component: lazy(() => import("./personalization/CartRecovery")), requiredContent: [], optionalContent: ["abandoned_items", "_dynamic_cart_items", "incentive_type", "incentive_value", "incentive_expires_in_hours"], fields: {}, variantGroup: "cart_recovery", supportedSettings: [], defaultContent: { incentive_value: 15, incentive_expires_in_hours: 24 } },
2200
+ stock_urgency: { component: lazy(() => import("./personalization/CartRecovery")), requiredContent: [], optionalContent: ["abandoned_items", "_dynamic_cart_items", "stock_status"], fields: {}, variantGroup: "cart_recovery", supportedSettings: [], defaultContent: {} },
2201
+ bundle_completion: { component: lazy(() => import("./personalization/CartRecovery")), requiredContent: [], optionalContent: ["abandoned_items", "_dynamic_cart_items", "bundle_product"], fields: {}, variantGroup: "cart_recovery", supportedSettings: [], defaultContent: {} },
2202
+ },
2203
+ },
2204
+ lx_loyalty_status: {
2205
+ category: "personalization",
2206
+ defaultVariant: "points_balance_card",
2207
+ variants: {
2208
+ points_balance_card: { component: lazy(() => import("./personalization/LoyaltyStatus")), requiredContent: [], optionalContent: ["customer_points", "_dynamic_customer_points", "tier_name", "redemption_rate", "bonus_multiplier_active"], fields: {}, variantGroup: "loyalty_status", supportedSettings: [], defaultContent: { redemption_rate: 0.01 } },
2209
+ tier_progress_bar: { component: lazy(() => import("./personalization/LoyaltyStatus")), requiredContent: [], optionalContent: ["tier_name", "next_tier_name", "points_to_next_tier", "tier_points_total", "_dynamic_customer_points"], fields: {}, variantGroup: "loyalty_status", supportedSettings: [], defaultContent: {} },
2210
+ next_milestone: { component: lazy(() => import("./personalization/LoyaltyStatus")), requiredContent: [], optionalContent: ["next_tier_name", "points_to_next_tier", "tier_benefits"], fields: {}, variantGroup: "loyalty_status", supportedSettings: [], defaultContent: {} },
2211
+ perks_comparison: { component: lazy(() => import("./personalization/LoyaltyStatus")), requiredContent: [], optionalContent: ["all_tiers", "_dynamic_tier_name"], fields: {}, variantGroup: "loyalty_status", supportedSettings: [], defaultContent: {} },
2212
+ redemption_offer: { component: lazy(() => import("./personalization/LoyaltyStatus")), requiredContent: [], optionalContent: ["customer_points", "_dynamic_customer_points", "redemption_rate", "bonus_multiplier_active", "bonus_expires_at"], fields: {}, variantGroup: "loyalty_status", supportedSettings: [], defaultContent: { redemption_rate: 0.01 } },
2213
+ },
2214
+ },
2215
+ lx_personalized_recommendations: {
2216
+ category: "personalization",
2217
+ defaultVariant: "bestsellers_for_new",
2218
+ variants: {
2219
+ complete_your_routine: { component: lazy(() => import("./personalization/PersonalizedRecommendations")), requiredContent: [], optionalContent: ["routine_steps"], fields: {}, variantGroup: "personalized_recommendations", supportedSettings: [], defaultContent: {} },
2220
+ collab_filter: { component: lazy(() => import("./personalization/PersonalizedRecommendations")), requiredContent: [], optionalContent: ["context_product_name", "recommended_products"], fields: {}, variantGroup: "personalized_recommendations", supportedSettings: [], defaultContent: {} },
2221
+ high_intent_alternatives: { component: lazy(() => import("./personalization/PersonalizedRecommendations")), requiredContent: [], optionalContent: ["alternatives"], fields: {}, variantGroup: "personalized_recommendations", supportedSettings: [], defaultContent: {} },
2222
+ vip_early_access: { component: lazy(() => import("./personalization/PersonalizedRecommendations")), requiredContent: [], optionalContent: ["exclusive_products", "_dynamic_is_vip"], fields: {}, variantGroup: "personalized_recommendations", supportedSettings: [], defaultContent: {} },
2223
+ bestsellers_for_new: { component: lazy(() => import("./personalization/PersonalizedRecommendations")), requiredContent: [], optionalContent: ["products", "max_items"], fields: {}, variantGroup: "personalized_recommendations", supportedSettings: [], defaultContent: { max_items: 4 } },
2224
+ },
2225
+ },
2226
+ lx_vip_gate: {
2227
+ category: "personalization",
2228
+ defaultVariant: "content_lock",
2229
+ variants: {
2230
+ content_lock: { component: lazy(() => import("./personalization/VipGate")), requiredContent: [], optionalContent: ["required_tier", "locked_content_preview", "non_member_cta", "cta_by_cohort", "_dynamic_visitor_tier"], fields: {}, variantGroup: "vip_gate", supportedSettings: [], defaultContent: { required_tier: "vip" } },
2231
+ early_access_countdown: { component: lazy(() => import("./personalization/VipGate")), requiredContent: [], optionalContent: ["required_tier", "early_access_end", "non_member_cta", "_dynamic_visitor_tier"], fields: {}, variantGroup: "vip_gate", supportedSettings: [], defaultContent: { required_tier: "vip" } },
2232
+ tier_pricing_reveal: { component: lazy(() => import("./personalization/VipGate")), requiredContent: [], optionalContent: ["required_tier", "regular_price", "vip_price", "non_member_cta", "_dynamic_visitor_tier"], fields: {}, variantGroup: "vip_gate", supportedSettings: [], defaultContent: { required_tier: "vip" } },
2233
+ exclusive_bundle: { component: lazy(() => import("./personalization/VipGate")), requiredContent: [], optionalContent: ["required_tier", "bundle_products", "bundle_price", "regular_individual_total", "non_member_cta", "_dynamic_visitor_tier"], fields: {}, variantGroup: "vip_gate", supportedSettings: [], defaultContent: { required_tier: "vip" } },
2234
+ },
2235
+ },
2236
+ lx_reengagement_banner: {
2237
+ category: "personalization",
2238
+ defaultVariant: "flash_return_offer",
2239
+ variants: {
2240
+ new_arrivals_since_visit: { component: lazy(() => import("./personalization/ReengagementBanner")), requiredContent: [], optionalContent: ["days_since_last_visit", "_dynamic_days_since_visit", "new_products_count", "_dynamic_new_products_count", "new_products"], fields: {}, variantGroup: "reengagement_banner", supportedSettings: [], defaultContent: {} },
2241
+ flash_return_offer: { component: lazy(() => import("./personalization/ReengagementBanner")), requiredContent: [], optionalContent: ["offer_discount_pct", "discount_code", "offer_expires_at"], fields: {}, variantGroup: "reengagement_banner", supportedSettings: [], defaultContent: { offer_discount_pct: 20 } },
2242
+ category_update: { component: lazy(() => import("./personalization/ReengagementBanner")), requiredContent: [], optionalContent: ["favorite_category", "category_icon", "new_products_count", "new_products"], fields: {}, variantGroup: "reengagement_banner", supportedSettings: [], defaultContent: {} },
2243
+ price_drop_alert: { component: lazy(() => import("./personalization/ReengagementBanner")), requiredContent: [], optionalContent: ["price_drops"], fields: {}, variantGroup: "reengagement_banner", supportedSettings: [], defaultContent: {} },
2244
+ },
2245
+ },
2246
+ lx_personalized_greeting: {
2247
+ category: "personalization",
2248
+ defaultVariant: "name_welcome",
2249
+ variants: {
2250
+ name_welcome: { component: lazy(() => import("./personalization/PersonalizedGreeting")), requiredContent: [], optionalContent: ["customer_first_name", "_dynamic_customer_name"], fields: {}, variantGroup: "personalized_greeting", supportedSettings: [], defaultContent: {} },
2251
+ purchase_context: { component: lazy(() => import("./personalization/PersonalizedGreeting")), requiredContent: [], optionalContent: ["customer_first_name", "_dynamic_customer_name", "last_purchase_name", "_dynamic_last_purchase_name", "last_purchase_date", "_dynamic_last_purchase_date", "last_purchase_image", "days_since_purchase"], fields: {}, variantGroup: "personalized_greeting", supportedSettings: [], defaultContent: {} },
2252
+ status_milestone: { component: lazy(() => import("./personalization/PersonalizedGreeting")), requiredContent: [], optionalContent: ["customer_first_name", "_dynamic_customer_name", "purchase_count", "_dynamic_purchase_count", "milestone_reward"], fields: {}, variantGroup: "personalized_greeting", supportedSettings: [], defaultContent: {} },
2253
+ reengagement_personal: { component: lazy(() => import("./personalization/PersonalizedGreeting")), requiredContent: [], optionalContent: ["customer_first_name", "_dynamic_customer_name", "last_purchase_date", "_dynamic_last_purchase_date", "new_products"], fields: {}, variantGroup: "personalized_greeting", supportedSettings: [], defaultContent: {} },
2254
+ },
2255
+ },
2256
+ lx_progress_milestone: {
2257
+ category: "personalization",
2258
+ defaultVariant: "free_shipping_bar",
2259
+ variants: {
2260
+ free_shipping_bar: { component: lazy(() => import("./personalization/ProgressMilestone")), requiredContent: [], optionalContent: ["current_value", "_dynamic_current_value", "target_value", "reward_description", "motivational_copy"], fields: {}, variantGroup: "progress_milestone", supportedSettings: [], defaultContent: { target_value: 100 } },
2261
+ loyalty_tier_ring: { component: lazy(() => import("./personalization/ProgressMilestone")), requiredContent: [], optionalContent: ["current_value", "_dynamic_current_value", "target_value", "unit", "next_milestone_name"], fields: {}, variantGroup: "progress_milestone", supportedSettings: [], defaultContent: {} },
2262
+ quantity_breaks: { component: lazy(() => import("./personalization/ProgressMilestone")), requiredContent: [], optionalContent: ["quantity_breaks", "current_value"], fields: {}, variantGroup: "progress_milestone", supportedSettings: [], defaultContent: {} },
2263
+ membership_progress: { component: lazy(() => import("./personalization/ProgressMilestone")), requiredContent: [], optionalContent: ["milestone_steps", "next_milestone_name", "current_value"], fields: {}, variantGroup: "progress_milestone", supportedSettings: [], defaultContent: {} },
2264
+ },
2265
+ },
2266
+ lx_cohort_trust_stack: {
2267
+ category: "personalization",
2268
+ defaultVariant: "full_credentials",
2269
+ variants: {
2270
+ full_credentials: { component: lazy(() => import("./personalization/CohortTrustStack")), requiredContent: [], optionalContent: ["credentials"], fields: {}, variantGroup: "cohort_trust_stack", supportedSettings: [], defaultContent: {} },
2271
+ badge_strip: { component: lazy(() => import("./personalization/CohortTrustStack")), requiredContent: [], optionalContent: ["credentials"], fields: {}, variantGroup: "cohort_trust_stack", supportedSettings: [], defaultContent: {} },
2272
+ clinical_proof: { component: lazy(() => import("./personalization/CohortTrustStack")), requiredContent: [], optionalContent: ["studies"], fields: {}, variantGroup: "cohort_trust_stack", supportedSettings: [], defaultContent: {} },
2273
+ sourcing_transparency: { component: lazy(() => import("./personalization/CohortTrustStack")), requiredContent: [], optionalContent: ["suppliers"], fields: {}, variantGroup: "cohort_trust_stack", supportedSettings: [], defaultContent: {} },
2274
+ },
2275
+ },
2276
+ };
2277
+ /**
2278
+ * Resolve a component from registry by lx_ type and variant.
2279
+ * Handles legacy `category/variant-type` format via normalization.
2280
+ */
2281
+ export function resolveComponent(typeOrComponent, variant) {
2282
+ let lxType = typeOrComponent;
2283
+ let resolvedVariant = variant || "";
2284
+ // Legacy format: "hero/split" → lx_hero + split
2285
+ if (typeOrComponent.includes("/")) {
2286
+ const [category, variantPart] = typeOrComponent.split("/", 2);
2287
+ lxType = `lx_${category.replace(/-/g, "_")}`;
2288
+ resolvedVariant = (variantPart || variant || "").replace(/-/g, "_");
2289
+ }
2290
+ const typeEntry = COMPONENT_REGISTRY[lxType];
2291
+ if (!typeEntry)
2292
+ return null;
2293
+ // Normalize variant hyphens to underscores
2294
+ resolvedVariant = resolvedVariant.replace(/-/g, "_");
2295
+ // Use default variant if none specified
2296
+ if (!resolvedVariant) {
2297
+ resolvedVariant = typeEntry.defaultVariant;
2298
+ }
2299
+ return typeEntry.variants[resolvedVariant] || null;
2300
+ }
2301
+ export const REGISTRY_EXPORT = Object.fromEntries(Object.entries(COMPONENT_REGISTRY).map(([type, entry]) => [
2302
+ type,
2303
+ {
2304
+ category: entry.category,
2305
+ defaultVariant: entry.defaultVariant,
2306
+ variants: Object.fromEntries(Object.entries(entry.variants).map(([variantKey, v]) => [
2307
+ variantKey,
2308
+ {
2309
+ requiredContent: v.requiredContent ?? [],
2310
+ optionalContent: v.optionalContent ?? [],
2311
+ defaultContent: (v.defaultContent ?? {}),
2312
+ supportedSettings: v.supportedSettings ?? [],
2313
+ },
2314
+ ])),
2315
+ },
2316
+ ]));
2317
+ //# sourceMappingURL=registry.js.map