@gem-sdk/core 2.0.0-dev.896 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (396) hide show
  1. package/dist/cjs/components/AddOn.js +18 -1
  2. package/dist/cjs/components/ComponentAnimation.js +17 -0
  3. package/dist/cjs/components/ComponentToolbarPreview.js +752 -1
  4. package/dist/cjs/components/ComponentWrapper.js +61 -1
  5. package/dist/cjs/components/ComponentWrapperPreview.js +213 -1
  6. package/dist/cjs/components/Empty.js +7 -1
  7. package/dist/cjs/components/InteractionSuffix.js +42 -0
  8. package/dist/cjs/components/Render.js +75 -1
  9. package/dist/cjs/components/Render.liquid.js +313 -17
  10. package/dist/cjs/components/RenderBlock.js +54 -1
  11. package/dist/cjs/components/RenderCustomCode.js +59 -3
  12. package/dist/cjs/components/RenderPreview.js +67 -1
  13. package/dist/cjs/components/RenderSection.js +23 -1
  14. package/dist/cjs/components/ai-generator/AIContentGenerator.js +252 -1
  15. package/dist/cjs/components/ai-generator/AIGenContentLoading.js +85 -1
  16. package/dist/cjs/components/ai-generator/components/PickProduct.js +220 -1
  17. package/dist/cjs/components/ai-generator/components/ToneAndVoice.js +77 -1
  18. package/dist/cjs/components/ai-generator/hooks/useCheckingProductInside.js +47 -0
  19. package/dist/cjs/components/ai-generator/hooks/useFlipPopup.js +110 -0
  20. package/dist/cjs/components/ai-generator/hooks/useGettingGenerateRequest.js +37 -1
  21. package/dist/cjs/components/ai-generator/hooks/useListenEventGenerate.js +70 -1
  22. package/dist/cjs/components/ai-generator/icons/AIIcon.js +67 -1
  23. package/dist/cjs/components/ai-generator/icons/CloseIcon.js +19 -1
  24. package/dist/cjs/components/ai-generator/icons/DropdownIcon.js +37 -1
  25. package/dist/cjs/components/ai-generator/icons/SearchIcon.js +21 -1
  26. package/dist/cjs/components/ai-generator/icons/ShowMoreIcon.js +21 -1
  27. package/dist/cjs/components/ai-generator/icons/UpgradeIcon.js +27 -0
  28. package/dist/cjs/components/ai-generator/icons/WarningIcon.js +31 -0
  29. package/dist/cjs/components/constant.js +83 -1
  30. package/dist/cjs/components/resize/Resize.js +16 -1
  31. package/dist/cjs/components/resize/Spacing.js +260 -1
  32. package/dist/cjs/components/src/product/helpers/variant-presets.js +56 -1
  33. package/dist/cjs/components/theme-section/CreateThemeSection.js +123 -1
  34. package/dist/cjs/components/theme-section/ThemeSectionStatus.js +45 -1
  35. package/dist/cjs/components/theme-section/ThemeSectionTooltip.js +126 -1
  36. package/dist/cjs/components/toolbar/Tooltip.js +28 -1
  37. package/dist/cjs/contexts/AddonContext.js +36 -1
  38. package/dist/cjs/contexts/ArticleContext.js +39 -1
  39. package/dist/cjs/contexts/ArticleListContext.js +31 -1
  40. package/dist/cjs/contexts/BuilderComponent.js +34 -1
  41. package/dist/cjs/contexts/BuilderContext.js +39 -1
  42. package/dist/cjs/contexts/BuilderPreviewContext.js +486 -1
  43. package/dist/cjs/contexts/CartLineContext.js +29 -1
  44. package/dist/cjs/contexts/CollectionContext.js +38 -1
  45. package/dist/cjs/contexts/ModalContext.js +47 -1
  46. package/dist/cjs/contexts/PageContext.js +104 -1
  47. package/dist/cjs/contexts/ProductContext.js +177 -1
  48. package/dist/cjs/contexts/ProductListContext.js +32 -1
  49. package/dist/cjs/contexts/SectionContext.js +53 -1
  50. package/dist/cjs/contexts/ShopContext.js +107 -1
  51. package/dist/cjs/graphql/fragments/analytic.generated.js +6 -2
  52. package/dist/cjs/graphql/fragments/collection-detail.generated.js +6 -2
  53. package/dist/cjs/graphql/fragments/collection-product.generated.js +6 -2
  54. package/dist/cjs/graphql/fragments/collection.generated.js +6 -2
  55. package/dist/cjs/graphql/fragments/custom-code.generated.js +6 -2
  56. package/dist/cjs/graphql/fragments/custom-font.generated.js +6 -2
  57. package/dist/cjs/graphql/fragments/data-seo.generated.js +6 -2
  58. package/dist/cjs/graphql/fragments/media.generated.js +6 -2
  59. package/dist/cjs/graphql/fragments/preview-theme-page.generated.js +39 -0
  60. package/dist/cjs/graphql/fragments/product-little.generated.js +7 -2
  61. package/dist/cjs/graphql/fragments/product-option-value.generated.js +6 -2
  62. package/dist/cjs/graphql/fragments/product-option.generated.js +6 -2
  63. package/dist/cjs/graphql/fragments/product.generated.js +6 -2
  64. package/dist/cjs/graphql/fragments/published-custom-section.generated.js +6 -2
  65. package/dist/cjs/graphql/fragments/published-page-section.generated.js +6 -2
  66. package/dist/cjs/graphql/fragments/published-theme-page.generated.js +10 -28
  67. package/dist/cjs/graphql/fragments/published-theme-style.generated.js +6 -2
  68. package/dist/cjs/graphql/fragments/selected-option.generated.js +6 -2
  69. package/dist/cjs/graphql/fragments/variant.generated.js +6 -2
  70. package/dist/cjs/graphql/mutations/page-view-up.generated.js +8 -4
  71. package/dist/cjs/graphql/queries/articles.generated.js +61 -0
  72. package/dist/cjs/graphql/queries/blogs.generated.js +69 -0
  73. package/dist/cjs/graphql/queries/collection-detail-filter.generated.js +16 -2
  74. package/dist/cjs/graphql/queries/collection.generated.js +14 -2
  75. package/dist/cjs/graphql/queries/collections.generated.js +9 -2
  76. package/dist/cjs/graphql/queries/preview-page.generated.js +16 -8
  77. package/dist/cjs/graphql/queries/product-little-detail.generated.js +11 -2
  78. package/dist/cjs/graphql/queries/product-medias.generated.js +8 -2
  79. package/dist/cjs/graphql/queries/product-value-label.generated.js +6 -2
  80. package/dist/cjs/graphql/queries/product-variants.generated.js +10 -2
  81. package/dist/cjs/graphql/queries/products.generated.js +17 -3
  82. package/dist/cjs/graphql/queries/published-shop-metas.js +15 -0
  83. package/dist/cjs/graphql/queries/published-theme-pages.generated.js +15 -2
  84. package/dist/cjs/graphql/queries/store-property.generated.js +6 -2
  85. package/dist/cjs/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +6 -2
  86. package/dist/cjs/graphql-app-api/queries/LibraryTemplate.generated.js +6 -2
  87. package/dist/cjs/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +6 -2
  88. package/dist/cjs/graphql-app-api/queries/ShopLibraryPage.generated.js +17 -0
  89. package/dist/cjs/graphql-app-api/queries/ThemePage.generated.js +6 -2
  90. package/dist/cjs/helpers/GlobalEvent.js +19 -1
  91. package/dist/cjs/helpers/align.js +19 -0
  92. package/dist/cjs/helpers/animations.js +222 -1
  93. package/dist/cjs/helpers/background.js +235 -1
  94. package/dist/cjs/helpers/borders.js +198 -4
  95. package/dist/cjs/helpers/carousel.js +55 -1
  96. package/dist/cjs/helpers/clone-deep.js +5 -1
  97. package/dist/cjs/helpers/cls.js +16 -1
  98. package/dist/cjs/helpers/colors.js +184 -1
  99. package/dist/cjs/helpers/compose-advance-style.js +327 -1
  100. package/dist/cjs/helpers/constant.js +23 -1
  101. package/dist/cjs/helpers/convert.js +7 -1
  102. package/dist/cjs/helpers/covert-entities-html.js +19 -1
  103. package/dist/cjs/helpers/css-variable.js +7 -1
  104. package/dist/cjs/helpers/email.js +11 -1
  105. package/dist/cjs/helpers/filter-toolbar-preview.js +14 -1
  106. package/dist/cjs/helpers/flatten-connection.js +9 -1
  107. package/dist/cjs/helpers/get-resonsive-value.js +36 -1
  108. package/dist/cjs/helpers/get-shortname.js +92 -1
  109. package/dist/cjs/helpers/icon-list.js +61 -1
  110. package/dist/cjs/helpers/interaction/index.js +134 -0
  111. package/dist/cjs/helpers/is-browser.js +9 -1
  112. package/dist/cjs/helpers/is-defined.js +7 -1
  113. package/dist/cjs/helpers/is-empty-children.js +15 -1
  114. package/dist/cjs/helpers/is-safari.js +9 -1
  115. package/dist/cjs/helpers/layout.js +59 -1
  116. package/dist/cjs/helpers/load-script.js +31 -1
  117. package/dist/cjs/helpers/loop-component.js +16 -0
  118. package/dist/cjs/helpers/make-style.js +163 -1
  119. package/dist/cjs/helpers/normalize-builder-data.js +23 -1
  120. package/dist/cjs/helpers/pascal-to-kebab-case.js +7 -0
  121. package/dist/cjs/helpers/prefetch-queries.js +78 -1
  122. package/dist/cjs/helpers/product.js +48 -1
  123. package/dist/cjs/helpers/queries/get-collection.js +226 -1
  124. package/dist/cjs/helpers/queries/get-collections.js +21 -1
  125. package/dist/cjs/helpers/queries/get-product-by-slug.js +125 -1
  126. package/dist/cjs/helpers/queries/get-product.js +154 -1
  127. package/dist/cjs/helpers/queries/get-products.js +214 -1
  128. package/dist/cjs/helpers/query.js +29 -1
  129. package/dist/cjs/helpers/radius.js +140 -6
  130. package/dist/cjs/helpers/render.js +78 -1
  131. package/dist/cjs/helpers/shadow.js +69 -1
  132. package/dist/cjs/helpers/size.js +206 -4
  133. package/dist/cjs/helpers/spacing.js +43 -1
  134. package/dist/cjs/helpers/third-party/addAppBlockId.js +20 -0
  135. package/dist/cjs/helpers/third-party/appConfig.js +234 -0
  136. package/dist/cjs/helpers/third-party/appSetting.js +661 -0
  137. package/dist/cjs/helpers/third-party/composeAppBlockId.js +11 -0
  138. package/dist/cjs/helpers/third-party/constant.js +43 -0
  139. package/dist/cjs/helpers/third-party/generateAppBlockConfigs.js +34 -0
  140. package/dist/cjs/helpers/third-party/getAppBlockConfig.js +47 -0
  141. package/dist/cjs/helpers/third-party/getAppBlockType.js +12 -0
  142. package/dist/cjs/helpers/third-party/getAppBlocks.js +30 -0
  143. package/dist/cjs/helpers/third-party/mergeBlock.js +19 -0
  144. package/dist/cjs/helpers/third-party/mergeBlockOrder.js +47 -0
  145. package/dist/cjs/helpers/third-party/removeGPAppItems.js +18 -0
  146. package/dist/cjs/helpers/tracking/fpixel.js +28 -1
  147. package/dist/cjs/helpers/tracking/gtag.js +93 -1
  148. package/dist/cjs/helpers/tracking/tiktokpixel.js +17 -1
  149. package/dist/cjs/helpers/typography.js +160 -17
  150. package/dist/cjs/helpers/variant.js +11 -1
  151. package/dist/cjs/hooks/animation/useAnimationActions.js +39 -1
  152. package/dist/cjs/hooks/animation/useAnimationConfig.js +30 -1
  153. package/dist/cjs/hooks/animation/useAnimationPreview.js +31 -1
  154. package/dist/cjs/hooks/animation/useAnimationTarget.js +122 -1
  155. package/dist/cjs/hooks/animation/useApplyAnimation.js +89 -1
  156. package/dist/cjs/hooks/articles/useArticlesQuery.js +33 -1
  157. package/dist/cjs/hooks/cart/use-add-to-cart.js +20 -1
  158. package/dist/cjs/hooks/cart/use-cart-data.js +28 -1
  159. package/dist/cjs/hooks/cart/use-cart-discount-codes-update.js +20 -1
  160. package/dist/cjs/hooks/cart/use-cart-note-update.js +20 -1
  161. package/dist/cjs/hooks/cart/use-create-cart.js +22 -1
  162. package/dist/cjs/hooks/cart/use-remove-cart-item.js +20 -1
  163. package/dist/cjs/hooks/cart/use-update-cart-item.js +20 -1
  164. package/dist/cjs/hooks/shop/use-collection-query.js +22 -1
  165. package/dist/cjs/hooks/shop/use-collections-query.js +17 -1
  166. package/dist/cjs/hooks/shop/use-product-query.js +22 -1
  167. package/dist/cjs/hooks/shop/use-products-query.js +63 -1
  168. package/dist/cjs/hooks/shop.js +126 -1
  169. package/dist/cjs/hooks/use-current-device.js +30 -1
  170. package/dist/cjs/hooks/use-lazy-video.js +15 -1
  171. package/dist/cjs/hooks/useAnimations.js +29 -1
  172. package/dist/cjs/hooks/useCartId.js +44 -1
  173. package/dist/cjs/hooks/useCartLine.js +11 -1
  174. package/dist/cjs/hooks/useCartUI.js +48 -1
  175. package/dist/cjs/hooks/useCollection.js +9 -1
  176. package/dist/cjs/hooks/useFetchHandle.js +13 -1
  177. package/dist/cjs/hooks/useFormatMoney.js +75 -1
  178. package/dist/cjs/hooks/useInitialSwatchesOptions.js +128 -1
  179. package/dist/cjs/hooks/useInteraction.js +19 -0
  180. package/dist/cjs/hooks/useIsomorphicLayoutEffect.js +10 -1
  181. package/dist/cjs/hooks/useLoadScript.js +32 -1
  182. package/dist/cjs/hooks/useMoney.js +84 -1
  183. package/dist/cjs/hooks/usePrevious.js +19 -1
  184. package/dist/cjs/hooks/useProduct.js +245 -1
  185. package/dist/cjs/hooks/useProductList.js +21 -1
  186. package/dist/cjs/hooks/useSuspenseFetch.js +27 -1
  187. package/dist/cjs/hooks/useSwatchesOptions.js +41 -1
  188. package/dist/cjs/hooks/useToolbarPostPurchase.js +89 -1
  189. package/dist/cjs/index.js +416 -1
  190. package/dist/cjs/types/animations.js +49 -1
  191. package/dist/cjs/types/appAPI.js +2 -1
  192. package/dist/cjs/types/custom.js +52 -0
  193. package/dist/cjs/types/global-style.js +15 -1
  194. package/dist/cjs/types/shop.js +2 -1
  195. package/dist/cjs/web-components/src/helpers/styles/constant.js +9 -1
  196. package/dist/esm/components/AddOn.js +14 -1
  197. package/dist/esm/components/ComponentAnimation.js +13 -0
  198. package/dist/esm/components/ComponentToolbarPreview.js +748 -1
  199. package/dist/esm/components/ComponentWrapper.js +57 -1
  200. package/dist/esm/components/ComponentWrapperPreview.js +209 -1
  201. package/dist/esm/components/Empty.js +3 -1
  202. package/dist/esm/components/InteractionSuffix.js +40 -0
  203. package/dist/esm/components/Render.js +71 -1
  204. package/dist/esm/components/Render.liquid.js +307 -17
  205. package/dist/esm/components/RenderBlock.js +50 -1
  206. package/dist/esm/components/RenderCustomCode.js +55 -3
  207. package/dist/esm/components/RenderPreview.js +63 -1
  208. package/dist/esm/components/RenderSection.js +19 -1
  209. package/dist/esm/components/ai-generator/AIContentGenerator.js +250 -1
  210. package/dist/esm/components/ai-generator/AIGenContentLoading.js +83 -1
  211. package/dist/esm/components/ai-generator/components/PickProduct.js +218 -1
  212. package/dist/esm/components/ai-generator/components/ToneAndVoice.js +75 -1
  213. package/dist/esm/components/ai-generator/hooks/useCheckingProductInside.js +45 -0
  214. package/dist/esm/components/ai-generator/hooks/useFlipPopup.js +108 -0
  215. package/dist/esm/components/ai-generator/hooks/useGettingGenerateRequest.js +35 -1
  216. package/dist/esm/components/ai-generator/hooks/useListenEventGenerate.js +68 -1
  217. package/dist/esm/components/ai-generator/icons/AIIcon.js +65 -1
  218. package/dist/esm/components/ai-generator/icons/CloseIcon.js +17 -1
  219. package/dist/esm/components/ai-generator/icons/DropdownIcon.js +34 -1
  220. package/dist/esm/components/ai-generator/icons/SearchIcon.js +19 -1
  221. package/dist/esm/components/ai-generator/icons/ShowMoreIcon.js +19 -1
  222. package/dist/esm/components/ai-generator/icons/UpgradeIcon.js +25 -0
  223. package/dist/esm/components/ai-generator/icons/WarningIcon.js +29 -0
  224. package/dist/esm/components/constant.js +76 -1
  225. package/dist/esm/components/resize/Resize.js +12 -1
  226. package/dist/esm/components/resize/Spacing.js +256 -1
  227. package/dist/esm/components/src/product/helpers/variant-presets.js +54 -1
  228. package/dist/esm/components/theme-section/CreateThemeSection.js +121 -1
  229. package/dist/esm/components/theme-section/ThemeSectionStatus.js +43 -1
  230. package/dist/esm/components/theme-section/ThemeSectionTooltip.js +124 -1
  231. package/dist/esm/components/toolbar/Tooltip.js +24 -1
  232. package/dist/esm/contexts/AddonContext.js +32 -1
  233. package/dist/esm/contexts/ArticleContext.js +36 -1
  234. package/dist/esm/contexts/ArticleListContext.js +27 -1
  235. package/dist/esm/contexts/BuilderComponent.js +31 -1
  236. package/dist/esm/contexts/BuilderContext.js +36 -1
  237. package/dist/esm/contexts/BuilderPreviewContext.js +483 -1
  238. package/dist/esm/contexts/CartLineContext.js +26 -1
  239. package/dist/esm/contexts/CollectionContext.js +35 -1
  240. package/dist/esm/contexts/ModalContext.js +44 -1
  241. package/dist/esm/contexts/PageContext.js +101 -1
  242. package/dist/esm/contexts/ProductContext.js +174 -1
  243. package/dist/esm/contexts/ProductListContext.js +28 -1
  244. package/dist/esm/contexts/SectionContext.js +49 -1
  245. package/dist/esm/contexts/ShopContext.js +104 -1
  246. package/dist/esm/graphql/fragments/analytic.generated.js +4 -2
  247. package/dist/esm/graphql/fragments/collection-detail.generated.js +4 -2
  248. package/dist/esm/graphql/fragments/collection-product.generated.js +4 -2
  249. package/dist/esm/graphql/fragments/collection.generated.js +4 -2
  250. package/dist/esm/graphql/fragments/custom-code.generated.js +4 -2
  251. package/dist/esm/graphql/fragments/custom-font.generated.js +4 -2
  252. package/dist/esm/graphql/fragments/data-seo.generated.js +4 -2
  253. package/dist/esm/graphql/fragments/media.generated.js +4 -2
  254. package/dist/esm/graphql/fragments/preview-theme-page.generated.js +37 -0
  255. package/dist/esm/graphql/fragments/product-little.generated.js +5 -2
  256. package/dist/esm/graphql/fragments/product-option-value.generated.js +4 -2
  257. package/dist/esm/graphql/fragments/product-option.generated.js +4 -2
  258. package/dist/esm/graphql/fragments/product.generated.js +4 -2
  259. package/dist/esm/graphql/fragments/published-custom-section.generated.js +4 -2
  260. package/dist/esm/graphql/fragments/published-page-section.generated.js +4 -2
  261. package/dist/esm/graphql/fragments/published-theme-page.generated.js +8 -28
  262. package/dist/esm/graphql/fragments/published-theme-style.generated.js +4 -2
  263. package/dist/esm/graphql/fragments/selected-option.generated.js +4 -2
  264. package/dist/esm/graphql/fragments/variant.generated.js +4 -2
  265. package/dist/esm/graphql/mutations/page-view-up.generated.js +6 -4
  266. package/dist/esm/graphql/queries/articles.generated.js +59 -0
  267. package/dist/esm/graphql/queries/blogs.generated.js +67 -0
  268. package/dist/esm/graphql/queries/collection-detail-filter.generated.js +22 -10
  269. package/dist/esm/graphql/queries/collection.generated.js +18 -8
  270. package/dist/esm/graphql/queries/collections.generated.js +8 -3
  271. package/dist/esm/graphql/queries/preview-page.generated.js +16 -10
  272. package/dist/esm/graphql/queries/product-little-detail.generated.js +12 -5
  273. package/dist/esm/graphql/queries/product-medias.generated.js +6 -2
  274. package/dist/esm/graphql/queries/product-value-label.generated.js +4 -2
  275. package/dist/esm/graphql/queries/product-variants.generated.js +10 -4
  276. package/dist/esm/graphql/queries/products.generated.js +20 -9
  277. package/dist/esm/graphql/queries/published-shop-metas.js +13 -0
  278. package/dist/esm/graphql/queries/published-theme-pages.generated.js +20 -9
  279. package/dist/esm/graphql/queries/store-property.generated.js +4 -2
  280. package/dist/esm/graphql-app-api/queries/LibrarySaleFunnelDiscount.generated.js +4 -2
  281. package/dist/esm/graphql-app-api/queries/LibraryTemplate.generated.js +4 -2
  282. package/dist/esm/graphql-app-api/queries/SaleFunnelDiscounts.generated.js +4 -2
  283. package/dist/esm/graphql-app-api/queries/ShopLibraryPage.generated.js +15 -0
  284. package/dist/esm/graphql-app-api/queries/ThemePage.generated.js +4 -2
  285. package/dist/esm/helpers/GlobalEvent.js +15 -1
  286. package/dist/esm/helpers/align.js +17 -0
  287. package/dist/esm/helpers/animations.js +220 -1
  288. package/dist/esm/helpers/background.js +226 -1
  289. package/dist/esm/helpers/borders.js +189 -4
  290. package/dist/esm/helpers/carousel.js +51 -1
  291. package/dist/esm/helpers/clone-deep.js +3 -1
  292. package/dist/esm/helpers/cls.js +14 -1
  293. package/dist/esm/helpers/colors.js +169 -1
  294. package/dist/esm/helpers/compose-advance-style.js +319 -1
  295. package/dist/esm/helpers/constant.js +19 -1
  296. package/dist/esm/helpers/convert.js +4 -1
  297. package/dist/esm/helpers/covert-entities-html.js +17 -1
  298. package/dist/esm/helpers/css-variable.js +5 -1
  299. package/dist/esm/helpers/email.js +6 -1
  300. package/dist/esm/helpers/filter-toolbar-preview.js +9 -1
  301. package/dist/esm/helpers/flatten-connection.js +7 -1
  302. package/dist/esm/helpers/get-resonsive-value.js +31 -1
  303. package/dist/esm/helpers/get-shortname.js +90 -1
  304. package/dist/esm/helpers/icon-list.js +58 -1
  305. package/dist/esm/helpers/interaction/index.js +132 -0
  306. package/dist/esm/helpers/is-browser.js +5 -1
  307. package/dist/esm/helpers/is-defined.js +5 -1
  308. package/dist/esm/helpers/is-empty-children.js +10 -1
  309. package/dist/esm/helpers/is-safari.js +5 -1
  310. package/dist/esm/helpers/layout.js +54 -1
  311. package/dist/esm/helpers/load-script.js +29 -1
  312. package/dist/esm/helpers/loop-component.js +14 -0
  313. package/dist/esm/helpers/make-style.js +149 -1
  314. package/dist/esm/helpers/normalize-builder-data.js +21 -1
  315. package/dist/esm/helpers/pascal-to-kebab-case.js +5 -0
  316. package/dist/esm/helpers/prefetch-queries.js +76 -1
  317. package/dist/esm/helpers/product.js +44 -1
  318. package/dist/esm/helpers/queries/get-collection.js +223 -1
  319. package/dist/esm/helpers/queries/get-collections.js +19 -1
  320. package/dist/esm/helpers/queries/get-product-by-slug.js +123 -1
  321. package/dist/esm/helpers/queries/get-product.js +150 -1
  322. package/dist/esm/helpers/queries/get-products.js +210 -1
  323. package/dist/esm/helpers/query.js +25 -1
  324. package/dist/esm/helpers/radius.js +132 -6
  325. package/dist/esm/helpers/render.js +70 -1
  326. package/dist/esm/helpers/shadow.js +63 -1
  327. package/dist/esm/helpers/size.js +192 -4
  328. package/dist/esm/helpers/spacing.js +40 -1
  329. package/dist/esm/helpers/third-party/addAppBlockId.js +18 -0
  330. package/dist/esm/helpers/third-party/appConfig.js +200 -0
  331. package/dist/esm/helpers/third-party/appSetting.js +658 -0
  332. package/dist/esm/helpers/third-party/composeAppBlockId.js +9 -0
  333. package/dist/esm/helpers/third-party/constant.js +40 -0
  334. package/dist/esm/helpers/third-party/generateAppBlockConfigs.js +32 -0
  335. package/dist/esm/helpers/third-party/getAppBlockConfig.js +45 -0
  336. package/dist/esm/helpers/third-party/getAppBlockType.js +10 -0
  337. package/dist/esm/helpers/third-party/getAppBlocks.js +28 -0
  338. package/dist/esm/helpers/third-party/mergeBlock.js +17 -0
  339. package/dist/esm/helpers/third-party/mergeBlockOrder.js +45 -0
  340. package/dist/esm/helpers/third-party/removeGPAppItems.js +15 -0
  341. package/dist/esm/helpers/tracking/fpixel.js +24 -1
  342. package/dist/esm/helpers/tracking/gtag.js +87 -1
  343. package/dist/esm/helpers/tracking/tiktokpixel.js +15 -1
  344. package/dist/esm/helpers/typography.js +149 -17
  345. package/dist/esm/helpers/variant.js +9 -1
  346. package/dist/esm/hooks/animation/useAnimationActions.js +37 -1
  347. package/dist/esm/hooks/animation/useAnimationConfig.js +28 -1
  348. package/dist/esm/hooks/animation/useAnimationPreview.js +29 -1
  349. package/dist/esm/hooks/animation/useAnimationTarget.js +120 -1
  350. package/dist/esm/hooks/animation/useApplyAnimation.js +85 -1
  351. package/dist/esm/hooks/articles/useArticlesQuery.js +30 -1
  352. package/dist/esm/hooks/cart/use-add-to-cart.js +18 -1
  353. package/dist/esm/hooks/cart/use-cart-data.js +26 -1
  354. package/dist/esm/hooks/cart/use-cart-discount-codes-update.js +18 -1
  355. package/dist/esm/hooks/cart/use-cart-note-update.js +18 -1
  356. package/dist/esm/hooks/cart/use-create-cart.js +20 -1
  357. package/dist/esm/hooks/cart/use-remove-cart-item.js +18 -1
  358. package/dist/esm/hooks/cart/use-update-cart-item.js +18 -1
  359. package/dist/esm/hooks/shop/use-collection-query.js +20 -1
  360. package/dist/esm/hooks/shop/use-collections-query.js +15 -1
  361. package/dist/esm/hooks/shop/use-product-query.js +20 -1
  362. package/dist/esm/hooks/shop/use-products-query.js +59 -1
  363. package/dist/esm/hooks/shop.js +111 -1
  364. package/dist/esm/hooks/use-current-device.js +28 -1
  365. package/dist/esm/hooks/use-lazy-video.js +13 -1
  366. package/dist/esm/hooks/useAnimations.js +27 -1
  367. package/dist/esm/hooks/useCartId.js +40 -1
  368. package/dist/esm/hooks/useCartLine.js +7 -1
  369. package/dist/esm/hooks/useCartUI.js +44 -1
  370. package/dist/esm/hooks/useCollection.js +7 -1
  371. package/dist/esm/hooks/useFetchHandle.js +11 -1
  372. package/dist/esm/hooks/useFormatMoney.js +71 -1
  373. package/dist/esm/hooks/useInitialSwatchesOptions.js +124 -1
  374. package/dist/esm/hooks/useInteraction.js +17 -0
  375. package/dist/esm/hooks/useIsomorphicLayoutEffect.js +6 -1
  376. package/dist/esm/hooks/useLoadScript.js +28 -1
  377. package/dist/esm/hooks/useMoney.js +80 -1
  378. package/dist/esm/hooks/usePrevious.js +17 -1
  379. package/dist/esm/hooks/useProduct.js +228 -1
  380. package/dist/esm/hooks/useProductList.js +16 -1
  381. package/dist/esm/hooks/useSuspenseFetch.js +23 -1
  382. package/dist/esm/hooks/useSwatchesOptions.js +37 -1
  383. package/dist/esm/hooks/useToolbarPostPurchase.js +87 -1
  384. package/dist/esm/index.js +117 -1
  385. package/dist/esm/types/animations.js +49 -1
  386. package/dist/esm/types/custom.js +52 -0
  387. package/dist/esm/types/global-style.js +12 -1
  388. package/dist/esm/web-components/src/helpers/styles/constant.js +7 -1
  389. package/dist/types/index.d.ts +23183 -17335
  390. package/package.json +5 -3
  391. package/dist/cjs/components/animation/AnimationWrapper.js +0 -1
  392. package/dist/cjs/hooks/animation/animations.js +0 -1
  393. package/dist/cjs/hooks/animation/useLivePageAnimation.js +0 -1
  394. package/dist/esm/components/animation/AnimationWrapper.js +0 -1
  395. package/dist/esm/hooks/animation/animations.js +0 -1
  396. package/dist/esm/hooks/animation/useLivePageAnimation.js +0 -1
