@gem-sdk/core 3.0.0-pre-production.15 → 3.0.6
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/README.md +1 -1
- package/dist/cjs/components/AddOn.js +2 -18
- package/dist/cjs/components/ComponentAnimation.js +2 -17
- package/dist/cjs/components/ComponentToolbarPreview.js +2 -752
- package/dist/cjs/components/ComponentWrapper.js +2 -61
- package/dist/cjs/components/ComponentWrapperPreview.js +2 -213
- package/dist/cjs/components/Empty.js +2 -7
- package/dist/cjs/components/InteractionSuffix.js +2 -42
- package/dist/cjs/components/Render.js +2 -75
- package/dist/cjs/components/Render.liquid.js +16 -307
- package/dist/cjs/components/RenderBlock.js +2 -54
- package/dist/cjs/components/RenderCustomCode.js +4 -59
- package/dist/cjs/components/RenderPreview.js +2 -67
- package/dist/cjs/components/RenderSection.js +2 -23
- package/dist/cjs/components/ai-generator/AIContentGenerator.js +2 -252
- package/dist/cjs/components/ai-generator/AIGenContentLoading.js +2 -85
- package/dist/cjs/components/ai-generator/components/PickProduct.js +2 -220
- package/dist/cjs/components/ai-generator/components/ToneAndVoice.js +2 -77
- package/dist/cjs/components/ai-generator/hooks/useCheckingProductInside.js +1 -47
- package/dist/cjs/components/ai-generator/hooks/useFlipPopup.js +1 -110
- package/dist/cjs/components/ai-generator/hooks/useGettingGenerateRequest.js +1 -37
- package/dist/cjs/components/ai-generator/hooks/useListenEventGenerate.js +1 -70
- package/dist/cjs/components/ai-generator/icons/AIIcon.js +2 -67
- package/dist/cjs/components/ai-generator/icons/CloseIcon.js +2 -19
- package/dist/cjs/components/ai-generator/icons/DropdownIcon.js +2 -37
- package/dist/cjs/components/ai-generator/icons/SearchIcon.js +2 -21
- package/dist/cjs/components/ai-generator/icons/ShowMoreIcon.js +2 -21
- package/dist/cjs/components/ai-generator/icons/UpgradeIcon.js +2 -27
- package/dist/cjs/components/ai-generator/icons/WarningIcon.js +2 -31
- package/dist/cjs/components/constant.js +1 -82
- package/dist/cjs/components/resize/Resize.js +2 -16
- package/dist/cjs/components/resize/Spacing.js +2 -260
- package/dist/cjs/components/src/product/helpers/variant-presets.js +1 -56
- package/dist/cjs/components/theme-section/CreateThemeSection.js +2 -123
- package/dist/cjs/components/theme-section/ThemeSectionStatus.js +2 -45
- package/dist/cjs/components/theme-section/ThemeSectionTooltip.js +2 -126
- package/dist/cjs/components/toolbar/Tooltip.js +2 -28
- package/dist/cjs/constants/device.js +1 -0
- package/dist/cjs/contexts/AddonContext.js +2 -36
- package/dist/cjs/contexts/ArticleContext.js +2 -39
- package/dist/cjs/contexts/ArticleListContext.js +2 -31
- package/dist/cjs/contexts/BuilderComponent.js +2 -34
- package/dist/cjs/contexts/BuilderContext.js +2 -39
- package/dist/cjs/contexts/BuilderPreviewContext.js +2 -482
- package/dist/cjs/contexts/CartLineContext.js +2 -29
- package/dist/cjs/contexts/CollectionContext.js +2 -38
- package/dist/cjs/contexts/I18nContext.js +2 -0
- package/dist/cjs/contexts/ModalContext.js +2 -47
- package/dist/cjs/contexts/PageContext.js +2 -111
- package/dist/cjs/contexts/ProductContext.js +2 -182
- package/dist/cjs/contexts/ProductListContext.js +2 -32
- package/dist/cjs/contexts/SectionContext.js +2 -53
- package/dist/cjs/contexts/ShopContext.js +2 -107
- package/dist/cjs/graphql/fragments/analytic.generated.js +2 -6
- package/dist/cjs/graphql/fragments/collection-detail.generated.js +2 -6
- package/dist/cjs/graphql/fragments/collection-product.generated.js +2 -6
- package/dist/cjs/graphql/fragments/collection.generated.js +2 -6
- package/dist/cjs/graphql/fragments/custom-code.generated.js +2 -6
- package/dist/cjs/graphql/fragments/custom-font.generated.js +7 -7
- package/dist/cjs/graphql/fragments/data-seo.generated.js +2 -6
- package/dist/cjs/graphql/fragments/media.generated.js +2 -6
- package/dist/cjs/graphql/fragments/preview-theme-page.generated.js +6 -6
- package/dist/cjs/graphql/fragments/product-little.generated.js +2 -6
- package/dist/cjs/graphql/fragments/product-option-value.generated.js +2 -6
- package/dist/cjs/graphql/fragments/product-option.generated.js +2 -6
- package/dist/cjs/graphql/fragments/product.generated.js +2 -6
- package/dist/cjs/graphql/fragments/published-custom-section.generated.js +2 -6
- package/dist/cjs/graphql/fragments/published-page-section.generated.js +2 -6
- package/dist/cjs/graphql/fragments/published-theme-page.generated.js +4 -18
- package/dist/cjs/graphql/fragments/published-theme-style.generated.js +2 -6
- package/dist/cjs/graphql/fragments/selected-option.generated.js +2 -6
- package/dist/cjs/graphql/fragments/variant.generated.js +2 -6
- package/dist/cjs/graphql/mutations/page-view-up.generated.js +2 -6
- package/dist/cjs/graphql/queries/articles.generated.js +2 -6
- package/dist/cjs/graphql/queries/blogs.generated.js +2 -6
- package/dist/cjs/graphql/queries/collection-detail-filter.generated.js +2 -16
- package/dist/cjs/graphql/queries/collection.generated.js +2 -14
- package/dist/cjs/graphql/queries/collections.generated.js +2 -9
- package/dist/cjs/graphql/queries/preview-page.generated.js +2 -12
- package/dist/cjs/graphql/queries/product-little-detail.generated.js +2 -11
- package/dist/cjs/graphql/queries/product-medias.generated.js +2 -8
- package/dist/cjs/graphql/queries/product-value-label.generated.js +2 -6
- package/dist/cjs/graphql/queries/product-variants.generated.js +3 -11
- package/dist/cjs/graphql/queries/products.generated.js +3 -17
- package/dist/cjs/graphql/queries/{published-shop-metas.js → published-shop-metas.generated.js} +2 -6
- package/dist/cjs/graphql/queries/published-theme-pages.generated.js +3 -19
- package/dist/cjs/graphql/queries/shop-shopify.generated.js +2 -6
- package/dist/cjs/graphql/queries/store-property.generated.js +2 -6
- package/dist/cjs/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +2 -6
- package/dist/cjs/graphql-app-api/queries/LibraryTemplate.generated.js +2 -6
- package/dist/cjs/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +2 -6
- package/dist/cjs/graphql-app-api/queries/SaleFunnelOffer.generated.js +2 -6
- package/dist/cjs/graphql-app-api/queries/ShopLibraryPage.generated.js +2 -6
- package/dist/cjs/graphql-app-api/queries/ThemePage.generated.js +2 -6
- package/dist/cjs/helpers/GlobalEvent.js +1 -19
- package/dist/cjs/helpers/align.js +1 -37
- package/dist/cjs/helpers/animations.js +1 -222
- package/dist/cjs/helpers/background.js +1 -236
- package/dist/cjs/helpers/backgroundImage.js +1 -0
- package/dist/cjs/helpers/borders.js +4 -198
- package/dist/cjs/helpers/carousel.js +1 -55
- package/dist/cjs/helpers/clone-deep.js +1 -5
- package/dist/cjs/helpers/cls.js +1 -16
- package/dist/cjs/helpers/colors.js +1 -184
- package/dist/cjs/helpers/compose-advance-style.js +1 -323
- package/dist/cjs/helpers/composeClasses.js +1 -0
- package/dist/cjs/helpers/const.js +1 -0
- package/dist/cjs/helpers/constant.js +1 -23
- package/dist/cjs/helpers/convert.js +1 -7
- package/dist/cjs/helpers/covert-entities-html.js +1 -19
- package/dist/cjs/helpers/css-variable.js +1 -7
- package/dist/cjs/helpers/email.js +1 -11
- package/dist/cjs/helpers/filter-styles.js +1 -0
- package/dist/cjs/helpers/filter-toolbar-preview.js +2 -14
- package/dist/cjs/helpers/flatten-connection.js +1 -9
- package/dist/cjs/helpers/get-resonsive-value.js +1 -36
- package/dist/cjs/helpers/get-shortname.js +1 -92
- package/dist/cjs/helpers/icon-list.js +1 -61
- package/dist/cjs/helpers/interaction/index.js +2 -134
- package/dist/cjs/helpers/is-browser.js +1 -9
- package/dist/cjs/helpers/is-defined.js +1 -7
- package/dist/cjs/helpers/is-empty-children.js +2 -15
- package/dist/cjs/helpers/is-safari.js +1 -9
- package/dist/cjs/helpers/layout.js +1 -76
- package/dist/cjs/helpers/load-script.js +1 -31
- package/dist/cjs/helpers/loop-component.js +1 -16
- package/dist/cjs/helpers/make-style.js +1 -163
- package/dist/cjs/helpers/normalize-builder-data.js +1 -23
- package/dist/cjs/helpers/pascal-to-kebab-case.js +1 -7
- package/dist/cjs/helpers/prefetch-queries.js +1 -78
- package/dist/cjs/helpers/product.js +1 -48
- package/dist/cjs/helpers/queries/get-collection.js +1 -226
- package/dist/cjs/helpers/queries/get-collections.js +1 -21
- package/dist/cjs/helpers/queries/get-product-by-slug.js +1 -125
- package/dist/cjs/helpers/queries/get-product.js +1 -154
- package/dist/cjs/helpers/queries/get-products.js +1 -214
- package/dist/cjs/helpers/query.js +1 -29
- package/dist/cjs/helpers/radius.js +6 -140
- package/dist/cjs/helpers/render.js +1 -91
- package/dist/cjs/helpers/shadow.js +1 -69
- package/dist/cjs/helpers/size.js +4 -228
- package/dist/cjs/helpers/spacing.js +1 -43
- package/dist/cjs/helpers/third-party/addAppBlockId.js +1 -20
- package/dist/cjs/helpers/third-party/appConfig.js +1 -416
- package/dist/cjs/helpers/third-party/appSetting.js +1 -1324
- package/dist/cjs/helpers/third-party/composeAppBlockId.js +1 -11
- package/dist/cjs/helpers/third-party/constant.js +1 -69
- package/dist/cjs/helpers/third-party/generateAppBlockConfigs.js +1 -34
- package/dist/cjs/helpers/third-party/getAppBlockConfig.js +1 -55
- package/dist/cjs/helpers/third-party/getAppBlockType.js +1 -12
- package/dist/cjs/helpers/third-party/getAppBlocks.js +1 -30
- package/dist/cjs/helpers/third-party/mergeBlock.js +1 -19
- package/dist/cjs/helpers/third-party/mergeBlockOrder.js +1 -47
- package/dist/cjs/helpers/third-party/removeGPAppItems.js +1 -18
- package/dist/cjs/helpers/tracking/fpixel.js +1 -28
- package/dist/cjs/helpers/tracking/gtag.js +1 -93
- package/dist/cjs/helpers/tracking/tiktokpixel.js +1 -17
- package/dist/cjs/helpers/typography.js +19 -160
- package/dist/cjs/helpers/variant.js +1 -11
- package/dist/cjs/hooks/animation/useAnimationActions.js +2 -39
- package/dist/cjs/hooks/animation/useAnimationConfig.js +2 -30
- package/dist/cjs/hooks/animation/useAnimationPreview.js +2 -31
- package/dist/cjs/hooks/animation/useAnimationTarget.js +2 -122
- package/dist/cjs/hooks/animation/useApplyAnimation.js +2 -89
- package/dist/cjs/hooks/articles/useArticlesQuery.js +2 -33
- package/dist/cjs/hooks/cart/use-add-to-cart.js +2 -20
- package/dist/cjs/hooks/cart/use-cart-data.js +2 -28
- package/dist/cjs/hooks/cart/use-cart-discount-codes-update.js +2 -20
- package/dist/cjs/hooks/cart/use-cart-note-update.js +2 -20
- package/dist/cjs/hooks/cart/use-create-cart.js +2 -22
- package/dist/cjs/hooks/cart/use-remove-cart-item.js +2 -20
- package/dist/cjs/hooks/cart/use-update-cart-item.js +2 -20
- package/dist/cjs/hooks/shop/use-collection-query.js +2 -22
- package/dist/cjs/hooks/shop/use-collections-query.js +2 -17
- package/dist/cjs/hooks/shop/use-product-query.js +2 -22
- package/dist/cjs/hooks/shop/use-products-query.js +2 -63
- package/dist/cjs/hooks/shop/useShopifyLink.js +2 -0
- package/dist/cjs/hooks/shop.js +2 -135
- package/dist/cjs/hooks/use-current-device.js +2 -30
- package/dist/cjs/hooks/use-lazy-video.js +2 -15
- package/dist/cjs/hooks/useAnimations.js +2 -29
- package/dist/cjs/hooks/useCartId.js +2 -44
- package/dist/cjs/hooks/useCartLine.js +2 -11
- package/dist/cjs/hooks/useCartUI.js +2 -48
- package/dist/cjs/hooks/useCollection.js +2 -9
- package/dist/cjs/hooks/useFetchHandle.js +2 -13
- package/dist/cjs/hooks/useFormatMoney.js +2 -75
- package/dist/cjs/hooks/useI18n.js +2 -0
- package/dist/cjs/hooks/useInitialSwatchesOptions.js +2 -127
- package/dist/cjs/hooks/useInteraction.js +2 -19
- package/dist/cjs/hooks/useIsomorphicLayoutEffect.js +2 -10
- package/dist/cjs/hooks/useLoadScript.js +2 -32
- package/dist/cjs/hooks/useMoney.js +2 -84
- package/dist/cjs/hooks/usePrevious.js +2 -19
- package/dist/cjs/hooks/useProduct.js +2 -250
- package/dist/cjs/hooks/useProductList.js +2 -21
- package/dist/cjs/hooks/useStickyStore.js +1 -0
- package/dist/cjs/hooks/useSuspenseFetch.js +2 -27
- package/dist/cjs/hooks/useSwatchesOptions.js +2 -41
- package/dist/cjs/hooks/useToolbarPostPurchase.js +2 -89
- package/dist/cjs/index.js +1 -425
- package/dist/cjs/types/animations.js +1 -49
- package/dist/cjs/types/appAPI.js +1 -2
- package/dist/cjs/types/custom.js +1 -52
- package/dist/cjs/types/global-style.js +1 -15
- package/dist/cjs/types/shop.js +1 -2
- package/dist/esm/components/AddOn.js +2 -14
- package/dist/esm/components/ComponentAnimation.js +2 -13
- package/dist/esm/components/ComponentToolbarPreview.js +2 -748
- package/dist/esm/components/ComponentWrapper.js +2 -57
- package/dist/esm/components/ComponentWrapperPreview.js +2 -209
- package/dist/esm/components/Empty.js +2 -3
- package/dist/esm/components/InteractionSuffix.js +2 -40
- package/dist/esm/components/Render.js +2 -71
- package/dist/esm/components/Render.liquid.js +16 -301
- package/dist/esm/components/RenderBlock.js +2 -50
- package/dist/esm/components/RenderCustomCode.js +4 -55
- package/dist/esm/components/RenderPreview.js +2 -63
- package/dist/esm/components/RenderSection.js +2 -19
- package/dist/esm/components/ai-generator/AIContentGenerator.js +2 -250
- package/dist/esm/components/ai-generator/AIGenContentLoading.js +2 -83
- package/dist/esm/components/ai-generator/components/PickProduct.js +2 -218
- package/dist/esm/components/ai-generator/components/ToneAndVoice.js +2 -75
- package/dist/esm/components/ai-generator/hooks/useCheckingProductInside.js +1 -45
- package/dist/esm/components/ai-generator/hooks/useFlipPopup.js +1 -108
- package/dist/esm/components/ai-generator/hooks/useGettingGenerateRequest.js +1 -35
- package/dist/esm/components/ai-generator/hooks/useListenEventGenerate.js +1 -68
- package/dist/esm/components/ai-generator/icons/AIIcon.js +2 -65
- package/dist/esm/components/ai-generator/icons/CloseIcon.js +2 -17
- package/dist/esm/components/ai-generator/icons/DropdownIcon.js +2 -34
- package/dist/esm/components/ai-generator/icons/SearchIcon.js +2 -19
- package/dist/esm/components/ai-generator/icons/ShowMoreIcon.js +2 -19
- package/dist/esm/components/ai-generator/icons/UpgradeIcon.js +2 -25
- package/dist/esm/components/ai-generator/icons/WarningIcon.js +2 -29
- package/dist/esm/components/constant.js +1 -75
- package/dist/esm/components/resize/Resize.js +2 -12
- package/dist/esm/components/resize/Spacing.js +2 -256
- package/dist/esm/components/src/product/helpers/variant-presets.js +1 -54
- package/dist/esm/components/theme-section/CreateThemeSection.js +2 -121
- package/dist/esm/components/theme-section/ThemeSectionStatus.js +2 -43
- package/dist/esm/components/theme-section/ThemeSectionTooltip.js +2 -124
- package/dist/esm/components/toolbar/Tooltip.js +2 -24
- package/dist/esm/constants/device.js +1 -0
- package/dist/esm/contexts/AddonContext.js +2 -32
- package/dist/esm/contexts/ArticleContext.js +2 -36
- package/dist/esm/contexts/ArticleListContext.js +2 -27
- package/dist/esm/contexts/BuilderComponent.js +2 -31
- package/dist/esm/contexts/BuilderContext.js +2 -36
- package/dist/esm/contexts/BuilderPreviewContext.js +2 -479
- package/dist/esm/contexts/CartLineContext.js +2 -26
- package/dist/esm/contexts/CollectionContext.js +2 -35
- package/dist/esm/contexts/I18nContext.js +2 -0
- package/dist/esm/contexts/ModalContext.js +2 -44
- package/dist/esm/contexts/PageContext.js +2 -108
- package/dist/esm/contexts/ProductContext.js +2 -179
- package/dist/esm/contexts/ProductListContext.js +2 -28
- package/dist/esm/contexts/SectionContext.js +2 -49
- package/dist/esm/contexts/ShopContext.js +2 -104
- package/dist/esm/graphql/fragments/analytic.generated.js +2 -4
- package/dist/esm/graphql/fragments/collection-detail.generated.js +2 -4
- package/dist/esm/graphql/fragments/collection-product.generated.js +2 -4
- package/dist/esm/graphql/fragments/collection.generated.js +2 -4
- package/dist/esm/graphql/fragments/custom-code.generated.js +2 -4
- package/dist/esm/graphql/fragments/custom-font.generated.js +7 -5
- package/dist/esm/graphql/fragments/data-seo.generated.js +2 -4
- package/dist/esm/graphql/fragments/media.generated.js +2 -4
- package/dist/esm/graphql/fragments/preview-theme-page.generated.js +6 -4
- package/dist/esm/graphql/fragments/product-little.generated.js +2 -4
- package/dist/esm/graphql/fragments/product-option-value.generated.js +2 -4
- package/dist/esm/graphql/fragments/product-option.generated.js +2 -4
- package/dist/esm/graphql/fragments/product.generated.js +2 -4
- package/dist/esm/graphql/fragments/published-custom-section.generated.js +2 -4
- package/dist/esm/graphql/fragments/published-page-section.generated.js +2 -4
- package/dist/esm/graphql/fragments/published-theme-page.generated.js +4 -16
- package/dist/esm/graphql/fragments/published-theme-style.generated.js +2 -4
- package/dist/esm/graphql/fragments/selected-option.generated.js +2 -4
- package/dist/esm/graphql/fragments/variant.generated.js +2 -4
- package/dist/esm/graphql/mutations/page-view-up.generated.js +2 -4
- package/dist/esm/graphql/queries/articles.generated.js +2 -4
- package/dist/esm/graphql/queries/blogs.generated.js +2 -4
- package/dist/esm/graphql/queries/collection-detail-filter.generated.js +10 -22
- package/dist/esm/graphql/queries/collection.generated.js +8 -18
- package/dist/esm/graphql/queries/collections.generated.js +3 -8
- package/dist/esm/graphql/queries/preview-page.generated.js +6 -14
- package/dist/esm/graphql/queries/product-little-detail.generated.js +5 -12
- package/dist/esm/graphql/queries/product-medias.generated.js +2 -6
- package/dist/esm/graphql/queries/product-value-label.generated.js +2 -4
- package/dist/esm/graphql/queries/product-variants.generated.js +5 -11
- package/dist/esm/graphql/queries/products.generated.js +9 -20
- package/dist/esm/graphql/queries/{published-shop-metas.js → published-shop-metas.generated.js} +2 -4
- package/dist/esm/graphql/queries/published-theme-pages.generated.js +6 -20
- package/dist/esm/graphql/queries/shop-shopify.generated.js +2 -4
- package/dist/esm/graphql/queries/store-property.generated.js +2 -4
- package/dist/esm/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +2 -4
- package/dist/esm/graphql-app-api/queries/LibraryTemplate.generated.js +2 -4
- package/dist/esm/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +2 -4
- package/dist/esm/graphql-app-api/queries/SaleFunnelOffer.generated.js +2 -4
- package/dist/esm/graphql-app-api/queries/ShopLibraryPage.generated.js +2 -4
- package/dist/esm/graphql-app-api/queries/ThemePage.generated.js +2 -4
- package/dist/esm/helpers/GlobalEvent.js +1 -15
- package/dist/esm/helpers/align.js +1 -34
- package/dist/esm/helpers/animations.js +1 -220
- package/dist/esm/helpers/background.js +1 -227
- package/dist/esm/helpers/backgroundImage.js +1 -0
- package/dist/esm/helpers/borders.js +4 -189
- package/dist/esm/helpers/carousel.js +1 -51
- package/dist/esm/helpers/clone-deep.js +1 -3
- package/dist/esm/helpers/cls.js +1 -14
- package/dist/esm/helpers/colors.js +1 -169
- package/dist/esm/helpers/compose-advance-style.js +1 -315
- package/dist/esm/helpers/composeClasses.js +1 -0
- package/dist/esm/helpers/const.js +1 -0
- package/dist/esm/helpers/constant.js +1 -19
- package/dist/esm/helpers/convert.js +1 -4
- package/dist/esm/helpers/covert-entities-html.js +1 -17
- package/dist/esm/helpers/css-variable.js +1 -5
- package/dist/esm/helpers/email.js +1 -6
- package/dist/esm/helpers/filter-styles.js +1 -0
- package/dist/esm/helpers/filter-toolbar-preview.js +2 -9
- package/dist/esm/helpers/flatten-connection.js +1 -7
- package/dist/esm/helpers/get-resonsive-value.js +1 -31
- package/dist/esm/helpers/get-shortname.js +1 -90
- package/dist/esm/helpers/icon-list.js +1 -58
- package/dist/esm/helpers/interaction/index.js +2 -132
- package/dist/esm/helpers/is-browser.js +1 -5
- package/dist/esm/helpers/is-defined.js +1 -5
- package/dist/esm/helpers/is-empty-children.js +2 -10
- package/dist/esm/helpers/is-safari.js +1 -5
- package/dist/esm/helpers/layout.js +1 -70
- package/dist/esm/helpers/load-script.js +1 -29
- package/dist/esm/helpers/loop-component.js +1 -14
- package/dist/esm/helpers/make-style.js +1 -149
- package/dist/esm/helpers/normalize-builder-data.js +1 -21
- package/dist/esm/helpers/pascal-to-kebab-case.js +1 -5
- package/dist/esm/helpers/prefetch-queries.js +1 -76
- package/dist/esm/helpers/product.js +1 -44
- package/dist/esm/helpers/queries/get-collection.js +1 -223
- package/dist/esm/helpers/queries/get-collections.js +1 -19
- package/dist/esm/helpers/queries/get-product-by-slug.js +1 -123
- package/dist/esm/helpers/queries/get-product.js +1 -150
- package/dist/esm/helpers/queries/get-products.js +1 -210
- package/dist/esm/helpers/query.js +1 -25
- package/dist/esm/helpers/radius.js +6 -132
- package/dist/esm/helpers/render.js +1 -82
- package/dist/esm/helpers/shadow.js +1 -63
- package/dist/esm/helpers/size.js +4 -213
- package/dist/esm/helpers/spacing.js +1 -40
- package/dist/esm/helpers/third-party/addAppBlockId.js +1 -18
- package/dist/esm/helpers/third-party/appConfig.js +1 -356
- package/dist/esm/helpers/third-party/appSetting.js +1 -1321
- package/dist/esm/helpers/third-party/composeAppBlockId.js +1 -9
- package/dist/esm/helpers/third-party/constant.js +1 -66
- package/dist/esm/helpers/third-party/generateAppBlockConfigs.js +1 -32
- package/dist/esm/helpers/third-party/getAppBlockConfig.js +1 -53
- package/dist/esm/helpers/third-party/getAppBlockType.js +1 -10
- package/dist/esm/helpers/third-party/getAppBlocks.js +1 -28
- package/dist/esm/helpers/third-party/mergeBlock.js +1 -17
- package/dist/esm/helpers/third-party/mergeBlockOrder.js +1 -45
- package/dist/esm/helpers/third-party/removeGPAppItems.js +1 -15
- package/dist/esm/helpers/tracking/fpixel.js +1 -24
- package/dist/esm/helpers/tracking/gtag.js +1 -87
- package/dist/esm/helpers/tracking/tiktokpixel.js +1 -15
- package/dist/esm/helpers/typography.js +19 -149
- package/dist/esm/helpers/variant.js +1 -9
- package/dist/esm/hooks/animation/useAnimationActions.js +2 -37
- package/dist/esm/hooks/animation/useAnimationConfig.js +2 -28
- package/dist/esm/hooks/animation/useAnimationPreview.js +2 -29
- package/dist/esm/hooks/animation/useAnimationTarget.js +2 -120
- package/dist/esm/hooks/animation/useApplyAnimation.js +2 -85
- package/dist/esm/hooks/articles/useArticlesQuery.js +2 -30
- package/dist/esm/hooks/cart/use-add-to-cart.js +2 -18
- package/dist/esm/hooks/cart/use-cart-data.js +2 -26
- package/dist/esm/hooks/cart/use-cart-discount-codes-update.js +2 -18
- package/dist/esm/hooks/cart/use-cart-note-update.js +2 -18
- package/dist/esm/hooks/cart/use-create-cart.js +2 -20
- package/dist/esm/hooks/cart/use-remove-cart-item.js +2 -18
- package/dist/esm/hooks/cart/use-update-cart-item.js +2 -18
- package/dist/esm/hooks/shop/use-collection-query.js +2 -20
- package/dist/esm/hooks/shop/use-collections-query.js +2 -15
- package/dist/esm/hooks/shop/use-product-query.js +2 -20
- package/dist/esm/hooks/shop/use-products-query.js +2 -59
- package/dist/esm/hooks/shop/useShopifyLink.js +2 -0
- package/dist/esm/hooks/shop.js +2 -119
- package/dist/esm/hooks/use-current-device.js +2 -28
- package/dist/esm/hooks/use-lazy-video.js +2 -13
- package/dist/esm/hooks/useAnimations.js +2 -27
- package/dist/esm/hooks/useCartId.js +2 -40
- package/dist/esm/hooks/useCartLine.js +2 -7
- package/dist/esm/hooks/useCartUI.js +2 -44
- package/dist/esm/hooks/useCollection.js +2 -7
- package/dist/esm/hooks/useFetchHandle.js +2 -11
- package/dist/esm/hooks/useFormatMoney.js +2 -71
- package/dist/esm/hooks/useI18n.js +2 -0
- package/dist/esm/hooks/useInitialSwatchesOptions.js +2 -123
- package/dist/esm/hooks/useInteraction.js +2 -17
- package/dist/esm/hooks/useIsomorphicLayoutEffect.js +2 -6
- package/dist/esm/hooks/useLoadScript.js +2 -28
- package/dist/esm/hooks/useMoney.js +2 -80
- package/dist/esm/hooks/usePrevious.js +2 -17
- package/dist/esm/hooks/useProduct.js +2 -233
- package/dist/esm/hooks/useProductList.js +2 -16
- package/dist/esm/hooks/useStickyStore.js +1 -0
- package/dist/esm/hooks/useSuspenseFetch.js +2 -23
- package/dist/esm/hooks/useSwatchesOptions.js +2 -37
- package/dist/esm/hooks/useToolbarPostPurchase.js +2 -87
- package/dist/esm/index.js +1 -119
- package/dist/esm/types/animations.js +1 -49
- package/dist/esm/types/custom.js +1 -52
- package/dist/esm/types/global-style.js +1 -12
- package/dist/types/index.d.ts +12025 -8969
- package/package.json +6 -6
- package/dist/cjs/web-components/src/helpers/styles/constant.js +0 -9
- package/dist/esm/web-components/src/helpers/styles/constant.js +0 -7
|
@@ -1,309 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
import
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
import 'swr/mutation';
|
|
8
|
-
import 'swr/infinite';
|
|
9
|
-
import 'vanilla-lazyload';
|
|
10
|
-
import '../hooks/useCartUI.js';
|
|
11
|
-
import 'react-transition-group';
|
|
12
|
-
import '@gem-sdk/core';
|
|
13
|
-
import { disableWrap, customRenderChildren } from './constant.js';
|
|
14
|
-
import 'classnames';
|
|
15
|
-
import 'dayjs';
|
|
16
|
-
import { composeAdvanceStyle } from '../helpers/compose-advance-style.js';
|
|
17
|
-
import { baseAssetURL, isLocalEnv } from '../helpers/convert.js';
|
|
18
|
-
import { RenderIf, template } from '../helpers/render.js';
|
|
19
|
-
|
|
20
|
-
const componentsRenderWithParentId = [
|
|
21
|
-
'CarouselItem'
|
|
22
|
-
];
|
|
23
|
-
const componentTexts = [
|
|
24
|
-
'Text',
|
|
25
|
-
'Heading'
|
|
26
|
-
];
|
|
27
|
-
const componentIconList = [
|
|
28
|
-
'IconListV2',
|
|
29
|
-
'IconList'
|
|
30
|
-
];
|
|
31
|
-
const componentUsingAdvanced = [
|
|
32
|
-
'IconList',
|
|
33
|
-
'ProductVariants'
|
|
34
|
-
];
|
|
35
|
-
const Render = ({ uid, builder, components, parentId, extraFiles = {}, pageContext, ...passProps })=>{
|
|
36
|
-
const item = builder[uid];
|
|
37
|
-
const Component = components[item?.tag];
|
|
38
|
-
if (!Component) {
|
|
39
|
-
return {
|
|
40
|
-
liquid: '',
|
|
41
|
-
extraFiles
|
|
42
|
-
};
|
|
43
|
-
}
|
|
44
|
-
if (!item) {
|
|
45
|
-
return {
|
|
46
|
-
liquid: '',
|
|
47
|
-
extraFiles
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
if (item?.type === 'section') {
|
|
51
|
-
return {
|
|
52
|
-
liquid: '',
|
|
53
|
-
extraFiles
|
|
54
|
-
};
|
|
55
|
-
} else {
|
|
56
|
-
const customProps = {
|
|
57
|
-
extraFiles: {}
|
|
58
|
-
};
|
|
59
|
-
const style = composeAdvanceStyle(item.advanced, item.tag);
|
|
60
|
-
let liquid = '';
|
|
61
|
-
if (disableWrap.includes(item.tag)) {
|
|
62
|
-
liquid = RenderIf(item?.childrens?.length, ()=>{
|
|
63
|
-
return Component({
|
|
64
|
-
builderProps: {
|
|
65
|
-
uid,
|
|
66
|
-
builderData: item
|
|
67
|
-
},
|
|
68
|
-
styles: item.styles,
|
|
69
|
-
setting: item.settings,
|
|
70
|
-
style,
|
|
71
|
-
advanced: item.advanced,
|
|
72
|
-
parentId: componentsRenderWithParentId.includes(item.tag) ? parentId : null,
|
|
73
|
-
pageContext,
|
|
74
|
-
...passProps,
|
|
75
|
-
builderAttrs: {
|
|
76
|
-
...passProps.builderAttrs
|
|
77
|
-
},
|
|
78
|
-
rawChildren: item.childrens.map((id)=>{
|
|
79
|
-
return {
|
|
80
|
-
...builder[id],
|
|
81
|
-
uid: id,
|
|
82
|
-
builder,
|
|
83
|
-
components,
|
|
84
|
-
customProps,
|
|
85
|
-
pageContext
|
|
86
|
-
};
|
|
87
|
-
}),
|
|
88
|
-
children: !customRenderChildren.includes(item.tag) ? WrapRenderChildren({
|
|
89
|
-
uid,
|
|
90
|
-
customProps
|
|
91
|
-
}, item.childrens.map((id)=>RenderChildren({
|
|
92
|
-
uid: id,
|
|
93
|
-
builder,
|
|
94
|
-
components,
|
|
95
|
-
customProps,
|
|
96
|
-
parentTag: item.tag,
|
|
97
|
-
pageContext
|
|
98
|
-
}))) : ''
|
|
99
|
-
});
|
|
100
|
-
}, ()=>{
|
|
101
|
-
return Component({
|
|
102
|
-
builderProps: {
|
|
103
|
-
uid,
|
|
104
|
-
builderData: item
|
|
105
|
-
},
|
|
106
|
-
styles: item.styles,
|
|
107
|
-
setting: item.settings,
|
|
108
|
-
advanced: item.advanced,
|
|
109
|
-
style,
|
|
110
|
-
isText: componentTexts.includes(item.tag) ? true : null,
|
|
111
|
-
parentId: componentsRenderWithParentId.includes(item.tag) ? parentId : null,
|
|
112
|
-
pageContext,
|
|
113
|
-
...passProps,
|
|
114
|
-
builderAttrs: {
|
|
115
|
-
...passProps.builderAttrs
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
} else {
|
|
120
|
-
liquid = template`<div gp-el-wrapper style="${!componentIconList.includes(item.tag) ? style : ''}" class="${item.uid} ${!item?.childrens?.length && item.tag === 'IconListItemHoz' ? 'hidden' : ''}">
|
|
121
|
-
${RenderIf(item?.childrens?.length, ()=>{
|
|
122
|
-
return Component({
|
|
123
|
-
builderProps: {
|
|
124
|
-
uid,
|
|
125
|
-
builderData: item
|
|
126
|
-
},
|
|
127
|
-
styles: item.styles,
|
|
128
|
-
setting: item.settings,
|
|
129
|
-
advanced: {
|
|
130
|
-
...componentUsingAdvanced.includes(item.tag) ? item?.advanced : {},
|
|
131
|
-
cssClass: item?.advanced?.cssClass
|
|
132
|
-
},
|
|
133
|
-
pageContext,
|
|
134
|
-
...passProps,
|
|
135
|
-
builderAttrs: {
|
|
136
|
-
...passProps.builderAttrs
|
|
137
|
-
},
|
|
138
|
-
rawChildren: item.childrens.map((id)=>{
|
|
139
|
-
return {
|
|
140
|
-
...builder[id],
|
|
141
|
-
uid: id,
|
|
142
|
-
builder,
|
|
143
|
-
components,
|
|
144
|
-
customProps,
|
|
145
|
-
pageContext
|
|
146
|
-
};
|
|
147
|
-
}),
|
|
148
|
-
children: !customRenderChildren.includes(item.tag) ? WrapRenderChildren({
|
|
149
|
-
uid,
|
|
150
|
-
customProps
|
|
151
|
-
}, item.childrens.map((id)=>RenderChildren({
|
|
152
|
-
uid: id,
|
|
153
|
-
builder,
|
|
154
|
-
components,
|
|
155
|
-
customProps,
|
|
156
|
-
parentTag: item.tag,
|
|
157
|
-
pageContext
|
|
158
|
-
}))) : ''
|
|
159
|
-
});
|
|
160
|
-
}, ()=>{
|
|
161
|
-
return Component({
|
|
162
|
-
builderProps: {
|
|
163
|
-
uid,
|
|
164
|
-
builderData: item
|
|
165
|
-
},
|
|
166
|
-
styles: item.styles,
|
|
167
|
-
setting: item.settings,
|
|
168
|
-
advanced: {
|
|
169
|
-
...componentUsingAdvanced.includes(item.tag) ? item?.advanced : {},
|
|
170
|
-
cssClass: item?.advanced?.cssClass
|
|
171
|
-
},
|
|
172
|
-
pageContext,
|
|
173
|
-
isText: componentTexts.includes(item.tag) ? true : null,
|
|
174
|
-
style: componentIconList.includes(item.tag) ? style : null,
|
|
175
|
-
...passProps,
|
|
176
|
-
builderAttrs: {
|
|
177
|
-
...passProps.builderAttrs
|
|
178
|
-
}
|
|
179
|
-
});
|
|
180
|
-
})}
|
|
181
|
-
</div>`;
|
|
182
|
-
}
|
|
183
|
-
const { cssCode, jsCode } = RenderCustomCode(item);
|
|
184
|
-
if (cssCode) liquid += cssCode;
|
|
185
|
-
if (jsCode) liquid += jsCode;
|
|
186
|
-
liquid = appendAnimation(item, liquid);
|
|
187
|
-
return {
|
|
188
|
-
liquid,
|
|
189
|
-
extraFiles: customProps.extraFiles
|
|
190
|
-
};
|
|
191
|
-
}
|
|
192
|
-
};
|
|
193
|
-
const RenderCustomCode = (item)=>{
|
|
194
|
-
const { css, javascript, rootClassName } = item.advanced?.editorData || {};
|
|
195
|
-
const replacedCSS = css?.replaceAll(rootClassName, item.uid);
|
|
196
|
-
const replacedJS = javascript?.replaceAll(rootClassName, item.uid);
|
|
197
|
-
const cssCode = RenderIf(!!css, template`
|
|
198
|
-
<style id="${`custom-css-${item?.uid}`}">
|
|
199
|
-
${replacedCSS}
|
|
1
|
+
'use client';
|
|
2
|
+
import{makeStyleResponsive as e}from"../helpers/make-style.js";import"react";import"react/jsx-runtime";import"zustand";import"swr";import"@gem-sdk/adapter-shopify";import"swr/mutation";import"swr/infinite";import"vanilla-lazyload";import"../hooks/useCartUI.js";import"../hooks/useStickyStore.js";import"react-transition-group";import"@gem-sdk/core";import{disableWrap as t,customRenderChildren as n}from"./constant.js";import"classnames";import"dayjs";import{composeAdvanceStyle as r}from"../helpers/compose-advance-style.js";import{baseAssetURL as i,isLocalEnv as s}from"../helpers/convert.js";import{RenderIf as d,template as a}from"../helpers/render.js";let componentsRenderWithParentId=["CarouselItem"],componentTexts=["Text","Heading"],componentIconList=["IconListV2","IconList"],componentUsingAdvanced=["IconList","ProductVariants"],Render=({uid:e,builder:i,components:s,parentId:l,extraFiles:o={},pageContext:p,additionalSettings:c,...u})=>{let m=i[e],g=s[m?.tag];if(!g||!m||m?.type==="section")return{liquid:"",extraFiles:o};{let o={extraFiles:{}},h=r(m.advanced,m.tag),b="";b=t.includes(m.tag)?d(m?.childrens?.length,()=>g({builderProps:{uid:e,builderData:m},styles:m.styles,setting:m.settings,style:h,advanced:m.advanced,parentId:componentsRenderWithParentId.includes(m.tag)?l:null,pageContext:p,...c,...u,builderAttrs:{...u.builderAttrs},rawChildren:m.childrens.map(e=>({...i[e],uid:e,builder:i,components:s,customProps:o,pageContext:p,...c})),children:n.includes(m.tag)?"":WrapRenderChildren({uid:e,customProps:o},m.childrens.map(e=>RenderChildren({uid:e,builder:i,components:s,customProps:o,parentTag:m.tag,pageContext:p,...c})))}),()=>g({builderProps:{uid:e,builderData:m},styles:m.styles,setting:m.settings,advanced:m.advanced,style:h,isText:!!componentTexts.includes(m.tag)||null,parentId:componentsRenderWithParentId.includes(m.tag)?l:null,pageContext:p,...u,builderAttrs:{...u.builderAttrs}})):a`<div gp-el-wrapper style="${componentIconList.includes(m.tag)?"":h}" class="${m.uid} ${m?.childrens?.length||"IconListItemHoz"!==m.tag?"":"hidden"}">
|
|
3
|
+
${d(m?.childrens?.length,()=>g({builderProps:{uid:e,builderData:m},styles:m.styles,setting:m.settings,advanced:{...componentUsingAdvanced.includes(m.tag)?m?.advanced:{},cssClass:m?.advanced?.cssClass},pageContext:p,...c,...u,builderAttrs:{...u.builderAttrs},rawChildren:m.childrens.map(e=>({...i[e],uid:e,builder:i,components:s,customProps:o,pageContext:p,...c})),children:n.includes(m.tag)?"":WrapRenderChildren({uid:e,customProps:o},m.childrens.map(e=>RenderChildren({uid:e,builder:i,components:s,customProps:o,parentTag:m.tag,pageContext:p,...c})))}),()=>g({builderProps:{uid:e,builderData:m},styles:m.styles,setting:m.settings,advanced:{...componentUsingAdvanced.includes(m.tag)?m?.advanced:{},cssClass:m?.advanced?.cssClass},pageContext:p,...c,isText:!!componentTexts.includes(m.tag)||null,style:componentIconList.includes(m.tag)?h:null,...u,builderAttrs:{...u.builderAttrs}}))}
|
|
4
|
+
</div>`;let{cssCode:f,jsCode:v}=RenderCustomCode(m);return f&&(b+=f),v&&(b+=v),{liquid:b=appendAnimation(m,b),extraFiles:o.extraFiles}}},RenderCustomCode=e=>{let{css:t,javascript:n,rootClassName:r}=e.advanced?.editorData||{},i=t?.replaceAll(r,e.uid),s=n?.replaceAll(r,e.uid),l=d(!!t,a`
|
|
5
|
+
<style id="${`custom-css-${e?.uid}`}">
|
|
6
|
+
${i}
|
|
200
7
|
</style>
|
|
201
|
-
`)
|
|
202
|
-
|
|
203
|
-
<script id="${`custom-js-${item?.uid}`}">
|
|
8
|
+
`),o=d(!!n,a`
|
|
9
|
+
<script id="${`custom-js-${e?.uid}`}">
|
|
204
10
|
try {
|
|
205
|
-
${
|
|
11
|
+
${s}
|
|
206
12
|
} catch(err){}
|
|
207
13
|
</script>
|
|
208
|
-
`);
|
|
209
|
-
return {
|
|
210
|
-
cssCode,
|
|
211
|
-
jsCode
|
|
212
|
-
};
|
|
213
|
-
};
|
|
214
|
-
const appendAnimation = (props, liquid)=>{
|
|
215
|
-
const { advanced, tag } = props;
|
|
216
|
-
const { animation, op: opacity, hasAnimationInteraction, displayInitInteraction } = advanced ?? {};
|
|
217
|
-
const getAnimationType = (settings, type)=>{
|
|
218
|
-
return settings?.triggerConfig?.[type]?.animation ?? 'none';
|
|
219
|
-
};
|
|
220
|
-
const getSettingsByDevice = (device)=>{
|
|
221
|
-
if (device === 'desktop') return animation?.desktop;
|
|
222
|
-
else if (device === 'tablet') return animation?.tablet ?? animation?.desktop;
|
|
223
|
-
else if (device === 'mobile') return animation?.mobile ?? animation?.tablet ?? animation?.desktop;
|
|
224
|
-
return animation?.desktop;
|
|
225
|
-
};
|
|
226
|
-
const appearDesktop = getAnimationType(getSettingsByDevice('desktop'), 'appear');
|
|
227
|
-
const hoverDesktop = getAnimationType(getSettingsByDevice('desktop'), 'hover');
|
|
228
|
-
const appearTablet = getAnimationType(getSettingsByDevice('tablet'), 'appear');
|
|
229
|
-
const appearMobile = getAnimationType(getSettingsByDevice('mobile'), 'appear');
|
|
230
|
-
const enableAnimation = animation?.desktop?.enabled && (appearDesktop !== 'none' || hoverDesktop !== 'none') || animation?.tablet?.enabled && appearTablet !== 'none' || animation?.mobile?.enabled && appearMobile !== 'none' || !!hasAnimationInteraction;
|
|
231
|
-
const enableAnimationWhenInit = animation?.desktop?.enabled && (appearDesktop !== 'none' || hoverDesktop !== 'none') || animation?.tablet?.enabled && appearTablet !== 'none' || animation?.mobile?.enabled && appearMobile !== 'none';
|
|
232
|
-
if (!enableAnimation) return liquid;
|
|
233
|
-
const getInitVisibility = (device)=>getSettingsByDevice(device)?.enabled && ![
|
|
234
|
-
'shake',
|
|
235
|
-
'none'
|
|
236
|
-
].includes(getAnimationType(getSettingsByDevice(device), 'appear')) ? 'hidden' : 'visible';
|
|
237
|
-
const opacityObject = {
|
|
238
|
-
desktop: getInitVisibility('desktop'),
|
|
239
|
-
tablet: getInitVisibility('tablet'),
|
|
240
|
-
mobile: getInitVisibility('mobile')
|
|
241
|
-
};
|
|
242
|
-
return template`
|
|
14
|
+
`);return{cssCode:l,jsCode:o}},appendAnimation=(t,n)=>{let{advanced:r,tag:l}=t,{animation:o,op:p,hasAnimationInteraction:c,displayInitInteraction:u}=r??{},m=(e,t)=>e?.triggerConfig?.[t]?.animation??"none",g=e=>{if("desktop"===e);else if("tablet"===e)return o?.tablet??o?.desktop;else if("mobile"===e)return o?.mobile??o?.tablet??o?.desktop;return o?.desktop},h=m(g("desktop"),"appear"),b=m(g("desktop"),"hover"),f=m(g("tablet"),"appear"),v=m(g("mobile"),"appear"),y=o?.desktop?.enabled&&("none"!==h||"none"!==b)||o?.tablet?.enabled&&"none"!==f||o?.mobile?.enabled&&"none"!==v||!!c,C=o?.desktop?.enabled&&("none"!==h||"none"!==b)||o?.tablet?.enabled&&"none"!==f||o?.mobile?.enabled&&"none"!==v;if(!y)return n;let $=e=>g(e)?.enabled&&!["shake","none"].includes(m(g(e),"appear"))?"hidden":"visible",x={desktop:$("desktop"),tablet:$("tablet"),mobile:$("mobile")};return a`
|
|
243
15
|
<gp-animation
|
|
244
16
|
gp-interaction-wrapper
|
|
245
|
-
display-init="${
|
|
246
|
-
gp-data='${JSON.stringify({
|
|
247
|
-
|
|
248
|
-
tag,
|
|
249
|
-
opacity,
|
|
250
|
-
notEnableAnimationWhenInit: !enableAnimationWhenInit
|
|
251
|
-
})}'
|
|
252
|
-
style="${{
|
|
253
|
-
display: 'contents'
|
|
254
|
-
}}"
|
|
17
|
+
display-init="${!1===u?"hide":"show"}"
|
|
18
|
+
gp-data='${JSON.stringify({config:o,tag:l,opacity:p,notEnableAnimationWhenInit:!C})}'
|
|
19
|
+
style="${{display:"contents"}}"
|
|
255
20
|
>
|
|
256
|
-
<div style="${{
|
|
257
|
-
...makeStyleResponsive('v', opacityObject),
|
|
258
|
-
display: 'contents'
|
|
259
|
-
}}">${liquid}</div>
|
|
21
|
+
<div style="${{...e("v",x),display:"contents"}}">${n}</div>
|
|
260
22
|
</gp-animation>
|
|
261
|
-
${
|
|
262
|
-
`;
|
|
263
|
-
};
|
|
264
|
-
const RenderChildren = (props)=>{
|
|
265
|
-
const data = Render(props);
|
|
266
|
-
// Append to prop parent
|
|
267
|
-
for(const key in data.extraFiles){
|
|
268
|
-
if (Object.prototype.hasOwnProperty.call(data.extraFiles, key)) {
|
|
269
|
-
props.customProps.extraFiles[key] = data.extraFiles[key];
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
// Fix limit 256kb
|
|
273
|
-
const textEncoder = new TextEncoder();
|
|
274
|
-
const size = data?.liquid ? textEncoder.encode(data.liquid).length : 0;
|
|
275
|
-
if (Math.ceil(size / 1024) >= 180) {
|
|
276
|
-
const fileName = `gp-section-snippet-${props.uid}`;
|
|
277
|
-
props.customProps.extraFiles[fileName] = data.liquid;
|
|
278
|
-
return `{% render '${fileName}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`;
|
|
279
|
-
}
|
|
280
|
-
return data.liquid;
|
|
281
|
-
};
|
|
282
|
-
const WrapRenderChildren = ({ uid, customProps }, codes)=>{
|
|
283
|
-
let liquid = '';
|
|
284
|
-
if (codes?.length) {
|
|
285
|
-
let tempLiquid = '';
|
|
286
|
-
let fileIndex = 0;
|
|
287
|
-
for (const code of codes){
|
|
288
|
-
if (code) {
|
|
289
|
-
const textEncoder = new TextEncoder();
|
|
290
|
-
const newTempLiquid = tempLiquid + code;
|
|
291
|
-
const newSize = textEncoder.encode(newTempLiquid).length;
|
|
292
|
-
if (Math.ceil(newSize / 1024) < 180) {
|
|
293
|
-
tempLiquid = newTempLiquid;
|
|
294
|
-
} else {
|
|
295
|
-
const fileName = `gp-section-snippet-${uid}-${fileIndex++}`;
|
|
296
|
-
customProps.extraFiles[fileName] = tempLiquid;
|
|
297
|
-
liquid += `{% render '${fileName}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`;
|
|
298
|
-
tempLiquid = code;
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
if (tempLiquid) {
|
|
303
|
-
liquid += tempLiquid;
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
return liquid;
|
|
307
|
-
};
|
|
308
|
-
|
|
309
|
-
export { RenderChildren, WrapRenderChildren, Render as default };
|
|
23
|
+
${d(s,'<script src="{{ \'gp-animation-v7-5.js\' | asset_url }}" defer="defer"></script>',`<script src="${i}/assets-v2/gp-animation-v7-5.js?v={{ shop.metafields.GEMPAGES.ASSETS_VERSION }}" defer="defer"></script>`)}
|
|
24
|
+
`},RenderChildren=e=>{let t=Render(e);for(let n in t.extraFiles)Object.prototype.hasOwnProperty.call(t.extraFiles,n)&&(e.customProps.extraFiles[n]=t.extraFiles[n]);let n=new TextEncoder,r=t?.liquid?n.encode(t.liquid).length:0;if(Math.ceil(r/1024)>=180){let n=`gp-section-snippet-${e.uid}`;return e.customProps.extraFiles[n]=t.liquid,`{% render '${n}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`}return t.liquid},WrapRenderChildren=({uid:e,customProps:t},n)=>{let r="";if(n?.length)for(let i=0;i<n.length;i++){let s=n[i];if(s){let n=r+s,d=new TextEncoder,a=n?d.encode(n).length:0;if(Math.ceil(a/1024)>=180){let n=`gp-section-snippet-${e+i}`;t.extraFiles[n]=s,r+=`{% render '${n}', product: product, variant: variant, product_form_id: product_form_id, productSelectedVariant: productSelectedVariant, form: form %}`}else r+=s}}return r};export{RenderChildren,WrapRenderChildren,Render as default};
|
|
@@ -1,50 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import { ErrorBoundary } from 'react-error-boundary';
|
|
4
|
-
import { useBuilderComponent } from '../contexts/BuilderComponent.js';
|
|
5
|
-
import { useBuilderStore } from '../contexts/BuilderContext.js';
|
|
6
|
-
import ComponentWrapper from './ComponentWrapper.js';
|
|
7
|
-
|
|
8
|
-
const RenderBlock = ({ uid })=>{
|
|
9
|
-
const item = useBuilderStore((s)=>s.getItem(uid));
|
|
10
|
-
const Component = useBuilderComponent(item?.tag);
|
|
11
|
-
if (!item || item.type === 'section') return null;
|
|
12
|
-
return /*#__PURE__*/ jsx(ErrorBoundary, {
|
|
13
|
-
fallbackRender: ({ error, resetErrorBoundary })=>/*#__PURE__*/ jsxs(ComponentWrapper, {
|
|
14
|
-
...item,
|
|
15
|
-
children: [
|
|
16
|
-
/*#__PURE__*/ jsx("span", {
|
|
17
|
-
"aria-label": "Error message",
|
|
18
|
-
children: error.message
|
|
19
|
-
}),
|
|
20
|
-
/*#__PURE__*/ jsx("button", {
|
|
21
|
-
type: "button",
|
|
22
|
-
onClick: resetErrorBoundary,
|
|
23
|
-
children: "Try again"
|
|
24
|
-
})
|
|
25
|
-
]
|
|
26
|
-
}),
|
|
27
|
-
children: /*#__PURE__*/ jsx(ComponentWrapper, {
|
|
28
|
-
...item,
|
|
29
|
-
children: item?.childrens?.length ? /*#__PURE__*/ jsx(Component, {
|
|
30
|
-
builderProps: {
|
|
31
|
-
uid
|
|
32
|
-
},
|
|
33
|
-
styles: item.styles ?? {},
|
|
34
|
-
setting: item.settings ?? {},
|
|
35
|
-
children: item?.childrens?.map((id)=>/*#__PURE__*/ jsx(RenderBlockMemo, {
|
|
36
|
-
uid: id
|
|
37
|
-
}, id))
|
|
38
|
-
}) : /*#__PURE__*/ jsx(Component, {
|
|
39
|
-
builderProps: {
|
|
40
|
-
uid
|
|
41
|
-
},
|
|
42
|
-
styles: item.styles ?? {},
|
|
43
|
-
setting: item.settings ?? {}
|
|
44
|
-
})
|
|
45
|
-
})
|
|
46
|
-
}, item.uid);
|
|
47
|
-
};
|
|
48
|
-
const RenderBlockMemo = /*#__PURE__*/ memo(RenderBlock);
|
|
49
|
-
|
|
50
|
-
export { RenderBlockMemo as default };
|
|
1
|
+
'use client';
|
|
2
|
+
import{jsx as e,jsxs as r}from"react/jsx-runtime";import{memo as t}from"react";import{ErrorBoundary as o}from"react-error-boundary";import{useBuilderComponent as n}from"../contexts/BuilderComponent.js";import{useBuilderStore as l}from"../contexts/BuilderContext.js";import s from"./ComponentWrapper.js";let RenderBlock=({uid:t})=>{let i=l(e=>e.getItem(t)),d=n(i?.tag);return i&&"section"!==i.type?e(o,{fallbackRender:({error:t,resetErrorBoundary:o})=>r(s,{...i,children:[e("span",{"aria-label":"Error message",children:t.message}),e("button",{type:"button",onClick:o,children:"Try again"})]}),children:e(s,{...i,children:i?.childrens?.length?e(d,{builderProps:{uid:t},styles:i.styles??{},setting:i.settings??{},children:i?.childrens?.map(r=>e(RenderBlockMemo,{uid:r},r))}):e(d,{builderProps:{uid:t},styles:i.styles??{},setting:i.settings??{}})})},i.uid):null},RenderBlockMemo=t(RenderBlock);export{RenderBlockMemo as default};
|
|
@@ -1,57 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
import
|
|
3
|
-
import Script from 'next/script';
|
|
4
|
-
import { useMemo } from 'react';
|
|
5
|
-
import 'zustand';
|
|
6
|
-
import 'react-transition-group';
|
|
7
|
-
import '@gem-sdk/core';
|
|
8
|
-
import 'swr';
|
|
9
|
-
import 'swr/infinite';
|
|
10
|
-
import { useEditorMode } from '../hooks/shop.js';
|
|
11
|
-
import 'classnames';
|
|
12
|
-
import 'dayjs';
|
|
13
|
-
import '../helpers/convert.js';
|
|
14
|
-
import '@gem-sdk/adapter-shopify';
|
|
15
|
-
import 'swr/mutation';
|
|
16
|
-
import 'vanilla-lazyload';
|
|
17
|
-
import '../hooks/useCartUI.js';
|
|
18
|
-
|
|
19
|
-
const RenderCustomCode = ({ uid, advanced })=>{
|
|
20
|
-
const mode = useEditorMode();
|
|
21
|
-
const { css, javascript, rootClassName } = advanced?.editorData || {};
|
|
22
|
-
const replacedCSS = css?.replaceAll(rootClassName, uid);
|
|
23
|
-
const replacedJS = javascript?.replaceAll(rootClassName, uid);
|
|
24
|
-
const mapId = {
|
|
25
|
-
css: `custom-css-${uid}`,
|
|
26
|
-
javascript: `custom-js-${uid}`
|
|
27
|
-
};
|
|
28
|
-
const jsCode = useMemo(()=>{
|
|
29
|
-
return `
|
|
1
|
+
'use client';
|
|
2
|
+
import{jsxs as r,Fragment as t,jsx as o}from"react/jsx-runtime";import e from"next/head";import s from"next/script";import{useMemo as i}from"react";import"zustand";import"react-transition-group";import"@gem-sdk/core";import"swr";import"swr/infinite";import{useEditorMode as m}from"../hooks/shop.js";import"classnames";import"dayjs";import"../helpers/convert.js";import"@gem-sdk/adapter-shopify";import"swr/mutation";import"vanilla-lazyload";import"../hooks/useCartUI.js";import"../hooks/useStickyStore.js";let RenderCustomCode=({uid:a,advanced:p})=>{let n=m(),{css:l,javascript:c,rootClassName:d}=p?.editorData||{},u=l?.replaceAll(d,a),h=c?.replaceAll(d,a),j={css:`custom-css-${a}`,javascript:`custom-js-${a}`},f=i(()=>`
|
|
30
3
|
try {
|
|
31
|
-
${
|
|
4
|
+
${h}
|
|
32
5
|
} catch(err){}
|
|
33
|
-
|
|
34
|
-
}, [
|
|
35
|
-
replacedJS
|
|
36
|
-
]);
|
|
37
|
-
return /*#__PURE__*/ jsxs(Fragment, {
|
|
38
|
-
children: [
|
|
39
|
-
/*#__PURE__*/ jsx(Head, {
|
|
40
|
-
children: !!css && /*#__PURE__*/ jsx("style", {
|
|
41
|
-
id: mapId['css'],
|
|
42
|
-
dangerouslySetInnerHTML: {
|
|
43
|
-
__html: replacedCSS
|
|
44
|
-
}
|
|
45
|
-
})
|
|
46
|
-
}),
|
|
47
|
-
!!javascript && mode !== 'edit' && /*#__PURE__*/ jsx(Script, {
|
|
48
|
-
id: mapId['javascript'],
|
|
49
|
-
dangerouslySetInnerHTML: {
|
|
50
|
-
__html: jsCode
|
|
51
|
-
}
|
|
52
|
-
})
|
|
53
|
-
]
|
|
54
|
-
});
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
export { RenderCustomCode as default };
|
|
6
|
+
`,[h]);return r(t,{children:[o(e,{children:!!l&&o("style",{id:j.css,dangerouslySetInnerHTML:{__html:u}})}),!!c&&"edit"!==n&&o(s,{id:j.javascript,dangerouslySetInnerHTML:{__html:f}})]})};export{RenderCustomCode as default};
|
|
@@ -1,63 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import { ErrorBoundary } from 'react-error-boundary';
|
|
4
|
-
import { useBuilderComponent } from '../contexts/BuilderComponent.js';
|
|
5
|
-
import { useBuilderPreviewStore } from '../contexts/BuilderPreviewContext.js';
|
|
6
|
-
import ComponentWrapperPreview from './ComponentWrapperPreview.js';
|
|
7
|
-
import RenderSectionMemo from './RenderSection.js';
|
|
8
|
-
|
|
9
|
-
const RenderPreview = ({ uid, ...passProps })=>{
|
|
10
|
-
const item = useBuilderPreviewStore((s)=>s.getItem(uid));
|
|
11
|
-
const Component = useBuilderComponent(item?.tag);
|
|
12
|
-
if (!item) return null;
|
|
13
|
-
if (item?.type === 'section') {
|
|
14
|
-
return /*#__PURE__*/ jsx(RenderSectionMemo, {
|
|
15
|
-
sectionId: item.uid
|
|
16
|
-
});
|
|
17
|
-
} else {
|
|
18
|
-
return /*#__PURE__*/ jsx(ErrorBoundary, {
|
|
19
|
-
fallbackRender: ({ error, resetErrorBoundary })=>/*#__PURE__*/ jsxs(ComponentWrapperPreview, {
|
|
20
|
-
...item,
|
|
21
|
-
children: [
|
|
22
|
-
/*#__PURE__*/ jsx("span", {
|
|
23
|
-
"aria-label": "Error message",
|
|
24
|
-
children: error.message
|
|
25
|
-
}),
|
|
26
|
-
/*#__PURE__*/ jsx("button", {
|
|
27
|
-
type: "button",
|
|
28
|
-
onClick: resetErrorBoundary,
|
|
29
|
-
children: "Try again"
|
|
30
|
-
})
|
|
31
|
-
]
|
|
32
|
-
}),
|
|
33
|
-
children: /*#__PURE__*/ jsx(ComponentWrapperPreview, {
|
|
34
|
-
...item,
|
|
35
|
-
children: item?.childrens?.length ? /*#__PURE__*/ jsx(Component, {
|
|
36
|
-
builderProps: {
|
|
37
|
-
uid,
|
|
38
|
-
builderData: item
|
|
39
|
-
},
|
|
40
|
-
styles: item.styles,
|
|
41
|
-
setting: item.settings,
|
|
42
|
-
...passProps,
|
|
43
|
-
children: item.childrens.map((id)=>/*#__PURE__*/ jsx(RenderPreviewMemo, {
|
|
44
|
-
"bundle-item": passProps?.['bundle-item'],
|
|
45
|
-
uid: id
|
|
46
|
-
}, id))
|
|
47
|
-
}) : /*#__PURE__*/ jsx(Component, {
|
|
48
|
-
builderProps: {
|
|
49
|
-
uid,
|
|
50
|
-
builderData: item
|
|
51
|
-
},
|
|
52
|
-
styles: item.styles,
|
|
53
|
-
setting: item.settings,
|
|
54
|
-
...passProps
|
|
55
|
-
})
|
|
56
|
-
})
|
|
57
|
-
}, item.uid);
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
const RenderPreviewMemo = /*#__PURE__*/ memo(RenderPreview);
|
|
61
|
-
RenderPreviewMemo.displayName = 'RenderPreviewMemo';
|
|
62
|
-
|
|
63
|
-
export { RenderPreviewMemo as default };
|
|
1
|
+
'use client';
|
|
2
|
+
import{jsx as e,jsxs as r}from"react/jsx-runtime";import{memo as t}from"react";import{ErrorBoundary as i}from"react-error-boundary";import{useBuilderComponent as n}from"../contexts/BuilderComponent.js";import{useBuilderPreviewStore as o}from"../contexts/BuilderPreviewContext.js";import l from"./ComponentWrapperPreview.js";import s from"./RenderSection.js";let RenderPreview=({uid:t,...d})=>{let m=o(e=>e.getItem(t)),a=n(m?.tag);return m?m?.type==="section"?e(s,{sectionId:m.uid}):e(i,{fallbackRender:({error:t,resetErrorBoundary:i})=>r(l,{...m,children:[e("span",{"aria-label":"Error message",children:t.message}),e("button",{type:"button",onClick:i,children:"Try again"})]}),children:e(l,{...m,children:m?.childrens?.length?e(a,{builderProps:{uid:t,builderData:m},styles:m.styles,setting:m.settings,...d,children:m.childrens.map(r=>e(RenderPreviewMemo,{parentStyle:d?.parentStyle,"bundle-item":d?.["bundle-item"],uid:r},r))}):e(a,{builderProps:{uid:t,builderData:m},styles:m.styles,setting:m.settings,...d})})},m.uid):null},RenderPreviewMemo=t(RenderPreview);RenderPreviewMemo.displayName="RenderPreviewMemo";export{RenderPreviewMemo as default};
|
|
@@ -1,19 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import { BuilderProvider } from '../contexts/BuilderContext.js';
|
|
4
|
-
import { useSection } from '../contexts/SectionContext.js';
|
|
5
|
-
import RenderBlockMemo from './RenderBlock.js';
|
|
6
|
-
|
|
7
|
-
const RenderSection = ({ sectionId })=>{
|
|
8
|
-
const state = useSection(sectionId);
|
|
9
|
-
if (!state) return null;
|
|
10
|
-
return /*#__PURE__*/ jsx(BuilderProvider, {
|
|
11
|
-
state: state,
|
|
12
|
-
children: /*#__PURE__*/ jsx(RenderBlockMemo, {
|
|
13
|
-
uid: sectionId
|
|
14
|
-
})
|
|
15
|
-
}, sectionId);
|
|
16
|
-
};
|
|
17
|
-
const RenderSectionMemo = /*#__PURE__*/ memo(RenderSection);
|
|
18
|
-
|
|
19
|
-
export { RenderSectionMemo as default };
|
|
1
|
+
'use client';
|
|
2
|
+
import{jsx as e}from"react/jsx-runtime";import{memo as t}from"react";import{BuilderProvider as o}from"../contexts/BuilderContext.js";import{useSection as r}from"../contexts/SectionContext.js";import n from"./RenderBlock.js";let RenderSection=({sectionId:t})=>{let i=r(t);return i?e(o,{state:i,children:e(n,{uid:t})},t):null},RenderSectionMemo=t(RenderSection);export{RenderSectionMemo as default};
|