@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,23 +1,319 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var makeStyle=require("../helpers/make-style.js");require("react"),require("react/jsx-runtime"),require("zustand"),require("swr"),require("@gem-sdk/adapter-shopify"),require("swr/mutation"),require("vanilla-lazyload"),require("../hooks/useCartUI.js"),require("react-transition-group"),require("@gem-sdk/core"),require("classnames");var constant=require("./constant.js"),composeAdvanceStyle=require("../helpers/compose-advance-style.js"),convert=require("../helpers/convert.js"),render=require("../helpers/render.js");const componentsRenderWithParentId=["CarouselItem"],componentTexts=["Text","Heading"],componentIconList=["IconListV2","IconList"],componentUsingAdvanced=["IconList"],Render=({uid:e,builder:t,components:r,parentId:n,extraFiles:s={},pageContext:d,...i})=>{let a=t[e],l=r[a?.tag];if(!l)return console.log("Miss component: ",a),{liquid:"",extraFiles:s};if(!a||a?.type==="section")return{liquid:"",extraFiles:s};{let s={extraFiles:{}},o=composeAdvanceStyle.composeAdvanceStyle(a.advanced,a.tag),c="";c=constant.disableWrap.includes(a.tag)?render.RenderIf(a?.childrens?.length,()=>l({builderProps:{uid:e,builderData:a},styles:a.styles,setting:a.settings,style:o,advanced:a.advanced,parentId:componentsRenderWithParentId.includes(a.tag)?n:null,pageContext:d,...i,rawChildren:a.childrens.map(e=>({...t[e],uid:e,builder:t,components:r,customProps:s,pageContext:d})),children:constant.customRenderChildren.includes(a.tag)?"":WrapRenderChildren({uid:e,customProps:s},a.childrens.map(e=>RenderChildren({uid:e,builder:t,components:r,customProps:s,parentTag:a.tag,pageContext:d})))}),()=>l({builderProps:{uid:e,builderData:a},styles:a.styles,setting:a.settings,advanced:a.advanced,style:o,isText:!!componentTexts.includes(a.tag)||null,parentId:componentsRenderWithParentId.includes(a.tag)?n:null,pageContext:d,...i})):render.template`<div style="${componentIconList.includes(a.tag)?"":o}" class="${a.uid} ${a?.childrens?.length||"IconListItemHoz"!==a.tag?"":"hidden"}">
2
- ${render.RenderIf(a?.childrens?.length,()=>l({builderProps:{uid:e,builderData:a},styles:a.styles,setting:a.settings,advanced:{...componentUsingAdvanced.includes(a.tag)?a?.advanced:{},cssClass:a?.advanced?.cssClass},pageContext:d,...i,rawChildren:a.childrens.map(e=>({...t[e],uid:e,builder:t,components:r,customProps:s,pageContext:d})),children:constant.customRenderChildren.includes(a.tag)?"":WrapRenderChildren({uid:e,customProps:s},a.childrens.map(e=>RenderChildren({uid:e,builder:t,components:r,customProps:s,parentTag:a.tag,pageContext:d})))}),()=>l({builderProps:{uid:e,builderData:a},styles:a.styles,setting:a.settings,advanced:{cssClass:a?.advanced?.cssClass},pageContext:d,isText:!!componentTexts.includes(a.tag)||null,style:componentIconList.includes(a.tag)?o:null,...i}))}
3
- </div>`;let{cssCode:p,jsCode:u}=RenderCustomCode(a);return p&&(c+=p),u&&(c+=u),{liquid:c=appendAnimation(a,c),extraFiles:s.extraFiles}}},RenderCustomCode=e=>{let{css:t,javascript:r,rootClassName:n}=e.advanced?.editorData||{},s=t?.replaceAll(n,e.uid),d=r?.replaceAll(n,e.uid),i=render.RenderIf(!!t,render.template`
4
- <style
5
- id="${`custom-css-${e?.uid}`}"
6
- >${s}</style>
7
- `),a=render.RenderIf(!!r,render.template`
8
- <script
9
- id="${`custom-js-${e?.uid}`}"
10
- >
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var makeStyle = require('../helpers/make-style.js');
6
+ require('react');
7
+ require('react/jsx-runtime');
8
+ require('zustand');
9
+ require('swr');
10
+ require('@gem-sdk/adapter-shopify');
11
+ require('swr/mutation');
12
+ require('swr/infinite');
13
+ require('vanilla-lazyload');
14
+ require('../hooks/useCartUI.js');
15
+ require('react-transition-group');
16
+ require('@gem-sdk/core');
17
+ var constant = require('./constant.js');
18
+ require('classnames');
19
+ require('dayjs');
20
+ var composeAdvanceStyle = require('../helpers/compose-advance-style.js');
21
+ var convert = require('../helpers/convert.js');
22
+ var render = require('../helpers/render.js');
23
+
24
+ const componentsRenderWithParentId = [
25
+ 'CarouselItem'
26
+ ];
27
+ const componentTexts = [
28
+ 'Text',
29
+ 'Heading'
30
+ ];
31
+ const componentIconList = [
32
+ 'IconListV2',
33
+ 'IconList'
34
+ ];
35
+ const componentUsingAdvanced = [
36
+ 'IconList',
37
+ 'ProductVariants'
38
+ ];
39
+ const Render = ({ uid, builder, components, parentId, extraFiles = {}, pageContext, enableLazyloadImage, ...passProps })=>{
40
+ const item = builder[uid];
41
+ const Component = components[item?.tag];
42
+ if (!Component) {
43
+ return {
44
+ liquid: '',
45
+ extraFiles
46
+ };
47
+ }
48
+ if (!item) {
49
+ return {
50
+ liquid: '',
51
+ extraFiles
52
+ };
53
+ }
54
+ if (item?.type === 'section') {
55
+ return {
56
+ liquid: '',
57
+ extraFiles
58
+ };
59
+ } else {
60
+ const customProps = {
61
+ extraFiles: {}
62
+ };
63
+ const style = composeAdvanceStyle.composeAdvanceStyle(item.advanced, item.tag);
64
+ let liquid = '';
65
+ if (constant.disableWrap.includes(item.tag)) {
66
+ liquid = render.RenderIf(item?.childrens?.length, ()=>{
67
+ return Component({
68
+ builderProps: {
69
+ uid,
70
+ builderData: item
71
+ },
72
+ styles: item.styles,
73
+ setting: item.settings,
74
+ style,
75
+ advanced: item.advanced,
76
+ parentId: componentsRenderWithParentId.includes(item.tag) ? parentId : null,
77
+ pageContext,
78
+ enableLazyloadImage,
79
+ ...passProps,
80
+ builderAttrs: {
81
+ ...passProps.builderAttrs
82
+ },
83
+ rawChildren: item.childrens.map((id)=>{
84
+ return {
85
+ ...builder[id],
86
+ uid: id,
87
+ builder,
88
+ components,
89
+ customProps,
90
+ pageContext,
91
+ enableLazyloadImage
92
+ };
93
+ }),
94
+ children: !constant.customRenderChildren.includes(item.tag) ? WrapRenderChildren({
95
+ uid,
96
+ customProps
97
+ }, item.childrens.map((id)=>RenderChildren({
98
+ uid: id,
99
+ builder,
100
+ components,
101
+ customProps,
102
+ parentTag: item.tag,
103
+ pageContext,
104
+ enableLazyloadImage
105
+ }))) : ''
106
+ });
107
+ }, ()=>{
108
+ return Component({
109
+ builderProps: {
110
+ uid,
111
+ builderData: item
112
+ },
113
+ styles: item.styles,
114
+ setting: item.settings,
115
+ advanced: item.advanced,
116
+ style,
117
+ isText: componentTexts.includes(item.tag) ? true : null,
118
+ parentId: componentsRenderWithParentId.includes(item.tag) ? parentId : null,
119
+ pageContext,
120
+ enableLazyloadImage,
121
+ ...passProps,
122
+ builderAttrs: {
123
+ ...passProps.builderAttrs
124
+ }
125
+ });
126
+ });
127
+ } else {
128
+ liquid = render.template`<div gp-el-wrapper style="${!componentIconList.includes(item.tag) ? style : ''}" class="${item.uid} ${!item?.childrens?.length && item.tag === 'IconListItemHoz' ? 'hidden' : ''}">
129
+ ${render.RenderIf(item?.childrens?.length, ()=>{
130
+ return Component({
131
+ builderProps: {
132
+ uid,
133
+ builderData: item
134
+ },
135
+ styles: item.styles,
136
+ setting: item.settings,
137
+ advanced: {
138
+ ...componentUsingAdvanced.includes(item.tag) ? item?.advanced : {},
139
+ cssClass: item?.advanced?.cssClass
140
+ },
141
+ pageContext,
142
+ enableLazyloadImage,
143
+ ...passProps,
144
+ builderAttrs: {
145
+ ...passProps.builderAttrs
146
+ },
147
+ rawChildren: item.childrens.map((id)=>{
148
+ return {
149
+ ...builder[id],
150
+ uid: id,
151
+ builder,
152
+ components,
153
+ customProps,
154
+ pageContext,
155
+ enableLazyloadImage
156
+ };
157
+ }),
158
+ children: !constant.customRenderChildren.includes(item.tag) ? WrapRenderChildren({
159
+ uid,
160
+ customProps
161
+ }, item.childrens.map((id)=>RenderChildren({
162
+ uid: id,
163
+ builder,
164
+ components,
165
+ customProps,
166
+ parentTag: item.tag,
167
+ pageContext,
168
+ enableLazyloadImage
169
+ }))) : ''
170
+ });
171
+ }, ()=>{
172
+ return Component({
173
+ builderProps: {
174
+ uid,
175
+ builderData: item
176
+ },
177
+ styles: item.styles,
178
+ setting: item.settings,
179
+ advanced: {
180
+ ...componentUsingAdvanced.includes(item.tag) ? item?.advanced : {},
181
+ cssClass: item?.advanced?.cssClass
182
+ },
183
+ pageContext,
184
+ enableLazyloadImage,
185
+ isText: componentTexts.includes(item.tag) ? true : null,
186
+ style: componentIconList.includes(item.tag) ? style : null,
187
+ ...passProps,
188
+ builderAttrs: {
189
+ ...passProps.builderAttrs
190
+ }
191
+ });
192
+ })}
193
+ </div>`;
194
+ }
195
+ const { cssCode, jsCode } = RenderCustomCode(item);
196
+ if (cssCode) liquid += cssCode;
197
+ if (jsCode) liquid += jsCode;
198
+ liquid = appendAnimation(item, liquid);
199
+ return {
200
+ liquid,
201
+ extraFiles: customProps.extraFiles
202
+ };
203
+ }
204
+ };
205
+ const RenderCustomCode = (item)=>{
206
+ const { css, javascript, rootClassName } = item.advanced?.editorData || {};
207
+ const replacedCSS = css?.replaceAll(rootClassName, item.uid);
208
+ const replacedJS = javascript?.replaceAll(rootClassName, item.uid);
209
+ const cssCode = render.RenderIf(!!css, render.template`
210
+ <style id="${`custom-css-${item?.uid}`}">
211
+ ${replacedCSS}
212
+ </style>
213
+ `);
214
+ const jsCode = render.RenderIf(!!javascript, render.template`
215
+ <script id="${`custom-js-${item?.uid}`}">
11
216
  try {
12
- ${d}
217
+ ${replacedJS}
13
218
  } catch(err){}
14
219
  </script>
15
- `);return{cssCode:i,jsCode:a}},appendAnimation=(e,t)=>{let{advanced:r,tag:n}=e,{animation:s,op:d}=r??{},i=(e,t)=>e?.triggerConfig?.[t]?.animation??"none",a=e=>{if("desktop"===e);else if("tablet"===e)return s?.tablet??s?.desktop;else if("mobile"===e)return s?.mobile??s?.tablet??s?.desktop;return s?.desktop},l=i(a("desktop"),"appear"),o=i(a("desktop"),"hover"),c=i(a("tablet"),"appear"),p=i(a("mobile"),"appear"),u=s?.desktop?.enabled&&("none"!==l||"none"!==o)||s?.tablet?.enabled&&"none"!==c||s?.mobile?.enabled&&"none"!==p;if(!u)return t;let m=e=>a(e)?.enabled&&!["shake","none"].includes(i(a(e),"appear"))?"hidden":"visible",g={desktop:m("desktop"),tablet:m("tablet"),mobile:m("mobile")};return render.template`
220
+ `);
221
+ return {
222
+ cssCode,
223
+ jsCode
224
+ };
225
+ };
226
+ const appendAnimation = (props, liquid)=>{
227
+ const { advanced, tag } = props;
228
+ const { animation, op: opacity, hasAnimationInteraction, displayInitInteraction } = advanced ?? {};
229
+ const getAnimationType = (settings, type)=>{
230
+ return settings?.triggerConfig?.[type]?.animation ?? 'none';
231
+ };
232
+ const getSettingsByDevice = (device)=>{
233
+ if (device === 'desktop') return animation?.desktop;
234
+ else if (device === 'tablet') return animation?.tablet ?? animation?.desktop;
235
+ else if (device === 'mobile') return animation?.mobile ?? animation?.tablet ?? animation?.desktop;
236
+ return animation?.desktop;
237
+ };
238
+ const appearDesktop = getAnimationType(getSettingsByDevice('desktop'), 'appear');
239
+ const hoverDesktop = getAnimationType(getSettingsByDevice('desktop'), 'hover');
240
+ const appearTablet = getAnimationType(getSettingsByDevice('tablet'), 'appear');
241
+ const appearMobile = getAnimationType(getSettingsByDevice('mobile'), 'appear');
242
+ const enableAnimation = animation?.desktop?.enabled && (appearDesktop !== 'none' || hoverDesktop !== 'none') || animation?.tablet?.enabled && appearTablet !== 'none' || animation?.mobile?.enabled && appearMobile !== 'none' || !!hasAnimationInteraction;
243
+ const enableAnimationWhenInit = animation?.desktop?.enabled && (appearDesktop !== 'none' || hoverDesktop !== 'none') || animation?.tablet?.enabled && appearTablet !== 'none' || animation?.mobile?.enabled && appearMobile !== 'none';
244
+ if (!enableAnimation) return liquid;
245
+ const getInitVisibility = (device)=>getSettingsByDevice(device)?.enabled && ![
246
+ 'shake',
247
+ 'none'
248
+ ].includes(getAnimationType(getSettingsByDevice(device), 'appear')) ? 'hidden' : 'visible';
249
+ const opacityObject = {
250
+ desktop: getInitVisibility('desktop'),
251
+ tablet: getInitVisibility('tablet'),
252
+ mobile: getInitVisibility('mobile')
253
+ };
254
+ return render.template`
16
255
  <gp-animation
17
- gp-data='${JSON.stringify({config:s,tag:n,opacity:d})}'
18
- style="${{display:"contents"}}"
256
+ gp-interaction-wrapper
257
+ display-init="${displayInitInteraction === false ? 'hide' : 'show'}"
258
+ gp-data='${JSON.stringify({
259
+ config: animation,
260
+ tag,
261
+ opacity,
262
+ notEnableAnimationWhenInit: !enableAnimationWhenInit
263
+ })}'
264
+ style="${{
265
+ display: 'contents'
266
+ }}"
19
267
  >
