@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.
- package/dist/cjs/components/AddOn.js +18 -1
- package/dist/cjs/components/ComponentAnimation.js +17 -0
- package/dist/cjs/components/ComponentToolbarPreview.js +752 -1
- package/dist/cjs/components/ComponentWrapper.js +61 -1
- package/dist/cjs/components/ComponentWrapperPreview.js +213 -1
- package/dist/cjs/components/Empty.js +7 -1
- package/dist/cjs/components/InteractionSuffix.js +42 -0
- package/dist/cjs/components/Render.js +75 -1
- package/dist/cjs/components/Render.liquid.js +313 -17
- package/dist/cjs/components/RenderBlock.js +54 -1
- package/dist/cjs/components/RenderCustomCode.js +59 -3
- package/dist/cjs/components/RenderPreview.js +67 -1
- package/dist/cjs/components/RenderSection.js +23 -1
- package/dist/cjs/components/ai-generator/AIContentGenerator.js +252 -1
- package/dist/cjs/components/ai-generator/AIGenContentLoading.js +85 -1
- package/dist/cjs/components/ai-generator/components/PickProduct.js +220 -1
- package/dist/cjs/components/ai-generator/components/ToneAndVoice.js +77 -1
- package/dist/cjs/components/ai-generator/hooks/useCheckingProductInside.js +47 -0
- package/dist/cjs/components/ai-generator/hooks/useFlipPopup.js +110 -0
- package/dist/cjs/components/ai-generator/hooks/useGettingGenerateRequest.js +37 -1
- package/dist/cjs/components/ai-generator/hooks/useListenEventGenerate.js +70 -1
- package/dist/cjs/components/ai-generator/icons/AIIcon.js +67 -1
- package/dist/cjs/components/ai-generator/icons/CloseIcon.js +19 -1
- package/dist/cjs/components/ai-generator/icons/DropdownIcon.js +37 -1
- package/dist/cjs/components/ai-generator/icons/SearchIcon.js +21 -1
- package/dist/cjs/components/ai-generator/icons/ShowMoreIcon.js +21 -1
- package/dist/cjs/components/ai-generator/icons/UpgradeIcon.js +27 -0
- package/dist/cjs/components/ai-generator/icons/WarningIcon.js +31 -0
- package/dist/cjs/components/constant.js +83 -1
- package/dist/cjs/components/resize/Resize.js +16 -1
- package/dist/cjs/components/resize/Spacing.js +260 -1
- package/dist/cjs/components/src/product/helpers/variant-presets.js +56 -1
- package/dist/cjs/components/theme-section/CreateThemeSection.js +123 -1
- package/dist/cjs/components/theme-section/ThemeSectionStatus.js +45 -1
- package/dist/cjs/components/theme-section/ThemeSectionTooltip.js +126 -1
- package/dist/cjs/components/toolbar/Tooltip.js +28 -1
- package/dist/cjs/contexts/AddonContext.js +36 -1
- package/dist/cjs/contexts/ArticleContext.js +39 -1
- package/dist/cjs/contexts/ArticleListContext.js +31 -1
- package/dist/cjs/contexts/BuilderComponent.js +34 -1
- package/dist/cjs/contexts/BuilderContext.js +39 -1
- package/dist/cjs/contexts/BuilderPreviewContext.js +486 -1
- package/dist/cjs/contexts/CartLineContext.js +29 -1
- package/dist/cjs/contexts/CollectionContext.js +38 -1
- package/dist/cjs/contexts/ModalContext.js +47 -1
- package/dist/cjs/contexts/PageContext.js +104 -1
- package/dist/cjs/contexts/ProductContext.js +177 -1
- package/dist/cjs/contexts/ProductListContext.js +32 -1
- package/dist/cjs/contexts/SectionContext.js +53 -1
- package/dist/cjs/contexts/ShopContext.js +107 -1
- package/dist/cjs/graphql/fragments/analytic.generated.js +6 -2
- package/dist/cjs/graphql/fragments/collection-detail.generated.js +6 -2
- package/dist/cjs/graphql/fragments/collection-product.generated.js +6 -2
- package/dist/cjs/graphql/fragments/collection.generated.js +6 -2
- package/dist/cjs/graphql/fragments/custom-code.generated.js +6 -2
- package/dist/cjs/graphql/fragments/custom-font.generated.js +6 -2
- package/dist/cjs/graphql/fragments/data-seo.generated.js +6 -2
- package/dist/cjs/graphql/fragments/media.generated.js +6 -2
- package/dist/cjs/graphql/fragments/preview-theme-page.generated.js +39 -0
- package/dist/cjs/graphql/fragments/product-little.generated.js +7 -2
- package/dist/cjs/graphql/fragments/product-option-value.generated.js +6 -2
- package/dist/cjs/graphql/fragments/product-option.generated.js +6 -2
- package/dist/cjs/graphql/fragments/product.generated.js +6 -2
- package/dist/cjs/graphql/fragments/published-custom-section.generated.js +6 -2
- package/dist/cjs/graphql/fragments/published-page-section.generated.js +6 -2
- package/dist/cjs/graphql/fragments/published-theme-page.generated.js +10 -28
- package/dist/cjs/graphql/fragments/published-theme-style.generated.js +6 -2
- package/dist/cjs/graphql/fragments/selected-option.generated.js +6 -2
- package/dist/cjs/graphql/fragments/variant.generated.js +6 -2
- package/dist/cjs/graphql/mutations/page-view-up.generated.js +8 -4
- package/dist/cjs/graphql/queries/articles.generated.js +61 -0
- package/dist/cjs/graphql/queries/blogs.generated.js +69 -0
- package/dist/cjs/graphql/queries/collection-detail-filter.generated.js +16 -2
- package/dist/cjs/graphql/queries/collection.generated.js +14 -2
- package/dist/cjs/graphql/queries/collections.generated.js +9 -2
- package/dist/cjs/graphql/queries/preview-page.generated.js +16 -8
- package/dist/cjs/graphql/queries/product-little-detail.generated.js +11 -2
- package/dist/cjs/graphql/queries/product-medias.generated.js +8 -2
- package/dist/cjs/graphql/queries/product-value-label.generated.js +6 -2
- package/dist/cjs/graphql/queries/product-variants.generated.js +10 -2
- package/dist/cjs/graphql/queries/products.generated.js +17 -3
- package/dist/cjs/graphql/queries/published-shop-metas.js +15 -0
- package/dist/cjs/graphql/queries/published-theme-pages.generated.js +15 -2
- package/dist/cjs/graphql/queries/store-property.generated.js +6 -2
- package/dist/cjs/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +6 -2
- package/dist/cjs/graphql-app-api/queries/LibraryTemplate.generated.js +6 -2
- package/dist/cjs/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +6 -2
- package/dist/cjs/graphql-app-api/queries/ShopLibraryPage.generated.js +17 -0
- package/dist/cjs/graphql-app-api/queries/ThemePage.generated.js +6 -2
- package/dist/cjs/helpers/GlobalEvent.js +19 -1
- package/dist/cjs/helpers/align.js +19 -0
- package/dist/cjs/helpers/animations.js +222 -1
- package/dist/cjs/helpers/background.js +235 -1
- package/dist/cjs/helpers/borders.js +198 -4
- package/dist/cjs/helpers/carousel.js +55 -1
- package/dist/cjs/helpers/clone-deep.js +5 -1
- package/dist/cjs/helpers/cls.js +16 -1
- package/dist/cjs/helpers/colors.js +184 -1
- package/dist/cjs/helpers/compose-advance-style.js +327 -1
- package/dist/cjs/helpers/constant.js +23 -1
- package/dist/cjs/helpers/convert.js +7 -1
- package/dist/cjs/helpers/covert-entities-html.js +19 -1
- package/dist/cjs/helpers/css-variable.js +7 -1
- package/dist/cjs/helpers/email.js +11 -1
- package/dist/cjs/helpers/filter-toolbar-preview.js +14 -1
- package/dist/cjs/helpers/flatten-connection.js +9 -1
- package/dist/cjs/helpers/get-resonsive-value.js +36 -1
- package/dist/cjs/helpers/get-shortname.js +92 -1
- package/dist/cjs/helpers/icon-list.js +61 -1
- package/dist/cjs/helpers/interaction/index.js +134 -0
- package/dist/cjs/helpers/is-browser.js +9 -1
- package/dist/cjs/helpers/is-defined.js +7 -1
- package/dist/cjs/helpers/is-empty-children.js +15 -1
- package/dist/cjs/helpers/is-safari.js +9 -1
- package/dist/cjs/helpers/layout.js +59 -1
- package/dist/cjs/helpers/load-script.js +31 -1
- package/dist/cjs/helpers/loop-component.js +16 -0
- package/dist/cjs/helpers/make-style.js +163 -1
- package/dist/cjs/helpers/normalize-builder-data.js +23 -1
- package/dist/cjs/helpers/pascal-to-kebab-case.js +7 -0
- package/dist/cjs/helpers/prefetch-queries.js +78 -1
- package/dist/cjs/helpers/product.js +48 -1
- package/dist/cjs/helpers/queries/get-collection.js +226 -1
- package/dist/cjs/helpers/queries/get-collections.js +21 -1
- package/dist/cjs/helpers/queries/get-product-by-slug.js +125 -1
- package/dist/cjs/helpers/queries/get-product.js +154 -1
- package/dist/cjs/helpers/queries/get-products.js +214 -1
- package/dist/cjs/helpers/query.js +29 -1
- package/dist/cjs/helpers/radius.js +140 -6
- package/dist/cjs/helpers/render.js +78 -1
- package/dist/cjs/helpers/shadow.js +69 -1
- package/dist/cjs/helpers/size.js +206 -4
- package/dist/cjs/helpers/spacing.js +43 -1
- package/dist/cjs/helpers/third-party/addAppBlockId.js +20 -0
- package/dist/cjs/helpers/third-party/appConfig.js +234 -0
- package/dist/cjs/helpers/third-party/appSetting.js +661 -0
- package/dist/cjs/helpers/third-party/composeAppBlockId.js +11 -0
- package/dist/cjs/helpers/third-party/constant.js +43 -0
- package/dist/cjs/helpers/third-party/generateAppBlockConfigs.js +34 -0
- package/dist/cjs/helpers/third-party/getAppBlockConfig.js +47 -0
- package/dist/cjs/helpers/third-party/getAppBlockType.js +12 -0
- package/dist/cjs/helpers/third-party/getAppBlocks.js +30 -0
- package/dist/cjs/helpers/third-party/mergeBlock.js +19 -0
- package/dist/cjs/helpers/third-party/mergeBlockOrder.js +47 -0
- package/dist/cjs/helpers/third-party/removeGPAppItems.js +18 -0
- package/dist/cjs/helpers/tracking/fpixel.js +28 -1
- package/dist/cjs/helpers/tracking/gtag.js +93 -1
- package/dist/cjs/helpers/tracking/tiktokpixel.js +17 -1
- package/dist/cjs/helpers/typography.js +160 -17
- package/dist/cjs/helpers/variant.js +11 -1
- package/dist/cjs/hooks/animation/useAnimationActions.js +39 -1
- package/dist/cjs/hooks/animation/useAnimationConfig.js +30 -1
- package/dist/cjs/hooks/animation/useAnimationPreview.js +31 -1
- package/dist/cjs/hooks/animation/useAnimationTarget.js +122 -1
- package/dist/cjs/hooks/animation/useApplyAnimation.js +89 -1
- package/dist/cjs/hooks/articles/useArticlesQuery.js +33 -1
- package/dist/cjs/hooks/cart/use-add-to-cart.js +20 -1
- package/dist/cjs/hooks/cart/use-cart-data.js +28 -1
- package/dist/cjs/hooks/cart/use-cart-discount-codes-update.js +20 -1
- package/dist/cjs/hooks/cart/use-cart-note-update.js +20 -1
- package/dist/cjs/hooks/cart/use-create-cart.js +22 -1
- package/dist/cjs/hooks/cart/use-remove-cart-item.js +20 -1
- package/dist/cjs/hooks/cart/use-update-cart-item.js +20 -1
- package/dist/cjs/hooks/shop/use-collection-query.js +22 -1
- package/dist/cjs/hooks/shop/use-collections-query.js +17 -1
- package/dist/cjs/hooks/shop/use-product-query.js +22 -1
- package/dist/cjs/hooks/shop/use-products-query.js +63 -1
- package/dist/cjs/hooks/shop.js +126 -1
- package/dist/cjs/hooks/use-current-device.js +30 -1
- package/dist/cjs/hooks/use-lazy-video.js +15 -1
- package/dist/cjs/hooks/useAnimations.js +29 -1
- package/dist/cjs/hooks/useCartId.js +44 -1
- package/dist/cjs/hooks/useCartLine.js +11 -1
- package/dist/cjs/hooks/useCartUI.js +48 -1
- package/dist/cjs/hooks/useCollection.js +9 -1
- package/dist/cjs/hooks/useFetchHandle.js +13 -1
- package/dist/cjs/hooks/useFormatMoney.js +75 -1
- package/dist/cjs/hooks/useInitialSwatchesOptions.js +128 -1
- package/dist/cjs/hooks/useInteraction.js +19 -0
- package/dist/cjs/hooks/useIsomorphicLayoutEffect.js +10 -1
- package/dist/cjs/hooks/useLoadScript.js +32 -1
- package/dist/cjs/hooks/useMoney.js +84 -1
- package/dist/cjs/hooks/usePrevious.js +19 -1
- package/dist/cjs/hooks/useProduct.js +245 -1
- package/dist/cjs/hooks/useProductList.js +21 -1
- package/dist/cjs/hooks/useSuspenseFetch.js +27 -1
- package/dist/cjs/hooks/useSwatchesOptions.js +41 -1
- package/dist/cjs/hooks/useToolbarPostPurchase.js +89 -1
- package/dist/cjs/index.js +416 -1
- package/dist/cjs/types/animations.js +49 -1
- package/dist/cjs/types/appAPI.js +2 -1
- package/dist/cjs/types/custom.js +52 -0
- package/dist/cjs/types/global-style.js +15 -1
- package/dist/cjs/types/shop.js +2 -1
- package/dist/cjs/web-components/src/helpers/styles/constant.js +9 -1
- package/dist/esm/components/AddOn.js +14 -1
- package/dist/esm/components/ComponentAnimation.js +13 -0
- package/dist/esm/components/ComponentToolbarPreview.js +748 -1
- package/dist/esm/components/ComponentWrapper.js +57 -1
- package/dist/esm/components/ComponentWrapperPreview.js +209 -1
- package/dist/esm/components/Empty.js +3 -1
- package/dist/esm/components/InteractionSuffix.js +40 -0
- package/dist/esm/components/Render.js +71 -1
- package/dist/esm/components/Render.liquid.js +307 -17
- package/dist/esm/components/RenderBlock.js +50 -1
- package/dist/esm/components/RenderCustomCode.js +55 -3
- package/dist/esm/components/RenderPreview.js +63 -1
- package/dist/esm/components/RenderSection.js +19 -1
- package/dist/esm/components/ai-generator/AIContentGenerator.js +250 -1
- package/dist/esm/components/ai-generator/AIGenContentLoading.js +83 -1
- package/dist/esm/components/ai-generator/components/PickProduct.js +218 -1
- package/dist/esm/components/ai-generator/components/ToneAndVoice.js +75 -1
- package/dist/esm/components/ai-generator/hooks/useCheckingProductInside.js +45 -0
- package/dist/esm/components/ai-generator/hooks/useFlipPopup.js +108 -0
- package/dist/esm/components/ai-generator/hooks/useGettingGenerateRequest.js +35 -1
- package/dist/esm/components/ai-generator/hooks/useListenEventGenerate.js +68 -1
- package/dist/esm/components/ai-generator/icons/AIIcon.js +65 -1
- package/dist/esm/components/ai-generator/icons/CloseIcon.js +17 -1
- package/dist/esm/components/ai-generator/icons/DropdownIcon.js +34 -1
- package/dist/esm/components/ai-generator/icons/SearchIcon.js +19 -1
- package/dist/esm/components/ai-generator/icons/ShowMoreIcon.js +19 -1
- package/dist/esm/components/ai-generator/icons/UpgradeIcon.js +25 -0
- package/dist/esm/components/ai-generator/icons/WarningIcon.js +29 -0
- package/dist/esm/components/constant.js +76 -1
- package/dist/esm/components/resize/Resize.js +12 -1
- package/dist/esm/components/resize/Spacing.js +256 -1
- package/dist/esm/components/src/product/helpers/variant-presets.js +54 -1
- package/dist/esm/components/theme-section/CreateThemeSection.js +121 -1
- package/dist/esm/components/theme-section/ThemeSectionStatus.js +43 -1
- package/dist/esm/components/theme-section/ThemeSectionTooltip.js +124 -1
- package/dist/esm/components/toolbar/Tooltip.js +24 -1
- package/dist/esm/contexts/AddonContext.js +32 -1
- package/dist/esm/contexts/ArticleContext.js +36 -1
- package/dist/esm/contexts/ArticleListContext.js +27 -1
- package/dist/esm/contexts/BuilderComponent.js +31 -1
- package/dist/esm/contexts/BuilderContext.js +36 -1
- package/dist/esm/contexts/BuilderPreviewContext.js +483 -1
- package/dist/esm/contexts/CartLineContext.js +26 -1
- package/dist/esm/contexts/CollectionContext.js +35 -1
- package/dist/esm/contexts/ModalContext.js +44 -1
- package/dist/esm/contexts/PageContext.js +101 -1
- package/dist/esm/contexts/ProductContext.js +174 -1
- package/dist/esm/contexts/ProductListContext.js +28 -1
- package/dist/esm/contexts/SectionContext.js +49 -1
- package/dist/esm/contexts/ShopContext.js +104 -1
- package/dist/esm/graphql/fragments/analytic.generated.js +4 -2
- package/dist/esm/graphql/fragments/collection-detail.generated.js +4 -2
- package/dist/esm/graphql/fragments/collection-product.generated.js +4 -2
- package/dist/esm/graphql/fragments/collection.generated.js +4 -2
- package/dist/esm/graphql/fragments/custom-code.generated.js +4 -2
- package/dist/esm/graphql/fragments/custom-font.generated.js +4 -2
- package/dist/esm/graphql/fragments/data-seo.generated.js +4 -2
- package/dist/esm/graphql/fragments/media.generated.js +4 -2
- package/dist/esm/graphql/fragments/preview-theme-page.generated.js +37 -0
- package/dist/esm/graphql/fragments/product-little.generated.js +5 -2
- package/dist/esm/graphql/fragments/product-option-value.generated.js +4 -2
- package/dist/esm/graphql/fragments/product-option.generated.js +4 -2
- package/dist/esm/graphql/fragments/product.generated.js +4 -2
- package/dist/esm/graphql/fragments/published-custom-section.generated.js +4 -2
- package/dist/esm/graphql/fragments/published-page-section.generated.js +4 -2
- package/dist/esm/graphql/fragments/published-theme-page.generated.js +8 -28
- package/dist/esm/graphql/fragments/published-theme-style.generated.js +4 -2
- package/dist/esm/graphql/fragments/selected-option.generated.js +4 -2
- package/dist/esm/graphql/fragments/variant.generated.js +4 -2
- package/dist/esm/graphql/mutations/page-view-up.generated.js +6 -4
- package/dist/esm/graphql/queries/articles.generated.js +59 -0
- package/dist/esm/graphql/queries/blogs.generated.js +67 -0
- package/dist/esm/graphql/queries/collection-detail-filter.generated.js +22 -10
- package/dist/esm/graphql/queries/collection.generated.js +18 -8
- package/dist/esm/graphql/queries/collections.generated.js +8 -3
- package/dist/esm/graphql/queries/preview-page.generated.js +16 -10
- package/dist/esm/graphql/queries/product-little-detail.generated.js +12 -5
- package/dist/esm/graphql/queries/product-medias.generated.js +6 -2
- package/dist/esm/graphql/queries/product-value-label.generated.js +4 -2
- package/dist/esm/graphql/queries/product-variants.generated.js +10 -4
- package/dist/esm/graphql/queries/products.generated.js +20 -9
- package/dist/esm/graphql/queries/published-shop-metas.js +13 -0
- package/dist/esm/graphql/queries/published-theme-pages.generated.js +20 -9
- package/dist/esm/graphql/queries/store-property.generated.js +4 -2
- package/dist/esm/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +4 -2
- package/dist/esm/graphql-app-api/queries/LibraryTemplate.generated.js +4 -2
- package/dist/esm/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +4 -2
- package/dist/esm/graphql-app-api/queries/ShopLibraryPage.generated.js +15 -0
- package/dist/esm/graphql-app-api/queries/ThemePage.generated.js +4 -2
- package/dist/esm/helpers/GlobalEvent.js +15 -1
- package/dist/esm/helpers/align.js +17 -0
- package/dist/esm/helpers/animations.js +220 -1
- package/dist/esm/helpers/background.js +226 -1
- package/dist/esm/helpers/borders.js +189 -4
- package/dist/esm/helpers/carousel.js +51 -1
- package/dist/esm/helpers/clone-deep.js +3 -1
- package/dist/esm/helpers/cls.js +14 -1
- package/dist/esm/helpers/colors.js +169 -1
- package/dist/esm/helpers/compose-advance-style.js +319 -1
- package/dist/esm/helpers/constant.js +19 -1
- package/dist/esm/helpers/convert.js +4 -1
- package/dist/esm/helpers/covert-entities-html.js +17 -1
- package/dist/esm/helpers/css-variable.js +5 -1
- package/dist/esm/helpers/email.js +6 -1
- package/dist/esm/helpers/filter-toolbar-preview.js +9 -1
- package/dist/esm/helpers/flatten-connection.js +7 -1
- package/dist/esm/helpers/get-resonsive-value.js +31 -1
- package/dist/esm/helpers/get-shortname.js +90 -1
- package/dist/esm/helpers/icon-list.js +58 -1
- package/dist/esm/helpers/interaction/index.js +132 -0
- package/dist/esm/helpers/is-browser.js +5 -1
- package/dist/esm/helpers/is-defined.js +5 -1
- package/dist/esm/helpers/is-empty-children.js +10 -1
- package/dist/esm/helpers/is-safari.js +5 -1
- package/dist/esm/helpers/layout.js +54 -1
- package/dist/esm/helpers/load-script.js +29 -1
- package/dist/esm/helpers/loop-component.js +14 -0
- package/dist/esm/helpers/make-style.js +149 -1
- package/dist/esm/helpers/normalize-builder-data.js +21 -1
- package/dist/esm/helpers/pascal-to-kebab-case.js +5 -0
- package/dist/esm/helpers/prefetch-queries.js +76 -1
- package/dist/esm/helpers/product.js +44 -1
- package/dist/esm/helpers/queries/get-collection.js +223 -1
- package/dist/esm/helpers/queries/get-collections.js +19 -1
- package/dist/esm/helpers/queries/get-product-by-slug.js +123 -1
- package/dist/esm/helpers/queries/get-product.js +150 -1
- package/dist/esm/helpers/queries/get-products.js +210 -1
- package/dist/esm/helpers/query.js +25 -1
- package/dist/esm/helpers/radius.js +132 -6
- package/dist/esm/helpers/render.js +70 -1
- package/dist/esm/helpers/shadow.js +63 -1
- package/dist/esm/helpers/size.js +192 -4
- package/dist/esm/helpers/spacing.js +40 -1
- package/dist/esm/helpers/third-party/addAppBlockId.js +18 -0
- package/dist/esm/helpers/third-party/appConfig.js +200 -0
- package/dist/esm/helpers/third-party/appSetting.js +658 -0
- package/dist/esm/helpers/third-party/composeAppBlockId.js +9 -0
- package/dist/esm/helpers/third-party/constant.js +40 -0
- package/dist/esm/helpers/third-party/generateAppBlockConfigs.js +32 -0
- package/dist/esm/helpers/third-party/getAppBlockConfig.js +45 -0
- package/dist/esm/helpers/third-party/getAppBlockType.js +10 -0
- package/dist/esm/helpers/third-party/getAppBlocks.js +28 -0
- package/dist/esm/helpers/third-party/mergeBlock.js +17 -0
- package/dist/esm/helpers/third-party/mergeBlockOrder.js +45 -0
- package/dist/esm/helpers/third-party/removeGPAppItems.js +15 -0
- package/dist/esm/helpers/tracking/fpixel.js +24 -1
- package/dist/esm/helpers/tracking/gtag.js +87 -1
- package/dist/esm/helpers/tracking/tiktokpixel.js +15 -1
- package/dist/esm/helpers/typography.js +149 -17
- package/dist/esm/helpers/variant.js +9 -1
- package/dist/esm/hooks/animation/useAnimationActions.js +37 -1
- package/dist/esm/hooks/animation/useAnimationConfig.js +28 -1
- package/dist/esm/hooks/animation/useAnimationPreview.js +29 -1
- package/dist/esm/hooks/animation/useAnimationTarget.js +120 -1
- package/dist/esm/hooks/animation/useApplyAnimation.js +85 -1
- package/dist/esm/hooks/articles/useArticlesQuery.js +30 -1
- package/dist/esm/hooks/cart/use-add-to-cart.js +18 -1
- package/dist/esm/hooks/cart/use-cart-data.js +26 -1
- package/dist/esm/hooks/cart/use-cart-discount-codes-update.js +18 -1
- package/dist/esm/hooks/cart/use-cart-note-update.js +18 -1
- package/dist/esm/hooks/cart/use-create-cart.js +20 -1
- package/dist/esm/hooks/cart/use-remove-cart-item.js +18 -1
- package/dist/esm/hooks/cart/use-update-cart-item.js +18 -1
- package/dist/esm/hooks/shop/use-collection-query.js +20 -1
- package/dist/esm/hooks/shop/use-collections-query.js +15 -1
- package/dist/esm/hooks/shop/use-product-query.js +20 -1
- package/dist/esm/hooks/shop/use-products-query.js +59 -1
- package/dist/esm/hooks/shop.js +111 -1
- package/dist/esm/hooks/use-current-device.js +28 -1
- package/dist/esm/hooks/use-lazy-video.js +13 -1
- package/dist/esm/hooks/useAnimations.js +27 -1
- package/dist/esm/hooks/useCartId.js +40 -1
- package/dist/esm/hooks/useCartLine.js +7 -1
- package/dist/esm/hooks/useCartUI.js +44 -1
- package/dist/esm/hooks/useCollection.js +7 -1
- package/dist/esm/hooks/useFetchHandle.js +11 -1
- package/dist/esm/hooks/useFormatMoney.js +71 -1
- package/dist/esm/hooks/useInitialSwatchesOptions.js +124 -1
- package/dist/esm/hooks/useInteraction.js +17 -0
- package/dist/esm/hooks/useIsomorphicLayoutEffect.js +6 -1
- package/dist/esm/hooks/useLoadScript.js +28 -1
- package/dist/esm/hooks/useMoney.js +80 -1
- package/dist/esm/hooks/usePrevious.js +17 -1
- package/dist/esm/hooks/useProduct.js +228 -1
- package/dist/esm/hooks/useProductList.js +16 -1
- package/dist/esm/hooks/useSuspenseFetch.js +23 -1
- package/dist/esm/hooks/useSwatchesOptions.js +37 -1
- package/dist/esm/hooks/useToolbarPostPurchase.js +87 -1
- package/dist/esm/index.js +117 -1
- package/dist/esm/types/animations.js +49 -1
- package/dist/esm/types/custom.js +52 -0
- package/dist/esm/types/global-style.js +12 -1
- package/dist/esm/web-components/src/helpers/styles/constant.js +7 -1
- package/dist/types/index.d.ts +23183 -17335
- package/package.json +5 -3
- package/dist/cjs/components/animation/AnimationWrapper.js +0 -1
- package/dist/cjs/hooks/animation/animations.js +0 -1
- package/dist/cjs/hooks/animation/useLivePageAnimation.js +0 -1
- package/dist/esm/components/animation/AnimationWrapper.js +0 -1
- package/dist/esm/hooks/animation/animations.js +0 -1
- package/dist/esm/hooks/animation/useLivePageAnimation.js +0 -1
|
@@ -1 +1,32 @@
|
|
|
1
|
-
import{jsx
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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 };
|