@@ -1,14 +1,25 @@
1
- import{PublishedThemePageSelect as e}from"../fragments/published-theme-page.generated.js";import{PublishedPageSectionSelect as s}from"../fragments/published-page-section.generated.js";import{PublishedCustomSectionSelect as t}from"../fragments/published-custom-section.generated.js";import{DataSeoSelect as m}from"../fragments/data-seo.generated.js";import{PublishedThemeStyleSelect as r}from"../fragments/published-theme-style.generated.js";import{AnalyticSelect as g}from"../fragments/analytic.generated.js";import{CustomCodeSelect as a}from"../fragments/custom-code.generated.js";import{CustomFontSelect as o}from"../fragments/custom-font.generated.js";let PublishedThemePagesDocument=`
1
+ import { PublishedThemePageSelect } from '../fragments/published-theme-page.generated.js';
2
+ import { PublishedPageSectionSelect } from '../fragments/published-page-section.generated.js';
3
+ import { PublishedCustomSectionSelect } from '../fragments/published-custom-section.generated.js';
4
+ import { DataSeoSelect } from '../fragments/data-seo.generated.js';
5
+ import { PublishedThemeStyleSelect } from '../fragments/published-theme-style.generated.js';
6
+ import { AnalyticSelect } from '../fragments/analytic.generated.js';
7
+ import { CustomCodeSelect } from '../fragments/custom-code.generated.js';
8
+ import { CustomFontSelect } from '../fragments/custom-font.generated.js';
9
+
10
+ const PublishedThemePagesDocument = `
2
11
  query publishedThemePages($slug: String, $slugType: PublishedThemePageType!) {
3
12
  publishedThemePages(slug: $slug, slugType: $slugType) {
4
13
  ...PublishedThemePageSelect
5
14
  }
6
15
  }