20
- <div style="${{...makeStyle.makeStyleResponsive("v",g),display:"contents"}}">${t}</div>
268
+ <div style="${{
269
+ ...makeStyle.makeStyleResponsive('v', opacityObject),
270
+ display: 'contents'
271
+ }}">${liquid}</div>
21
272
  </gp-animation>
22
- ${render.RenderIf(convert.isLocalEnv,'<script src="{{ \'gp-animation.js\' | asset_url }}" defer="defer"></script>',`<script src="${convert.baseAssetURL}/assets-v2/gp-animation.js?v={{ shop.metafields.GEMPAGES.ASSETS_VERSION }}" defer="defer"></script>`)}
23
- `},RenderChildren=e=>{let t=Render(e);for(let r in t.extraFiles)Object.prototype.hasOwnProperty.call(t.extraFiles,r)&&(e.customProps.extraFiles[r]=t.extraFiles[r]);let r=new TextEncoder,n=t?.liquid?r.encode(t.liquid).length:0;if(Math.ceil(n/1024)>=180){let r=`gp-section-snippet-${e.uid}`;return e.customProps.extraFiles[r]=t.liquid,`{% render '${r}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`}return t.liquid},WrapRenderChildren=({uid:e,customProps:t},r)=>{let n="";if(r?.length)for(let s=0;s<r.length;s++){let d=r[s];if(d){let r=n+d,i=new TextEncoder,a=r?i.encode(r).length:0;if(Math.ceil(a/1024)>=180){let r=`gp-section-snippet-${e+s}`;t.extraFiles[r]=d,n+=`{% render '${r}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`}else n+=d}}return n};exports.RenderChildren=RenderChildren,exports.WrapRenderChildren=WrapRenderChildren,exports.default=Render;
273
+ ${render.RenderIf(convert.isLocalEnv, `<script src="{{ 'gp-animation.js' | asset_url }}" defer="defer"></script>`, `<script src="${convert.baseAssetURL}/assets-v2/gp-animation.js?v={{ shop.metafields.GEMPAGES.ASSETS_VERSION }}" defer="defer"></script>`)}
274
+ `;
275
+ };
276
+ const RenderChildren = (props)=>{
277
+ const data = Render(props);
278
+ // Append to prop parent
279
+ for(const key in data.extraFiles){
280
+ if (Object.prototype.hasOwnProperty.call(data.extraFiles, key)) {
281
+ props.customProps.extraFiles[key] = data.extraFiles[key];
282
+ }
283
+ }
284
+ // Fix limit 256kb
285
+ const textEncoder = new TextEncoder();
286
+ const size = data?.liquid ? textEncoder.encode(data.liquid).length : 0;
287
+ if (Math.ceil(size / 1024) >= 180) {
288
+ const fileName = `gp-section-snippet-${props.uid}`;
289
+ props.customProps.extraFiles[fileName] = data.liquid;
290
+ return `{% render '${fileName}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`;
291
+ }
292
+ return data.liquid;
293
+ };
294
+ const WrapRenderChildren = ({ uid, customProps }, codes)=>{
295
+ let liquid = '';
296
+ if (codes?.length) {
297
+ for(let i = 0; i < codes.length; i++){
298
+ const code = codes[i];
299
+ if (code) {
300
+ const newLiquid = liquid + code;
301
+ // Fix limit 256kb
302
+ const textEncoder = new TextEncoder();
303
+ const size = newLiquid ? textEncoder.encode(newLiquid).length : 0;
304
+ if (Math.ceil(size / 1024) >= 180) {
305
+ const fileName = `gp-section-snippet-${uid + i}`;
306
+ customProps.extraFiles[fileName] = code;
307
+ liquid += `{% render '${fileName}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`;
308
+ } else {
309
+ liquid += code;
310
+ }
311
+ }
312
+ }
313
+ }
314
+ return liquid;
315
+ };
316
+
317
+ exports.RenderChildren = RenderChildren;
318
+ exports.WrapRenderChildren = WrapRenderChildren;
319
+ exports.default = Render;
@@ -1 +1,54 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var jsxRuntime=require("react/jsx-runtime"),react=require("react"),reactErrorBoundary=require("react-error-boundary"),BuilderComponent=require("../contexts/BuilderComponent.js"),BuilderContext=require("../contexts/BuilderContext.js"),ComponentWrapper=require("./ComponentWrapper.js");const RenderBlock=({uid:e})=>{let r=BuilderContext.useBuilderStore(r=>r.getItem(e)),t=BuilderComponent.useBuilderComponent(r?.tag);return r&&"section"!==r.type?jsxRuntime.jsx(reactErrorBoundary.ErrorBoundary,{fallbackRender:({error:e,resetErrorBoundary:t})=>jsxRuntime.jsxs(ComponentWrapper.default,{...r,children:[jsxRuntime.jsx("span",{"aria-label":"Error message",children:e.message}),jsxRuntime.jsx("button",{type:"button",onClick:t,children:"Try again"})]}),children:jsxRuntime.jsx(ComponentWrapper.default,{...r,children:r?.childrens?.length?jsxRuntime.jsx(t,{builderProps:{uid:e},styles:r.styles??{},setting:r.settings??{},children:r?.childrens?.map(e=>jsxRuntime.jsx(RenderBlockMemo,{uid:e},e))}):jsxRuntime.jsx(t,{builderProps:{uid:e},styles:r.styles??{},setting:r.settings??{}})})},r.uid):null},RenderBlockMemo=react.memo(RenderBlock);exports.default=RenderBlockMemo;
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var react = require('react');
7
+ var reactErrorBoundary = require('react-error-boundary');
8
+ var BuilderComponent = require('../contexts/BuilderComponent.js');
9
+ var BuilderContext = require('../contexts/BuilderContext.js');
10
+ var ComponentWrapper = require('./ComponentWrapper.js');
11
+
12
+ const RenderBlock = ({ uid })=>{
13
+ const item = BuilderContext.useBuilderStore((s)=>s.getItem(uid));
14
+ const Component = BuilderComponent.useBuilderComponent(item?.tag);
15
+ if (!item || item.type === 'section') return null;
16
+ return /*#__PURE__*/ jsxRuntime.jsx(reactErrorBoundary.ErrorBoundary, {
17
+ fallbackRender: ({ error, resetErrorBoundary })=>/*#__PURE__*/ jsxRuntime.jsxs(ComponentWrapper.default, {
18
+ ...item,
19
+ children: [
20
+ /*#__PURE__*/ jsxRuntime.jsx("span", {
21
+ "aria-label": "Error message",
22
+ children: error.message
23
+ }),
24
+ /*#__PURE__*/ jsxRuntime.jsx("button", {
25
+ type: "button",
26
+ onClick: resetErrorBoundary,
27
+ children: "Try again"
28
+ })
29
+ ]
30
+ }),
31
+ children: /*#__PURE__*/ jsxRuntime.jsx(ComponentWrapper.default, {
32
+ ...item,
33
+ children: item?.childrens?.length ? /*#__PURE__*/ jsxRuntime.jsx(Component, {
34
+ builderProps: {
35
+ uid
36
+ },
37
+ styles: item.styles ?? {},
38
+ setting: item.settings ?? {},
39
+ children: item?.childrens?.map((id)=>/*#__PURE__*/ jsxRuntime.jsx(RenderBlockMemo, {
40
+ uid: id
41
+ }, id))
42
+ }) : /*#__PURE__*/ jsxRuntime.jsx(Component, {
43
+ builderProps: {
44
+ uid
45
+ },
46
+ styles: item.styles ?? {},
47
+ setting: item.settings ?? {}
48
+ })
49
+ })
50
+ }, item.uid);
51
+ };
52
+ const RenderBlockMemo = /*#__PURE__*/ react.memo(RenderBlock);
53
+
54
+ exports.default = RenderBlockMemo;
@@ -1,5 +1,61 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var jsxRuntime=require("react/jsx-runtime"),Head=require("next/head"),Script=require("next/script"),react=require("react");require("zustand"),require("swr"),require("@gem-sdk/adapter-shopify"),require("swr/mutation");var shop=require("../hooks/shop.js");require("vanilla-lazyload"),require("../hooks/useCartUI.js"),require("react-transition-group"),require("@gem-sdk/core"),require("classnames"),require("../helpers/convert.js");const RenderCustomCode=({uid:e,advanced:r})=>{let s=shop.useEditorMode(),{css:t,javascript:i,rootClassName:u}=r?.editorData||{},a=t?.replaceAll(u,e),o=i?.replaceAll(u,e),n={css:`custom-css-${e}`,javascript:`custom-js-${e}`},c=react.useMemo(()=>`
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var Head = require('next/head');
7
+ var Script = require('next/script');
8
+ var react = require('react');
9
+ require('zustand');
10
+ require('react-transition-group');
11
+ require('@gem-sdk/core');
12
+ require('swr');
13
+ require('swr/infinite');
14
+ var shop = require('../hooks/shop.js');
15
+ require('classnames');
16
+ require('dayjs');
17
+ require('../helpers/convert.js');
18
+ require('@gem-sdk/adapter-shopify');
19
+ require('swr/mutation');
20
+ require('vanilla-lazyload');
21
+ require('../hooks/useCartUI.js');
22
+
23
+ const RenderCustomCode = ({ uid, advanced })=>{
24
+ const mode = shop.useEditorMode();
25
+ const { css, javascript, rootClassName } = advanced?.editorData || {};
26
+ const replacedCSS = css?.replaceAll(rootClassName, uid);
27
+ const replacedJS = javascript?.replaceAll(rootClassName, uid);
28
+ const mapId = {
29
+ css: `custom-css-${uid}`,
30
+ javascript: `custom-js-${uid}`
31
+ };
32
+ const jsCode = react.useMemo(()=>{
33
+ return `
2
34
  try {
3
- ${o}
35
+ ${replacedJS}
4
36
  } catch(err){}
5
- `,[o]);return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(Head,{children:!!t&&jsxRuntime.jsx("style",{id:n.css,dangerouslySetInnerHTML:{__html:a}})}),!!i&&"edit"!==s&&jsxRuntime.jsx(Script,{id:n.javascript,dangerouslySetInnerHTML:{__html:c}})]})};exports.default=RenderCustomCode;
37
+ `;
38
+ }, [
39
+ replacedJS
40
+ ]);
41
+ return /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
42
+ children: [
43
+ /*#__PURE__*/ jsxRuntime.jsx(Head, {
44
+ children: !!css && /*#__PURE__*/ jsxRuntime.jsx("style", {
45
+ id: mapId['css'],
46
+ dangerouslySetInnerHTML: {
47
+ __html: replacedCSS
48
+ }
49
+ })
50
+ }),
51
+ !!javascript && mode !== 'edit' && /*#__PURE__*/ jsxRuntime.jsx(Script, {
52
+ id: mapId['javascript'],
53
+ dangerouslySetInnerHTML: {
54
+ __html: jsCode
55
+ }
56
+ })
57
+ ]
58
+ });
59
+ };
60
+
61
+ exports.default = RenderCustomCode;
@@ -1 +1,67 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var jsxRuntime=require("react/jsx-runtime"),react=require("react"),reactErrorBoundary=require("react-error-boundary"),BuilderComponent=require("../contexts/BuilderComponent.js"),BuilderPreviewContext=require("../contexts/BuilderPreviewContext.js"),ComponentWrapperPreview=require("./ComponentWrapperPreview.js"),RenderSection=require("./RenderSection.js");const RenderPreview=({uid:e,...r})=>{let t=BuilderPreviewContext.useBuilderPreviewStore(r=>r.getItem(e)),n=BuilderComponent.useBuilderComponent(t?.tag);return t?t?.type==="section"?jsxRuntime.jsx(RenderSection.default,{sectionId:t.uid}):jsxRuntime.jsx(reactErrorBoundary.ErrorBoundary,{fallbackRender:({error:e,resetErrorBoundary:r})=>jsxRuntime.jsxs(ComponentWrapperPreview.default,{...t,children:[jsxRuntime.jsx("span",{"aria-label":"Error message",children:e.message}),jsxRuntime.jsx("button",{type:"button",onClick:r,children:"Try again"})]}),children:jsxRuntime.jsx(ComponentWrapperPreview.default,{...t,children:t?.childrens?.length?jsxRuntime.jsx(n,{builderProps:{uid:e,builderData:t},styles:t.styles,setting:t.settings,...r,children:t.childrens.map(e=>jsxRuntime.jsx(RenderPreviewMemo,{...r,uid:e},e))}):jsxRuntime.jsx(n,{builderProps:{uid:e,builderData:t},styles:t.styles,setting:t.settings,...r})})},t.uid):null},RenderPreviewMemo=react.memo(RenderPreview);RenderPreviewMemo.displayName="RenderPreviewMemo",exports.default=RenderPreviewMemo;
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var react = require('react');
7
+ var reactErrorBoundary = require('react-error-boundary');
8
+ var BuilderComponent = require('../contexts/BuilderComponent.js');
9
+ var BuilderPreviewContext = require('../contexts/BuilderPreviewContext.js');
10
+ var ComponentWrapperPreview = require('./ComponentWrapperPreview.js');
11
+ var RenderSection = require('./RenderSection.js');
12
+
13
+ const RenderPreview = ({ uid, ...passProps })=>{
14
+ const item = BuilderPreviewContext.useBuilderPreviewStore((s)=>s.getItem(uid));
15
+ const Component = BuilderComponent.useBuilderComponent(item?.tag);
16
+ if (!item) return null;
17
+ if (item?.type === 'section') {
18
+ return /*#__PURE__*/ jsxRuntime.jsx(RenderSection.default, {
19
+ sectionId: item.uid
20
+ });
21
+ } else {
22
+ return /*#__PURE__*/ jsxRuntime.jsx(reactErrorBoundary.ErrorBoundary, {
23
+ fallbackRender: ({ error, resetErrorBoundary })=>/*#__PURE__*/ jsxRuntime.jsxs(ComponentWrapperPreview.default, {
24
+ ...item,
25
+ children: [
26
+ /*#__PURE__*/ jsxRuntime.jsx("span", {
27
+ "aria-label": "Error message",
28
+ children: error.message
29
+ }),
30
+ /*#__PURE__*/ jsxRuntime.jsx("button", {
31
+ type: "button",
32
+ onClick: resetErrorBoundary,
33
+ children: "Try again"
34
+ })
35
+ ]
36
+ }),
37
+ children: /*#__PURE__*/ jsxRuntime.jsx(ComponentWrapperPreview.default, {
38
+ ...item,
39
+ children: item?.childrens?.length ? /*#__PURE__*/ jsxRuntime.jsx(Component, {
40
+ builderProps: {
41
+ uid,
42
+ builderData: item
43
+ },
44
+ styles: item.styles,
45
+ setting: item.settings,
46
+ ...passProps,
47
+ children: item.childrens.map((id)=>/*#__PURE__*/ jsxRuntime.jsx(RenderPreviewMemo, {
48
+ "bundle-item": passProps?.['bundle-item'],
49
+ uid: id
50
+ }, id))
51
+ }) : /*#__PURE__*/ jsxRuntime.jsx(Component, {
52
+ builderProps: {
53
+ uid,
54
+ builderData: item
55
+ },
56
+ styles: item.styles,
57
+ setting: item.settings,
58
+ ...passProps
59
+ })
60
+ })
61
+ }, item.uid);
62
+ }
63
+ };
64
+ const RenderPreviewMemo = /*#__PURE__*/ react.memo(RenderPreview);
65
+ RenderPreviewMemo.displayName = 'RenderPreviewMemo';
66
+
67
+ exports.default = RenderPreviewMemo;
@@ -1 +1,23 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var jsxRuntime=require("react/jsx-runtime"),react=require("react"),BuilderContext=require("../contexts/BuilderContext.js"),SectionContext=require("../contexts/SectionContext.js"),RenderBlock=require("./RenderBlock.js");const RenderSection=({sectionId:e})=>{let t=SectionContext.useSection(e);return t?jsxRuntime.jsx(BuilderContext.BuilderProvider,{state:t,children:jsxRuntime.jsx(RenderBlock.default,{uid:e})},e):null},RenderSectionMemo=react.memo(RenderSection);exports.default=RenderSectionMemo;
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var react = require('react');
7
+ var BuilderContext = require('../contexts/BuilderContext.js');
8
+ var SectionContext = require('../contexts/SectionContext.js');
9
+ var RenderBlock = require('./RenderBlock.js');
10
+
11
+ const RenderSection = ({ sectionId })=>{
12
+ const state = SectionContext.useSection(sectionId);
13
+ if (!state) return null;
14
+ return /*#__PURE__*/ jsxRuntime.jsx(BuilderContext.BuilderProvider, {
15
+ state: state,
16
+ children: /*#__PURE__*/ jsxRuntime.jsx(RenderBlock.default, {
17
+ uid: sectionId
18
+ })
19
+ }, sectionId);
20
+ };
21
+ const RenderSectionMemo = /*#__PURE__*/ react.memo(RenderSection);
22
+
23
+ exports.default = RenderSectionMemo;