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