@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,220 +1 @@
|
|
|
1
|
-
|
|
2
|
-
ease: 'cubic-bezier(0.46,0.03,0.52,0.96)',
|
|
3
|
-
'ease-in': 'cubic-bezier(0.55,0.08,0.68,0.53)',
|
|
4
|
-
'ease-out': 'cubic-bezier(0.46,0.03,0.52,0.96)',
|
|
5
|
-
linear: 'linear'
|
|
6
|
-
};
|
|
7
|
-
const animations = ()=>{
|
|
8
|
-
const normalizeOptions = (options)=>{
|
|
9
|
-
const cloneOptions = JSON.parse(JSON.stringify(options));
|
|
10
|
-
const numberMember = [
|
|
11
|
-
'delay',
|
|
12
|
-
'speed',
|
|
13
|
-
'scale',
|
|
14
|
-
'intensity'
|
|
15
|
-
];
|
|
16
|
-
numberMember.forEach((keyName)=>{
|
|
17
|
-
if (!cloneOptions?.[keyName]) return;
|
|
18
|
-
if (keyName === 'scale') {
|
|
19
|
-
if (!cloneOptions?.zoomDirection) throw new TypeError(`zoomDirection not found on zoom preset`);
|
|
20
|
-
const [i1, i2] = cloneOptions?.scale?.in ?? [
|
|
21
|
-
1,
|
|
22
|
-
1
|
|
23
|
-
];
|
|
24
|
-
const [o1, o2] = cloneOptions?.scale?.out ?? [
|
|
25
|
-
1,
|
|
26
|
-
1
|
|
27
|
-
];
|
|
28
|
-
cloneOptions[keyName] = {
|
|
29
|
-
in: [
|
|
30
|
-
Number(i1) / 100,
|
|
31
|
-
Number(i2) / 100
|
|
32
|
-
],
|
|
33
|
-
out: [
|
|
34
|
-
Number(o1) / 100,
|
|
35
|
-
Number(o2) / 100
|
|
36
|
-
]
|
|
37
|
-
};
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
const num = Number(cloneOptions?.[keyName]);
|
|
41
|
-
if (keyName === 'delay') cloneOptions[keyName] = num * 1000;
|
|
42
|
-
else cloneOptions[keyName] = num;
|
|
43
|
-
if (!isFinite(num)) throw new TypeError(`${keyName} must be a number`);
|
|
44
|
-
});
|
|
45
|
-
return cloneOptions;
|
|
46
|
-
};
|
|
47
|
-
const slide = (target, options, reverse)=>{
|
|
48
|
-
const normalizedOptions = normalizeOptions(options);
|
|
49
|
-
const { direction, distance } = normalizedOptions;
|
|
50
|
-
const coordinate = [
|
|
51
|
-
'left',
|
|
52
|
-
'right'
|
|
53
|
-
].includes(direction ?? '') ? 'X' : 'Y';
|
|
54
|
-
let isNeg = [
|
|
55
|
-
'left',
|
|
56
|
-
'down'
|
|
57
|
-
].includes(direction ?? '') ? '-' : '';
|
|
58
|
-
if (reverse) {
|
|
59
|
-
isNeg = [
|
|
60
|
-
'left',
|
|
61
|
-
'down'
|
|
62
|
-
].includes(direction ?? '') ? '' : '-';
|
|
63
|
-
}
|
|
64
|
-
const preset = [
|
|
65
|
-
{
|
|
66
|
-
opacity: 0,
|
|
67
|
-
transform: `translate${coordinate}(${isNeg}${distance ?? 50}%)`
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
opacity: 1,
|
|
71
|
-
transform: `translate${coordinate}(0)`
|
|
72
|
-
}
|
|
73
|
-
];
|
|
74
|
-
return generateAnimationInstance(target, reverse ? preset.reverse() : preset, {
|
|
75
|
-
...generateOptions(normalizedOptions, 500)
|
|
76
|
-
});
|
|
77
|
-
};
|
|
78
|
-
const fade = (target, options, reverse)=>{
|
|
79
|
-
const normalizedOptions = normalizeOptions(options);
|
|
80
|
-
const preset = [
|
|
81
|
-
{
|
|
82
|
-
opacity: 0
|
|
83
|
-
},
|
|
84
|
-
{
|
|
85
|
-
opacity: 1
|
|
86
|
-
}
|
|
87
|
-
];
|
|
88
|
-
return generateAnimationInstance(target, reverse ? preset.reverse() : preset, {
|
|
89
|
-
...generateOptions(normalizedOptions, 500)
|
|
90
|
-
});
|
|
91
|
-
};
|
|
92
|
-
const generateOptions = (options, defaultDuration)=>{
|
|
93
|
-
const convertSpeedToDuration = (speed)=>{
|
|
94
|
-
if (!speed) return defaultDuration;
|
|
95
|
-
return 1.5 / speed * 1000;
|
|
96
|
-
};
|
|
97
|
-
const { loop, delay, speed, easing } = options ?? {};
|
|
98
|
-
const duration = convertSpeedToDuration(speed);
|
|
99
|
-
const actualDelay = delay ?? 0;
|
|
100
|
-
const actualDuration = loop ? duration + actualDelay : duration;
|
|
101
|
-
return {
|
|
102
|
-
iterations: loop ? Infinity : 1,
|
|
103
|
-
duration: actualDuration,
|
|
104
|
-
delay: actualDelay,
|
|
105
|
-
easing: EASING[easing ?? 'linear']
|
|
106
|
-
};
|
|
107
|
-
};
|
|
108
|
-
const zoom = (target, options, reverse)=>{
|
|
109
|
-
const normalizedOptions = normalizeOptions(options);
|
|
110
|
-
const { scale, zoomDirection, isFade } = normalizedOptions;
|
|
111
|
-
const [i1, i2] = scale.in;
|
|
112
|
-
const [o1, o2] = scale.out;
|
|
113
|
-
const zoomInPreset = [
|
|
114
|
-
{
|
|
115
|
-
transform: `scale(${i1}, ${i1})`,
|
|
116
|
-
opacity: isFade ? 0 : 1
|
|
117
|
-
},
|
|
118
|
-
{
|
|
119
|
-
transform: `scale(${i2 ?? 1.2}, ${i2 ?? 1.2})`,
|
|
120
|
-
opacity: 1
|
|
121
|
-
}
|
|
122
|
-
];
|
|
123
|
-
const zoomOutPreset = [
|
|
124
|
-
{
|
|
125
|
-
transform: `scale(${o1}, ${o1})`,
|
|
126
|
-
opacity: isFade ? 0 : 1
|
|
127
|
-
},
|
|
128
|
-
{
|
|
129
|
-
transform: `scale(${o2 ?? 0.8}, ${o2 ?? 0.8})`,
|
|
130
|
-
opacity: 1
|
|
131
|
-
}
|
|
132
|
-
];
|
|
133
|
-
let zoomPreset = zoomDirection === 'in' ? zoomInPreset : zoomOutPreset;
|
|
134
|
-
if (reverse) {
|
|
135
|
-
zoomPreset = zoomDirection === 'in' ? zoomOutPreset : zoomInPreset;
|
|
136
|
-
}
|
|
137
|
-
return generateAnimationInstance(target, reverse ? zoomPreset.reverse() : zoomPreset, {
|
|
138
|
-
...generateOptions(normalizedOptions, 700)
|
|
139
|
-
});
|
|
140
|
-
};
|
|
141
|
-
const generateLoopDelayEffect = (keyframes, delay, duration)=>{
|
|
142
|
-
if (!delay) return keyframes;
|
|
143
|
-
const offset = delay / duration;
|
|
144
|
-
const keyframe = [
|
|
145
|
-
...keyframes
|
|
146
|
-
].pop();
|
|
147
|
-
return [
|
|
148
|
-
...keyframes,
|
|
149
|
-
{
|
|
150
|
-
...keyframe,
|
|
151
|
-
offset: 1 - offset
|
|
152
|
-
}
|
|
153
|
-
];
|
|
154
|
-
};
|
|
155
|
-
const shake = (target, options)=>{
|
|
156
|
-
const normalizedOptions = normalizeOptions(options);
|
|
157
|
-
const { intensity } = normalizedOptions ?? {};
|
|
158
|
-
const zeroIntensity = [
|
|
159
|
-
{
|
|
160
|
-
transform: 'translate3d(0, 0, 0)'
|
|
161
|
-
}
|
|
162
|
-
];
|
|
163
|
-
const unitIntensity = [
|
|
164
|
-
{
|
|
165
|
-
transform: 'translate3d(4px, 0, 0)'
|
|
166
|
-
},
|
|
167
|
-
{
|
|
168
|
-
transform: 'translate3d(-4px, 0, 0)'
|
|
169
|
-
},
|
|
170
|
-
{
|
|
171
|
-
transform: 'translate3d(4px, 0, 0)'
|
|
172
|
-
}
|
|
173
|
-
];
|
|
174
|
-
let keyframes = [];
|
|
175
|
-
Array.from(Array(intensity ?? 1).keys()).forEach(()=>{
|
|
176
|
-
keyframes = [
|
|
177
|
-
...keyframes,
|
|
178
|
-
...unitIntensity
|
|
179
|
-
];
|
|
180
|
-
});
|
|
181
|
-
const shakePreset = [
|
|
182
|
-
{
|
|
183
|
-
transform: 'translate3d(-1px, 0, 0)'
|
|
184
|
-
},
|
|
185
|
-
{
|
|
186
|
-
transform: 'translate3d(2px, 0, 0)'
|
|
187
|
-
},
|
|
188
|
-
{
|
|
189
|
-
transform: 'translate3d(-4px, 0, 0)'
|
|
190
|
-
},
|
|
191
|
-
...keyframes,
|
|
192
|
-
{
|
|
193
|
-
transform: 'translate3d(-4px, 0, 0)'
|
|
194
|
-
},
|
|
195
|
-
{
|
|
196
|
-
transform: 'translate3d(2px, 0, 0)'
|
|
197
|
-
},
|
|
198
|
-
{
|
|
199
|
-
transform: 'translate3d(-1px, 0, 0)'
|
|
200
|
-
}
|
|
201
|
-
];
|
|
202
|
-
return generateAnimationInstance(target, intensity ? shakePreset : zeroIntensity, {
|
|
203
|
-
...generateOptions(normalizedOptions ?? {}, 820)
|
|
204
|
-
});
|
|
205
|
-
};
|
|
206
|
-
const generateAnimationInstance = (target, effectPreset, options)=>{
|
|
207
|
-
const effect = new KeyframeEffect(target, options.iterations && options.iterations === 1 ? effectPreset : generateLoopDelayEffect(effectPreset, options?.delay ?? 0, (options?.duration) ?? 0), {
|
|
208
|
-
...options
|
|
209
|
-
});
|
|
210
|
-
return new Animation(effect, document.timeline);
|
|
211
|
-
};
|
|
212
|
-
return {
|
|
213
|
-
zoom,
|
|
214
|
-
shake,
|
|
215
|
-
fade,
|
|
216
|
-
slide
|
|
217
|
-
};
|
|
218
|
-
};
|
|
219
|
-
|
|
220
|
-
export { animations };
|
|
1
|
+
let EASING={ease:"cubic-bezier(0.46,0.03,0.52,0.96)","ease-in":"cubic-bezier(0.55,0.08,0.68,0.53)","ease-out":"cubic-bezier(0.46,0.03,0.52,0.96)",linear:"linear"},animations=()=>{let e=e=>{let r=JSON.parse(JSON.stringify(e)),t=["delay","speed","scale","intensity"];return t.forEach(e=>{if(!r?.[e])return;if("scale"===e){if(!r?.zoomDirection)throw TypeError("zoomDirection not found on zoom preset");let[t,a]=r?.scale?.in??[1,1],[n,i]=r?.scale?.out??[1,1];r[e]={in:[Number(t)/100,Number(a)/100],out:[Number(n)/100,Number(i)/100]};return}let t=Number(r?.[e]);if("delay"===e?r[e]=1e3*t:r[e]=t,!isFinite(t))throw TypeError(`${e} must be a number`)}),r},r=(r,t,n)=>{let i=e(t),{direction:o,distance:l}=i,f=["left","right"].includes(o??"")?"X":"Y",m=["left","down"].includes(o??"")?"-":"";n&&(m=["left","down"].includes(o??"")?"":"-");let u=[{opacity:0,transform:`translate${f}(${m}${l??50}%)`},{opacity:1,transform:`translate${f}(0)`}];return s(r,n?u.reverse():u,{...a(i,500)})},t=(r,t,n)=>{let i=e(t),o=[{opacity:0},{opacity:1}];return s(r,n?o.reverse():o,{...a(i,500)})},a=(e,r)=>{let t=e=>e?1.5/e*1e3:r,{loop:a,delay:n,speed:i,easing:o}=e??{},s=t(i),l=n??0,f=a?s+l:s;return{iterations:a?1/0:1,duration:f,delay:l,easing:EASING[o??"linear"]}},n=(r,t,n)=>{let i=e(t),{scale:o,zoomDirection:l,isFade:f}=i,[m,u]=o.in,[c,p]=o.out,d=[{transform:`scale(${m}, ${m})`,opacity:f?0:1},{transform:`scale(${u??1.2}, ${u??1.2})`,opacity:1}],y=[{transform:`scale(${c}, ${c})`,opacity:f?0:1},{transform:`scale(${p??.8}, ${p??.8})`,opacity:1}],b="in"===l?d:y;return n&&(b="in"===l?y:d),s(r,n?b.reverse():b,{...a(i,700)})},i=(e,r,t)=>{if(!r)return e;let a=r/t,n=[...e].pop();return[...e,{...n,offset:1-a}]},o=(r,t)=>{let n=e(t),{intensity:i}=n??{},o=[{transform:"translate3d(0, 0, 0)"}],l=[{transform:"translate3d(4px, 0, 0)"},{transform:"translate3d(-4px, 0, 0)"},{transform:"translate3d(4px, 0, 0)"}],f=[];Array.from(Array(i??1).keys()).forEach(()=>{f=[...f,...l]});let m=[{transform:"translate3d(-1px, 0, 0)"},{transform:"translate3d(2px, 0, 0)"},{transform:"translate3d(-4px, 0, 0)"},...f,{transform:"translate3d(-4px, 0, 0)"},{transform:"translate3d(2px, 0, 0)"},{transform:"translate3d(-1px, 0, 0)"}];return s(r,i?m:o,{...a(n??{},820)})},s=(e,r,t)=>{let a=new KeyframeEffect(e,t.iterations&&1===t.iterations?r:i(r,t?.delay??0,t?.duration??0),{...t});return new Animation(a,document.timeline)};return{zoom:n,shake:o,fade:t,slide:r}};export{animations};
|
|
@@ -1,227 +1 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { isColor, getSingleColorVariable } from './colors.js';
|
|
3
|
-
import { makeStyleResponsive } from './make-style.js';
|
|
4
|
-
|
|
5
|
-
const getStyleBackgroundByDevice = (background, options)=>{
|
|
6
|
-
if (!background) {
|
|
7
|
-
return {};
|
|
8
|
-
}
|
|
9
|
-
return {
|
|
10
|
-
...!options?.ignoreBackgroundColor ? {
|
|
11
|
-
...getStyleBgColor(background)
|
|
12
|
-
} : {},
|
|
13
|
-
...!options?.ignoreBackgroundImage ? {
|
|
14
|
-
...getStyleBgImage(background, options)
|
|
15
|
-
} : {},
|
|
16
|
-
...!options?.ignoreBackgroundImageProperties ? {
|
|
17
|
-
...getStyleBgPosition(background),
|
|
18
|
-
...getStyleBgSize(background),
|
|
19
|
-
...getStyleBgRepeat(background)
|
|
20
|
-
} : {},
|
|
21
|
-
...!options?.ignoreBgAttachment ? getStyleBgAttachment(background) : {}
|
|
22
|
-
};
|
|
23
|
-
};
|
|
24
|
-
const getStyleBgColor = (background)=>{
|
|
25
|
-
const bgColor = {
|
|
26
|
-
desktop: getBgColorByDevice(background, 'desktop'),
|
|
27
|
-
tablet: getBgColorByDevice(background, 'tablet'),
|
|
28
|
-
mobile: getBgColorByDevice(background, 'mobile')
|
|
29
|
-
};
|
|
30
|
-
return makeStyleResponsive('bgc', bgColor);
|
|
31
|
-
};
|
|
32
|
-
const getBgColorByDevice = (background, device)=>{
|
|
33
|
-
return getColor(background?.[device]?.color);
|
|
34
|
-
};
|
|
35
|
-
const getColor = (color)=>{
|
|
36
|
-
if (!color) {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
if (isColor(color?.toString())) {
|
|
40
|
-
return color;
|
|
41
|
-
}
|
|
42
|
-
return `var(--g-c-${color})`;
|
|
43
|
-
};
|
|
44
|
-
const getStyleBgImage = (background, options)=>{
|
|
45
|
-
const bgImage = {
|
|
46
|
-
desktop: getBgImageByDevice(background, 'desktop', options),
|
|
47
|
-
tablet: getBgImageByDevice(background, 'tablet', options),
|
|
48
|
-
mobile: getBgImageByDevice(background, 'mobile', options)
|
|
49
|
-
};
|
|
50
|
-
return makeStyleResponsive('bgi', bgImage);
|
|
51
|
-
};
|
|
52
|
-
const getBgImageByDevice = (background, device, options)=>{
|
|
53
|
-
const isBgVideo = background?.[device]?.type === 'video';
|
|
54
|
-
if (isBgVideo) return;
|
|
55
|
-
if (background?.[device]?.type === 'color') return 'url()'; // To prevent overriding background image from upper device
|
|
56
|
-
const backupFileKey = background?.[device]?.image?.backupFileKey;
|
|
57
|
-
const storage = background?.[device]?.image?.storage;
|
|
58
|
-
let imageByDevice = background?.[device]?.image?.src;
|
|
59
|
-
let newBackupFilekey = backupFileKey;
|
|
60
|
-
const shopifyHandleName = imageByDevice?.match(// eslint-disable-next-line
|
|
61
|
-
/\/files\/([^\/]+\.(jpg|jpeg|gif|png|webp|svg))/)?.[1];
|
|
62
|
-
if (backupFileKey && shopifyHandleName && shopifyHandleName != backupFileKey) {
|
|
63
|
-
newBackupFilekey = shopifyHandleName;
|
|
64
|
-
}
|
|
65
|
-
if (storage === 'FILE_CONTENT') {
|
|
66
|
-
if (options?.liquid && newBackupFilekey) {
|
|
67
|
-
imageByDevice = `{{ "${newBackupFilekey.replace('.jpeg', '.jpg')}" | file_url }}`;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
if (storage === 'THEME' || !storage) {
|
|
71
|
-
if (options?.liquid && newBackupFilekey) {
|
|
72
|
-
imageByDevice = `{{ "${newBackupFilekey}" | asset_url }}`;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
if (typeof imageByDevice === 'string') {
|
|
76
|
-
return `url(${imageByDevice})`;
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
const getStyleBgPosition = (background)=>{
|
|
80
|
-
const bgPosition = {
|
|
81
|
-
desktop: getBgPositionByDevice(background, 'desktop'),
|
|
82
|
-
tablet: getBgPositionByDevice(background, 'tablet'),
|
|
83
|
-
mobile: getBgPositionByDevice(background, 'mobile')
|
|
84
|
-
};
|
|
85
|
-
return makeStyleResponsive('bgp', bgPosition);
|
|
86
|
-
};
|
|
87
|
-
const getBgPositionByDevice = (background, device)=>{
|
|
88
|
-
const positionByDevice = background?.[device]?.position;
|
|
89
|
-
return positionByDevice && `${positionByDevice.x}% ${positionByDevice.y}%`;
|
|
90
|
-
};
|
|
91
|
-
const getStyleBgSize = (background)=>{
|
|
92
|
-
const bgSize = {
|
|
93
|
-
desktop: getBgSizeByDevice(background, 'desktop'),
|
|
94
|
-
tablet: getBgSizeByDevice(background, 'tablet'),
|
|
95
|
-
mobile: getBgSizeByDevice(background, 'mobile')
|
|
96
|
-
};
|
|
97
|
-
return makeStyleResponsive('bgs', bgSize);
|
|
98
|
-
};
|
|
99
|
-
const getBgSizeByDevice = (background, device)=>{
|
|
100
|
-
return background?.[device]?.size;
|
|
101
|
-
};
|
|
102
|
-
const getStyleBgRepeat = (background)=>{
|
|
103
|
-
const bgRepeat = {
|
|
104
|
-
desktop: getBgRepeatByDevice(background, 'desktop'),
|
|
105
|
-
tablet: getBgRepeatByDevice(background, 'tablet'),
|
|
106
|
-
mobile: getBgRepeatByDevice(background, 'mobile')
|
|
107
|
-
};
|
|
108
|
-
return makeStyleResponsive('bgr', bgRepeat);
|
|
109
|
-
};
|
|
110
|
-
const getBgRepeatByDevice = (background, device)=>{
|
|
111
|
-
return background?.[device]?.repeat;
|
|
112
|
-
};
|
|
113
|
-
const getStyleBgAttachment = (background)=>{
|
|
114
|
-
const bgAttachment = {
|
|
115
|
-
desktop: getBgAttachmentByDevice(background, 'desktop'),
|
|
116
|
-
tablet: getBgAttachmentByDevice(background, 'tablet'),
|
|
117
|
-
mobile: getBgAttachmentByDevice(background, 'mobile')
|
|
118
|
-
};
|
|
119
|
-
return makeStyleResponsive('bga', bgAttachment);
|
|
120
|
-
};
|
|
121
|
-
const getBgAttachmentByDevice = (background, device)=>{
|
|
122
|
-
return background?.[device]?.attachment;
|
|
123
|
-
};
|
|
124
|
-
const composeBackgroundCss = (backgroundColor)=>{
|
|
125
|
-
return `${backgroundColor ? `background-color: ${getSingleColorVariable(backgroundColor)};` : undefined}`;
|
|
126
|
-
};
|
|
127
|
-
const makeFixedBgAttachment = (background)=>{
|
|
128
|
-
if (!background) return;
|
|
129
|
-
background.tablet = background.tablet ? background.tablet : background.desktop;
|
|
130
|
-
background.mobile = background.mobile ? background.mobile : background.tablet;
|
|
131
|
-
const bgAttachment = {
|
|
132
|
-
desktop: getBgAttachmentByDevice(background, 'desktop'),
|
|
133
|
-
tablet: getBgAttachmentByDevice(background, 'tablet'),
|
|
134
|
-
mobile: getBgAttachmentByDevice(background, 'mobile')
|
|
135
|
-
};
|
|
136
|
-
const composeFixed = {
|
|
137
|
-
desktop: {
|
|
138
|
-
...makeFixedBgAttachmentByDevice('desktop', bgAttachment.desktop)
|
|
139
|
-
},
|
|
140
|
-
tablet: {
|
|
141
|
-
...makeFixedBgAttachmentByDevice('tablet', bgAttachment.tablet)
|
|
142
|
-
},
|
|
143
|
-
mobile: {
|
|
144
|
-
...makeFixedBgAttachmentByDevice('mobile', bgAttachment.mobile)
|
|
145
|
-
}
|
|
146
|
-
};
|
|
147
|
-
return {
|
|
148
|
-
wrapper: {
|
|
149
|
-
...composeFixed.desktop?.wrapper,
|
|
150
|
-
...composeFixed.tablet?.wrapper,
|
|
151
|
-
...composeFixed.mobile?.wrapper
|
|
152
|
-
},
|
|
153
|
-
content: {
|
|
154
|
-
...composeFixed.desktop?.content,
|
|
155
|
-
...composeFixed.tablet?.content,
|
|
156
|
-
...composeFixed.mobile?.content
|
|
157
|
-
}
|
|
158
|
-
};
|
|
159
|
-
};
|
|
160
|
-
const makeFixedBgAttachmentByDevice = (device, bgAttachment)=>{
|
|
161
|
-
const suffix = devicesMapping[device] ?? '';
|
|
162
|
-
if (bgAttachment === 'fixed') {
|
|
163
|
-
return {
|
|
164
|
-
wrapper: {
|
|
165
|
-
[`--pos${suffix}`]: 'absolute',
|
|
166
|
-
[`--top${suffix}`]: '0',
|
|
167
|
-
[`--left${suffix}`]: '0',
|
|
168
|
-
[`--w${suffix}`]: '100%',
|
|
169
|
-
[`--h${suffix}`]: '100%'
|
|
170
|
-
},
|
|
171
|
-
content: {
|
|
172
|
-
[`--pos${suffix}`]: 'fixed',
|
|
173
|
-
[`--w${suffix}`]: '100vw',
|
|
174
|
-
[`--h${suffix}`]: '100vh',
|
|
175
|
-
[`--bga${suffix}`]: 'unset'
|
|
176
|
-
}
|
|
177
|
-
};
|
|
178
|
-
}
|
|
179
|
-
return {
|
|
180
|
-
wrapper: {
|
|
181
|
-
[`--pos${suffix}`]: 'absolute'
|
|
182
|
-
},
|
|
183
|
-
content: {
|
|
184
|
-
[`--w${suffix}`]: '100%',
|
|
185
|
-
[`--h${suffix}`]: '100%',
|
|
186
|
-
[`--pos${suffix}`]: 'absolute',
|
|
187
|
-
[`--bga${suffix}`]: bgAttachment
|
|
188
|
-
}
|
|
189
|
-
};
|
|
190
|
-
};
|
|
191
|
-
const GRADIENT_BGR_KEY = 'linear-gradient';
|
|
192
|
-
const getGradientBgrStyleForButton = (backgroundStyle)=>{
|
|
193
|
-
if (!backgroundStyle) return;
|
|
194
|
-
const bgrStyle = {};
|
|
195
|
-
Object.keys(backgroundStyle).forEach((state)=>{
|
|
196
|
-
if (!backgroundStyle[state]?.startsWith(GRADIENT_BGR_KEY)) return;
|
|
197
|
-
if (state === 'normal') {
|
|
198
|
-
Object.assign(bgrStyle, {
|
|
199
|
-
'--bg': backgroundStyle[state]
|
|
200
|
-
});
|
|
201
|
-
} else {
|
|
202
|
-
Object.assign(bgrStyle, {
|
|
203
|
-
'--hvr-bg': backgroundStyle[state]
|
|
204
|
-
});
|
|
205
|
-
}
|
|
206
|
-
});
|
|
207
|
-
return bgrStyle;
|
|
208
|
-
};
|
|
209
|
-
const getGradientBgrStyleByDevice = (backgroundStyle, ignoreBackgroundImage)=>{
|
|
210
|
-
if (!backgroundStyle) return;
|
|
211
|
-
const bgrStyle = {};
|
|
212
|
-
[
|
|
213
|
-
'desktop',
|
|
214
|
-
'tablet',
|
|
215
|
-
'mobile'
|
|
216
|
-
].forEach((device)=>{
|
|
217
|
-
if (backgroundStyle[device]?.color?.includes(GRADIENT_BGR_KEY)) {
|
|
218
|
-
Object.assign(bgrStyle, {
|
|
219
|
-
[`--bgc${device !== 'desktop' ? '-' + device : ''}`]: backgroundStyle[device]?.color,
|
|
220
|
-
[`--bgi${device !== 'desktop' ? '-' + device : ''}`]: !ignoreBackgroundImage?.[device] ? `${backgroundStyle[device]?.color}` : `${getBgImageByDevice(backgroundStyle, device) || 'url()'}, ${backgroundStyle[device]?.color}`
|
|
221
|
-
});
|
|
222
|
-
}
|
|
223
|
-
});
|
|
224
|
-
return bgrStyle;
|
|
225
|
-
};
|
|
226
|
-
|
|
227
|
-
export { GRADIENT_BGR_KEY, composeBackgroundCss, getBgImageByDevice, getGradientBgrStyleByDevice, getGradientBgrStyleForButton, getStyleBackgroundByDevice, getStyleBgColor, makeFixedBgAttachment };
|
|
1
|
+
import{devicesMapping as e}from"./constant.js";import{isColor as t,getSingleColorVariable as g}from"./colors.js";import{makeStyleResponsive as o}from"./make-style.js";import{getResponsiveValueByScreen as i}from"./get-resonsive-value.js";import{DEVICES as r}from"../constants/device.js";let isEmptyBg=e=>e?.videoHtml5===void 0&&e?.video===void 0&&!e?.videoType,getBgVideoByDevice=(e,t="desktop")=>{let g=e?.[t];if(isEmptyBg(g)&&"desktop"!==t){let t=e?.tablet;g=isEmptyBg(t)?e?.desktop:t}return g},getStyleBackgroundByDevice=(e,t)=>e?{...t?.ignoreBackgroundColor?{}:{...getStyleBgColor(e)},...t?.ignoreBackgroundImage?{}:{...getStyleBgImage(e,t)},...t?.ignoreBackgroundImageProperties?{}:{...getStyleBgPosition(e),...getStyleBgSize(e),...getStyleBgRepeat(e)},...t?.ignoreBgAttachment?{}:getStyleBgAttachment(e)}:{},getStyleBgColor=e=>{let t={desktop:getBgColorByDevice(e,"desktop"),tablet:getBgColorByDevice(e,"tablet"),mobile:getBgColorByDevice(e,"mobile")};return o("bgc",t)},getBgColorByDevice=(e,t)=>getColor(e?.[t]?.color),getColor=e=>e?t(e?.toString())?e:`var(--g-c-${e})`:void 0,getStyleBgImage=(e,t)=>{let g={desktop:getBgImageByDevice(e,"desktop",t),tablet:getBgImageByDevice(e,"tablet",t),mobile:getBgImageByDevice(e,"mobile",t)};return o("bgi",g)},getBgImageByDevice=(e,t,g)=>{let o=e?.[t]?.type==="video";if(o)return;if(e?.[t]?.type==="color")return"url()";let i=e?.[t]?.image?.backupFileKey,r=e?.[t]?.image?.storage,l=e?.[t]?.image?.src,a=i,B=l?.match(/\/files\/([^\/]+\.(jpg|jpeg|gif|png|webp|svg))/)?.[1];return(i&&B&&B!=i&&(a=B),"FILE_CONTENT"===r&&g?.liquid&&a&&(l=`{{ "${a.replace(".jpeg",".jpg")}" | file_url }}`),("THEME"===r||!r)&&g?.liquid&&a&&(l=`{{ "${a}" | asset_url }}`),"string"==typeof l&&l)?`url(${l})`:void 0!==l?"none":void 0},getStyleBgPosition=e=>{let t={desktop:getBgPositionByDevice(e,"desktop"),tablet:getBgPositionByDevice(e,"tablet"),mobile:getBgPositionByDevice(e,"mobile")};return o("bgp",t)},getBgPositionByDevice=(e,t)=>{let g=e?.[t]?.position;return g&&`${g.x}% ${g.y}%`},getStyleBgSize=e=>{let t={desktop:getBgSizeByDevice(e,"desktop"),tablet:getBgSizeByDevice(e,"tablet"),mobile:getBgSizeByDevice(e,"mobile")};return o("bgs",t)},getBgSizeByDevice=(e,t)=>e?.[t]?.size,getStyleBgRepeat=e=>{let t={desktop:getBgRepeatByDevice(e,"desktop"),tablet:getBgRepeatByDevice(e,"tablet"),mobile:getBgRepeatByDevice(e,"mobile")};return o("bgr",t)},getBgRepeatByDevice=(e,t)=>e?.[t]?.repeat,getStyleBgAttachment=e=>{let t={desktop:getBgAttachmentByDevice(e,"desktop"),tablet:getBgAttachmentByDevice(e,"tablet"),mobile:getBgAttachmentByDevice(e,"mobile")};return o("bga",t)},getBgAttachmentByDevice=(e,t)=>e?.[t]?.attachment,composeBackgroundCss=e=>`${e?`background-color: ${g(e)};`:void 0}`,makeFixedBgAttachment=e=>{if(!e)return;e.tablet=e.tablet?e.tablet:e.desktop,e.mobile=e.mobile?e.mobile:e.tablet;let t={desktop:getBgAttachmentByDevice(e,"desktop"),tablet:getBgAttachmentByDevice(e,"tablet"),mobile:getBgAttachmentByDevice(e,"mobile")},g={desktop:{...makeFixedBgAttachmentByDevice("desktop",t.desktop)},tablet:{...makeFixedBgAttachmentByDevice("tablet",t.tablet)},mobile:{...makeFixedBgAttachmentByDevice("mobile",t.mobile)}};return{wrapper:{...g.desktop?.wrapper,...g.tablet?.wrapper,...g.mobile?.wrapper},content:{...g.desktop?.content,...g.tablet?.content,...g.mobile?.content}}},makeFixedBgAttachmentByDevice=(t,g)=>{let o=e[t]??"";return"fixed"===g?{wrapper:{[`--pos${o}`]:"absolute",[`--top${o}`]:"0",[`--left${o}`]:"0",[`--w${o}`]:"100%",[`--h${o}`]:"100%"},content:{[`--pos${o}`]:"fixed",[`--w${o}`]:"100vw",[`--h${o}`]:"100vh",[`--bga${o}`]:"unset"}}:{wrapper:{[`--pos${o}`]:"absolute"},content:{[`--w${o}`]:"100%",[`--h${o}`]:"100%",[`--pos${o}`]:"absolute",[`--bga${o}`]:g}}},getGradientBgrStyleForButton=e=>{if(!e)return;let t={};for(let g of Object.keys(e)){let o=e[g];if(!o?.startsWith(GRADIENT_BGR_KEY))continue;let i="normal"===g?"--bgi":"--hvr-bgi";t[i]=o}return t},GRADIENT_BGR_KEY="linear-gradient",getCombinedBackgroundImage=e=>{if(!e)return;let{color:t,image:g}=e,o=g?.src&&g?.src?.trim()!=="",i=t?.includes(GRADIENT_BGR_KEY);return o&&i?`url('${g?.src}'), ${t}`:o?`url('${g?.src}')`:i?t:void 0},getGradientImageBgrStyleByDevice=e=>{if(!e)return;let t={};return r.forEach(g=>{let o=e[g];if(!o)return;let i="desktop"!==g?`-${g}`:"";o.color&&Object.assign(t,{[`--bgc${i}`]:o.color});let r=getCombinedBackgroundImage(o);r&&Object.assign(t,{[`--bgi${i}`]:r})}),t},getGradientBgrStyleByDevice=(e,t)=>{if(!e)return;let g={};return r.forEach(o=>{if(e[o]?.color?.includes(GRADIENT_BGR_KEY)){let i=`${getBgImageByDevice(e,o)||"url()"}, ${e[o]?.color}`;Object.assign(g,{[`--bgc${"desktop"!==o?"-"+o:""}`]:e[o]?.color,[`--bgi${"desktop"!==o?"-"+o:""}`]:t?.[o]?i:`${e[o]?.color}`})}}),g},getBgByDevice=e=>{let{backgroundColor:t,backgroundImage:g}=e;if(!t&&!g)return;let o={desktop:i(g,"desktop"),tablet:i(g,"tablet"),mobile:i(g,"mobile")},l={};return r.forEach(e=>{let r=i(t,e),a=g?getBgImageByDevice(o,e):void 0;r?.includes(GRADIENT_BGR_KEY)?Object.assign(l,{[`--bgi${"desktop"!==e?"-"+e:""}`]:r}):Object.assign(l,{[`--bgc${"desktop"!==e?"-"+e:""}`]:r,[`--bgi${"desktop"!==e?"-"+e:""}`]:"none"}),a&&"none"!==a&&Object.assign(l,{[`--bgi${"desktop"!==e?"-"+e:""}`]:a})}),{...l,...getStyleBgPosition(g),...getStyleBgSize(g),...getStyleBgRepeat(g),...getStyleBgAttachment(g)}};export{GRADIENT_BGR_KEY,composeBackgroundCss,getBgByDevice,getBgImageByDevice,getBgVideoByDevice,getColor,getCombinedBackgroundImage,getGradientBgrStyleByDevice,getGradientBgrStyleForButton,getGradientImageBgrStyleByDevice,getStyleBackgroundByDevice,getStyleBgColor,makeFixedBgAttachment};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{makeStyleState as e}from"./make-style.js";let getStyleBackgroundImage=(e,g)=>e?{...g?.ignoreBackgroundImage?{}:{...getStyleBgImageSource(e,g)},...g?.ignoreBackgroundImageProperties?{}:{...getStyleBgImagePosition(e),...getStyleBgImageSize(e),...getStyleBgImageRepeat(e)},...g?.ignoreBgAttachment?{}:getStyleBgImageAttachment(e)}:{},getStyleBgImageSource=(g,t)=>{let a={normal:getBgImageSourceByDevice(g,"normal",t),hover:getBgImageSourceByDevice(g,"hover",t)};return e("bgi",a)},getBgImageSourceByDevice=(e,g,t)=>{let a=e?.[g],r=a?.image?.backupFileKey,i=a?.image?.storage,o=a?.image?.src,m=r,n=o?.match(/\/files\/([^\/]+\.(jpg|jpeg|gif|png|webp|svg))/)?.[1];return r&&n&&n!==r&&(m=n),"FILE_CONTENT"===i&&t?.liquid&&m&&(o=`{{ "${m.replace(".jpeg",".jpg")}" | file_url }}`),("THEME"===i||!i)&&t?.liquid&&m&&(o=`{{ "${m}" | asset_url }}`),o?`url(${o})`:"none"},getStyleBgImagePosition=g=>{let t={normal:getBgImagePositionByDevice(g,"normal"),hover:getBgImagePositionByDevice(g,"hover")};return e("bgp",t)},getBgImagePositionByDevice=(e,g)=>{let t=e?.[g]?.position;return t&&`${t.x}% ${t.y}%`},getStyleBgImageSize=g=>{let t={normal:getBgImageSizeByDevice(g,"normal"),hover:getBgImageSizeByDevice(g,"hover")};return e("bgs",t)},getBgImageSizeByDevice=(e,g)=>e?.[g]?.size,getStyleBgImageRepeat=g=>{let t={normal:getBgImageRepeatByDevice(g,"normal"),hover:getBgImageRepeatByDevice(g,"hover")};return e("bgr",t)},getBgImageRepeatByDevice=(e,g)=>e?.[g]?.repeat,getStyleBgImageAttachment=g=>{let t={normal:getBgImageAttachmentByDevice(g,"normal"),hover:getBgImageAttachmentByDevice(g,"hover")};return e("bga",t)},getBgImageAttachmentByDevice=(e,g)=>e?.[g]?.attachment,composeBackgroundImageCss=(e,g={})=>{if(!e)return;let{device:t="desktop",state:a="normal",useLiquid:r=!1,responsive:i}=g,o=[],m=i?e?.[t]?.[a]:e?.[a];if(!m)return"";if(m.image?.src){let e=m.image.src;r&&m.image.backupFileKey&&("FILE_CONTENT"===m.image.storage?e=`{{ "${m.image.backupFileKey.replace(".jpeg",".jpg")}" | file_url }}`:"THEME"!==m.image.storage&&m.image.storage||(e=`{{ "${m.image.backupFileKey}" | asset_url }}`)),o.push(`background-image: url(${e});`)}return m.position&&o.push(`background-position: ${m.position.x}% ${m.position.y}%;`),m.size&&o.push(`background-size: ${m.size};`),m.repeat&&o.push(`background-repeat: ${m.repeat};`),m.attachment&&o.push(`background-attachment: ${m.attachment};`),o.join("\n ")};export{composeBackgroundImageCss,getBgImageSourceByDevice,getStyleBackgroundImage,getStyleBgImageSource};
|