7
- ${e}
8
- ${s}
9
- ${t}
10
- ${m}
11
- ${r}
12
- ${g}
13
- ${a}
14
- ${o}`;export{PublishedThemePagesDocument};
16
+ ${PublishedThemePageSelect}
17
+ ${PublishedPageSectionSelect}
18
+ ${PublishedCustomSectionSelect}
19
+ ${DataSeoSelect}
20
+ ${PublishedThemeStyleSelect}
21
+ ${AnalyticSelect}
22
+ ${CustomCodeSelect}
23
+ ${CustomFontSelect}`;
24
+
25
+ export { PublishedThemePagesDocument };
@@ -1,4 +1,4 @@
1
- let StorePropertyDocument=`
1
+ /* eslint-disable */ const StorePropertyDocument = `
2
2
  query storeProperty {
3
3
  storeProperty {
4
4
  favicon
@@ -6,4 +6,6 @@ let StorePropertyDocument=`
6
6
  primaryDomain
7
7
  }
8
8
  }
9
- `;export{StorePropertyDocument};
9
+ `;
10
+
11
+ export { StorePropertyDocument };
@@ -1,4 +1,4 @@
1
- let LibrarySaleFunnelDocument=`
1
+ /* eslint-disable */ const LibrarySaleFunnelDocument = `
2
2
  query LibrarySaleFunnel($librarySaleFunnelId: ID!) {
3
3
  librarySaleFunnel(id: $librarySaleFunnelId) {
4
4
  id
@@ -18,4 +18,6 @@ let LibrarySaleFunnelDocument=`
18
18
  }
19
19
  }
