@gem-sdk/core 2.0.0-dev.896 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (396) hide show
  1. package/dist/cjs/components/AddOn.js +18 -1
  2. package/dist/cjs/components/ComponentAnimation.js +17 -0
  3. package/dist/cjs/components/ComponentToolbarPreview.js +752 -1
  4. package/dist/cjs/components/ComponentWrapper.js +61 -1
  5. package/dist/cjs/components/ComponentWrapperPreview.js +213 -1
  6. package/dist/cjs/components/Empty.js +7 -1
  7. package/dist/cjs/components/InteractionSuffix.js +42 -0
  8. package/dist/cjs/components/Render.js +75 -1
  9. package/dist/cjs/components/Render.liquid.js +313 -17
  10. package/dist/cjs/components/RenderBlock.js +54 -1
  11. package/dist/cjs/components/RenderCustomCode.js +59 -3
  12. package/dist/cjs/components/RenderPreview.js +67 -1
  13. package/dist/cjs/components/RenderSection.js +23 -1
  14. package/dist/cjs/components/ai-generator/AIContentGenerator.js +252 -1
  15. package/dist/cjs/components/ai-generator/AIGenContentLoading.js +85 -1
  16. package/dist/cjs/components/ai-generator/components/PickProduct.js +220 -1
  17. package/dist/cjs/components/ai-generator/components/ToneAndVoice.js +77 -1
  18. package/dist/cjs/components/ai-generator/hooks/useCheckingProductInside.js +47 -0
  19. package/dist/cjs/components/ai-generator/hooks/useFlipPopup.js +110 -0
  20. package/dist/cjs/components/ai-generator/hooks/useGettingGenerateRequest.js +37 -1
  21. package/dist/cjs/components/ai-generator/hooks/useListenEventGenerate.js +70 -1
  22. package/dist/cjs/components/ai-generator/icons/AIIcon.js +67 -1
  23. package/dist/cjs/components/ai-generator/icons/CloseIcon.js +19 -1
  24. package/dist/cjs/components/ai-generator/icons/DropdownIcon.js +37 -1
  25. package/dist/cjs/components/ai-generator/icons/SearchIcon.js +21 -1
  26. package/dist/cjs/components/ai-generator/icons/ShowMoreIcon.js +21 -1
  27. package/dist/cjs/components/ai-generator/icons/UpgradeIcon.js +27 -0
  28. package/dist/cjs/components/ai-generator/icons/WarningIcon.js +31 -0
  29. package/dist/cjs/components/constant.js +83 -1
  30. package/dist/cjs/components/resize/Resize.js +16 -1
  31. package/dist/cjs/components/resize/Spacing.js +260 -1
  32. package/dist/cjs/components/src/product/helpers/variant-presets.js +56 -1
  33. package/dist/cjs/components/theme-section/CreateThemeSection.js +123 -1
  34. package/dist/cjs/components/theme-section/ThemeSectionStatus.js +45 -1
  35. package/dist/cjs/components/theme-section/ThemeSectionTooltip.js +126 -1
  36. package/dist/cjs/components/toolbar/Tooltip.js +28 -1
  37. package/dist/cjs/contexts/AddonContext.js +36 -1
  38. package/dist/cjs/contexts/ArticleContext.js +39 -1
  39. package/dist/cjs/contexts/ArticleListContext.js +31 -1
  40. package/dist/cjs/contexts/BuilderComponent.js +34 -1
  41. package/dist/cjs/contexts/BuilderContext.js +39 -1
  42. package/dist/cjs/contexts/BuilderPreviewContext.js +486 -1
  43. package/dist/cjs/contexts/CartLineContext.js +29 -1
  44. package/dist/cjs/contexts/CollectionContext.js +38 -1
  45. package/dist/cjs/contexts/ModalContext.js +47 -1
  46. package/dist/cjs/contexts/PageContext.js +104 -1
  47. package/dist/cjs/contexts/ProductContext.js +177 -1
  48. package/dist/cjs/contexts/ProductListContext.js +32 -1
  49. package/dist/cjs/contexts/SectionContext.js +53 -1
  50. package/dist/cjs/contexts/ShopContext.js +107 -1
  51. package/dist/cjs/graphql/fragments/analytic.generated.js +6 -2
  52. package/dist/cjs/graphql/fragments/collection-detail.generated.js +6 -2
  53. package/dist/cjs/graphql/fragments/collection-product.generated.js +6 -2
  54. package/dist/cjs/graphql/fragments/collection.generated.js +6 -2
  55. package/dist/cjs/graphql/fragments/custom-code.generated.js +6 -2
  56. package/dist/cjs/graphql/fragments/custom-font.generated.js +6 -2
  57. package/dist/cjs/graphql/fragments/data-seo.generated.js +6 -2
  58. package/dist/cjs/graphql/fragments/media.generated.js +6 -2
  59. package/dist/cjs/graphql/fragments/preview-theme-page.generated.js +39 -0
  60. package/dist/cjs/graphql/fragments/product-little.generated.js +7 -2
  61. package/dist/cjs/graphql/fragments/product-option-value.generated.js +6 -2
  62. package/dist/cjs/graphql/fragments/product-option.generated.js +6 -2
  63. package/dist/cjs/graphql/fragments/product.generated.js +6 -2
  64. package/dist/cjs/graphql/fragments/published-custom-section.generated.js +6 -2
  65. package/dist/cjs/graphql/fragments/published-page-section.generated.js +6 -2
  66. package/dist/cjs/graphql/fragments/published-theme-page.generated.js +10 -28
  67. package/dist/cjs/graphql/fragments/published-theme-style.generated.js +6 -2
  68. package/dist/cjs/graphql/fragments/selected-option.generated.js +6 -2
  69. package/dist/cjs/graphql/fragments/variant.generated.js +6 -2
  70. package/dist/cjs/graphql/mutations/page-view-up.generated.js +8 -4
  71. package/dist/cjs/graphql/queries/articles.generated.js +61 -0
  72. package/dist/cjs/graphql/queries/blogs.generated.js +69 -0
  73. package/dist/cjs/graphql/queries/collection-detail-filter.generated.js +16 -2
  74. package/dist/cjs/graphql/queries/collection.generated.js +14 -2
  75. package/dist/cjs/graphql/queries/collections.generated.js +9 -2
  76. package/dist/cjs/graphql/queries/preview-page.generated.js +16 -8
  77. package/dist/cjs/graphql/queries/product-little-detail.generated.js +11 -2
  78. package/dist/cjs/graphql/queries/product-medias.generated.js +8 -2
  79. package/dist/cjs/graphql/queries/product-value-label.generated.js +6 -2
  80. package/dist/cjs/graphql/queries/product-variants.generated.js +10 -2
  81. package/dist/cjs/graphql/queries/products.generated.js +17 -3
  82. package/dist/cjs/graphql/queries/published-shop-metas.js +15 -0
  83. package/dist/cjs/graphql/queries/published-theme-pages.generated.js +15 -2
  84. package/dist/cjs/graphql/queries/store-property.generated.js +6 -2
  85. package/dist/cjs/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +6 -2
  86. package/dist/cjs/graphql-app-api/queries/LibraryTemplate.generated.js +6 -2
  87. package/dist/cjs/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +6 -2
  88. package/dist/cjs/graphql-app-api/queries/ShopLibraryPage.generated.js +17 -0
  89. package/dist/cjs/graphql-app-api/queries/ThemePage.generated.js +6 -2
  90. package/dist/cjs/helpers/GlobalEvent.js +19 -1
  91. package/dist/cjs/helpers/align.js +19 -0
  92. package/dist/cjs/helpers/animations.js +222 -1
  93. package/dist/cjs/helpers/background.js +235 -1
  94. package/dist/cjs/helpers/borders.js +198 -4
  95. package/dist/cjs/helpers/carousel.js +55 -1
  96. package/dist/cjs/helpers/clone-deep.js +5 -1
  97. package/dist/cjs/helpers/cls.js +16 -1
  98. package/dist/cjs/helpers/colors.js +184 -1
  99. package/dist/cjs/helpers/compose-advance-style.js +327 -1
  100. package/dist/cjs/helpers/constant.js +23 -1
  101. package/dist/cjs/helpers/convert.js +7 -1
  102. package/dist/cjs/helpers/covert-entities-html.js +19 -1
  103. package/dist/cjs/helpers/css-variable.js +7 -1
  104. package/dist/cjs/helpers/email.js +11 -1
  105. package/dist/cjs/helpers/filter-toolbar-preview.js +14 -1
  106. package/dist/cjs/helpers/flatten-connection.js +9 -1
  107. package/dist/cjs/helpers/get-resonsive-value.js +36 -1
  108. package/dist/cjs/helpers/get-shortname.js +92 -1
  109. package/dist/cjs/helpers/icon-list.js +61 -1
  110. package/dist/cjs/helpers/interaction/index.js +134 -0
  111. package/dist/cjs/helpers/is-browser.js +9 -1
  112. package/dist/cjs/helpers/is-defined.js +7 -1
  113. package/dist/cjs/helpers/is-empty-children.js +15 -1
  114. package/dist/cjs/helpers/is-safari.js +9 -1
  115. package/dist/cjs/helpers/layout.js +59 -1
  116. package/dist/cjs/helpers/load-script.js +31 -1
  117. package/dist/cjs/helpers/loop-component.js +16 -0
  118. package/dist/cjs/helpers/make-style.js +163 -1
  119. package/dist/cjs/helpers/normalize-builder-data.js +23 -1
  120. package/dist/cjs/helpers/pascal-to-kebab-case.js +7 -0
  121. package/dist/cjs/helpers/prefetch-queries.js +78 -1
  122. package/dist/cjs/helpers/product.js +48 -1
  123. package/dist/cjs/helpers/queries/get-collection.js +226 -1
  124. package/dist/cjs/helpers/queries/get-collections.js +21 -1
  125. package/dist/cjs/helpers/queries/get-product-by-slug.js +125 -1
  126. package/dist/cjs/helpers/queries/get-product.js +154 -1
  127. package/dist/cjs/helpers/queries/get-products.js +214 -1
  128. package/dist/cjs/helpers/query.js +29 -1
  129. package/dist/cjs/helpers/radius.js +140 -6
  130. package/dist/cjs/helpers/render.js +78 -1
  131. package/dist/cjs/helpers/shadow.js +69 -1
  132. package/dist/cjs/helpers/size.js +206 -4
  133. package/dist/cjs/helpers/spacing.js +43 -1
  134. package/dist/cjs/helpers/third-party/addAppBlockId.js +20 -0
  135. package/dist/cjs/helpers/third-party/appConfig.js +234 -0
  136. package/dist/cjs/helpers/third-party/appSetting.js +661 -0
  137. package/dist/cjs/helpers/third-party/composeAppBlockId.js +11 -0
  138. package/dist/cjs/helpers/third-party/constant.js +43 -0
  139. package/dist/cjs/helpers/third-party/generateAppBlockConfigs.js +34 -0
  140. package/dist/cjs/helpers/third-party/getAppBlockConfig.js +47 -0
  141. package/dist/cjs/helpers/third-party/getAppBlockType.js +12 -0
  142. package/dist/cjs/helpers/third-party/getAppBlocks.js +30 -0
  143. package/dist/cjs/helpers/third-party/mergeBlock.js +19 -0
  144. package/dist/cjs/helpers/third-party/mergeBlockOrder.js +47 -0
  145. package/dist/cjs/helpers/third-party/removeGPAppItems.js +18 -0
  146. package/dist/cjs/helpers/tracking/fpixel.js +28 -1
  147. package/dist/cjs/helpers/tracking/gtag.js +93 -1
  148. package/dist/cjs/helpers/tracking/tiktokpixel.js +17 -1
  149. package/dist/cjs/helpers/typography.js +160 -17
  150. package/dist/cjs/helpers/variant.js +11 -1
  151. package/dist/cjs/hooks/animation/useAnimationActions.js +39 -1
  152. package/dist/cjs/hooks/animation/useAnimationConfig.js +30 -1
  153. package/dist/cjs/hooks/animation/useAnimationPreview.js +31 -1
  154. package/dist/cjs/hooks/animation/useAnimationTarget.js +122 -1
  155. package/dist/cjs/hooks/animation/useApplyAnimation.js +89 -1
  156. package/dist/cjs/hooks/articles/useArticlesQuery.js +33 -1
  157. package/dist/cjs/hooks/cart/use-add-to-cart.js +20 -1
  158. package/dist/cjs/hooks/cart/use-cart-data.js +28 -1
  159. package/dist/cjs/hooks/cart/use-cart-discount-codes-update.js +20 -1
  160. package/dist/cjs/hooks/cart/use-cart-note-update.js +20 -1
  161. package/dist/cjs/hooks/cart/use-create-cart.js +22 -1
  162. package/dist/cjs/hooks/cart/use-remove-cart-item.js +20 -1
  163. package/dist/cjs/hooks/cart/use-update-cart-item.js +20 -1
  164. package/dist/cjs/hooks/shop/use-collection-query.js +22 -1
  165. package/dist/cjs/hooks/shop/use-collections-query.js +17 -1
  166. package/dist/cjs/hooks/shop/use-product-query.js +22 -1
  167. package/dist/cjs/hooks/shop/use-products-query.js +63 -1
  168. package/dist/cjs/hooks/shop.js +126 -1
  169. package/dist/cjs/hooks/use-current-device.js +30 -1
  170. package/dist/cjs/hooks/use-lazy-video.js +15 -1
  171. package/dist/cjs/hooks/useAnimations.js +29 -1
  172. package/dist/cjs/hooks/useCartId.js +44 -1
  173. package/dist/cjs/hooks/useCartLine.js +11 -1
  174. package/dist/cjs/hooks/useCartUI.js +48 -1
  175. package/dist/cjs/hooks/useCollection.js +9 -1
  176. package/dist/cjs/hooks/useFetchHandle.js +13 -1
  177. package/dist/cjs/hooks/useFormatMoney.js +75 -1
  178. package/dist/cjs/hooks/useInitialSwatchesOptions.js +128 -1
  179. package/dist/cjs/hooks/useInteraction.js +19 -0
  180. package/dist/cjs/hooks/useIsomorphicLayoutEffect.js +10 -1
  181. package/dist/cjs/hooks/useLoadScript.js +32 -1
  182. package/dist/cjs/hooks/useMoney.js +84 -1
  183. package/dist/cjs/hooks/usePrevious.js +19 -1
  184. package/dist/cjs/hooks/useProduct.js +245 -1
  185. package/dist/cjs/hooks/useProductList.js +21 -1
  186. package/dist/cjs/hooks/useSuspenseFetch.js +27 -1
  187. package/dist/cjs/hooks/useSwatchesOptions.js +41 -1
  188. package/dist/cjs/hooks/useToolbarPostPurchase.js +89 -1
  189. package/dist/cjs/index.js +416 -1
  190. package/dist/cjs/types/animations.js +49 -1
  191. package/dist/cjs/types/appAPI.js +2 -1
  192. package/dist/cjs/types/custom.js +52 -0
  193. package/dist/cjs/types/global-style.js +15 -1
  194. package/dist/cjs/types/shop.js +2 -1
  195. package/dist/cjs/web-components/src/helpers/styles/constant.js +9 -1
  196. package/dist/esm/components/AddOn.js +14 -1
  197. package/dist/esm/components/ComponentAnimation.js +13 -0
  198. package/dist/esm/components/ComponentToolbarPreview.js +748 -1
  199. package/dist/esm/components/ComponentWrapper.js +57 -1
  200. package/dist/esm/components/ComponentWrapperPreview.js +209 -1
  201. package/dist/esm/components/Empty.js +3 -1
  202. package/dist/esm/components/InteractionSuffix.js +40 -0
  203. package/dist/esm/components/Render.js +71 -1
  204. package/dist/esm/components/Render.liquid.js +307 -17
  205. package/dist/esm/components/RenderBlock.js +50 -1
  206. package/dist/esm/components/RenderCustomCode.js +55 -3
  207. package/dist/esm/components/RenderPreview.js +63 -1
  208. package/dist/esm/components/RenderSection.js +19 -1
  209. package/dist/esm/components/ai-generator/AIContentGenerator.js +250 -1
  210. package/dist/esm/components/ai-generator/AIGenContentLoading.js +83 -1
  211. package/dist/esm/components/ai-generator/components/PickProduct.js +218 -1
  212. package/dist/esm/components/ai-generator/components/ToneAndVoice.js +75 -1
  213. package/dist/esm/components/ai-generator/hooks/useCheckingProductInside.js +45 -0
  214. package/dist/esm/components/ai-generator/hooks/useFlipPopup.js +108 -0
  215. package/dist/esm/components/ai-generator/hooks/useGettingGenerateRequest.js +35 -1
  216. package/dist/esm/components/ai-generator/hooks/useListenEventGenerate.js +68 -1
  217. package/dist/esm/components/ai-generator/icons/AIIcon.js +65 -1
  218. package/dist/esm/components/ai-generator/icons/CloseIcon.js +17 -1
  219. package/dist/esm/components/ai-generator/icons/DropdownIcon.js +34 -1
  220. package/dist/esm/components/ai-generator/icons/SearchIcon.js +19 -1
  221. package/dist/esm/components/ai-generator/icons/ShowMoreIcon.js +19 -1
  222. package/dist/esm/components/ai-generator/icons/UpgradeIcon.js +25 -0
  223. package/dist/esm/components/ai-generator/icons/WarningIcon.js +29 -0
  224. package/dist/esm/components/constant.js +76 -1
  225. package/dist/esm/components/resize/Resize.js +12 -1
  226. package/dist/esm/components/resize/Spacing.js +256 -1
  227. package/dist/esm/components/src/product/helpers/variant-presets.js +54 -1
  228. package/dist/esm/components/theme-section/CreateThemeSection.js +121 -1
  229. package/dist/esm/components/theme-section/ThemeSectionStatus.js +43 -1
  230. package/dist/esm/components/theme-section/ThemeSectionTooltip.js +124 -1
  231. package/dist/esm/components/toolbar/Tooltip.js +24 -1
  232. package/dist/esm/contexts/AddonContext.js +32 -1
  233. package/dist/esm/contexts/ArticleContext.js +36 -1
  234. package/dist/esm/contexts/ArticleListContext.js +27 -1
  235. package/dist/esm/contexts/BuilderComponent.js +31 -1
  236. package/dist/esm/contexts/BuilderContext.js +36 -1
  237. package/dist/esm/contexts/BuilderPreviewContext.js +483 -1
  238. package/dist/esm/contexts/CartLineContext.js +26 -1
  239. package/dist/esm/contexts/CollectionContext.js +35 -1
  240. package/dist/esm/contexts/ModalContext.js +44 -1
  241. package/dist/esm/contexts/PageContext.js +101 -1
  242. package/dist/esm/contexts/ProductContext.js +174 -1
  243. package/dist/esm/contexts/ProductListContext.js +28 -1
  244. package/dist/esm/contexts/SectionContext.js +49 -1
  245. package/dist/esm/contexts/ShopContext.js +104 -1
  246. package/dist/esm/graphql/fragments/analytic.generated.js +4 -2
  247. package/dist/esm/graphql/fragments/collection-detail.generated.js +4 -2
  248. package/dist/esm/graphql/fragments/collection-product.generated.js +4 -2
  249. package/dist/esm/graphql/fragments/collection.generated.js +4 -2
  250. package/dist/esm/graphql/fragments/custom-code.generated.js +4 -2
  251. package/dist/esm/graphql/fragments/custom-font.generated.js +4 -2
  252. package/dist/esm/graphql/fragments/data-seo.generated.js +4 -2
  253. package/dist/esm/graphql/fragments/media.generated.js +4 -2
  254. package/dist/esm/graphql/fragments/preview-theme-page.generated.js +37 -0
  255. package/dist/esm/graphql/fragments/product-little.generated.js +5 -2
  256. package/dist/esm/graphql/fragments/product-option-value.generated.js +4 -2
  257. package/dist/esm/graphql/fragments/product-option.generated.js +4 -2
  258. package/dist/esm/graphql/fragments/product.generated.js +4 -2
  259. package/dist/esm/graphql/fragments/published-custom-section.generated.js +4 -2
  260. package/dist/esm/graphql/fragments/published-page-section.generated.js +4 -2
  261. package/dist/esm/graphql/fragments/published-theme-page.generated.js +8 -28
  262. package/dist/esm/graphql/fragments/published-theme-style.generated.js +4 -2
  263. package/dist/esm/graphql/fragments/selected-option.generated.js +4 -2
  264. package/dist/esm/graphql/fragments/variant.generated.js +4 -2
  265. package/dist/esm/graphql/mutations/page-view-up.generated.js +6 -4
  266. package/dist/esm/graphql/queries/articles.generated.js +59 -0
  267. package/dist/esm/graphql/queries/blogs.generated.js +67 -0
  268. package/dist/esm/graphql/queries/collection-detail-filter.generated.js +22 -10
  269. package/dist/esm/graphql/queries/collection.generated.js +18 -8
  270. package/dist/esm/graphql/queries/collections.generated.js +8 -3
  271. package/dist/esm/graphql/queries/preview-page.generated.js +16 -10
  272. package/dist/esm/graphql/queries/product-little-detail.generated.js +12 -5
  273. package/dist/esm/graphql/queries/product-medias.generated.js +6 -2
  274. package/dist/esm/graphql/queries/product-value-label.generated.js +4 -2
  275. package/dist/esm/graphql/queries/product-variants.generated.js +10 -4
  276. package/dist/esm/graphql/queries/products.generated.js +20 -9
  277. package/dist/esm/graphql/queries/published-shop-metas.js +13 -0
  278. package/dist/esm/graphql/queries/published-theme-pages.generated.js +20 -9
  279. package/dist/esm/graphql/queries/store-property.generated.js +4 -2
  280. package/dist/esm/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +4 -2
  281. package/dist/esm/graphql-app-api/queries/LibraryTemplate.generated.js +4 -2
  282. package/dist/esm/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +4 -2
  283. package/dist/esm/graphql-app-api/queries/ShopLibraryPage.generated.js +15 -0
  284. package/dist/esm/graphql-app-api/queries/ThemePage.generated.js +4 -2
  285. package/dist/esm/helpers/GlobalEvent.js +15 -1
  286. package/dist/esm/helpers/align.js +17 -0
  287. package/dist/esm/helpers/animations.js +220 -1
  288. package/dist/esm/helpers/background.js +226 -1
  289. package/dist/esm/helpers/borders.js +189 -4
  290. package/dist/esm/helpers/carousel.js +51 -1
  291. package/dist/esm/helpers/clone-deep.js +3 -1
  292. package/dist/esm/helpers/cls.js +14 -1
  293. package/dist/esm/helpers/colors.js +169 -1
  294. package/dist/esm/helpers/compose-advance-style.js +319 -1
  295. package/dist/esm/helpers/constant.js +19 -1
  296. package/dist/esm/helpers/convert.js +4 -1
  297. package/dist/esm/helpers/covert-entities-html.js +17 -1
  298. package/dist/esm/helpers/css-variable.js +5 -1
  299. package/dist/esm/helpers/email.js +6 -1
  300. package/dist/esm/helpers/filter-toolbar-preview.js +9 -1
  301. package/dist/esm/helpers/flatten-connection.js +7 -1
  302. package/dist/esm/helpers/get-resonsive-value.js +31 -1
  303. package/dist/esm/helpers/get-shortname.js +90 -1
  304. package/dist/esm/helpers/icon-list.js +58 -1
  305. package/dist/esm/helpers/interaction/index.js +132 -0
  306. package/dist/esm/helpers/is-browser.js +5 -1
  307. package/dist/esm/helpers/is-defined.js +5 -1
  308. package/dist/esm/helpers/is-empty-children.js +10 -1
  309. package/dist/esm/helpers/is-safari.js +5 -1
  310. package/dist/esm/helpers/layout.js +54 -1
  311. package/dist/esm/helpers/load-script.js +29 -1
  312. package/dist/esm/helpers/loop-component.js +14 -0
  313. package/dist/esm/helpers/make-style.js +149 -1
  314. package/dist/esm/helpers/normalize-builder-data.js +21 -1
  315. package/dist/esm/helpers/pascal-to-kebab-case.js +5 -0
  316. package/dist/esm/helpers/prefetch-queries.js +76 -1
  317. package/dist/esm/helpers/product.js +44 -1
  318. package/dist/esm/helpers/queries/get-collection.js +223 -1
  319. package/dist/esm/helpers/queries/get-collections.js +19 -1
  320. package/dist/esm/helpers/queries/get-product-by-slug.js +123 -1
  321. package/dist/esm/helpers/queries/get-product.js +150 -1
  322. package/dist/esm/helpers/queries/get-products.js +210 -1
  323. package/dist/esm/helpers/query.js +25 -1
  324. package/dist/esm/helpers/radius.js +132 -6
  325. package/dist/esm/helpers/render.js +70 -1
  326. package/dist/esm/helpers/shadow.js +63 -1
  327. package/dist/esm/helpers/size.js +192 -4
  328. package/dist/esm/helpers/spacing.js +40 -1
  329. package/dist/esm/helpers/third-party/addAppBlockId.js +18 -0
  330. package/dist/esm/helpers/third-party/appConfig.js +200 -0
  331. package/dist/esm/helpers/third-party/appSetting.js +658 -0
  332. package/dist/esm/helpers/third-party/composeAppBlockId.js +9 -0
  333. package/dist/esm/helpers/third-party/constant.js +40 -0
  334. package/dist/esm/helpers/third-party/generateAppBlockConfigs.js +32 -0
  335. package/dist/esm/helpers/third-party/getAppBlockConfig.js +45 -0
  336. package/dist/esm/helpers/third-party/getAppBlockType.js +10 -0
  337. package/dist/esm/helpers/third-party/getAppBlocks.js +28 -0
  338. package/dist/esm/helpers/third-party/mergeBlock.js +17 -0
  339. package/dist/esm/helpers/third-party/mergeBlockOrder.js +45 -0
  340. package/dist/esm/helpers/third-party/removeGPAppItems.js +15 -0
  341. package/dist/esm/helpers/tracking/fpixel.js +24 -1
  342. package/dist/esm/helpers/tracking/gtag.js +87 -1
  343. package/dist/esm/helpers/tracking/tiktokpixel.js +15 -1
  344. package/dist/esm/helpers/typography.js +149 -17
  345. package/dist/esm/helpers/variant.js +9 -1
  346. package/dist/esm/hooks/animation/useAnimationActions.js +37 -1
  347. package/dist/esm/hooks/animation/useAnimationConfig.js +28 -1
  348. package/dist/esm/hooks/animation/useAnimationPreview.js +29 -1
  349. package/dist/esm/hooks/animation/useAnimationTarget.js +120 -1
  350. package/dist/esm/hooks/animation/useApplyAnimation.js +85 -1
  351. package/dist/esm/hooks/articles/useArticlesQuery.js +30 -1
  352. package/dist/esm/hooks/cart/use-add-to-cart.js +18 -1
  353. package/dist/esm/hooks/cart/use-cart-data.js +26 -1
  354. package/dist/esm/hooks/cart/use-cart-discount-codes-update.js +18 -1
  355. package/dist/esm/hooks/cart/use-cart-note-update.js +18 -1
  356. package/dist/esm/hooks/cart/use-create-cart.js +20 -1
  357. package/dist/esm/hooks/cart/use-remove-cart-item.js +18 -1
  358. package/dist/esm/hooks/cart/use-update-cart-item.js +18 -1
  359. package/dist/esm/hooks/shop/use-collection-query.js +20 -1
  360. package/dist/esm/hooks/shop/use-collections-query.js +15 -1
  361. package/dist/esm/hooks/shop/use-product-query.js +20 -1
  362. package/dist/esm/hooks/shop/use-products-query.js +59 -1
  363. package/dist/esm/hooks/shop.js +111 -1
  364. package/dist/esm/hooks/use-current-device.js +28 -1
  365. package/dist/esm/hooks/use-lazy-video.js +13 -1
  366. package/dist/esm/hooks/useAnimations.js +27 -1
  367. package/dist/esm/hooks/useCartId.js +40 -1
  368. package/dist/esm/hooks/useCartLine.js +7 -1
  369. package/dist/esm/hooks/useCartUI.js +44 -1
  370. package/dist/esm/hooks/useCollection.js +7 -1
  371. package/dist/esm/hooks/useFetchHandle.js +11 -1
  372. package/dist/esm/hooks/useFormatMoney.js +71 -1
  373. package/dist/esm/hooks/useInitialSwatchesOptions.js +124 -1
  374. package/dist/esm/hooks/useInteraction.js +17 -0
  375. package/dist/esm/hooks/useIsomorphicLayoutEffect.js +6 -1
  376. package/dist/esm/hooks/useLoadScript.js +28 -1
  377. package/dist/esm/hooks/useMoney.js +80 -1
  378. package/dist/esm/hooks/usePrevious.js +17 -1
  379. package/dist/esm/hooks/useProduct.js +228 -1
  380. package/dist/esm/hooks/useProductList.js +16 -1
  381. package/dist/esm/hooks/useSuspenseFetch.js +23 -1
  382. package/dist/esm/hooks/useSwatchesOptions.js +37 -1
  383. package/dist/esm/hooks/useToolbarPostPurchase.js +87 -1
  384. package/dist/esm/index.js +117 -1
  385. package/dist/esm/types/animations.js +49 -1
  386. package/dist/esm/types/custom.js +52 -0
  387. package/dist/esm/types/global-style.js +12 -1
  388. package/dist/esm/web-components/src/helpers/styles/constant.js +7 -1
  389. package/dist/types/index.d.ts +23183 -17335
  390. package/package.json +5 -3
  391. package/dist/cjs/components/animation/AnimationWrapper.js +0 -1
  392. package/dist/cjs/hooks/animation/animations.js +0 -1
  393. package/dist/cjs/hooks/animation/useLivePageAnimation.js +0 -1
  394. package/dist/esm/components/animation/AnimationWrapper.js +0 -1
  395. package/dist/esm/hooks/animation/animations.js +0 -1
  396. package/dist/esm/hooks/animation/useLivePageAnimation.js +0 -1
