@gem-sdk/core 2.0.0-dev.896 → 2.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 (396) hide show
  1. package/dist/cjs/components/AddOn.js +18 -1
  2. package/dist/cjs/components/ComponentAnimation.js +17 -0
  3. package/dist/cjs/components/ComponentToolbarPreview.js +752 -1
  4. package/dist/cjs/components/ComponentWrapper.js +61 -1
  5. package/dist/cjs/components/ComponentWrapperPreview.js +213 -1
  6. package/dist/cjs/components/Empty.js +7 -1
  7. package/dist/cjs/components/InteractionSuffix.js +42 -0
  8. package/dist/cjs/components/Render.js +75 -1
  9. package/dist/cjs/components/Render.liquid.js +313 -17
  10. package/dist/cjs/components/RenderBlock.js +54 -1
  11. package/dist/cjs/components/RenderCustomCode.js +59 -3
  12. package/dist/cjs/components/RenderPreview.js +67 -1
  13. package/dist/cjs/components/RenderSection.js +23 -1
  14. package/dist/cjs/components/ai-generator/AIContentGenerator.js +252 -1
  15. package/dist/cjs/components/ai-generator/AIGenContentLoading.js +85 -1
  16. package/dist/cjs/components/ai-generator/components/PickProduct.js +220 -1
  17. package/dist/cjs/components/ai-generator/components/ToneAndVoice.js +77 -1
  18. package/dist/cjs/components/ai-generator/hooks/useCheckingProductInside.js +47 -0
  19. package/dist/cjs/components/ai-generator/hooks/useFlipPopup.js +110 -0
  20. package/dist/cjs/components/ai-generator/hooks/useGettingGenerateRequest.js +37 -1
  21. package/dist/cjs/components/ai-generator/hooks/useListenEventGenerate.js +70 -1
  22. package/dist/cjs/components/ai-generator/icons/AIIcon.js +67 -1
  23. package/dist/cjs/components/ai-generator/icons/CloseIcon.js +19 -1
  24. package/dist/cjs/components/ai-generator/icons/DropdownIcon.js +37 -1
  25. package/dist/cjs/components/ai-generator/icons/SearchIcon.js +21 -1
  26. package/dist/cjs/components/ai-generator/icons/ShowMoreIcon.js +21 -1
  27. package/dist/cjs/components/ai-generator/icons/UpgradeIcon.js +27 -0
  28. package/dist/cjs/components/ai-generator/icons/WarningIcon.js +31 -0
  29. package/dist/cjs/components/constant.js +83 -1
  30. package/dist/cjs/components/resize/Resize.js +16 -1
  31. package/dist/cjs/components/resize/Spacing.js +260 -1
  32. package/dist/cjs/components/src/product/helpers/variant-presets.js +56 -1
  33. package/dist/cjs/components/theme-section/CreateThemeSection.js +123 -1
  34. package/dist/cjs/components/theme-section/ThemeSectionStatus.js +45 -1
  35. package/dist/cjs/components/theme-section/ThemeSectionTooltip.js +126 -1
  36. package/dist/cjs/components/toolbar/Tooltip.js +28 -1
  37. package/dist/cjs/contexts/AddonContext.js +36 -1
  38. package/dist/cjs/contexts/ArticleContext.js +39 -1
  39. package/dist/cjs/contexts/ArticleListContext.js +31 -1
  40. package/dist/cjs/contexts/BuilderComponent.js +34 -1
  41. package/dist/cjs/contexts/BuilderContext.js +39 -1
  42. package/dist/cjs/contexts/BuilderPreviewContext.js +486 -1
  43. package/dist/cjs/contexts/CartLineContext.js +29 -1
  44. package/dist/cjs/contexts/CollectionContext.js +38 -1
  45. package/dist/cjs/contexts/ModalContext.js +47 -1
  46. package/dist/cjs/contexts/PageContext.js +104 -1
  47. package/dist/cjs/contexts/ProductContext.js +177 -1
  48. package/dist/cjs/contexts/ProductListContext.js +32 -1
  49. package/dist/cjs/contexts/SectionContext.js +53 -1
  50. package/dist/cjs/contexts/ShopContext.js +107 -1
  51. package/dist/cjs/graphql/fragments/analytic.generated.js +6 -2
  52. package/dist/cjs/graphql/fragments/collection-detail.generated.js +6 -2
  53. package/dist/cjs/graphql/fragments/collection-product.generated.js +6 -2
  54. package/dist/cjs/graphql/fragments/collection.generated.js +6 -2
  55. package/dist/cjs/graphql/fragments/custom-code.generated.js +6 -2
  56. package/dist/cjs/graphql/fragments/custom-font.generated.js +6 -2
  57. package/dist/cjs/graphql/fragments/data-seo.generated.js +6 -2
  58. package/dist/cjs/graphql/fragments/media.generated.js +6 -2
  59. package/dist/cjs/graphql/fragments/preview-theme-page.generated.js +39 -0
  60. package/dist/cjs/graphql/fragments/product-little.generated.js +7 -2
  61. package/dist/cjs/graphql/fragments/product-option-value.generated.js +6 -2
  62. package/dist/cjs/graphql/fragments/product-option.generated.js +6 -2
  63. package/dist/cjs/graphql/fragments/product.generated.js +6 -2
  64. package/dist/cjs/graphql/fragments/published-custom-section.generated.js +6 -2
  65. package/dist/cjs/graphql/fragments/published-page-section.generated.js +6 -2
  66. package/dist/cjs/graphql/fragments/published-theme-page.generated.js +10 -28
  67. package/dist/cjs/graphql/fragments/published-theme-style.generated.js +6 -2
  68. package/dist/cjs/graphql/fragments/selected-option.generated.js +6 -2
  69. package/dist/cjs/graphql/fragments/variant.generated.js +6 -2
  70. package/dist/cjs/graphql/mutations/page-view-up.generated.js +8 -4
  71. package/dist/cjs/graphql/queries/articles.generated.js +61 -0
  72. package/dist/cjs/graphql/queries/blogs.generated.js +69 -0
  73. package/dist/cjs/graphql/queries/collection-detail-filter.generated.js +16 -2
  74. package/dist/cjs/graphql/queries/collection.generated.js +14 -2
  75. package/dist/cjs/graphql/queries/collections.generated.js +9 -2
  76. package/dist/cjs/graphql/queries/preview-page.generated.js +16 -8
  77. package/dist/cjs/graphql/queries/product-little-detail.generated.js +11 -2
  78. package/dist/cjs/graphql/queries/product-medias.generated.js +8 -2
  79. package/dist/cjs/graphql/queries/product-value-label.generated.js +6 -2
  80. package/dist/cjs/graphql/queries/product-variants.generated.js +10 -2
  81. package/dist/cjs/graphql/queries/products.generated.js +17 -3
  82. package/dist/cjs/graphql/queries/published-shop-metas.js +15 -0
  83. package/dist/cjs/graphql/queries/published-theme-pages.generated.js +15 -2
  84. package/dist/cjs/graphql/queries/store-property.generated.js +6 -2
  85. package/dist/cjs/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +6 -2
  86. package/dist/cjs/graphql-app-api/queries/LibraryTemplate.generated.js +6 -2
  87. package/dist/cjs/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +6 -2
  88. package/dist/cjs/graphql-app-api/queries/ShopLibraryPage.generated.js +17 -0
  89. package/dist/cjs/graphql-app-api/queries/ThemePage.generated.js +6 -2
  90. package/dist/cjs/helpers/GlobalEvent.js +19 -1
  91. package/dist/cjs/helpers/align.js +19 -0
  92. package/dist/cjs/helpers/animations.js +222 -1
  93. package/dist/cjs/helpers/background.js +235 -1
  94. package/dist/cjs/helpers/borders.js +198 -4
  95. package/dist/cjs/helpers/carousel.js +55 -1
  96. package/dist/cjs/helpers/clone-deep.js +5 -1
  97. package/dist/cjs/helpers/cls.js +16 -1
  98. package/dist/cjs/helpers/colors.js +184 -1
  99. package/dist/cjs/helpers/compose-advance-style.js +327 -1
  100. package/dist/cjs/helpers/constant.js +23 -1
  101. package/dist/cjs/helpers/convert.js +7 -1
  102. package/dist/cjs/helpers/covert-entities-html.js +19 -1
  103. package/dist/cjs/helpers/css-variable.js +7 -1
  104. package/dist/cjs/helpers/email.js +11 -1
  105. package/dist/cjs/helpers/filter-toolbar-preview.js +14 -1
  106. package/dist/cjs/helpers/flatten-connection.js +9 -1
  107. package/dist/cjs/helpers/get-resonsive-value.js +36 -1
  108. package/dist/cjs/helpers/get-shortname.js +92 -1
  109. package/dist/cjs/helpers/icon-list.js +61 -1
  110. package/dist/cjs/helpers/interaction/index.js +134 -0
  111. package/dist/cjs/helpers/is-browser.js +9 -1
  112. package/dist/cjs/helpers/is-defined.js +7 -1
  113. package/dist/cjs/helpers/is-empty-children.js +15 -1
  114. package/dist/cjs/helpers/is-safari.js +9 -1
  115. package/dist/cjs/helpers/layout.js +59 -1
  116. package/dist/cjs/helpers/load-script.js +31 -1
  117. package/dist/cjs/helpers/loop-component.js +16 -0
  118. package/dist/cjs/helpers/make-style.js +163 -1
  119. package/dist/cjs/helpers/normalize-builder-data.js +23 -1
  120. package/dist/cjs/helpers/pascal-to-kebab-case.js +7 -0
  121. package/dist/cjs/helpers/prefetch-queries.js +78 -1
  122. package/dist/cjs/helpers/product.js +48 -1
  123. package/dist/cjs/helpers/queries/get-collection.js +226 -1
  124. package/dist/cjs/helpers/queries/get-collections.js +21 -1
  125. package/dist/cjs/helpers/queries/get-product-by-slug.js +125 -1
  126. package/dist/cjs/helpers/queries/get-product.js +154 -1
  127. package/dist/cjs/helpers/queries/get-products.js +214 -1
  128. package/dist/cjs/helpers/query.js +29 -1
  129. package/dist/cjs/helpers/radius.js +140 -6
  130. package/dist/cjs/helpers/render.js +78 -1
  131. package/dist/cjs/helpers/shadow.js +69 -1
  132. package/dist/cjs/helpers/size.js +206 -4
  133. package/dist/cjs/helpers/spacing.js +43 -1
  134. package/dist/cjs/helpers/third-party/addAppBlockId.js +20 -0
  135. package/dist/cjs/helpers/third-party/appConfig.js +234 -0
  136. package/dist/cjs/helpers/third-party/appSetting.js +661 -0
  137. package/dist/cjs/helpers/third-party/composeAppBlockId.js +11 -0
  138. package/dist/cjs/helpers/third-party/constant.js +43 -0
  139. package/dist/cjs/helpers/third-party/generateAppBlockConfigs.js +34 -0
  140. package/dist/cjs/helpers/third-party/getAppBlockConfig.js +47 -0
  141. package/dist/cjs/helpers/third-party/getAppBlockType.js +12 -0
  142. package/dist/cjs/helpers/third-party/getAppBlocks.js +30 -0
  143. package/dist/cjs/helpers/third-party/mergeBlock.js +19 -0
  144. package/dist/cjs/helpers/third-party/mergeBlockOrder.js +47 -0
  145. package/dist/cjs/helpers/third-party/removeGPAppItems.js +18 -0
  146. package/dist/cjs/helpers/tracking/fpixel.js +28 -1
  147. package/dist/cjs/helpers/tracking/gtag.js +93 -1
  148. package/dist/cjs/helpers/tracking/tiktokpixel.js +17 -1
  149. package/dist/cjs/helpers/typography.js +160 -17
  150. package/dist/cjs/helpers/variant.js +11 -1
  151. package/dist/cjs/hooks/animation/useAnimationActions.js +39 -1
  152. package/dist/cjs/hooks/animation/useAnimationConfig.js +30 -1
  153. package/dist/cjs/hooks/animation/useAnimationPreview.js +31 -1
  154. package/dist/cjs/hooks/animation/useAnimationTarget.js +122 -1
  155. package/dist/cjs/hooks/animation/useApplyAnimation.js +89 -1
  156. package/dist/cjs/hooks/articles/useArticlesQuery.js +33 -1
  157. package/dist/cjs/hooks/cart/use-add-to-cart.js +20 -1
  158. package/dist/cjs/hooks/cart/use-cart-data.js +28 -1
  159. package/dist/cjs/hooks/cart/use-cart-discount-codes-update.js +20 -1
  160. package/dist/cjs/hooks/cart/use-cart-note-update.js +20 -1
  161. package/dist/cjs/hooks/cart/use-create-cart.js +22 -1
  162. package/dist/cjs/hooks/cart/use-remove-cart-item.js +20 -1
  163. package/dist/cjs/hooks/cart/use-update-cart-item.js +20 -1
  164. package/dist/cjs/hooks/shop/use-collection-query.js +22 -1
  165. package/dist/cjs/hooks/shop/use-collections-query.js +17 -1
  166. package/dist/cjs/hooks/shop/use-product-query.js +22 -1
  167. package/dist/cjs/hooks/shop/use-products-query.js +63 -1
  168. package/dist/cjs/hooks/shop.js +126 -1
  169. package/dist/cjs/hooks/use-current-device.js +30 -1
  170. package/dist/cjs/hooks/use-lazy-video.js +15 -1
  171. package/dist/cjs/hooks/useAnimations.js +29 -1
  172. package/dist/cjs/hooks/useCartId.js +44 -1
  173. package/dist/cjs/hooks/useCartLine.js +11 -1
  174. package/dist/cjs/hooks/useCartUI.js +48 -1
  175. package/dist/cjs/hooks/useCollection.js +9 -1
  176. package/dist/cjs/hooks/useFetchHandle.js +13 -1
  177. package/dist/cjs/hooks/useFormatMoney.js +75 -1
  178. package/dist/cjs/hooks/useInitialSwatchesOptions.js +128 -1
  179. package/dist/cjs/hooks/useInteraction.js +19 -0
  180. package/dist/cjs/hooks/useIsomorphicLayoutEffect.js +10 -1
  181. package/dist/cjs/hooks/useLoadScript.js +32 -1
  182. package/dist/cjs/hooks/useMoney.js +84 -1
  183. package/dist/cjs/hooks/usePrevious.js +19 -1
  184. package/dist/cjs/hooks/useProduct.js +245 -1
  185. package/dist/cjs/hooks/useProductList.js +21 -1
  186. package/dist/cjs/hooks/useSuspenseFetch.js +27 -1
  187. package/dist/cjs/hooks/useSwatchesOptions.js +41 -1
  188. package/dist/cjs/hooks/useToolbarPostPurchase.js +89 -1
  189. package/dist/cjs/index.js +416 -1
  190. package/dist/cjs/types/animations.js +49 -1
  191. package/dist/cjs/types/appAPI.js +2 -1
  192. package/dist/cjs/types/custom.js +52 -0
  193. package/dist/cjs/types/global-style.js +15 -1
  194. package/dist/cjs/types/shop.js +2 -1
  195. package/dist/cjs/web-components/src/helpers/styles/constant.js +9 -1
  196. package/dist/esm/components/AddOn.js +14 -1
  197. package/dist/esm/components/ComponentAnimation.js +13 -0
  198. package/dist/esm/components/ComponentToolbarPreview.js +748 -1
  199. package/dist/esm/components/ComponentWrapper.js +57 -1
  200. package/dist/esm/components/ComponentWrapperPreview.js +209 -1
  201. package/dist/esm/components/Empty.js +3 -1
  202. package/dist/esm/components/InteractionSuffix.js +40 -0
  203. package/dist/esm/components/Render.js +71 -1
  204. package/dist/esm/components/Render.liquid.js +307 -17
  205. package/dist/esm/components/RenderBlock.js +50 -1
  206. package/dist/esm/components/RenderCustomCode.js +55 -3
  207. package/dist/esm/components/RenderPreview.js +63 -1
  208. package/dist/esm/components/RenderSection.js +19 -1
  209. package/dist/esm/components/ai-generator/AIContentGenerator.js +250 -1
  210. package/dist/esm/components/ai-generator/AIGenContentLoading.js +83 -1
  211. package/dist/esm/components/ai-generator/components/PickProduct.js +218 -1
  212. package/dist/esm/components/ai-generator/components/ToneAndVoice.js +75 -1
  213. package/dist/esm/components/ai-generator/hooks/useCheckingProductInside.js +45 -0
  214. package/dist/esm/components/ai-generator/hooks/useFlipPopup.js +108 -0
  215. package/dist/esm/components/ai-generator/hooks/useGettingGenerateRequest.js +35 -1
  216. package/dist/esm/components/ai-generator/hooks/useListenEventGenerate.js +68 -1
  217. package/dist/esm/components/ai-generator/icons/AIIcon.js +65 -1
  218. package/dist/esm/components/ai-generator/icons/CloseIcon.js +17 -1
  219. package/dist/esm/components/ai-generator/icons/DropdownIcon.js +34 -1
  220. package/dist/esm/components/ai-generator/icons/SearchIcon.js +19 -1
  221. package/dist/esm/components/ai-generator/icons/ShowMoreIcon.js +19 -1
  222. package/dist/esm/components/ai-generator/icons/UpgradeIcon.js +25 -0
  223. package/dist/esm/components/ai-generator/icons/WarningIcon.js +29 -0
  224. package/dist/esm/components/constant.js +76 -1
  225. package/dist/esm/components/resize/Resize.js +12 -1
  226. package/dist/esm/components/resize/Spacing.js +256 -1
  227. package/dist/esm/components/src/product/helpers/variant-presets.js +54 -1
  228. package/dist/esm/components/theme-section/CreateThemeSection.js +121 -1
  229. package/dist/esm/components/theme-section/ThemeSectionStatus.js +43 -1
  230. package/dist/esm/components/theme-section/ThemeSectionTooltip.js +124 -1
  231. package/dist/esm/components/toolbar/Tooltip.js +24 -1
  232. package/dist/esm/contexts/AddonContext.js +32 -1
  233. package/dist/esm/contexts/ArticleContext.js +36 -1
  234. package/dist/esm/contexts/ArticleListContext.js +27 -1
  235. package/dist/esm/contexts/BuilderComponent.js +31 -1
  236. package/dist/esm/contexts/BuilderContext.js +36 -1
  237. package/dist/esm/contexts/BuilderPreviewContext.js +483 -1
  238. package/dist/esm/contexts/CartLineContext.js +26 -1
  239. package/dist/esm/contexts/CollectionContext.js +35 -1
  240. package/dist/esm/contexts/ModalContext.js +44 -1
  241. package/dist/esm/contexts/PageContext.js +101 -1
  242. package/dist/esm/contexts/ProductContext.js +174 -1
  243. package/dist/esm/contexts/ProductListContext.js +28 -1
  244. package/dist/esm/contexts/SectionContext.js +49 -1
  245. package/dist/esm/contexts/ShopContext.js +104 -1
  246. package/dist/esm/graphql/fragments/analytic.generated.js +4 -2
  247. package/dist/esm/graphql/fragments/collection-detail.generated.js +4 -2
  248. package/dist/esm/graphql/fragments/collection-product.generated.js +4 -2
  249. package/dist/esm/graphql/fragments/collection.generated.js +4 -2
  250. package/dist/esm/graphql/fragments/custom-code.generated.js +4 -2
  251. package/dist/esm/graphql/fragments/custom-font.generated.js +4 -2
  252. package/dist/esm/graphql/fragments/data-seo.generated.js +4 -2
  253. package/dist/esm/graphql/fragments/media.generated.js +4 -2
  254. package/dist/esm/graphql/fragments/preview-theme-page.generated.js +37 -0
  255. package/dist/esm/graphql/fragments/product-little.generated.js +5 -2
  256. package/dist/esm/graphql/fragments/product-option-value.generated.js +4 -2
  257. package/dist/esm/graphql/fragments/product-option.generated.js +4 -2
  258. package/dist/esm/graphql/fragments/product.generated.js +4 -2
  259. package/dist/esm/graphql/fragments/published-custom-section.generated.js +4 -2
  260. package/dist/esm/graphql/fragments/published-page-section.generated.js +4 -2
  261. package/dist/esm/graphql/fragments/published-theme-page.generated.js +8 -28
  262. package/dist/esm/graphql/fragments/published-theme-style.generated.js +4 -2
  263. package/dist/esm/graphql/fragments/selected-option.generated.js +4 -2
  264. package/dist/esm/graphql/fragments/variant.generated.js +4 -2
  265. package/dist/esm/graphql/mutations/page-view-up.generated.js +6 -4
  266. package/dist/esm/graphql/queries/articles.generated.js +59 -0
  267. package/dist/esm/graphql/queries/blogs.generated.js +67 -0
  268. package/dist/esm/graphql/queries/collection-detail-filter.generated.js +22 -10
  269. package/dist/esm/graphql/queries/collection.generated.js +18 -8
  270. package/dist/esm/graphql/queries/collections.generated.js +8 -3
  271. package/dist/esm/graphql/queries/preview-page.generated.js +16 -10
  272. package/dist/esm/graphql/queries/product-little-detail.generated.js +12 -5
  273. package/dist/esm/graphql/queries/product-medias.generated.js +6 -2
  274. package/dist/esm/graphql/queries/product-value-label.generated.js +4 -2
  275. package/dist/esm/graphql/queries/product-variants.generated.js +10 -4
  276. package/dist/esm/graphql/queries/products.generated.js +20 -9
  277. package/dist/esm/graphql/queries/published-shop-metas.js +13 -0
  278. package/dist/esm/graphql/queries/published-theme-pages.generated.js +20 -9
  279. package/dist/esm/graphql/queries/store-property.generated.js +4 -2
  280. package/dist/esm/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +4 -2
  281. package/dist/esm/graphql-app-api/queries/LibraryTemplate.generated.js +4 -2
  282. package/dist/esm/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +4 -2
  283. package/dist/esm/graphql-app-api/queries/ShopLibraryPage.generated.js +15 -0
  284. package/dist/esm/graphql-app-api/queries/ThemePage.generated.js +4 -2
  285. package/dist/esm/helpers/GlobalEvent.js +15 -1
  286. package/dist/esm/helpers/align.js +17 -0
  287. package/dist/esm/helpers/animations.js +220 -1
  288. package/dist/esm/helpers/background.js +226 -1
  289. package/dist/esm/helpers/borders.js +189 -4
  290. package/dist/esm/helpers/carousel.js +51 -1
  291. package/dist/esm/helpers/clone-deep.js +3 -1
  292. package/dist/esm/helpers/cls.js +14 -1
  293. package/dist/esm/helpers/colors.js +169 -1
  294. package/dist/esm/helpers/compose-advance-style.js +319 -1
  295. package/dist/esm/helpers/constant.js +19 -1
  296. package/dist/esm/helpers/convert.js +4 -1
  297. package/dist/esm/helpers/covert-entities-html.js +17 -1
  298. package/dist/esm/helpers/css-variable.js +5 -1
  299. package/dist/esm/helpers/email.js +6 -1
  300. package/dist/esm/helpers/filter-toolbar-preview.js +9 -1
  301. package/dist/esm/helpers/flatten-connection.js +7 -1
  302. package/dist/esm/helpers/get-resonsive-value.js +31 -1
  303. package/dist/esm/helpers/get-shortname.js +90 -1
  304. package/dist/esm/helpers/icon-list.js +58 -1
  305. package/dist/esm/helpers/interaction/index.js +132 -0
  306. package/dist/esm/helpers/is-browser.js +5 -1
  307. package/dist/esm/helpers/is-defined.js +5 -1
  308. package/dist/esm/helpers/is-empty-children.js +10 -1
  309. package/dist/esm/helpers/is-safari.js +5 -1
  310. package/dist/esm/helpers/layout.js +54 -1
  311. package/dist/esm/helpers/load-script.js +29 -1
  312. package/dist/esm/helpers/loop-component.js +14 -0
  313. package/dist/esm/helpers/make-style.js +149 -1
  314. package/dist/esm/helpers/normalize-builder-data.js +21 -1
  315. package/dist/esm/helpers/pascal-to-kebab-case.js +5 -0
  316. package/dist/esm/helpers/prefetch-queries.js +76 -1
  317. package/dist/esm/helpers/product.js +44 -1
  318. package/dist/esm/helpers/queries/get-collection.js +223 -1
  319. package/dist/esm/helpers/queries/get-collections.js +19 -1
  320. package/dist/esm/helpers/queries/get-product-by-slug.js +123 -1
  321. package/dist/esm/helpers/queries/get-product.js +150 -1
  322. package/dist/esm/helpers/queries/get-products.js +210 -1
  323. package/dist/esm/helpers/query.js +25 -1
  324. package/dist/esm/helpers/radius.js +132 -6
  325. package/dist/esm/helpers/render.js +70 -1
  326. package/dist/esm/helpers/shadow.js +63 -1
  327. package/dist/esm/helpers/size.js +192 -4
  328. package/dist/esm/helpers/spacing.js +40 -1
  329. package/dist/esm/helpers/third-party/addAppBlockId.js +18 -0
  330. package/dist/esm/helpers/third-party/appConfig.js +200 -0
  331. package/dist/esm/helpers/third-party/appSetting.js +658 -0
  332. package/dist/esm/helpers/third-party/composeAppBlockId.js +9 -0
  333. package/dist/esm/helpers/third-party/constant.js +40 -0
  334. package/dist/esm/helpers/third-party/generateAppBlockConfigs.js +32 -0
  335. package/dist/esm/helpers/third-party/getAppBlockConfig.js +45 -0
  336. package/dist/esm/helpers/third-party/getAppBlockType.js +10 -0
  337. package/dist/esm/helpers/third-party/getAppBlocks.js +28 -0
  338. package/dist/esm/helpers/third-party/mergeBlock.js +17 -0
  339. package/dist/esm/helpers/third-party/mergeBlockOrder.js +45 -0
  340. package/dist/esm/helpers/third-party/removeGPAppItems.js +15 -0
  341. package/dist/esm/helpers/tracking/fpixel.js +24 -1
  342. package/dist/esm/helpers/tracking/gtag.js +87 -1
  343. package/dist/esm/helpers/tracking/tiktokpixel.js +15 -1
  344. package/dist/esm/helpers/typography.js +149 -17
  345. package/dist/esm/helpers/variant.js +9 -1
  346. package/dist/esm/hooks/animation/useAnimationActions.js +37 -1
  347. package/dist/esm/hooks/animation/useAnimationConfig.js +28 -1
  348. package/dist/esm/hooks/animation/useAnimationPreview.js +29 -1
  349. package/dist/esm/hooks/animation/useAnimationTarget.js +120 -1
  350. package/dist/esm/hooks/animation/useApplyAnimation.js +85 -1
  351. package/dist/esm/hooks/articles/useArticlesQuery.js +30 -1
  352. package/dist/esm/hooks/cart/use-add-to-cart.js +18 -1
  353. package/dist/esm/hooks/cart/use-cart-data.js +26 -1
  354. package/dist/esm/hooks/cart/use-cart-discount-codes-update.js +18 -1
  355. package/dist/esm/hooks/cart/use-cart-note-update.js +18 -1
  356. package/dist/esm/hooks/cart/use-create-cart.js +20 -1
  357. package/dist/esm/hooks/cart/use-remove-cart-item.js +18 -1
  358. package/dist/esm/hooks/cart/use-update-cart-item.js +18 -1
  359. package/dist/esm/hooks/shop/use-collection-query.js +20 -1
  360. package/dist/esm/hooks/shop/use-collections-query.js +15 -1
  361. package/dist/esm/hooks/shop/use-product-query.js +20 -1
  362. package/dist/esm/hooks/shop/use-products-query.js +59 -1
  363. package/dist/esm/hooks/shop.js +111 -1
  364. package/dist/esm/hooks/use-current-device.js +28 -1
  365. package/dist/esm/hooks/use-lazy-video.js +13 -1
  366. package/dist/esm/hooks/useAnimations.js +27 -1
  367. package/dist/esm/hooks/useCartId.js +40 -1
  368. package/dist/esm/hooks/useCartLine.js +7 -1
  369. package/dist/esm/hooks/useCartUI.js +44 -1
  370. package/dist/esm/hooks/useCollection.js +7 -1
  371. package/dist/esm/hooks/useFetchHandle.js +11 -1
  372. package/dist/esm/hooks/useFormatMoney.js +71 -1
  373. package/dist/esm/hooks/useInitialSwatchesOptions.js +124 -1
  374. package/dist/esm/hooks/useInteraction.js +17 -0
  375. package/dist/esm/hooks/useIsomorphicLayoutEffect.js +6 -1
  376. package/dist/esm/hooks/useLoadScript.js +28 -1
  377. package/dist/esm/hooks/useMoney.js +80 -1
  378. package/dist/esm/hooks/usePrevious.js +17 -1
  379. package/dist/esm/hooks/useProduct.js +228 -1
  380. package/dist/esm/hooks/useProductList.js +16 -1
  381. package/dist/esm/hooks/useSuspenseFetch.js +23 -1
  382. package/dist/esm/hooks/useSwatchesOptions.js +37 -1
  383. package/dist/esm/hooks/useToolbarPostPurchase.js +87 -1
  384. package/dist/esm/index.js +117 -1
  385. package/dist/esm/types/animations.js +49 -1
  386. package/dist/esm/types/custom.js +52 -0
  387. package/dist/esm/types/global-style.js +12 -1
  388. package/dist/esm/web-components/src/helpers/styles/constant.js +7 -1
  389. package/dist/types/index.d.ts +23183 -17335
  390. package/package.json +5 -3
  391. package/dist/cjs/components/animation/AnimationWrapper.js +0 -1
  392. package/dist/cjs/hooks/animation/animations.js +0 -1
  393. package/dist/cjs/hooks/animation/useLivePageAnimation.js +0 -1
  394. package/dist/esm/components/animation/AnimationWrapper.js +0 -1
  395. package/dist/esm/hooks/animation/animations.js +0 -1
  396. package/dist/esm/hooks/animation/useLivePageAnimation.js +0 -1