20
20
  }
21
- `;export{LibrarySaleFunnelDocument};
21
+ `;
22
+
23
+ export { LibrarySaleFunnelDocument };
@@ -1,4 +1,4 @@
1
- let LibraryTemplateDocument=`
1
+ /* eslint-disable */ const LibraryTemplateDocument = `
2
2
  query LibraryTemplate($libraryTemplateId: ID!) {
3
3
  libraryTemplate(id: $libraryTemplateId) {
4
4
  id
@@ -10,4 +10,6 @@ let LibraryTemplateDocument=`
10
10
  }
11
11
  }
12
12
  }
13
- `;export{LibraryTemplateDocument};
13
+ `;
14
+
15
+ export { LibraryTemplateDocument };
@@ -1,4 +1,4 @@
1
- let SaleFunnelDiscountsDocument=`
1
+ /* eslint-disable */ const SaleFunnelDiscountsDocument = `
2
2
  query SaleFunnelDiscounts($where: SaleFunnelDiscountWhereInput, $orderBy: SaleFunnelDiscountOrder, $last: Int, $before: Cursor, $first: Int, $after: Cursor) {
3
3
  saleFunnelDiscounts(
4
4
  where: $where
@@ -31,4 +31,6 @@ let SaleFunnelDiscountsDocument=`
31
31
  totalCount
32
32
  }
33
33
  }
