@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.
Files changed (413) hide show
  1. package/README.md +1 -1
  2. package/dist/cjs/components/AddOn.js +2 -18
  3. package/dist/cjs/components/ComponentAnimation.js +2 -17
  4. package/dist/cjs/components/ComponentToolbarPreview.js +2 -752
  5. package/dist/cjs/components/ComponentWrapper.js +2 -61
  6. package/dist/cjs/components/ComponentWrapperPreview.js +2 -213
  7. package/dist/cjs/components/Empty.js +2 -7
  8. package/dist/cjs/components/InteractionSuffix.js +2 -42
  9. package/dist/cjs/components/Render.js +2 -75
  10. package/dist/cjs/components/Render.liquid.js +16 -307
  11. package/dist/cjs/components/RenderBlock.js +2 -54
  12. package/dist/cjs/components/RenderCustomCode.js +4 -59
  13. package/dist/cjs/components/RenderPreview.js +2 -67
  14. package/dist/cjs/components/RenderSection.js +2 -23
  15. package/dist/cjs/components/ai-generator/AIContentGenerator.js +2 -252
  16. package/dist/cjs/components/ai-generator/AIGenContentLoading.js +2 -85
  17. package/dist/cjs/components/ai-generator/components/PickProduct.js +2 -220
  18. package/dist/cjs/components/ai-generator/components/ToneAndVoice.js +2 -77
  19. package/dist/cjs/components/ai-generator/hooks/useCheckingProductInside.js +1 -47
  20. package/dist/cjs/components/ai-generator/hooks/useFlipPopup.js +1 -110
  21. package/dist/cjs/components/ai-generator/hooks/useGettingGenerateRequest.js +1 -37
  22. package/dist/cjs/components/ai-generator/hooks/useListenEventGenerate.js +1 -70
  23. package/dist/cjs/components/ai-generator/icons/AIIcon.js +2 -67
  24. package/dist/cjs/components/ai-generator/icons/CloseIcon.js +2 -19
  25. package/dist/cjs/components/ai-generator/icons/DropdownIcon.js +2 -37
  26. package/dist/cjs/components/ai-generator/icons/SearchIcon.js +2 -21
  27. package/dist/cjs/components/ai-generator/icons/ShowMoreIcon.js +2 -21
  28. package/dist/cjs/components/ai-generator/icons/UpgradeIcon.js +2 -27
  29. package/dist/cjs/components/ai-generator/icons/WarningIcon.js +2 -31
  30. package/dist/cjs/components/constant.js +1 -82
  31. package/dist/cjs/components/resize/Resize.js +2 -16
  32. package/dist/cjs/components/resize/Spacing.js +2 -260
  33. package/dist/cjs/components/src/product/helpers/variant-presets.js +1 -56
  34. package/dist/cjs/components/theme-section/CreateThemeSection.js +2 -123
  35. package/dist/cjs/components/theme-section/ThemeSectionStatus.js +2 -45
  36. package/dist/cjs/components/theme-section/ThemeSectionTooltip.js +2 -126
  37. package/dist/cjs/components/toolbar/Tooltip.js +2 -28
  38. package/dist/cjs/constants/device.js +1 -0
  39. package/dist/cjs/contexts/AddonContext.js +2 -36
  40. package/dist/cjs/contexts/ArticleContext.js +2 -39
  41. package/dist/cjs/contexts/ArticleListContext.js +2 -31
  42. package/dist/cjs/contexts/BuilderComponent.js +2 -34
  43. package/dist/cjs/contexts/BuilderContext.js +2 -39
  44. package/dist/cjs/contexts/BuilderPreviewContext.js +2 -482
  45. package/dist/cjs/contexts/CartLineContext.js +2 -29
  46. package/dist/cjs/contexts/CollectionContext.js +2 -38
  47. package/dist/cjs/contexts/I18nContext.js +2 -0
  48. package/dist/cjs/contexts/ModalContext.js +2 -47
  49. package/dist/cjs/contexts/PageContext.js +2 -111
  50. package/dist/cjs/contexts/ProductContext.js +2 -182
  51. package/dist/cjs/contexts/ProductListContext.js +2 -32
  52. package/dist/cjs/contexts/SectionContext.js +2 -53
  53. package/dist/cjs/contexts/ShopContext.js +2 -107
  54. package/dist/cjs/graphql/fragments/analytic.generated.js +2 -6
  55. package/dist/cjs/graphql/fragments/collection-detail.generated.js +2 -6
  56. package/dist/cjs/graphql/fragments/collection-product.generated.js +2 -6
  57. package/dist/cjs/graphql/fragments/collection.generated.js +2 -6
  58. package/dist/cjs/graphql/fragments/custom-code.generated.js +2 -6
  59. package/dist/cjs/graphql/fragments/custom-font.generated.js +7 -7
  60. package/dist/cjs/graphql/fragments/data-seo.generated.js +2 -6
  61. package/dist/cjs/graphql/fragments/media.generated.js +2 -6
  62. package/dist/cjs/graphql/fragments/preview-theme-page.generated.js +6 -6
  63. package/dist/cjs/graphql/fragments/product-little.generated.js +2 -6
  64. package/dist/cjs/graphql/fragments/product-option-value.generated.js +2 -6
  65. package/dist/cjs/graphql/fragments/product-option.generated.js +2 -6
  66. package/dist/cjs/graphql/fragments/product.generated.js +2 -6
  67. package/dist/cjs/graphql/fragments/published-custom-section.generated.js +2 -6
  68. package/dist/cjs/graphql/fragments/published-page-section.generated.js +2 -6
  69. package/dist/cjs/graphql/fragments/published-theme-page.generated.js +4 -18
  70. package/dist/cjs/graphql/fragments/published-theme-style.generated.js +2 -6
  71. package/dist/cjs/graphql/fragments/selected-option.generated.js +2 -6
  72. package/dist/cjs/graphql/fragments/variant.generated.js +2 -6
  73. package/dist/cjs/graphql/mutations/page-view-up.generated.js +2 -6
  74. package/dist/cjs/graphql/queries/articles.generated.js +2 -6
  75. package/dist/cjs/graphql/queries/blogs.generated.js +2 -6
  76. package/dist/cjs/graphql/queries/collection-detail-filter.generated.js +2 -16
  77. package/dist/cjs/graphql/queries/collection.generated.js +2 -14
  78. package/dist/cjs/graphql/queries/collections.generated.js +2 -9
  79. package/dist/cjs/graphql/queries/preview-page.generated.js +2 -12
  80. package/dist/cjs/graphql/queries/product-little-detail.generated.js +2 -11
  81. package/dist/cjs/graphql/queries/product-medias.generated.js +2 -8
  82. package/dist/cjs/graphql/queries/product-value-label.generated.js +2 -6
  83. package/dist/cjs/graphql/queries/product-variants.generated.js +3 -11
  84. package/dist/cjs/graphql/queries/products.generated.js +3 -17
  85. package/dist/cjs/graphql/queries/{published-shop-metas.js → published-shop-metas.generated.js} +2 -6
  86. package/dist/cjs/graphql/queries/published-theme-pages.generated.js +3 -19
  87. package/dist/cjs/graphql/queries/shop-shopify.generated.js +2 -6
  88. package/dist/cjs/graphql/queries/store-property.generated.js +2 -6
  89. package/dist/cjs/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +2 -6
  90. package/dist/cjs/graphql-app-api/queries/LibraryTemplate.generated.js +2 -6
  91. package/dist/cjs/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +2 -6
  92. package/dist/cjs/graphql-app-api/queries/SaleFunnelOffer.generated.js +2 -6
  93. package/dist/cjs/graphql-app-api/queries/ShopLibraryPage.generated.js +2 -6
  94. package/dist/cjs/graphql-app-api/queries/ThemePage.generated.js +2 -6
  95. package/dist/cjs/helpers/GlobalEvent.js +1 -19
  96. package/dist/cjs/helpers/align.js +1 -37
  97. package/dist/cjs/helpers/animations.js +1 -222
  98. package/dist/cjs/helpers/background.js +1 -236
  99. package/dist/cjs/helpers/backgroundImage.js +1 -0
  100. package/dist/cjs/helpers/borders.js +4 -198
  101. package/dist/cjs/helpers/carousel.js +1 -55
  102. package/dist/cjs/helpers/clone-deep.js +1 -5
  103. package/dist/cjs/helpers/cls.js +1 -16
  104. package/dist/cjs/helpers/colors.js +1 -184
  105. package/dist/cjs/helpers/compose-advance-style.js +1 -323
  106. package/dist/cjs/helpers/composeClasses.js +1 -0
  107. package/dist/cjs/helpers/const.js +1 -0
  108. package/dist/cjs/helpers/constant.js +1 -23
  109. package/dist/cjs/helpers/convert.js +1 -7
  110. package/dist/cjs/helpers/covert-entities-html.js +1 -19
  111. package/dist/cjs/helpers/css-variable.js +1 -7
  112. package/dist/cjs/helpers/email.js +1 -11
  113. package/dist/cjs/helpers/filter-styles.js +1 -0
  114. package/dist/cjs/helpers/filter-toolbar-preview.js +2 -14
  115. package/dist/cjs/helpers/flatten-connection.js +1 -9
  116. package/dist/cjs/helpers/get-resonsive-value.js +1 -36
  117. package/dist/cjs/helpers/get-shortname.js +1 -92
  118. package/dist/cjs/helpers/icon-list.js +1 -61
  119. package/dist/cjs/helpers/interaction/index.js +2 -134
  120. package/dist/cjs/helpers/is-browser.js +1 -9
  121. package/dist/cjs/helpers/is-defined.js +1 -7
  122. package/dist/cjs/helpers/is-empty-children.js +2 -15
  123. package/dist/cjs/helpers/is-safari.js +1 -9
  124. package/dist/cjs/helpers/layout.js +1 -76
  125. package/dist/cjs/helpers/load-script.js +1 -31
  126. package/dist/cjs/helpers/loop-component.js +1 -16
  127. package/dist/cjs/helpers/make-style.js +1 -163
  128. package/dist/cjs/helpers/normalize-builder-data.js +1 -23
  129. package/dist/cjs/helpers/pascal-to-kebab-case.js +1 -7
  130. package/dist/cjs/helpers/prefetch-queries.js +1 -78
  131. package/dist/cjs/helpers/product.js +1 -48
  132. package/dist/cjs/helpers/queries/get-collection.js +1 -226
  133. package/dist/cjs/helpers/queries/get-collections.js +1 -21
  134. package/dist/cjs/helpers/queries/get-product-by-slug.js +1 -125
  135. package/dist/cjs/helpers/queries/get-product.js +1 -154
  136. package/dist/cjs/helpers/queries/get-products.js +1 -214
  137. package/dist/cjs/helpers/query.js +1 -29
  138. package/dist/cjs/helpers/radius.js +6 -140
  139. package/dist/cjs/helpers/render.js +1 -91
  140. package/dist/cjs/helpers/shadow.js +1 -69
  141. package/dist/cjs/helpers/size.js +4 -228
  142. package/dist/cjs/helpers/spacing.js +1 -43
  143. package/dist/cjs/helpers/third-party/addAppBlockId.js +1 -20
  144. package/dist/cjs/helpers/third-party/appConfig.js +1 -416
  145. package/dist/cjs/helpers/third-party/appSetting.js +1 -1324
  146. package/dist/cjs/helpers/third-party/composeAppBlockId.js +1 -11
  147. package/dist/cjs/helpers/third-party/constant.js +1 -69
  148. package/dist/cjs/helpers/third-party/generateAppBlockConfigs.js +1 -34
  149. package/dist/cjs/helpers/third-party/getAppBlockConfig.js +1 -55
  150. package/dist/cjs/helpers/third-party/getAppBlockType.js +1 -12
  151. package/dist/cjs/helpers/third-party/getAppBlocks.js +1 -30
  152. package/dist/cjs/helpers/third-party/mergeBlock.js +1 -19
  153. package/dist/cjs/helpers/third-party/mergeBlockOrder.js +1 -47
  154. package/dist/cjs/helpers/third-party/removeGPAppItems.js +1 -18
  155. package/dist/cjs/helpers/tracking/fpixel.js +1 -28
  156. package/dist/cjs/helpers/tracking/gtag.js +1 -93
  157. package/dist/cjs/helpers/tracking/tiktokpixel.js +1 -17
  158. package/dist/cjs/helpers/typography.js +19 -160
  159. package/dist/cjs/helpers/variant.js +1 -11
  160. package/dist/cjs/hooks/animation/useAnimationActions.js +2 -39
  161. package/dist/cjs/hooks/animation/useAnimationConfig.js +2 -30
  162. package/dist/cjs/hooks/animation/useAnimationPreview.js +2 -31
  163. package/dist/cjs/hooks/animation/useAnimationTarget.js +2 -122
  164. package/dist/cjs/hooks/animation/useApplyAnimation.js +2 -89
  165. package/dist/cjs/hooks/articles/useArticlesQuery.js +2 -33
  166. package/dist/cjs/hooks/cart/use-add-to-cart.js +2 -20
  167. package/dist/cjs/hooks/cart/use-cart-data.js +2 -28
  168. package/dist/cjs/hooks/cart/use-cart-discount-codes-update.js +2 -20
  169. package/dist/cjs/hooks/cart/use-cart-note-update.js +2 -20
  170. package/dist/cjs/hooks/cart/use-create-cart.js +2 -22
  171. package/dist/cjs/hooks/cart/use-remove-cart-item.js +2 -20
  172. package/dist/cjs/hooks/cart/use-update-cart-item.js +2 -20
  173. package/dist/cjs/hooks/shop/use-collection-query.js +2 -22
  174. package/dist/cjs/hooks/shop/use-collections-query.js +2 -17
  175. package/dist/cjs/hooks/shop/use-product-query.js +2 -22
  176. package/dist/cjs/hooks/shop/use-products-query.js +2 -63
  177. package/dist/cjs/hooks/shop/useShopifyLink.js +2 -0
  178. package/dist/cjs/hooks/shop.js +2 -135
  179. package/dist/cjs/hooks/use-current-device.js +2 -30
  180. package/dist/cjs/hooks/use-lazy-video.js +2 -15
  181. package/dist/cjs/hooks/useAnimations.js +2 -29
  182. package/dist/cjs/hooks/useCartId.js +2 -44
  183. package/dist/cjs/hooks/useCartLine.js +2 -11
  184. package/dist/cjs/hooks/useCartUI.js +2 -48
  185. package/dist/cjs/hooks/useCollection.js +2 -9
  186. package/dist/cjs/hooks/useFetchHandle.js +2 -13
  187. package/dist/cjs/hooks/useFormatMoney.js +2 -75
  188. package/dist/cjs/hooks/useI18n.js +2 -0
  189. package/dist/cjs/hooks/useInitialSwatchesOptions.js +2 -127
  190. package/dist/cjs/hooks/useInteraction.js +2 -19
  191. package/dist/cjs/hooks/useIsomorphicLayoutEffect.js +2 -10
  192. package/dist/cjs/hooks/useLoadScript.js +2 -32
  193. package/dist/cjs/hooks/useMoney.js +2 -84
  194. package/dist/cjs/hooks/usePrevious.js +2 -19
  195. package/dist/cjs/hooks/useProduct.js +2 -250
  196. package/dist/cjs/hooks/useProductList.js +2 -21
  197. package/dist/cjs/hooks/useStickyStore.js +1 -0
  198. package/dist/cjs/hooks/useSuspenseFetch.js +2 -27
  199. package/dist/cjs/hooks/useSwatchesOptions.js +2 -41
  200. package/dist/cjs/hooks/useToolbarPostPurchase.js +2 -89
  201. package/dist/cjs/index.js +1 -425
  202. package/dist/cjs/types/animations.js +1 -49
  203. package/dist/cjs/types/appAPI.js +1 -2
  204. package/dist/cjs/types/custom.js +1 -52
  205. package/dist/cjs/types/global-style.js +1 -15
  206. package/dist/cjs/types/shop.js +1 -2
  207. package/dist/esm/components/AddOn.js +2 -14
  208. package/dist/esm/components/ComponentAnimation.js +2 -13
  209. package/dist/esm/components/ComponentToolbarPreview.js +2 -748
  210. package/dist/esm/components/ComponentWrapper.js +2 -57
  211. package/dist/esm/components/ComponentWrapperPreview.js +2 -209
  212. package/dist/esm/components/Empty.js +2 -3
  213. package/dist/esm/components/InteractionSuffix.js +2 -40
  214. package/dist/esm/components/Render.js +2 -71
  215. package/dist/esm/components/Render.liquid.js +16 -301
  216. package/dist/esm/components/RenderBlock.js +2 -50
  217. package/dist/esm/components/RenderCustomCode.js +4 -55
  218. package/dist/esm/components/RenderPreview.js +2 -63
  219. package/dist/esm/components/RenderSection.js +2 -19
  220. package/dist/esm/components/ai-generator/AIContentGenerator.js +2 -250
  221. package/dist/esm/components/ai-generator/AIGenContentLoading.js +2 -83
  222. package/dist/esm/components/ai-generator/components/PickProduct.js +2 -218
  223. package/dist/esm/components/ai-generator/components/ToneAndVoice.js +2 -75
  224. package/dist/esm/components/ai-generator/hooks/useCheckingProductInside.js +1 -45
  225. package/dist/esm/components/ai-generator/hooks/useFlipPopup.js +1 -108
  226. package/dist/esm/components/ai-generator/hooks/useGettingGenerateRequest.js +1 -35
  227. package/dist/esm/components/ai-generator/hooks/useListenEventGenerate.js +1 -68
  228. package/dist/esm/components/ai-generator/icons/AIIcon.js +2 -65
  229. package/dist/esm/components/ai-generator/icons/CloseIcon.js +2 -17
  230. package/dist/esm/components/ai-generator/icons/DropdownIcon.js +2 -34
  231. package/dist/esm/components/ai-generator/icons/SearchIcon.js +2 -19
  232. package/dist/esm/components/ai-generator/icons/ShowMoreIcon.js +2 -19
  233. package/dist/esm/components/ai-generator/icons/UpgradeIcon.js +2 -25
  234. package/dist/esm/components/ai-generator/icons/WarningIcon.js +2 -29
  235. package/dist/esm/components/constant.js +1 -75
  236. package/dist/esm/components/resize/Resize.js +2 -12
  237. package/dist/esm/components/resize/Spacing.js +2 -256
  238. package/dist/esm/components/src/product/helpers/variant-presets.js +1 -54
  239. package/dist/esm/components/theme-section/CreateThemeSection.js +2 -121
  240. package/dist/esm/components/theme-section/ThemeSectionStatus.js +2 -43
  241. package/dist/esm/components/theme-section/ThemeSectionTooltip.js +2 -124
  242. package/dist/esm/components/toolbar/Tooltip.js +2 -24
  243. package/dist/esm/constants/device.js +1 -0
  244. package/dist/esm/contexts/AddonContext.js +2 -32
  245. package/dist/esm/contexts/ArticleContext.js +2 -36
  246. package/dist/esm/contexts/ArticleListContext.js +2 -27
  247. package/dist/esm/contexts/BuilderComponent.js +2 -31
  248. package/dist/esm/contexts/BuilderContext.js +2 -36
  249. package/dist/esm/contexts/BuilderPreviewContext.js +2 -479
  250. package/dist/esm/contexts/CartLineContext.js +2 -26
  251. package/dist/esm/contexts/CollectionContext.js +2 -35
  252. package/dist/esm/contexts/I18nContext.js +2 -0
  253. package/dist/esm/contexts/ModalContext.js +2 -44
  254. package/dist/esm/contexts/PageContext.js +2 -108
  255. package/dist/esm/contexts/ProductContext.js +2 -179
  256. package/dist/esm/contexts/ProductListContext.js +2 -28
  257. package/dist/esm/contexts/SectionContext.js +2 -49
  258. package/dist/esm/contexts/ShopContext.js +2 -104
  259. package/dist/esm/graphql/fragments/analytic.generated.js +2 -4
  260. package/dist/esm/graphql/fragments/collection-detail.generated.js +2 -4
  261. package/dist/esm/graphql/fragments/collection-product.generated.js +2 -4
  262. package/dist/esm/graphql/fragments/collection.generated.js +2 -4
  263. package/dist/esm/graphql/fragments/custom-code.generated.js +2 -4
  264. package/dist/esm/graphql/fragments/custom-font.generated.js +7 -5
  265. package/dist/esm/graphql/fragments/data-seo.generated.js +2 -4
  266. package/dist/esm/graphql/fragments/media.generated.js +2 -4
  267. package/dist/esm/graphql/fragments/preview-theme-page.generated.js +6 -4
  268. package/dist/esm/graphql/fragments/product-little.generated.js +2 -4
  269. package/dist/esm/graphql/fragments/product-option-value.generated.js +2 -4
  270. package/dist/esm/graphql/fragments/product-option.generated.js +2 -4
  271. package/dist/esm/graphql/fragments/product.generated.js +2 -4
  272. package/dist/esm/graphql/fragments/published-custom-section.generated.js +2 -4
  273. package/dist/esm/graphql/fragments/published-page-section.generated.js +2 -4
  274. package/dist/esm/graphql/fragments/published-theme-page.generated.js +4 -16
  275. package/dist/esm/graphql/fragments/published-theme-style.generated.js +2 -4
  276. package/dist/esm/graphql/fragments/selected-option.generated.js +2 -4
  277. package/dist/esm/graphql/fragments/variant.generated.js +2 -4
  278. package/dist/esm/graphql/mutations/page-view-up.generated.js +2 -4
  279. package/dist/esm/graphql/queries/articles.generated.js +2 -4
  280. package/dist/esm/graphql/queries/blogs.generated.js +2 -4
  281. package/dist/esm/graphql/queries/collection-detail-filter.generated.js +10 -22
  282. package/dist/esm/graphql/queries/collection.generated.js +8 -18
  283. package/dist/esm/graphql/queries/collections.generated.js +3 -8
  284. package/dist/esm/graphql/queries/preview-page.generated.js +6 -14
  285. package/dist/esm/graphql/queries/product-little-detail.generated.js +5 -12
  286. package/dist/esm/graphql/queries/product-medias.generated.js +2 -6
  287. package/dist/esm/graphql/queries/product-value-label.generated.js +2 -4
  288. package/dist/esm/graphql/queries/product-variants.generated.js +5 -11
  289. package/dist/esm/graphql/queries/products.generated.js +9 -20
  290. package/dist/esm/graphql/queries/{published-shop-metas.js → published-shop-metas.generated.js} +2 -4
  291. package/dist/esm/graphql/queries/published-theme-pages.generated.js +6 -20
  292. package/dist/esm/graphql/queries/shop-shopify.generated.js +2 -4
  293. package/dist/esm/graphql/queries/store-property.generated.js +2 -4
  294. package/dist/esm/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +2 -4
  295. package/dist/esm/graphql-app-api/queries/LibraryTemplate.generated.js +2 -4
  296. package/dist/esm/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +2 -4
  297. package/dist/esm/graphql-app-api/queries/SaleFunnelOffer.generated.js +2 -4
  298. package/dist/esm/graphql-app-api/queries/ShopLibraryPage.generated.js +2 -4
  299. package/dist/esm/graphql-app-api/queries/ThemePage.generated.js +2 -4
  300. package/dist/esm/helpers/GlobalEvent.js +1 -15
  301. package/dist/esm/helpers/align.js +1 -34
  302. package/dist/esm/helpers/animations.js +1 -220
  303. package/dist/esm/helpers/background.js +1 -227
  304. package/dist/esm/helpers/backgroundImage.js +1 -0
  305. package/dist/esm/helpers/borders.js +4 -189
  306. package/dist/esm/helpers/carousel.js +1 -51
  307. package/dist/esm/helpers/clone-deep.js +1 -3
  308. package/dist/esm/helpers/cls.js +1 -14
  309. package/dist/esm/helpers/colors.js +1 -169
  310. package/dist/esm/helpers/compose-advance-style.js +1 -315
  311. package/dist/esm/helpers/composeClasses.js +1 -0
  312. package/dist/esm/helpers/const.js +1 -0
  313. package/dist/esm/helpers/constant.js +1 -19
  314. package/dist/esm/helpers/convert.js +1 -4
  315. package/dist/esm/helpers/covert-entities-html.js +1 -17
  316. package/dist/esm/helpers/css-variable.js +1 -5
  317. package/dist/esm/helpers/email.js +1 -6
  318. package/dist/esm/helpers/filter-styles.js +1 -0
  319. package/dist/esm/helpers/filter-toolbar-preview.js +2 -9
  320. package/dist/esm/helpers/flatten-connection.js +1 -7
  321. package/dist/esm/helpers/get-resonsive-value.js +1 -31
  322. package/dist/esm/helpers/get-shortname.js +1 -90
  323. package/dist/esm/helpers/icon-list.js +1 -58
  324. package/dist/esm/helpers/interaction/index.js +2 -132
  325. package/dist/esm/helpers/is-browser.js +1 -5
  326. package/dist/esm/helpers/is-defined.js +1 -5
  327. package/dist/esm/helpers/is-empty-children.js +2 -10
  328. package/dist/esm/helpers/is-safari.js +1 -5
  329. package/dist/esm/helpers/layout.js +1 -70
  330. package/dist/esm/helpers/load-script.js +1 -29
  331. package/dist/esm/helpers/loop-component.js +1 -14
  332. package/dist/esm/helpers/make-style.js +1 -149
  333. package/dist/esm/helpers/normalize-builder-data.js +1 -21
  334. package/dist/esm/helpers/pascal-to-kebab-case.js +1 -5
  335. package/dist/esm/helpers/prefetch-queries.js +1 -76
  336. package/dist/esm/helpers/product.js +1 -44
  337. package/dist/esm/helpers/queries/get-collection.js +1 -223
  338. package/dist/esm/helpers/queries/get-collections.js +1 -19
  339. package/dist/esm/helpers/queries/get-product-by-slug.js +1 -123
  340. package/dist/esm/helpers/queries/get-product.js +1 -150
  341. package/dist/esm/helpers/queries/get-products.js +1 -210
  342. package/dist/esm/helpers/query.js +1 -25
  343. package/dist/esm/helpers/radius.js +6 -132
  344. package/dist/esm/helpers/render.js +1 -82
  345. package/dist/esm/helpers/shadow.js +1 -63
  346. package/dist/esm/helpers/size.js +4 -213
  347. package/dist/esm/helpers/spacing.js +1 -40
  348. package/dist/esm/helpers/third-party/addAppBlockId.js +1 -18
  349. package/dist/esm/helpers/third-party/appConfig.js +1 -356
  350. package/dist/esm/helpers/third-party/appSetting.js +1 -1321
  351. package/dist/esm/helpers/third-party/composeAppBlockId.js +1 -9
  352. package/dist/esm/helpers/third-party/constant.js +1 -66
  353. package/dist/esm/helpers/third-party/generateAppBlockConfigs.js +1 -32
  354. package/dist/esm/helpers/third-party/getAppBlockConfig.js +1 -53
  355. package/dist/esm/helpers/third-party/getAppBlockType.js +1 -10
  356. package/dist/esm/helpers/third-party/getAppBlocks.js +1 -28
  357. package/dist/esm/helpers/third-party/mergeBlock.js +1 -17
  358. package/dist/esm/helpers/third-party/mergeBlockOrder.js +1 -45
  359. package/dist/esm/helpers/third-party/removeGPAppItems.js +1 -15
  360. package/dist/esm/helpers/tracking/fpixel.js +1 -24
  361. package/dist/esm/helpers/tracking/gtag.js +1 -87
  362. package/dist/esm/helpers/tracking/tiktokpixel.js +1 -15
  363. package/dist/esm/helpers/typography.js +19 -149
  364. package/dist/esm/helpers/variant.js +1 -9
  365. package/dist/esm/hooks/animation/useAnimationActions.js +2 -37
  366. package/dist/esm/hooks/animation/useAnimationConfig.js +2 -28
  367. package/dist/esm/hooks/animation/useAnimationPreview.js +2 -29
  368. package/dist/esm/hooks/animation/useAnimationTarget.js +2 -120
  369. package/dist/esm/hooks/animation/useApplyAnimation.js +2 -85
  370. package/dist/esm/hooks/articles/useArticlesQuery.js +2 -30
  371. package/dist/esm/hooks/cart/use-add-to-cart.js +2 -18
  372. package/dist/esm/hooks/cart/use-cart-data.js +2 -26
  373. package/dist/esm/hooks/cart/use-cart-discount-codes-update.js +2 -18
  374. package/dist/esm/hooks/cart/use-cart-note-update.js +2 -18
  375. package/dist/esm/hooks/cart/use-create-cart.js +2 -20
  376. package/dist/esm/hooks/cart/use-remove-cart-item.js +2 -18
  377. package/dist/esm/hooks/cart/use-update-cart-item.js +2 -18
  378. package/dist/esm/hooks/shop/use-collection-query.js +2 -20
  379. package/dist/esm/hooks/shop/use-collections-query.js +2 -15
  380. package/dist/esm/hooks/shop/use-product-query.js +2 -20
  381. package/dist/esm/hooks/shop/use-products-query.js +2 -59
  382. package/dist/esm/hooks/shop/useShopifyLink.js +2 -0
  383. package/dist/esm/hooks/shop.js +2 -119
  384. package/dist/esm/hooks/use-current-device.js +2 -28
  385. package/dist/esm/hooks/use-lazy-video.js +2 -13
  386. package/dist/esm/hooks/useAnimations.js +2 -27
  387. package/dist/esm/hooks/useCartId.js +2 -40
  388. package/dist/esm/hooks/useCartLine.js +2 -7
  389. package/dist/esm/hooks/useCartUI.js +2 -44
  390. package/dist/esm/hooks/useCollection.js +2 -7
  391. package/dist/esm/hooks/useFetchHandle.js +2 -11
  392. package/dist/esm/hooks/useFormatMoney.js +2 -71
  393. package/dist/esm/hooks/useI18n.js +2 -0
  394. package/dist/esm/hooks/useInitialSwatchesOptions.js +2 -123
  395. package/dist/esm/hooks/useInteraction.js +2 -17
  396. package/dist/esm/hooks/useIsomorphicLayoutEffect.js +2 -6
  397. package/dist/esm/hooks/useLoadScript.js +2 -28
  398. package/dist/esm/hooks/useMoney.js +2 -80
  399. package/dist/esm/hooks/usePrevious.js +2 -17
  400. package/dist/esm/hooks/useProduct.js +2 -233
  401. package/dist/esm/hooks/useProductList.js +2 -16
  402. package/dist/esm/hooks/useStickyStore.js +1 -0
  403. package/dist/esm/hooks/useSuspenseFetch.js +2 -23
  404. package/dist/esm/hooks/useSwatchesOptions.js +2 -37
  405. package/dist/esm/hooks/useToolbarPostPurchase.js +2 -87
  406. package/dist/esm/index.js +1 -119
  407. package/dist/esm/types/animations.js +1 -49
  408. package/dist/esm/types/custom.js +1 -52
  409. package/dist/esm/types/global-style.js +1 -12
  410. package/dist/types/index.d.ts +12025 -8969
  411. package/package.json +6 -6
  412. package/dist/cjs/web-components/src/helpers/styles/constant.js +0 -9
  413. package/dist/esm/web-components/src/helpers/styles/constant.js +0 -7
@@ -1,220 +1 @@
1
- const EASING = {
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 { devicesMapping } from './constant.js';
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};