@@ -1 +1,319 @@
1
- import{handleConvertBorderStyle as e,handleConvertBorderWidth as t,handleConvertBorderColor as r,getBorderStyle as a}from"./borders.js";import{isColor as s}from"./colors.js";import{layoutComponent as o}from"./constant.js";import{makeStyleKey as i}from"./make-style.js";import{composeRadius as l,getCornerCSSFromGlobal as n}from"./radius.js";import{getStyleShadowState as c,getStyleShadow as p}from"./shadow.js";let composeSpacing=({source:e,spacing:t,type:r,suffix:a=""})=>{let{top:s,left:o,bottom:i,right:l}=t;s&&(e[`--${r}t${a}`]=s),o&&(e[`--${r}l${a}`]=o),i&&(e[`--${r}b${a}`]=i),l&&(e[`--${r}r${a}`]=l)},composeSpacingV2=({source:e,spacing:t,suffix:r="",tag:a=""})=>{if(t&&t.margin){let{top:s,left:i,bottom:l,right:n}=t.margin;s&&(e[`--mt${r}`]=s),i&&(e[`--ml${r}`]=o.includes(a)&&"0px"===i?"auto":i),l&&(e[`--mb${r}`]=l),n&&(e[`--mr${r}`]=o.includes(a)&&"0px"===n?"auto":n)}if(t&&t.padding){let{top:a,left:s,bottom:o,right:i}=t.padding;a&&(e[`--pt${r}`]=a),s&&(e[`--pl${r}`]=s),o&&(e[`--pb${r}`]=o),i&&(e[`--pr${r}`]=i)}},getAttrValue=(e,t,r)=>{if(null!=t)switch(e){case"bgc":case"c":return s(t.toString())?t:`var(--g-c-${t})`;case"d":if(!t)return"none";if(t&&r&&o.includes(r))return"grid";return"block";default:return t}},postPurchasePaddingMapping={loose:"21px",extraLoose:"38px",tight:"9px",extraTight:"5px",base:"14px"},composeAdvanceStyleForPostPurchase=(e,t)=>{if(!e)return{};let r={};return Object.keys(e).forEach(a=>{let s=e[a];if("blockPadding"===a){let e=postPurchasePaddingMapping[s];r["--pb"]=getAttrValue(a,e,t),r["--pt"]=getAttrValue(a,e,t),r["--mb"]="0px",r["--mt"]="0px"}if("inlinePadding"===a){let e=postPurchasePaddingMapping[s];r["--pl"]=getAttrValue(a,e,t),r["--pr"]=getAttrValue(a,e,t)}}),r};function composeAdvanceStyle(s,o,i){if(!s)return{};let d={"--pos":"relative"},u=["desktop","tablet","mobile"],b=["hover","normal"];Object.keys(s).forEach(g=>{let m=s[g];if("cssClass"===g||null==m)return;let f=s.hasBoxShadow?s.hasBoxShadow:{};if("object"==typeof m){if(Array.isArray(m))return;Object.keys(m).forEach(i=>{if(u.includes(i)){let a=m[i];if(void 0!==a){if("border"===g&&Object.assign(d,e(m),t(m),r(m)),"rounded"===g&&Object.assign(d,l(m)),"pos"==g&&"static"==a&&(a="relative"),"desktop"===i)switch(g){case"padding":composeSpacing({source:d,spacing:a,type:"p"});break;case"margin":composeSpacing({source:d,spacing:a,type:"m"});break;case"spacing-setting":composeSpacingV2({source:d,spacing:a,tag:o});break;case"m":case"p":break;default:d[`--${g}`]=getAttrValue(g,a,o)}else switch(g){case"padding":composeSpacing({source:d,spacing:a,type:"p",suffix:`-${i}`});break;case"margin":composeSpacing({source:d,spacing:a,type:"m",suffix:`-${i}`});break;case"spacing-setting":composeSpacingV2({source:d,spacing:a,suffix:`-${i}`,tag:o});break;case"m":case"p":break;default:d[`--${g}-${i}`]=getAttrValue(g,a,o)}}}else if(b.includes(i))switch(g){case"hasBoxShadow":break;case"boxShadow":Object.assign(d,c(m,"box-shadow",f))}else"border"===g&&("none"===m.border&&(m.border="solid",m.color="#121212",m.isCustom=!0,m.width="0px",m.position="all"),Object.assign(d,a(m))),"rounded"===g&&Object.assign(d,n(m)),"hasBoxShadow"===g&&Object.assign(d,p({value:s.boxShadow,styleAppliedFor:"box-shadow",isEnableShadow:s.hasBoxShadow})),"boxShadow"===g&&Object.assign(d,p({value:m,styleAppliedFor:"box-shadow",isEnableShadow:s.hasBoxShadow}))})}else d[`--${g}`]=getAttrValue(g,m,o),"hasBoxShadow"===g&&s.boxShadow&&Object.assign(d,p({value:s.boxShadow,styleAppliedFor:"box-shadow",isEnableShadow:s.hasBoxShadow}));if("blockPadding"===g&&"POST_PURCHASE"===i){let e=postPurchasePaddingMapping[m];d["--pb"]=getAttrValue(g,e,o),d["--pt"]=getAttrValue(g,e,o),d["--mb"]="0px",d["--mt"]="0px"}if("inlinePadding"===g&&"POST_PURCHASE"===i){let e=postPurchasePaddingMapping[m];d["--pl"]=getAttrValue(g,e,o),d["--pr"]=getAttrValue(g,e,o)}});let g="POST_PURCHASE"===i?composeAdvanceStyleForPostPurchase(s,o):{};return{...d,...g}}let splitStyle=(e,t={})=>{let r=e.map(e=>i(e)).flat(),a=Object.keys(t).filter(e=>r.includes(e)),s=a.reduce((e,r)=>({...e,[r]:t[r]}),{}),o=Object.keys(t).filter(e=>!a.includes(e)).reduce((e,r)=>({...e,[r]:t[r]}),{});return[s,o]},filterAttrInStyle=(e,t)=>{if(!e||!t)return{};let r={...e};return Object.entries(r).forEach(([e])=>{t.includes(e)||delete r[e]}),r},removeAttrInStyle=(e,t)=>{if(!e||!t)return{};let r={...e};return Object.entries(r).forEach(([e])=>{t.includes(e)&&delete r[e]}),r},filterCornerInStyle=e=>{let t=["--bblr","--bbrr","--btlr","--btrr"];return filterAttrInStyle(e,t)},removePaddingYInStyle=e=>{let t=["--pt","--pt-tablet","--pt-mobile","--pb","--pb-tablet","--pb-mobile"];return removeAttrInStyle(e,t)};export{composeAdvanceStyle,composeAdvanceStyleForPostPurchase,filterAttrInStyle,filterCornerInStyle,removeAttrInStyle,removePaddingYInStyle,splitStyle};
1
+ import { handleConvertBorderStyle, handleConvertBorderWidth, handleConvertBorderColor, getBorderStyle } from './borders.js';
2
+ import { isColor } from './colors.js';
3
+ import { layoutComponent } from './constant.js';
4
+ import { makeStyleKey } from './make-style.js';
5
+ import { composeRadius, getCornerCSSFromGlobal } from './radius.js';
6
+ import { getResponsiveStyleShadow, getStyleShadowState, getStyleShadow } from './shadow.js';
7
+
8
+ const composeSpacing = ({ source, spacing, type, suffix = '' })=>{
9
+ const { top, left, bottom, right } = spacing;
10
+ if (top) source[`--${type}t${suffix}`] = top;
11
+ if (left) source[`--${type}l${suffix}`] = left;
12
+ if (bottom) source[`--${type}b${suffix}`] = bottom;
13
+ if (right) source[`--${type}r${suffix}`] = right;
14
+ };
15
+ const composeSpacingV2 = ({ source, spacing, suffix = '', tag = '' })=>{
16
+ if (spacing && spacing.margin) {
17
+ const { top, left, bottom, right } = spacing.margin;
18
+ if (top) source[`--mt${suffix}`] = top;
19
+ if (left) source[`--ml${suffix}`] = layoutComponent.includes(tag) && left === '0px' ? 'auto' : left;
20
+ if (bottom) source[`--mb${suffix}`] = bottom;
21
+ if (right) source[`--mr${suffix}`] = layoutComponent.includes(tag) && right === '0px' ? 'auto' : right;
22
+ }
23
+ if (spacing && spacing.padding) {
24
+ const { top, left, bottom, right } = spacing.padding;
25
+ if (top) source[`--pt${suffix}`] = top;
26
+ if (left) source[`--pl${suffix}`] = left;
27
+ if (bottom) source[`--pb${suffix}`] = bottom;
28
+ if (right) source[`--pr${suffix}`] = right;
29
+ }
30
+ };
31
+ const getAttrValue = (attr, value, tag)=>{
32
+ if (value === undefined || value === null) return undefined;
33
+ switch(attr){
34
+ case 'bgc':
35
+ case 'c':
36
+ return isColor(value.toString()) ? value : `var(--g-c-${value})`;
37
+ case 'd':
38
+ if (!value) return 'none';
39
+ if (value && tag && layoutComponent.includes(tag)) return 'grid';
40
+ return 'block';
41
+ case 'animation':
42
+ return undefined;
43
+ case 'hasBoxShadow':
44
+ return undefined;
45
+ case 'rounded':
46
+ return undefined;
47
+ case 'boxShadow':
48
+ return undefined;
49
+ case 'border':
50
+ return undefined;
51
+ default:
52
+ return value;
53
+ }
54
+ };
55
+ const postPurchasePaddingMapping = {
56
+ loose: '21px',
57
+ extraLoose: '38px',
58
+ tight: '9px',
59
+ extraTight: '5px',
60
+ base: '14px'
61
+ };
62
+ const composeAdvanceStyleForPostPurchase = (data, tag)=>{
63
+ if (!data) return {};
64
+ const styles = {};
65
+ Object.keys(data).forEach((attr)=>{
66
+ const value = data[attr];
67
+ if (attr === 'blockPadding') {
68
+ const valueMapped = postPurchasePaddingMapping[value];
69
+ styles[`--pb`] = getAttrValue(attr, valueMapped, tag);
70
+ styles[`--pt`] = getAttrValue(attr, valueMapped, tag);
71
+ styles[`--mb`] = '0px';
72
+ styles[`--mt`] = '0px';
73
+ }
74
+ if (attr === 'inlinePadding') {
75
+ const valueMapped = postPurchasePaddingMapping[value];
76
+ styles[`--pl`] = getAttrValue(attr, valueMapped, tag);
77
+ styles[`--pr`] = getAttrValue(attr, valueMapped, tag);
78
+ }
79
+ });
80
+ return styles;
81
+ };
82
+ function composeAdvanceStyle(data, tag, pageType) {
83
+ if (!data) return {};
84
+ const styles = {};
85
+ const devices = [
86
+ 'desktop',
87
+ 'tablet',
88
+ 'mobile'
89
+ ];
90
+ const states = [
91
+ 'hover',
92
+ 'normal'
93
+ ];
94
+ Object.keys(data).forEach((attr)=>{
95
+ const value = data[attr];
96
+ if (attr === 'cssClass') return;
97
+ if (value === undefined || value === null) return;
98
+ const hasBoxShadow = data.hasBoxShadow ? data.hasBoxShadow : {};
99
+ if (typeof value === 'object') {
100
+ if (Array.isArray(value)) return;
101
+ Object.keys(value).forEach((composeAttr)=>{
102
+ if (devices.includes(composeAttr)) {
103
+ const deviceValue = value[composeAttr];
104
+ if (deviceValue !== undefined) {
105
+ // Responsive border with state
106
+ if (attr === 'border') {
107
+ Object.assign(styles, handleConvertBorderStyle(value), handleConvertBorderWidth(value), handleConvertBorderColor(value));
108
+ }
109
+ if (attr === 'rounded') {
110
+ Object.assign(styles, composeRadius(value));
111
+ }
112
+ if (attr === 'boxShadow') {
113
+ Object.assign(styles, getResponsiveStyleShadow(value, 'box-shadow', hasBoxShadow));
114
+ }
115
+ const styleValue = getAttrValue(attr, deviceValue, tag);
116
+ if (composeAttr === 'desktop') {
117
+ switch(attr){
118
+ case 'padding':
119
+ composeSpacing({
120
+ source: styles,
121
+ spacing: deviceValue,
122
+ type: 'p'
123
+ });
124
+ break;
125
+ case 'margin':
126
+ composeSpacing({
127
+ source: styles,
128
+ spacing: deviceValue,
129
+ type: 'm'
130
+ });
131
+ break;
132
+ case 'spacing-setting':
133
+ composeSpacingV2({
134
+ source: styles,
135
+ spacing: deviceValue,
136
+ tag
137
+ });
138
+ break;
139
+ case 'm':
140
+ case 'p':
141
+ break;
142
+ default:
143
+ styleValue && (styles[`--${attr}`] = styleValue);
144
+ break;
145
+ }
146
+ } else {
147
+ switch(attr){
148
+ case 'padding':
149
+ composeSpacing({
150
+ source: styles,
151
+ spacing: deviceValue,
152
+ type: 'p',
153
+ suffix: `-${composeAttr}`
154
+ });
155
+ break;
156
+ case 'margin':
157
+ composeSpacing({
158
+ source: styles,
159
+ spacing: deviceValue,
160
+ type: 'm',
161
+ suffix: `-${composeAttr}`
162
+ });
163
+ break;
164
+ case 'spacing-setting':
165
+ composeSpacingV2({
166
+ source: styles,
167
+ spacing: deviceValue,
168
+ suffix: `-${composeAttr}`,
169
+ tag
170
+ });
171
+ break;
172
+ case 'm':
173
+ case 'p':
174
+ break;
175
+ default:
176
+ styleValue && (styles[`--${attr}-${composeAttr}`] = styleValue);
177
+ break;
178
+ }
179
+ }
180
+ }
181
+ } else if (states.includes(composeAttr)) {
182
+ switch(attr){
183
+ case 'hasBoxShadow':
184
+ break;
185
+ case 'boxShadow':
186
+ Object.assign(styles, getStyleShadowState(value, 'box-shadow', hasBoxShadow));
187
+ break;
188
+ }
189
+ } else {
190
+ if (attr === 'border') {
191
+ const borderStyle = value;
192
+ if (borderStyle.border === 'none') {
193
+ borderStyle.border = 'solid';
194
+ borderStyle.color = '#121212';
195
+ borderStyle.isCustom = true;
196
+ borderStyle.width = '0px';
197
+ borderStyle.position = 'all';
198
+ }
199
+ Object.assign(styles, getBorderStyle(borderStyle));
200
+ }
201
+ if (attr === 'rounded') {
202
+ Object.assign(styles, getCornerCSSFromGlobal(value));
203
+ }
204
+ if (attr === 'hasBoxShadow') {
205
+ Object.assign(styles, getStyleShadow({
206
+ value: data.boxShadow,
207
+ styleAppliedFor: 'box-shadow',
208
+ isEnableShadow: data.hasBoxShadow
209
+ }));
210
+ }
211
+ if (attr === 'boxShadow') {
212
+ Object.assign(styles, getStyleShadow({
213
+ value: value,
214
+ styleAppliedFor: 'box-shadow',
215
+ isEnableShadow: data.hasBoxShadow
216
+ }));
217
+ }
218
+ }
219
+ });
220
+ } else {
221
+ const styleValue = getAttrValue(attr, value, tag);
222
+ styleValue && (styles[`--${attr}`] = styleValue);
223
+ if (attr === 'hasBoxShadow' && data.boxShadow) {
224
+ Object.assign(styles, getStyleShadow({
225
+ value: data.boxShadow,
226
+ styleAppliedFor: 'box-shadow',
227
+ isEnableShadow: data.hasBoxShadow
228
+ }));
229
+ }
230
+ }
231
+ if (attr === 'blockPadding' && pageType === 'POST_PURCHASE') {
232
+ const valueMapped = postPurchasePaddingMapping[value];
233
+ styles[`--pb`] = getAttrValue(attr, valueMapped, tag);
234
+ styles[`--pt`] = getAttrValue(attr, valueMapped, tag);
235
+ styles[`--mb`] = '0px';
236
+ styles[`--mt`] = '0px';
237
+ }
238
+ if (attr === 'inlinePadding' && pageType === 'POST_PURCHASE') {
239
+ const valueMapped = postPurchasePaddingMapping[value];
240
+ styles[`--pl`] = getAttrValue(attr, valueMapped, tag);
241
+ styles[`--pr`] = getAttrValue(attr, valueMapped, tag);
242
+ }
243
+ });
244
+ const advancedPostPurchaseStyles = pageType === 'POST_PURCHASE' ? composeAdvanceStyleForPostPurchase(data, tag) : {};
245
+ return {
246
+ ...styles,
247
+ ...advancedPostPurchaseStyles
248
+ };
249
+ }
250
+ const splitStyle = (keys, style = {})=>{
251
+ const fullKeys = keys.map((key)=>makeStyleKey(key)).flat();
252
+ const splitKeys = Object.keys(style).filter((key)=>{
253
+ return fullKeys.includes(key);
254
+ });
255
+ const splitStyle = splitKeys.reduce((curr, key)=>{
256
+ return {
257
+ ...curr,
258
+ [key]: style[key]
259
+ };
260
+ }, {});
261
+ const restStyle = Object.keys(style).filter((key)=>{
262
+ return !splitKeys.includes(key);
263
+ }).reduce((curr, key)=>{
264
+ return {
265
+ ...curr,
266
+ [key]: style[key]
267
+ };
268
+ }, {});
269
+ return [
270
+ splitStyle,
271
+ restStyle
272
+ ];
273
+ };
274
+ const filterAttrInStyle = (style, filterKeys)=>{
275
+ if (!style || !filterKeys) return {};
276
+ const newStyle = {
277
+ ...style
278
+ };
279
+ Object.entries(newStyle).forEach(([key])=>{
280
+ if (!filterKeys.includes(key)) {
281
+ delete newStyle[key];
282
+ }
283
+ });
284
+ return newStyle;
285
+ };
286
+ const removeAttrInStyle = (style, filterKeys)=>{
287
+ if (!style || !filterKeys) return {};
288
+ const newStyle = {
289
+ ...style
290
+ };
291
+ Object.entries(newStyle).forEach(([key])=>{
292
+ if (filterKeys.includes(key)) {
293
+ delete newStyle[key];
294
+ }
295
+ });
296
+ return newStyle;
297
+ };
298
+ const filterCornerInStyle = (style)=>{
299
+ const cornerKeys = [
300
+ '--bblr',
301
+ '--bbrr',
302
+ '--btlr',
303
+ '--btrr'
304
+ ];
305
+ return filterAttrInStyle(style, cornerKeys);
306
+ };
307
+ const removePaddingYInStyle = (style)=>{
308
+ const keys = [
309
+ '--pt',
310
+ '--pt-tablet',
311
+ '--pt-mobile',
312
+ '--pb',
313
+ '--pb-tablet',
314
+ '--pb-mobile'
315
+ ];
316
+ return removeAttrInStyle(style, keys);
317
+ };
318
+
319
+ export { composeAdvanceStyle, composeAdvanceStyleForPostPurchase, filterAttrInStyle, filterCornerInStyle, removeAttrInStyle, removePaddingYInStyle, splitStyle };
@@ -1 +1,19 @@
1
- let stateMapping={normal:"",hover:"-hvr",focus:"-focus"},devicesMapping={desktop:"",tablet:"-tablet",mobile:"-mobile"},layoutComponent=["Row","Section","Product","HeroBanner","CollectionBanner"];export{devicesMapping,layoutComponent,stateMapping};
1
+ const stateMapping = {
2
+ normal: '',
3
+ hover: '-hvr',
4
+ focus: '-focus'
5
+ };
6
+ const devicesMapping = {
7
+ desktop: '',
8
+ tablet: '-tablet',
9
+ mobile: '-mobile'
10
+ };
11
+ const layoutComponent = [
12
+ 'Row',
13
+ 'Section',
14
+ 'Product',
15
+ 'HeroBanner',
16
+ 'CollectionBanner'
17
+ ];
18
+
19
+ export { devicesMapping, layoutComponent, stateMapping };
@@ -1 +1,4 @@
1
- let isLocalEnv="local"===process.env.NEXT_CONVERT_ENV,baseAssetURL=process.env.GP_BASE_ASSET_URL||"https://d3kbi0je7pp4lw.cloudfront.net";export{baseAssetURL,isLocalEnv};
1
+ const isLocalEnv = process.env.NEXT_CONVERT_ENV === 'local';
2
+ const baseAssetURL = process.env.GP_BASE_ASSET_URL || 'https://d3kbi0je7pp4lw.cloudfront.net';
3
+
4
+ export { baseAssetURL, isLocalEnv };
@@ -1 +1,17 @@
1
- let convertHTML=e=>{let t={"&amp;":"&","&lt;":"<","&gt;":">","&nbsp;":" "},l=e;for(let r in t)e.indexOf(r)>=0&&(l=l.replaceAll(r,t[r]));return l};export{convertHTML};
1
+ const convertHTML = (str)=>{
2
+ const symbols = {
3
+ '&amp;': '&',
4
+ '&lt;': '<',
5
+ '&gt;': '>',
6
+ '&nbsp;': ' '
7
+ };
8
+ let newStr = str;
9
+ for(const symbol in symbols){
10
+ if (str.indexOf(symbol) >= 0) {
11
+ newStr = newStr.replaceAll(symbol, symbols[symbol]);
12
+ }
13
+ }
14
+ return newStr;
15
+ };
16
+
17
+ export { convertHTML };
@@ -1 +1,5 @@
1
- let genVariable=e=>`var(--g-${e})`;export{genVariable};
1
+ const genVariable = (variableName)=>{
2
+ return `var(--g-${variableName})`;
3
+ };
4
+
5
+ export { genVariable };
@@ -1 +1,6 @@
1
- let validateEmail=a=>{let e=new RegExp(/^(?:[^<>()[\]\\.,;:\s@"]+(?:\.[^<>()[\]\\.,;:\s@"]+)*|".+")@(?:\[\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\]|(?:[a-zA-Z\-\d]+\.)+[a-zA-Z]{2,})$/);return e.test(a)};export{validateEmail as default,validateEmail};
1
+ const validateEmail = (email)=>{
2
+ const emailRegex = new RegExp(/^(?:[^<>()[\]\\.,;:\s@"]+(?:\.[^<>()[\]\\.,;:\s@"]+)*|".+")@(?:\[\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\]|(?:[a-zA-Z\-\d]+\.)+[a-zA-Z]{2,})$/);
3
+ return emailRegex.test(email);
4
+ };
5
+
6
+ export { validateEmail as default, validateEmail };
@@ -1 +1,9 @@
1
- import{Children as e}from"react";import r from"../components/ComponentToolbarPreview.js";let filterToolbarPreview=(o,t=!1)=>{let l=e.toArray(o);return l.filter(e=>t?e?.type==r:e?.type!=r)};export{filterToolbarPreview as default,filterToolbarPreview};
1
+ import { Children } from 'react';
2
+ import ComponentToolbarPreview from '../components/ComponentToolbarPreview.js';
3
+
4
+ const filterToolbarPreview = (children, keep = false)=>{
5
+ const arrChild = Children.toArray(children);
6
+ return arrChild.filter((child)=>!keep ? child?.type != ComponentToolbarPreview : child?.type == ComponentToolbarPreview);
7
+ };
8
+
9
+ export { filterToolbarPreview as default, filterToolbarPreview };
@@ -1 +1,7 @@
1
- let flattenConnection=e=>e?.edges?.map(e=>e.node)??[];export{flattenConnection};
1
+ /**
2
+ * The `flattenConnection` utility transforms a connection object from the Storefront API (for example, [Product-related connections](api/storefront/reference/products/product#connections)) into a flat array of nodes.
3
+ */ const flattenConnection = (connection)=>{
4
+ return connection?.edges?.map((edge)=>edge.node) ?? [];
5
+ };
6
+
7
+ export { flattenConnection };
@@ -1 +1,31 @@
1
- let getResponsiveValue=(e,t)=>t?{desktop:e?.desktop?.[t],tablet:e?.tablet?.[t],mobile:e?.mobile?.[t]}:{},getResponsiveStateValue=(e,t)=>({desktop:t?.desktop?.[e],tablet:t?.tablet?.[e],mobile:t?.mobile?.[e]}),getResponsiveValueByScreen=(e,t,s)=>{switch(t){case"tablet":return e?.tablet??e?.desktop??s;case"mobile":return e?.mobile??e?.tablet??e?.desktop??s;default:return e?.desktop??s}},isColumnDirectionExist=(e,t)=>"desktop"!==t&&"tablet"!==t&&e?.[t]?.cols?.length!==e?.desktop?.cols?.length;export{getResponsiveStateValue,getResponsiveValue,getResponsiveValueByScreen,isColumnDirectionExist};
1
+ const getResponsiveValue = (input, k)=>{
2
+ if (!k) return {};
3
+ return {
4
+ desktop: input?.desktop?.[k],
5
+ tablet: input?.tablet?.[k],
6
+ mobile: input?.mobile?.[k]
7
+ };
8
+ };
9
+ const getResponsiveStateValue = (k, input)=>{
10
+ return {
11
+ desktop: input?.desktop?.[k],
12
+ tablet: input?.tablet?.[k],
13
+ mobile: input?.mobile?.[k]
14
+ };
15
+ };
16
+ const getResponsiveValueByScreen = (value, breakpoint, defaultValue)=>{
17
+ switch(breakpoint){
18
+ case 'tablet':
19
+ return value?.tablet ?? value?.desktop ?? defaultValue;
20
+ case 'mobile':
21
+ return value?.mobile ?? value?.tablet ?? value?.desktop ?? defaultValue;
22
+ default:
23
+ return value?.desktop ?? defaultValue;
24
+ }
25
+ };
26
+ const isColumnDirectionExist = (layout, breakpoint)=>{
27
+ if (breakpoint === 'desktop' || breakpoint === 'tablet') return false;
28
+ return layout?.[breakpoint]?.cols?.length !== layout?.desktop?.cols?.length;
29
+ };
30
+
31
+ export { getResponsiveStateValue, getResponsiveValue, getResponsiveValueByScreen, isColumnDirectionExist };
@@ -1 +1,90 @@
1
- let globalSortNameMapping={"typography-heading-1-fontFamily":"h1-ff","typography-heading-1-fontSize":"h1-size","typography-heading-1-fontWeight":"h1-weight","typography-heading-1-lineHeight":"h1-lh","typography-heading-1-letterSpacing":"h1-ls","typography-heading-1-fontStyle":"h1-fs","typography-heading-2-fontFamily":"h2-ff","typography-heading-2-fontSize":"h2-size","typography-heading-2-fontWeight":"h2-weight","typography-heading-2-lineHeight":"h2-lh","typography-heading-2-letterSpacing":"h2-ls","typography-heading-2-fontStyle":"h2-fs","typography-heading-3-fontFamily":"h3-ff","typography-heading-3-fontSize":"h3-size","typography-heading-3-fontWeight":"h3-weight","typography-heading-3-lineHeight":"h3-lh","typography-heading-3-letterSpacing":"h3-ls","typography-heading-3-fontStyle":"h3-fs","typography-subheading-1-fontFamily":"sh1-ff","typography-subheading-1-fontSize":"sh1-size","typography-subheading-1-fontWeight":"sh1-weight","typography-subheading-1-lineHeight":"sh1-lh","typography-subheading-1-letterSpacing":"sh1-ls","typography-subheading-1-fontStyle":"sh1-fs","typography-subheading-2-fontFamily":"sh2-ff","typography-subheading-2-fontSize":"sh2-size","typography-subheading-2-fontWeight":"sh2-weight","typography-subheading-2-lineHeight":"sh2-lh","typography-subheading-2-letterSpacing":"sh2-ls","typography-subheading-2-fontStyle":"sh2-fs","typography-subheading-3-fontFamily":"sh3-ff","typography-subheading-3-fontSize":"sh3-size","typography-subheading-3-fontWeight":"sh3-weight","typography-subheading-3-lineHeight":"sh3-lh","typography-subheading-3-letterSpacing":"sh3-ls","typography-subheading-3-fontStyle":"sh3-fs","typography-paragraph-1-fontFamily":"p1-ff","typography-paragraph-1-fontSize":"p1-size","typography-paragraph-1-fontWeight":"p1-weight","typography-paragraph-1-lineHeight":"p1-lh","typography-paragraph-1-letterSpacing":"p1-ls","typography-paragraph-1-fontStyle":"p1-fs","typography-paragraph-2-fontFamily":"p2-ff","typography-paragraph-2-fontSize":"p2-size","typography-paragraph-2-fontWeight":"p2-weight","typography-paragraph-2-lineHeight":"p2-lh","typography-paragraph-2-letterSpacing":"p2-ls","typography-paragraph-2-fontStyle":"p2-fs","typography-paragraph-3-fontFamily":"p3-ff","typography-paragraph-3-fontSize":"p3-size","typography-paragraph-3-fontWeight":"p3-weight","typography-paragraph-3-lineHeight":"p3-lh","typography-paragraph-3-letterSpacing":"p3-ls","typography-paragraph-3-fontStyle":"p3-fs","color-brand":"c-brand","color-highlight":"c-highlight","color-text-1":"c-text-1","color-text-2":"c-text-2","color-text-3":"c-text-3","color-bg-1":"c-bg-1","color-bg-2":"c-bg-2","color-bg-3":"c-bg-3","color-line-1":"c-line-1","color-line-2":"c-line-2","color-line-3":"c-line-3","color-success":"c-success","color-info":"c-info","color-warning":"c-warning","color-error":"c-error","spacing-xxs":"s-xxs","spacing-xs":"s-xs","spacing-s":"s-s","spacing-m":"s-m","spacing-l":"s-l","spacing-xl":"s-xl","spacing-2xl":"s-2xl","spacing-3xl":"s-3xl","spacing-4xl":"s-4xl","spacing-5xl":"s-5xl","container-width":"ct-w","container-padding":"ct-p","text-shadow":"ts","box-shadow":"shadow"};function getShortName(h){return globalSortNameMapping[h]||h}export{getShortName};
1
+ const globalSortNameMapping = {
2
+ 'typography-heading-1-fontFamily': 'h1-ff',
3
+ 'typography-heading-1-fontSize': 'h1-size',
4
+ 'typography-heading-1-fontWeight': 'h1-weight',
5
+ 'typography-heading-1-lineHeight': 'h1-lh',
6
+ 'typography-heading-1-letterSpacing': 'h1-ls',
7
+ 'typography-heading-1-fontStyle': 'h1-fs',
8
+ 'typography-heading-2-fontFamily': 'h2-ff',
9
+ 'typography-heading-2-fontSize': 'h2-size',
10
+ 'typography-heading-2-fontWeight': 'h2-weight',
11
+ 'typography-heading-2-lineHeight': 'h2-lh',
12
+ 'typography-heading-2-letterSpacing': 'h2-ls',
13
+ 'typography-heading-2-fontStyle': 'h2-fs',
14
+ 'typography-heading-3-fontFamily': 'h3-ff',
15
+ 'typography-heading-3-fontSize': 'h3-size',
16
+ 'typography-heading-3-fontWeight': 'h3-weight',
17
+ 'typography-heading-3-lineHeight': 'h3-lh',
18
+ 'typography-heading-3-letterSpacing': 'h3-ls',
19
+ 'typography-heading-3-fontStyle': 'h3-fs',
20
+ 'typography-subheading-1-fontFamily': 'sh1-ff',
21
+ 'typography-subheading-1-fontSize': 'sh1-size',
22
+ 'typography-subheading-1-fontWeight': 'sh1-weight',
23
+ 'typography-subheading-1-lineHeight': 'sh1-lh',
24
+ 'typography-subheading-1-letterSpacing': 'sh1-ls',
25
+ 'typography-subheading-1-fontStyle': 'sh1-fs',
26
+ 'typography-subheading-2-fontFamily': 'sh2-ff',
27
+ 'typography-subheading-2-fontSize': 'sh2-size',
28
+ 'typography-subheading-2-fontWeight': 'sh2-weight',
29
+ 'typography-subheading-2-lineHeight': 'sh2-lh',
30
+ 'typography-subheading-2-letterSpacing': 'sh2-ls',
31
+ 'typography-subheading-2-fontStyle': 'sh2-fs',
32
+ 'typography-subheading-3-fontFamily': 'sh3-ff',
33
+ 'typography-subheading-3-fontSize': 'sh3-size',
34
+ 'typography-subheading-3-fontWeight': 'sh3-weight',
35
+ 'typography-subheading-3-lineHeight': 'sh3-lh',
36
+ 'typography-subheading-3-letterSpacing': 'sh3-ls',
37
+ 'typography-subheading-3-fontStyle': 'sh3-fs',
38
+ 'typography-paragraph-1-fontFamily': 'p1-ff',
39
+ 'typography-paragraph-1-fontSize': 'p1-size',
40
+ 'typography-paragraph-1-fontWeight': 'p1-weight',
41
+ 'typography-paragraph-1-lineHeight': 'p1-lh',
42
+ 'typography-paragraph-1-letterSpacing': 'p1-ls',
43
+ 'typography-paragraph-1-fontStyle': 'p1-fs',
44
+ 'typography-paragraph-2-fontFamily': 'p2-ff',
45
+ 'typography-paragraph-2-fontSize': 'p2-size',
46
+ 'typography-paragraph-2-fontWeight': 'p2-weight',
47
+ 'typography-paragraph-2-lineHeight': 'p2-lh',
48
+ 'typography-paragraph-2-letterSpacing': 'p2-ls',
49
+ 'typography-paragraph-2-fontStyle': 'p2-fs',
50
+ 'typography-paragraph-3-fontFamily': 'p3-ff',
51
+ 'typography-paragraph-3-fontSize': 'p3-size',
52
+ 'typography-paragraph-3-fontWeight': 'p3-weight',
53
+ 'typography-paragraph-3-lineHeight': 'p3-lh',
54
+ 'typography-paragraph-3-letterSpacing': 'p3-ls',
55
+ 'typography-paragraph-3-fontStyle': 'p3-fs',
56
+ 'color-brand': 'c-brand',
57
+ 'color-highlight': 'c-highlight',
58
+ 'color-text-1': 'c-text-1',
59
+ 'color-text-2': 'c-text-2',
60
+ 'color-text-3': 'c-text-3',
61
+ 'color-bg-1': 'c-bg-1',
62
+ 'color-bg-2': 'c-bg-2',
63
+ 'color-bg-3': 'c-bg-3',
64
+ 'color-line-1': 'c-line-1',
65
+ 'color-line-2': 'c-line-2',
66
+ 'color-line-3': 'c-line-3',
67
+ 'color-success': 'c-success',
68
+ 'color-info': 'c-info',
69
+ 'color-warning': 'c-warning',
70
+ 'color-error': 'c-error',
71
+ 'spacing-xxs': 's-xxs',
72
+ 'spacing-xs': 's-xs',
73
+ 'spacing-s': 's-s',
74
+ 'spacing-m': 's-m',
75
+ 'spacing-l': 's-l',
76
+ 'spacing-xl': 's-xl',
77
+ 'spacing-2xl': 's-2xl',
78
+ 'spacing-3xl': 's-3xl',
79
+ 'spacing-4xl': 's-4xl',
80
+ 'spacing-5xl': 's-5xl',
81
+ 'container-width': 'ct-w',
82
+ 'container-padding': 'ct-p',
83
+ 'text-shadow': 'ts',
84
+ 'box-shadow': 'shadow'
85
+ };
86
+ function getShortName(name) {
87
+ return globalSortNameMapping[name] || name;
88
+ }
89
+
90
+ export { getShortName };
@@ -1 +1,58 @@
1
- import{devicesMapping as e}from"../web-components/src/helpers/styles/constant.js";let TEXT_TOTAL_SPACING=3,composePostionIconList=(e,t,o)=>{let i={};return composePositionLineHeight({compose:i,lineHeight:e,device:"desktop",position:t,iconWidth:o}),composePositionLineHeight({compose:i,lineHeight:e,device:"tablet",position:t,iconWidth:o}),composePositionLineHeight({compose:i,lineHeight:e,device:"mobile",position:t,iconWidth:o}),i},composePositionLineHeight=({compose:t,lineHeight:o,device:i,position:s,iconWidth:n})=>{let p=s?.[i],c=n?.[i];if(p){let s=e[i]??"";if("center"===p)t.wrapper={...t.wrapper,[`--ai${s}`]:"center"},t.content={...t.content,[`--pos${s}`]:"static"};else if(c){let e=parseFloat(o.replaceAll(/[a-zA-Z]/g,""))/2+3-c/2;t.wrapper={...t.wrapper,[`--ai${s}`]:"flex-start"},t.content={...t.content,[`--top${s}`]:`${Math.max(0,Math.ceil(e))}px`,[`--pos${s}`]:"relative"}}}};export{composePositionLineHeight,composePostionIconList};
1
+ import { devicesMapping } from '../web-components/src/helpers/styles/constant.js';
2
+
3
+ const TEXT_TOTAL_SPACING = 3; //Padding 2, margin 1
4
+ const composePostionIconList = (lineHeight, position, iconWidth)=>{
5
+ const compose = {};
6
+ composePositionLineHeight({
7
+ compose,
8
+ lineHeight,
9
+ device: 'desktop',
10
+ position,
11
+ iconWidth
12
+ });
13
+ composePositionLineHeight({
14
+ compose,
15
+ lineHeight,
16
+ device: 'tablet',
17
+ position,
18
+ iconWidth
19
+ });
20
+ composePositionLineHeight({
21
+ compose,
22
+ lineHeight,
23
+ device: 'mobile',
24
+ position,
25
+ iconWidth
26
+ });
27
+ return compose;
28
+ };
29
+ const composePositionLineHeight = ({ compose, lineHeight, device, position, iconWidth })=>{
30
+ const positionDevice = position?.[device];
31
+ const iconWidthDevice = iconWidth?.[device];
32
+ if (positionDevice) {
33
+ const suffix = devicesMapping[device] ?? '';
34
+ if (positionDevice === 'center') {
35
+ compose.wrapper = {
36
+ ...compose.wrapper,
37
+ [`--ai${suffix}`]: 'center'
38
+ };
39
+ compose.content = {
40
+ ...compose.content,
41
+ [`--pos${suffix}`]: 'static'
42
+ };
43
+ } else if (iconWidthDevice) {
44
+ const computedTop = parseFloat(lineHeight.replaceAll(/[a-zA-Z]/g, '')) / 2 + TEXT_TOTAL_SPACING - iconWidthDevice / 2;
45
+ compose.wrapper = {
46
+ ...compose.wrapper,
47
+ [`--ai${suffix}`]: 'flex-start'
48
+ };
49
+ compose.content = {
50
+ ...compose.content,
51
+ [`--top${suffix}`]: `${Math.max(0, Math.ceil(computedTop))}px`,
52
+ [`--pos${suffix}`]: 'relative'
53
+ };
54
+ }
55
+ }
56
+ };
57
+
58
+ export { composePositionLineHeight, composePostionIconList };