34
- `;export{SaleFunnelDiscountsDocument};
34
+ `;
35
+
36
+ export { SaleFunnelDiscountsDocument };
@@ -0,0 +1,15 @@
1
+ /* eslint-disable */ const ShopLibraryPageDocument = `
2
+ query ShopLibraryPage($shopLibraryPageId: ID!) {
3
+ shopLibraryPage(id: $shopLibraryPageId) {
4
+ id
5
+ name
6
+ sectionPosition
7
+ shopLibrarySections {
8
+ id
9
+ component
10
+ }
11
+ }
12
+ }
13
+ `;
14
+
15
+ export { ShopLibraryPageDocument };
@@ -1,4 +1,4 @@
1
- let ThemePageDocument=`
1
+ /* eslint-disable */ const ThemePageDocument = `
2
2
  query ThemePage($themePageId: ID!, $first: Int, $where: ThemeStyleWhereInput) {
3
3
  themePage(id: $themePageId) {
4
4
  id
@@ -26,4 +26,6 @@ let ThemePageDocument=`
26
26
  }
27
27
  }
28
28
  }
29
- `;export{ThemePageDocument};
29
+ `;
30
+
31
+ export { ThemePageDocument };
@@ -1 +1,15 @@
1
- let globalEvent={subscribe(e,t){document.addEventListener(e,e=>t(e.detail))},dispatch(e,t){document.dispatchEvent(new CustomEvent(e,{detail:t}))},remove(e,t){document.removeEventListener(e,t)}};export{globalEvent as default};
1
+ const globalEvent = {
2
+ subscribe (eventName, callback) {
3
+ document.addEventListener(eventName, (e)=>callback(e.detail));
4
+ },
5
+ dispatch (eventName, detail) {
6
+ document.dispatchEvent(new CustomEvent(eventName, {
7
+ detail
8
+ }));
9
+ },
10
+ remove (eventName, callback) {
11
+ document.removeEventListener(eventName, callback);
12
+ }
13
+ };
14
+
15
+ export { globalEvent as default };
@@ -0,0 +1,17 @@
1
+ const convertTextAlignToJustify = (align)=>{
2
+ const devices = [
3
+ 'desktop',
4
+ 'tablet',
5
+ 'mobile'
6
+ ];
7
+ const result = {};
8
+ devices.forEach((device)=>{
9
+ const deviceType = device === 'desktop' ? '' : `${device}:`;
10
+ result[`${deviceType}gp-justify-start`] = align?.[device] === 'left';
11
+ result[`${deviceType}gp-justify-center`] = align?.[device] === 'center';
12
+ result[`${deviceType}gp-justify-end`] = align?.[device] === 'right';
13
+ });
14
+ return result;
15
+ };
16
+
17
+ export { convertTextAlignToJustify };
@@ -1 +1,220 @@
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 r=r=>{let t=JSON.parse(JSON.stringify(r)),e=["delay","speed","scale","intensity"];return e.forEach(r=>{if(!t?.[r])return;if("scale"===r){if(!t?.zoomDirection)throw TypeError("zoomDirection not found on zoom preset");let[e,a]=t?.scale?.in??[1,1],[n,o]=t?.scale?.out??[1,1];t[r]={in:[Number(e)/100,Number(a)/100],out:[Number(n)/100,Number(o)/100]};return}let e=Number(t?.[r]);if("delay"===r?t[r]=1e3*e:t[r]=e,!isFinite(e))throw TypeError(`${r} must be a number`)}),t},t=(t,e)=>{let n=r(e),{direction:o,distance:i}=n,l=["left","right"].includes(o??"")?"X":"Y",f=["left","down"].includes(o??"")?"-":"",m=[{opacity:0,transform:`translate${l}(${f}${i??50}%)`},{opacity:1,transform:`translate${l}(0)`}];return s(t,m,{...a(n,500)})},e=(t,e)=>{let n=r(e),o=[{opacity:0},{opacity:1}];return s(t,o,{...a(n,500)})},a=(r,t)=>{let e=r=>r?1.5/r*1e3:t,{loop:a,delay:n,speed:o,easing:i}=r??{},s=e(o),l=n??0,f=a?s+l:s;return{iterations:a?1/0:1,duration:f,delay:l,easing:EASING[i??"linear"]}},n=(t,e)=>{let n=r(e),{scale:o,zoomDirection:i,isFade:l}=n,[f,m]=o.in,[u,c]=o.out,p=[{transform:`scale(${f}, ${f})`,opacity:l?0:1},{transform:`scale(${m??1.2}, ${m??1.2})`,opacity:1}],d=[{transform:`scale(${u}, ${u})`,opacity:l?0:1},{transform:`scale(${c??.8}, ${c??.8})`,opacity:1}],y="in"===i?p:d;return s(t,y,{...a(n,700)})},o=(r,t,e)=>{if(!t)return r;let a=t/e,n=[...r].pop();return[...r,{...n,offset:1-a}]},i=(t,e)=>{let n=r(e),{intensity:o}=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(o??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(t,o?m:i,{...a(n??{},820)})},s=(r,t,e)=>{let a=new KeyframeEffect(r,e.iterations&&1===e.iterations?t:o(t,e?.delay??0,e?.duration??0),{...e});return new Animation(a,document.timeline)};return{zoom:n,shake:i,fade:e,slide:t}};export{animations};
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 +1,226 @@
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";let getStyleBackgroundByDevice=(e,t)=>e?{...getStyleBgColor(e),...t?.ignoreBackgroundImage?{}:{...getStyleBgImage(e,t),...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;let i=e?.[t]?.image?.backupFileKey,l=e?.[t]?.image?.storage,a=e?.[t]?.image?.src,r=i,B=a?.match(/\/files\/([^\/]+\.(jpg|jpeg|gif|png|webp))$/)?.[1];if(B&&B!=i&&(r=B),"FILE_CONTENT"===l&&g?.liquid&&r&&(a=`{{ "${r.replace(".jpeg",".jpg")}" | file_url }}`),("THEME"===l||!l)&&g?.liquid&&r&&(a=`{{ "${r}" | asset_url }}`),"string"==typeof a)return`url(${a})`},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)} !important;`: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}}},GRADIENT_BGR_KEY="linear-gradient",getGradientBgrStyleForButton=e=>{if(!e)return;let t={};return Object.keys(e).forEach(g=>{e[g]?.startsWith(GRADIENT_BGR_KEY)&&("normal"===g?Object.assign(t,{"--bg":e[g]}):Object.assign(t,{"--hvr-bg":e[g]}))}),t},getGradientBgrStyleByDevice=e=>{if(!e)return;let t={};return["desktop","tablet","mobile"].forEach(g=>{e[g]?.color?.includes(GRADIENT_BGR_KEY)&&Object.assign(t,{[`--bgc${"desktop"!==g?"-"+g:""}`]:"transparent",[`--bgi${"desktop"!==g?"-"+g:""}`]:`${getBgImageByDevice(e,g)||"url()"}, ${e[g]?.color}`})}),t};export{GRADIENT_BGR_KEY,composeBackgroundCss,getBgImageByDevice,getGradientBgrStyleByDevice,getGradientBgrStyleForButton,getStyleBackgroundByDevice,makeFixedBgAttachment};
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
+ const backupFileKey = background?.[device]?.image?.backupFileKey;
56
+ const storage = background?.[device]?.image?.storage;
57
+ let imageByDevice = background?.[device]?.image?.src;
58
+ let newBackupFilekey = backupFileKey;
59
+ const shopifyHandleName = imageByDevice?.match(// eslint-disable-next-line
60
+ /\/files\/([^\/]+\.(jpg|jpeg|gif|png|webp|svg))/)?.[1];
61
+ if (backupFileKey && shopifyHandleName && shopifyHandleName != backupFileKey) {
62
+ newBackupFilekey = shopifyHandleName;
63
+ }
64
+ if (storage === 'FILE_CONTENT') {
65
+ if (options?.liquid && newBackupFilekey) {
66
+ imageByDevice = `{{ "${newBackupFilekey.replace('.jpeg', '.jpg')}" | file_url }}`;
67
+ }
68
+ }
69
+ if (storage === 'THEME' || !storage) {
70
+ if (options?.liquid && newBackupFilekey) {
71
+ imageByDevice = `{{ "${newBackupFilekey}" | asset_url }}`;
72
+ }
73
+ }
74
+ if (typeof imageByDevice === 'string') {
75
+ return `url(${imageByDevice})`;
76
+ }
77
+ };
78
+ const getStyleBgPosition = (background)=>{
79
+ const bgPosition = {
80
+ desktop: getBgPositionByDevice(background, 'desktop'),
81
+ tablet: getBgPositionByDevice(background, 'tablet'),
82
+ mobile: getBgPositionByDevice(background, 'mobile')
83
+ };
84
+ return makeStyleResponsive('bgp', bgPosition);
85
+ };
86
+ const getBgPositionByDevice = (background, device)=>{
87
+ const positionByDevice = background?.[device]?.position;
88
+ return positionByDevice && `${positionByDevice.x}% ${positionByDevice.y}%`;
89
+ };
90
+ const getStyleBgSize = (background)=>{
91
+ const bgSize = {
92
+ desktop: getBgSizeByDevice(background, 'desktop'),
93
+ tablet: getBgSizeByDevice(background, 'tablet'),
94
+ mobile: getBgSizeByDevice(background, 'mobile')
95
+ };
96
+ return makeStyleResponsive('bgs', bgSize);
97
+ };
98
+ const getBgSizeByDevice = (background, device)=>{
99
+ return background?.[device]?.size;
100
+ };
101
+ const getStyleBgRepeat = (background)=>{
102
+ const bgRepeat = {
103
+ desktop: getBgRepeatByDevice(background, 'desktop'),
104
+ tablet: getBgRepeatByDevice(background, 'tablet'),
105
+ mobile: getBgRepeatByDevice(background, 'mobile')
106
+ };
107
+ return makeStyleResponsive('bgr', bgRepeat);
108
+ };
109
+ const getBgRepeatByDevice = (background, device)=>{
110
+ return background?.[device]?.repeat;
111
+ };
112
+ const getStyleBgAttachment = (background)=>{
113
+ const bgAttachment = {
114
+ desktop: getBgAttachmentByDevice(background, 'desktop'),
115
+ tablet: getBgAttachmentByDevice(background, 'tablet'),
116
+ mobile: getBgAttachmentByDevice(background, 'mobile')
117
+ };
118
+ return makeStyleResponsive('bga', bgAttachment);
119
+ };
120
+ const getBgAttachmentByDevice = (background, device)=>{
121
+ return background?.[device]?.attachment;
122
+ };
123
+ const composeBackgroundCss = (backgroundColor)=>{
124
+ return `${backgroundColor ? `background-color: ${getSingleColorVariable(backgroundColor)};` : undefined}`;
125
+ };
126
+ const makeFixedBgAttachment = (background)=>{
127
+ if (!background) return;
128
+ background.tablet = background.tablet ? background.tablet : background.desktop;
129
+ background.mobile = background.mobile ? background.mobile : background.tablet;
130
+ const bgAttachment = {
131
+ desktop: getBgAttachmentByDevice(background, 'desktop'),
132
+ tablet: getBgAttachmentByDevice(background, 'tablet'),
133
+ mobile: getBgAttachmentByDevice(background, 'mobile')
134
+ };
135
+ const composeFixed = {
136
+ desktop: {
137
+ ...makeFixedBgAttachmentByDevice('desktop', bgAttachment.desktop)
138
+ },
139
+ tablet: {
140
+ ...makeFixedBgAttachmentByDevice('tablet', bgAttachment.tablet)
141
+ },
142
+ mobile: {
143
+ ...makeFixedBgAttachmentByDevice('mobile', bgAttachment.mobile)
144
+ }
145
+ };
146
+ return {
147
+ wrapper: {
148
+ ...composeFixed.desktop?.wrapper,
149
+ ...composeFixed.tablet?.wrapper,
150
+ ...composeFixed.mobile?.wrapper
151
+ },
152
+ content: {
153
+ ...composeFixed.desktop?.content,
154
+ ...composeFixed.tablet?.content,
155
+ ...composeFixed.mobile?.content
156
+ }
157
+ };
158
+ };
159
+ const makeFixedBgAttachmentByDevice = (device, bgAttachment)=>{
160
+ const suffix = devicesMapping[device] ?? '';
161
+ if (bgAttachment === 'fixed') {
162
+ return {
163
+ wrapper: {
164
+ [`--pos${suffix}`]: 'absolute',
165
+ [`--top${suffix}`]: '0',
166
+ [`--left${suffix}`]: '0',
167
+ [`--w${suffix}`]: '100%',
168
+ [`--h${suffix}`]: '100%'
169
+ },
170
+ content: {
171
+ [`--pos${suffix}`]: 'fixed',
172
+ [`--w${suffix}`]: '100vw',
173
+ [`--h${suffix}`]: '100vh',
174
+ [`--bga${suffix}`]: 'unset'
175
+ }
176
+ };
177
+ }
178
+ return {
179
+ wrapper: {
180
+ [`--pos${suffix}`]: 'absolute'
181
+ },
182
+ content: {
183
+ [`--w${suffix}`]: '100%',
184
+ [`--h${suffix}`]: '100%',
185
+ [`--pos${suffix}`]: 'absolute',
186
+ [`--bga${suffix}`]: bgAttachment
187
+ }
188
+ };
189
+ };
190
+ const GRADIENT_BGR_KEY = 'linear-gradient';
191
+ const getGradientBgrStyleForButton = (backgroundStyle)=>{
192
+ if (!backgroundStyle) return;
193
+ const bgrStyle = {};
194
+ Object.keys(backgroundStyle).forEach((state)=>{
195
+ if (!backgroundStyle[state]?.startsWith(GRADIENT_BGR_KEY)) return;
196
+ if (state === 'normal') {
197
+ Object.assign(bgrStyle, {
198
+ '--bg': backgroundStyle[state]
199
+ });
200
+ } else {
201
+ Object.assign(bgrStyle, {
202
+ '--hvr-bg': backgroundStyle[state]
203
+ });
204
+ }
205
+ });
206
+ return bgrStyle;
207
+ };
208
+ const getGradientBgrStyleByDevice = (backgroundStyle, ignoreBackgroundImage)=>{
209
+ if (!backgroundStyle) return;
210
+ const bgrStyle = {};
211
+ [
212
+ 'desktop',
213
+ 'tablet',
214
+ 'mobile'
215
+ ].forEach((device)=>{
216
+ if (backgroundStyle[device]?.color?.includes(GRADIENT_BGR_KEY)) {
217
+ Object.assign(bgrStyle, {
218
+ [`--bgc${device !== 'desktop' ? '-' + device : ''}`]: backgroundStyle[device]?.color,
219
+ [`--bgi${device !== 'desktop' ? '-' + device : ''}`]: !ignoreBackgroundImage?.[device] ? `${backgroundStyle[device]?.color}` : `${getBgImageByDevice(backgroundStyle, device) || 'url()'}, ${backgroundStyle[device]?.color}`
220
+ });
221
+ }
222
+ });
223
+ return bgrStyle;
224
+ };
225
+
226
+ export { GRADIENT_BGR_KEY, composeBackgroundCss, getBgImageByDevice, getGradientBgrStyleByDevice, getGradientBgrStyleForButton, getStyleBackgroundByDevice, getStyleBgColor, makeFixedBgAttachment };