@@ -1 +1,32 @@
1
- import{jsx as o}from"react/jsx-runtime";import{useContext as d,useMemo as e,createContext as n}from"react";import r from"../components/Empty.js";let AddonContext=n(null),AddonProvider=({children:d,components:e,...n})=>o(AddonContext.Provider,{...n,value:{components:e},children:d}),useAddons=()=>{let o=d(AddonContext);if(!o)throw Error("useAddons must be used within an AddonProvider");return e(()=>o.components,[o.components])},useAddon=o=>{let d=useAddons();return e(()=>o?d[o]??r:r,[o,d])};export{AddonProvider,useAddon,useAddons};
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useContext, useMemo, createContext } from 'react';
3
+ import Empty from '../components/Empty.js';
4
+
5
+ const AddonContext = /*#__PURE__*/ createContext(null);
6
+ const AddonProvider = ({ children, components, ...passProps })=>{
7
+ return /*#__PURE__*/ jsx(AddonContext.Provider, {
8
+ ...passProps,
9
+ value: {
10
+ components
11
+ },
12
+ children: children
13
+ });
14
+ };
15
+ const useAddons = ()=>{
16
+ const context = useContext(AddonContext);
17
+ if (!context) {
18
+ throw new Error('useAddons must be used within an AddonProvider');
19
+ }
20
+ return useMemo(()=>context.components, [
21
+ context.components
22
+ ]);
23
+ };
24
+ const useAddon = (id)=>{
25
+ const addons = useAddons();
26
+ return useMemo(()=>id ? addons[id] ?? Empty : Empty, [
27
+ id,
28
+ addons
29
+ ]);
30
+ };
31
+
32
+ export { AddonProvider, useAddon, useAddons };
@@ -1 +1,36 @@
1
- import{jsx as r,Fragment as e}from"react/jsx-runtime";import{useStore as t,createStore as i}from"zustand";import{useId as o,useMemo as l,useContext as c,createContext as n}from"react";let ArticleContext=n(null),createArticleStoreProvider=r=>i(()=>({...r})),ArticleProvider=({children:t,article:i})=>{let c=o(),n=l(()=>createArticleStoreProvider({article:i,uniqueId:c}),[i,c]);return r(ArticleContext.Provider,{value:n,children:r(e,{children:t})})},useArticleStore=(r,e)=>{let i=c(ArticleContext);if(!i)throw Error("Element of article must be used inside a Article");return t(i,r,e)};export{ArticleProvider,useArticleStore};
1
+ import { jsx, Fragment } from 'react/jsx-runtime';
2
+ import { useStore, createStore } from 'zustand';
3
+ import { useId, useMemo, useContext, createContext } from 'react';
4
+
5
+ // const { Provider, useStore } = createContext<StoreApi<ProductContextProps>>();
6
+ const ArticleContext = /*#__PURE__*/ createContext(null);
7
+ const createArticleStoreProvider = (data)=>createStore(()=>({
8
+ ...data
9
+ }));
10
+ const ArticleProvider = ({ children, article })=>{
11
+ const uniqueId = useId();
12
+ const store = useMemo(()=>{
13
+ return createArticleStoreProvider({
14
+ article,
15
+ uniqueId
16
+ });
17
+ }, [
18
+ article,
19
+ uniqueId
20
+ ]);
21
+ return /*#__PURE__*/ jsx(ArticleContext.Provider, {
22
+ value: store,
23
+ children: /*#__PURE__*/ jsx(Fragment, {
24
+ children: children
25
+ })
26
+ });
27
+ };
28
+ const useArticleStore = (selector, equalityFn)=>{
29
+ const store = useContext(ArticleContext);
30
+ if (!store) {
31
+ throw new Error('Element of article must be used inside a Article');
32
+ }
33
+ return useStore(store, selector, equalityFn);
34
+ };
35
+
36
+ export { ArticleProvider, useArticleStore };
@@ -1 +1,27 @@
1
- import{jsx as t}from"react/jsx-runtime";import{useContext as r,createContext as e}from"react";import{useStore as i,createStore as o}from"zustand";let ArticleListContext=e(null),createArticleListProvider=t=>o(()=>({...t})),ArticleListProvider=({articles:r,blogs:e,children:i,styles:o,settings:s})=>t(ArticleListContext.Provider,{value:createArticleListProvider({articles:r,styles:o,settings:s,blogs:e}),children:i}),useArticleListStore=(t,e)=>{let o=r(ArticleListContext);if(!o)throw Error("useArticleListStore must be used within a useArticleListStore");return i(o,t,e)};export{ArticleListContext,ArticleListProvider,useArticleListStore};
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useContext, createContext } from 'react';
3
+ import { useStore, createStore } from 'zustand';
4
+
5
+ const ArticleListContext = /*#__PURE__*/ createContext(null);
6
+ const createArticleListProvider = (data)=>createStore(()=>({
7
+ ...data
8
+ }));
9
+ const ArticleListProvider = ({ articles, children, styles, settings })=>{
10
+ return /*#__PURE__*/ jsx(ArticleListContext.Provider, {
11
+ value: createArticleListProvider({
12
+ articles,
13
+ styles,
14
+ settings
15
+ }),
16
+ children: children
17
+ });
18
+ };
19
+ const useArticleListStore = (selector, equalityFn)=>{
20
+ const store = useContext(ArticleListContext);
21
+ if (!store) {
22
+ throw new Error('useArticleListStore must be used within a useArticleListStore');
23
+ }
24
+ return useStore(store, selector, equalityFn);
25
+ };
26
+
27
+ export { ArticleListContext, ArticleListProvider, useArticleListStore };
@@ -1 +1,31 @@
1
- import{jsx as e}from"react/jsx-runtime";import{useStore as o,createStore as t}from"zustand";import{useContext as r,createContext as n}from"react";import m from"../components/Empty.js";let BuilderComponentContext=n(null),createBuilderComponentStore=e=>t((o,t)=>({components:e,getItem:e=>t().components[e]})),BuilderComponentProvider=({children:o,components:t,...r})=>e(BuilderComponentContext.Provider,{...r,value:createBuilderComponentStore(t),children:o}),useBuilderComponent=e=>{let t=r(BuilderComponentContext);if(!t)throw Error("useBuilderComponent must be used within a BuilderComponentProvider");return o(t,o=>e?o.getItem(e)??m:m)};export{BuilderComponentProvider,useBuilderComponent};
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useStore, createStore } from 'zustand';
3
+ import { useContext, createContext } from 'react';
4
+ import Empty from '../components/Empty.js';
5
+
6
+ const BuilderComponentContext = /*#__PURE__*/ createContext(null);
7
+ const createBuilderComponentStore = (components)=>createStore((_, get)=>({
8
+ components,
9
+ getItem: (id)=>{
10
+ return get().components[id];
11
+ }
12
+ }));
13
+ const BuilderComponentProvider = ({ children, components, ...passProps })=>{
14
+ return /*#__PURE__*/ jsx(BuilderComponentContext.Provider, {
15
+ ...passProps,
16
+ value: createBuilderComponentStore(components),
17
+ children: children
18
+ });
19
+ };
20
+ // export const useBuilderComponent = (id?: string) => {
21
+ // return useStore((s) => (id ? s.getItem(id) ?? Empty : Empty));
22
+ // };
23
+ const useBuilderComponent = (id)=>{
24
+ const store = useContext(BuilderComponentContext);
25
+ if (!store) {
26
+ throw new Error('useBuilderComponent must be used within a BuilderComponentProvider');
27
+ }
28
+ return useStore(store, (s)=>id ? s.getItem(id) ?? Empty : Empty);
29
+ };
30
+
31
+ export { BuilderComponentProvider, useBuilderComponent };
@@ -1 +1,36 @@
1
- import{jsx as e}from"react/jsx-runtime";import{useContext as r,createContext as t,Suspense as i,Fragment as u}from"react";import{useStore as o,createStore as d}from"zustand";let BuilderContext=t(null),createBuilderProvider=(e,r,t)=>d((i,u)=>({state:e,isPostPurchase:r,isPreview:t,getItem:e=>u().state[e],getIsPostPurchase:()=>u().isPostPurchase,getIsPreview:()=>u().isPreview})),BuilderProvider=({children:r,state:t,isPostPurchase:o,isPreview:d,lazy:s,priority:l,...P})=>{let a=s?i:u,n=createBuilderProvider(t,o,d);return e(a,{children:e(BuilderContext.Provider,{...P,value:n,children:r})})},useBuilderStore=(e,t)=>{let i=r(BuilderContext);if(!i)throw Error("useBuilderStore must be used within a BuilderProvider");return o(i,e,t)};export{BuilderProvider,useBuilderStore};
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useContext, createContext, Suspense, Fragment } from 'react';
3
+ import { useStore, createStore } from 'zustand';
4
+
5
+ const BuilderContext = /*#__PURE__*/ createContext(null);
6
+ const createBuilderProvider = (data, isPostPurchase, isPreview)=>createStore((_, get)=>({
7
+ state: data,
8
+ isPostPurchase: isPostPurchase,
9
+ isPreview: isPreview,
10
+ getItem: (id)=>{
11
+ return get().state[id];
12
+ },
13
+ getIsPostPurchase: ()=>get().isPostPurchase,
14
+ getIsPreview: ()=>get().isPreview
15
+ }));
16
+ const BuilderProvider = ({ children, state, isPostPurchase, isPreview, lazy, priority, ...passProps })=>{
17
+ const Component = lazy ? Suspense : Fragment;
18
+ const store = createBuilderProvider(state, isPostPurchase, isPreview);
19
+ return /*#__PURE__*/ jsx(Component, {
20
+ children: /*#__PURE__*/ jsx(BuilderContext.Provider, {
21
+ ...passProps,
22
+ value: store,
23
+ children: children
24
+ })
25
+ });
26
+ };
27
+ // export const useBuilderStore = useStore;
28
+ const useBuilderStore = (selector, equalityFn)=>{
29
+ const store = useContext(BuilderContext);
30
+ if (!store) {
31
+ throw new Error('useBuilderStore must be used within a BuilderProvider');
32
+ }
33
+ return useStore(store, selector, equalityFn);
34
+ };
35
+
36
+ export { BuilderProvider, useBuilderStore };
@@ -1 +1,483 @@
1
- import{jsx as e}from"react/jsx-runtime";import{useMemo as t,useContext as i,createContext as r,Suspense as s,Fragment as d}from"react";import{useStore as l,createStore as n}from"zustand";import{cloneDeep as a}from"../helpers/clone-deep.js";import{normalizeBuilderData as c}from"../helpers/normalize-builder-data.js";function moveByIndex(e,t,i){let r=e.splice(t,1)[0];void 0!==r&&e.splice(i,0,r)}function removeByKey(e,t){let i=t[e];i&&(delete t[e],"section"!==i.type&&i.childrens?.map(e=>removeByKey(e,t)))}let BuilderPreviewContext=r(null),root={uid:"ROOT",tag:"Root",label:"Root",childrens:[]},createBuilderPreviewProvider=(e,t)=>n((i,r)=>({state:e,loaded:!1,isThemeSectionEditor:!!t,dynamicProduct:null,dynamicCollection:null,addItem:e=>{let{position:t,data:s}=e,d=r().state,l=Date.now();if("section"===e.type){if(!Array.isArray(s)){let e=s.uid,r=d.ROOT;r.childrens?r.childrens.splice(t??0,0,e):r.childrens=[e],r.dateModified=l,i({state:{...d,[e]:{uid:e,type:"section",label:s.label},ROOT:a(r)}})}}else{let{id:r,data:s}=e,n=r?d[r]??d.ROOT:d.ROOT;if("section"===n.type)return;if(Array.isArray(s)){let e=s.map(e=>e.uid),r=s.reduceRight((e,t)=>{let i=c(t);return{...e,...i}},{});n.dateModified=l,n.childrens=n.childrens??[],n.childrens.splice(t??0,0,...e),i({state:{...d,...r,[n.uid]:a(n)}})}else{let e=c(s);n.dateModified=l,n.childrens=n.childrens??[],n.childrens.splice(t??0,0,s.uid),i({state:{...d,...e,[n.uid]:a(n)}})}}},changeItemProp:(e,t,s)=>{if(!s||!["setting","style","advanced"].includes(s))return;let d=r().state,l=d[e];if(l?.type!=="section"&&l){let r=Date.now();switch(l.dateModified=r,s){case"setting":i({state:{...d,[e]:{...l,settings:{...l.settings,...t}}}});break;case"style":i({state:{...d,[e]:{...l,styles:{...l.styles,...t}}}});break;case"advanced":i({state:{...d,[e]:{...l,advanced:{...l.advanced,...t}}}})}}},forceChangeItemProp:(e,t,s)=>{if(!s||!["setting","style","advanced"].includes(s))return;let d=r().state,l=d[e];if(l?.type!=="section"&&l){let r=Date.now();switch(l.dateModified=r,s){case"setting":i({state:{...d,[e]:{...l,settings:t}}});break;case"style":i({state:{...d,[e]:{...l,styles:t}}});break;case"advanced":i({state:{...d,[e]:{...l,advanced:t}}})}}},changeItemPropByKey:({id:e,key:t,data:s,group:d})=>{if(!d||!["setting","style","advanced"].includes(d))return;let l=r().state,n=l[e];if(n?.type!=="section"&&n){let r={style:n.styles??{},advanced:n.advanced??{},setting:n.settings??{}};void 0===s?(console.warn("Data is undefined"),delete r[d][t]):r[d][t]=s,i({state:{...l,[e]:{...n,settings:{...r.setting},styles:{...r.style},advanced:{...r.advanced}}}})}},getItem:e=>{let t=r().state[e];return{...t,rawChildrens:t?.childrens?.map(e=>r().state[e])}},removeItem:e=>{if("ROOT"===e)i({state:{ROOT:root}});else{let t=r().state;removeByKey(e,t);let s=Object.entries(t).find(([,t])=>"section"!==t.type&&t.childrens?.includes(e));if(s){let r=Date.now(),[d,l]=s;if("section"===l.type)return;l.childrens=l.childrens?.filter(t=>t!==e),l.dateModified=r,i({state:{...t,[d]:a(l)}})}}},moveItem:(e,t,s)=>{let d=r().state,l=d[e],n=d[t];if(l&&n&&"section"!==n.type){if("section"===l.type){let t=d.ROOT;if(!t.childrens)return;let r=t.childrens.findIndex(t=>t===e);moveByIndex(t.childrens,r,s??0),i({state:{...d,ROOT:a(t)}})}else{let r=Object.entries(d).find(([,t])=>"section"!==t.type&&t.childrens?.includes(e));if(l&&r){let c=Date.now(),[,o]=r;if("section"===o.type)return;if(o.dateModified=c,t===o.uid&&o.childrens){let t=o.childrens.findIndex(t=>t===e);o.childrens&&t!==s&&(moveByIndex(o.childrens,t,s??0),i({state:{...d,[o.uid]:a(o)}}))}else o.childrens=o.childrens?.filter(t=>t!==e),n&&(n.dateModified=c,n.childrens=n.childrens??[],n.childrens.splice(s??0,0,l.uid),i({state:{...d,[n.uid]:a(n),[o.uid]:a(o)}}))}}}},forceChangeState:e=>{i({state:e,loaded:!0})},initState:e=>{if(Array.isArray(e)){let t=e.map(e=>e.uid),r=e.reduceRight((e,t)=>{let i=c(t);return{...e,...i}},{});i({loaded:!0,state:{ROOT:{...root,childrens:t},...r}})}else{let t=c(e);i({loaded:!0,state:{ROOT:{...root,childrens:[e.uid]},...t}})}},addSection:(e,t)=>{let s=r().state,d=s.ROOT;d.childrens||(d.childrens=[]),d.childrens.splice(t??0,0,e.uid),i({state:{...s,ROOT:a(d)}})},getParents:(e,t)=>{let i=r().state,s=[],d=0,l=e;for(;!t||!(d>=t);){let e=Object.entries(i).find(([,e])=>"section"!==e.type&&e.childrens?.includes(l));if(!e)break;let[,t]=e;if(!t)break;s.push(t),l=t.uid,d++}return s},updateItemName:(e,t)=>{let s=r().state,d=s[e];d&&(d.name=t,i({state:{...s,[e]:a(d)}}))},updateItemAttribute:(e,t,s)=>{if(!s||!["label","customLabel","isShopifyVisibility"].includes(s))return;let d=r().state,l=d[e];if(l){if("section"!==l.type){let e=Date.now();l.dateModified=e}let r={...l,[s]:t};i({state:{...d,[e]:r}})}}})),BuilderPreviewProvider=({children:i,state:r,isThemeSectionEditor:l,lazy:n,...a})=>{let c=n?s:d,o=t(()=>createBuilderPreviewProvider(r,l),[r,l]);return e(c,{children:e(BuilderPreviewContext.Provider,{...a,value:o,children:i})})},useBuilderPreviewStore=(e,t)=>{let r=i(BuilderPreviewContext);if(!r)throw Error("useBuilderPreviewStore must be used within a BuilderPreviewProvider");return l(r,e,t)};export{BuilderPreviewProvider,useBuilderPreviewStore};
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useMemo, useContext, createContext, Suspense, Fragment } from 'react';
3
+ import { useStore, createStore } from 'zustand';
4
+ import { cloneDeep } from '../helpers/clone-deep.js';
5
+ import { normalizeBuilderData } from '../helpers/normalize-builder-data.js';
6
+
7
+ function moveByIndex(input, from, to) {
8
+ const elm = input.splice(from, 1)[0];
9
+ if (elm !== undefined) {
10
+ input.splice(to, 0, elm);
11
+ }
12
+ }
13
+ function removeByKey(id, data) {
14
+ const item = data[id];
15
+ if (item) {
16
+ delete data[id];
17
+ if (item.type !== 'section') {
18
+ item.childrens?.map((child)=>removeByKey(child, data));
19
+ }
20
+ }
21
+ }
22
+ const BuilderPreviewContext = /*#__PURE__*/ createContext(null);
23
+ const root = {
24
+ uid: 'ROOT',
25
+ tag: 'Root',
26
+ label: 'Root',
27
+ childrens: []
28
+ };
29
+ const createBuilderPreviewProvider = (args, pageName, isThemeSectionEditor)=>createStore((set, get)=>({
30
+ state: args,
31
+ loaded: false,
32
+ isThemeSectionEditor: !!isThemeSectionEditor,
33
+ pageName: pageName,
34
+ dynamicProduct: null,
35
+ dynamicCollection: null,
36
+ addItem: (args)=>{
37
+ const { position, data } = args;
38
+ const state = get().state;
39
+ const dateModified = Date.now();
40
+ if (args.type === 'section') {
41
+ if (!Array.isArray(data)) {
42
+ const sectionId = data.uid;
43
+ // Section only add to ROOT
44
+ const ROOT = state.ROOT;
45
+ if (!ROOT.childrens) {
46
+ ROOT.childrens = [
47
+ sectionId
48
+ ];
49
+ } else {
50
+ ROOT.childrens.splice(position ?? 0, 0, sectionId);
51
+ }
52
+ ROOT.dateModified = dateModified;
53
+ set({
54
+ state: {
55
+ ...state,
56
+ [sectionId]: {
57
+ uid: sectionId,
58
+ type: 'section',
59
+ label: data.label
60
+ },
61
+ ROOT: cloneDeep(ROOT)
62
+ }
63
+ });
64
+ }
65
+ } else {
66
+ const { id, data } = args;
67
+ const parent = id ? state[id] ?? state.ROOT : state.ROOT;
68
+ // Can't add item to section
69
+ if (parent.type === 'section') return;
70
+ if (Array.isArray(data)) {
71
+ const childrens = data.map((v)=>v.uid);
72
+ const newState = data.reduceRight((prev, current)=>{
73
+ const item = normalizeBuilderData(current);
74
+ return {
75
+ ...prev,
76
+ ...item
77
+ };
78
+ }, {});
79
+ parent.dateModified = dateModified;
80
+ parent.childrens = parent.childrens ?? [];
81
+ parent.childrens.splice(position ?? 0, 0, ...childrens);
82
+ set({
83
+ state: {
84
+ ...state,
85
+ ...newState,
86
+ [parent.uid]: cloneDeep(parent)
87
+ }
88
+ });
89
+ } else {
90
+ const item = normalizeBuilderData(data);
91
+ parent.dateModified = dateModified;
92
+ parent.childrens = parent.childrens ?? [];
93
+ parent.childrens.splice(position ?? 0, 0, data.uid);
94
+ set({
95
+ state: {
96
+ ...state,
97
+ ...item,
98
+ [parent.uid]: cloneDeep(parent)
99
+ }
100
+ });
101
+ }
102
+ }
103
+ },
104
+ changeItemProp: (id, data, group)=>{
105
+ if (!group || ![
106
+ 'setting',
107
+ 'style',
108
+ 'advanced'
109
+ ].includes(group)) return;
110
+ const state = get().state;
111
+ const item = state[id];
112
+ // Ignore section
113
+ if (item?.type === 'section') return;
114
+ if (item) {
115
+ const dateModified = Date.now();
116
+ item.dateModified = dateModified;
117
+ switch(group){
118
+ case 'setting':
119
+ set({
120
+ state: {
121
+ ...state,
122
+ [id]: {
123
+ ...item,
124
+ settings: {
125
+ ...item.settings,
126
+ ...data
127
+ }
128
+ }
129
+ }
130
+ });
131
+ break;
132
+ case 'style':
133
+ set({
134
+ state: {
135
+ ...state,
136
+ [id]: {
137
+ ...item,
138
+ styles: {
139
+ ...item.styles,
140
+ ...data
141
+ }
142
+ }
143
+ }
144
+ });
145
+ break;
146
+ case 'advanced':
147
+ set({
148
+ state: {
149
+ ...state,
150
+ [id]: {
151
+ ...item,
152
+ advanced: {
153
+ ...item.advanced,
154
+ ...data
155
+ }
156
+ }
157
+ }
158
+ });
159
+ break;
160
+ }
161
+ }
162
+ },
163
+ forceChangeItemProp: (id, data, group)=>{
164
+ if (!group || ![
165
+ 'setting',
166
+ 'style',
167
+ 'advanced'
168
+ ].includes(group)) return;
169
+ const state = get().state;
170
+ const item = state[id];
171
+ // Ignore section
172
+ if (item?.type === 'section') return;
173
+ if (item) {
174
+ const dateModified = Date.now();
175
+ item.dateModified = dateModified;
176
+ switch(group){
177
+ case 'setting':
178
+ set({
179
+ state: {
180
+ ...state,
181
+ [id]: {
182
+ ...item,
183
+ settings: data
184
+ }
185
+ }
186
+ });
187
+ break;
188
+ case 'style':
189
+ set({
190
+ state: {
191
+ ...state,
192
+ [id]: {
193
+ ...item,
194
+ styles: data
195
+ }
196
+ }
197
+ });
198
+ break;
199
+ case 'advanced':
200
+ set({
201
+ state: {
202
+ ...state,
203
+ [id]: {
204
+ ...item,
205
+ advanced: data
206
+ }
207
+ }
208
+ });
209
+ break;
210
+ }
211
+ }
212
+ },
213
+ changeItemPropByKey: ({ id, key, data, group })=>{
214
+ if (!group || ![
215
+ 'setting',
216
+ 'style',
217
+ 'advanced'
218
+ ].includes(group)) return;
219
+ const state = get().state;
220
+ const item = state[id];
221
+ // Ignore section
222
+ if (item?.type === 'section') return;
223
+ if (item) {
224
+ const itemSetting = {
225
+ style: item.styles ?? {},
226
+ advanced: item.advanced ?? {},
227
+ setting: item.settings ?? {}
228
+ };
229
+ if (data === undefined) {
230
+ console.warn('Data is undefined');
231
+ delete itemSetting[group][key];
232
+ } else {
233
+ itemSetting[group][key] = data;
234
+ }
235
+ set({
236
+ state: {
237
+ ...state,
238
+ [id]: {
239
+ ...item,
240
+ settings: {
241
+ ...itemSetting.setting
242
+ },
243
+ styles: {
244
+ ...itemSetting.style
245
+ },
246
+ advanced: {
247
+ ...itemSetting.advanced
248
+ }
249
+ }
250
+ }
251
+ });
252
+ }
253
+ },
254
+ getItem: (id)=>{
255
+ const item = get().state[id];
256
+ return {
257
+ ...item,
258
+ rawChildrens: item?.childrens?.map((v)=>get().state[v])
259
+ };
260
+ },
261
+ removeItem: (id)=>{
262
+ if (id === 'ROOT') {
263
+ set({
264
+ state: {
265
+ ROOT: root
266
+ }
267
+ });
268
+ } else {
269
+ const state = get().state;
270
+ removeByKey(id, state);
271
+ // Get parent node by id
272
+ const parent = Object.entries(state).find(([, value])=>value.type !== 'section' && value.childrens?.includes(id));
273
+ if (parent) {
274
+ const dateModified = Date.now();
275
+ const [parentId, parentValue] = parent;
276
+ if (parentValue.type === 'section') return;
277
+ parentValue.childrens = parentValue.childrens?.filter((child)=>child !== id);
278
+ parentValue.dateModified = dateModified;
279
+ set({
280
+ state: {
281
+ ...state,
282
+ [parentId]: cloneDeep(parentValue)
283
+ }
284
+ });
285
+ }
286
+ }
287
+ },
288
+ moveItem: (id, toId, position)=>{
289
+ const state = get().state;
290
+ const item = state[id];
291
+ const moveTo = state[toId];
292
+ // Ignore section
293
+ if (!item || !moveTo || moveTo.type === 'section') return;
294
+ if (item.type === 'section') {
295
+ // Section only add to ROOT
296
+ const ROOT = state.ROOT;
297
+ if (!ROOT.childrens) return;
298
+ const currentIndex = ROOT.childrens.findIndex((uid)=>uid === id);
299
+ moveByIndex(ROOT.childrens, currentIndex, position ?? 0);
300
+ set({
301
+ state: {
302
+ ...state,
303
+ ROOT: cloneDeep(ROOT)
304
+ }
305
+ });
306
+ } else {
307
+ const parent = Object.entries(state).find(([, value])=>value.type !== 'section' && value.childrens?.includes(id));
308
+ if (item && parent) {
309
+ const dateModified = Date.now();
310
+ const [, parentItem] = parent;
311
+ // Ignore section
312
+ if (parentItem.type === 'section') return;
313
+ parentItem.dateModified = dateModified;
314
+ if (toId === parentItem.uid && parentItem.childrens) {
315
+ // Move item to the same parent
316
+ const currentIndex = parentItem.childrens.findIndex((uid)=>uid === id);
317
+ if (parentItem.childrens && currentIndex !== position) {
318
+ moveByIndex(parentItem.childrens, currentIndex, position ?? 0);
319
+ set({
320
+ state: {
321
+ ...state,
322
+ [parentItem.uid]: cloneDeep(parentItem)
323
+ }
324
+ });
325
+ }
326
+ } else {
327
+ // Move item to another parent
328
+ // Remove item from parent node
329
+ parentItem.childrens = parentItem.childrens?.filter((uid)=>uid !== id);
330
+ if (moveTo) {
331
+ moveTo.dateModified = dateModified;
332
+ moveTo.childrens = moveTo.childrens ?? [];
333
+ moveTo.childrens.splice(position ?? 0, 0, item.uid);
334
+ set({
335
+ state: {
336
+ ...state,
337
+ [moveTo.uid]: cloneDeep(moveTo),
338
+ [parentItem.uid]: cloneDeep(parentItem)
339
+ }
340
+ });
341
+ }
342
+ }
343
+ }
344
+ }
345
+ },
346
+ forceChangeState: (data)=>{
347
+ set({
348
+ state: data,
349
+ loaded: true
350
+ });
351
+ },
352
+ initState: (data)=>{
353
+ if (Array.isArray(data)) {
354
+ const childrens = data.map((v)=>v.uid);
355
+ const newState = data.reduceRight((prev, current)=>{
356
+ const item = normalizeBuilderData(current);
357
+ return {
358
+ ...prev,
359
+ ...item
360
+ };
361
+ }, {});
362
+ set({
363
+ loaded: true,
364
+ state: {
365
+ ROOT: {
366
+ ...root,
367
+ childrens
368
+ },
369
+ ...newState
370
+ }
371
+ });
372
+ } else {
373
+ const newState = normalizeBuilderData(data);
374
+ set({
375
+ loaded: true,
376
+ state: {
377
+ ROOT: {
378
+ ...root,
379
+ childrens: [
380
+ data.uid
381
+ ]
382
+ },
383
+ ...newState
384
+ }
385
+ });
386
+ }
387
+ },
388
+ addSection: (data, position)=>{
389
+ const state = get().state;
390
+ const ROOT = state.ROOT;
391
+ if (!ROOT.childrens) ROOT.childrens = [];
392
+ ROOT.childrens.splice(position ?? 0, 0, data.uid);
393
+ set({
394
+ state: {
395
+ ...state,
396
+ ROOT: cloneDeep(ROOT)
397
+ }
398
+ });
399
+ },
400
+ getParents: (id, limit)=>{
401
+ const state = get().state;
402
+ const parents = [];
403
+ let index = 0;
404
+ let currentId = id;
405
+ // eslint-disable-next-line no-constant-condition
406
+ while(true){
407
+ if (limit && index >= limit) break;
408
+ const parent = Object.entries(state).find(([, value])=>value.type !== 'section' && value.childrens?.includes(currentId));
409
+ if (!parent) break;
410
+ const [, parentItem] = parent;
411
+ if (!parentItem) break;
412
+ parents.push(parentItem);
413
+ currentId = parentItem.uid;
414
+ index++;
415
+ }
416
+ return parents;
417
+ },
418
+ updateItemName: (id, name)=>{
419
+ const state = get().state;
420
+ const item = state[id];
421
+ if (item) {
422
+ item.name = name;
423
+ set({
424
+ state: {
425
+ ...state,
426
+ [id]: cloneDeep(item)
427
+ }
428
+ });
429
+ }
430
+ },
431
+ updateItemAttribute: (id, value, attr)=>{
432
+ if (!attr || ![
433
+ 'label',
434
+ 'customLabel',
435
+ 'isShopifyVisibility'
436
+ ].includes(attr)) return;
437
+ const state = get().state;
438
+ const item = state[id];
439
+ if (item) {
440
+ if (item.type !== 'section') {
441
+ const dateModified = Date.now();
442
+ item.dateModified = dateModified;
443
+ }
444
+ const updatedItem = {
445
+ ...item,
446
+ [attr]: value
447
+ };
448
+ set({
449
+ state: {
450
+ ...state,
451
+ [id]: updatedItem
452
+ }
453
+ });
454
+ }
455
+ }
456
+ }));
457
+ const BuilderPreviewProvider = ({ children, state, isThemeSectionEditor, pageName, lazy, ...passProps })=>{
458
+ const Component = lazy ? Suspense : Fragment;
459
+ const value = useMemo(()=>{
460
+ return createBuilderPreviewProvider(state, pageName, isThemeSectionEditor);
461
+ }, [
462
+ state,
463
+ isThemeSectionEditor,
464
+ pageName
465
+ ]);
466
+ return /*#__PURE__*/ jsx(Component, {
467
+ children: /*#__PURE__*/ jsx(BuilderPreviewContext.Provider, {
468
+ ...passProps,
469
+ value: value,
470
+ children: children
471
+ })
472
+ });
473
+ };
474
+ // export const useBuilderPreviewStore = useStore;
475
+ const useBuilderPreviewStore = (selector, equalityFn)=>{
476
+ const store = useContext(BuilderPreviewContext);
477
+ if (!store) {
478
+ throw new Error('useBuilderPreviewStore must be used within a BuilderPreviewProvider');
479
+ }
480
+ return useStore(store, selector, equalityFn);
481
+ };
482
+
483
+ export { BuilderPreviewProvider, useBuilderPreviewStore };