@gem-sdk/core 3.0.0-pre-production.14 → 3.0.0

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