@shopify/hydrogen-react 2022.10.8 → 2023.1.5

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 (646) hide show
  1. package/README.md +41 -47
  2. package/dist/browser-dev/AddToCartButton.mjs +43 -40
  3. package/dist/browser-dev/AddToCartButton.mjs.map +1 -1
  4. package/dist/browser-dev/BaseButton.mjs +13 -15
  5. package/dist/browser-dev/BaseButton.mjs.map +1 -1
  6. package/dist/browser-dev/BuyNowButton.mjs +19 -17
  7. package/dist/browser-dev/BuyNowButton.mjs.map +1 -1
  8. package/dist/browser-dev/CartCheckoutButton.mjs +12 -15
  9. package/dist/browser-dev/CartCheckoutButton.mjs.map +1 -1
  10. package/dist/browser-dev/CartCost.mjs +25 -0
  11. package/dist/browser-dev/CartCost.mjs.map +1 -0
  12. package/dist/browser-dev/CartLinePrice.mjs +21 -0
  13. package/dist/browser-dev/CartLinePrice.mjs.map +1 -0
  14. package/dist/browser-dev/CartLineProvider.mjs +22 -0
  15. package/dist/browser-dev/CartLineProvider.mjs.map +1 -0
  16. package/dist/browser-dev/CartLineQuantity.mjs +12 -0
  17. package/dist/browser-dev/CartLineQuantity.mjs.map +1 -0
  18. package/dist/browser-dev/CartLineQuantityAdjustButton.mjs +48 -0
  19. package/dist/browser-dev/CartLineQuantityAdjustButton.mjs.map +1 -0
  20. package/dist/browser-dev/CartProvider.mjs +74 -68
  21. package/dist/browser-dev/CartProvider.mjs.map +1 -1
  22. package/dist/browser-dev/ExternalVideo.mjs +13 -11
  23. package/dist/browser-dev/ExternalVideo.mjs.map +1 -1
  24. package/dist/browser-dev/Image.mjs +41 -30
  25. package/dist/browser-dev/Image.mjs.map +1 -1
  26. package/dist/browser-dev/MediaFile.mjs +29 -21
  27. package/dist/browser-dev/MediaFile.mjs.map +1 -1
  28. package/dist/browser-dev/ModelViewer.mjs +138 -76
  29. package/dist/browser-dev/ModelViewer.mjs.map +1 -1
  30. package/dist/browser-dev/Money.mjs +12 -9
  31. package/dist/browser-dev/Money.mjs.map +1 -1
  32. package/dist/browser-dev/ProductPrice.mjs +12 -17
  33. package/dist/browser-dev/ProductPrice.mjs.map +1 -1
  34. package/dist/browser-dev/ProductProvider.mjs +102 -73
  35. package/dist/browser-dev/ProductProvider.mjs.map +1 -1
  36. package/dist/browser-dev/ShopPayButton.mjs +14 -24
  37. package/dist/browser-dev/ShopPayButton.mjs.map +1 -1
  38. package/dist/browser-dev/ShopifyProvider.mjs +22 -38
  39. package/dist/browser-dev/ShopifyProvider.mjs.map +1 -1
  40. package/dist/browser-dev/Video.mjs +30 -21
  41. package/dist/browser-dev/Video.mjs.map +1 -1
  42. package/dist/browser-dev/_virtual/index.mjs +11 -2
  43. package/dist/browser-dev/_virtual/index.mjs.map +1 -1
  44. package/dist/browser-dev/_virtual/with-selector.mjs +11 -2
  45. package/dist/browser-dev/_virtual/with-selector.mjs.map +1 -1
  46. package/dist/browser-dev/analytics-constants.mjs +43 -0
  47. package/dist/browser-dev/analytics-constants.mjs.map +1 -0
  48. package/dist/browser-dev/analytics-schema-custom-storefront-customer-tracking.mjs +145 -0
  49. package/dist/browser-dev/analytics-schema-custom-storefront-customer-tracking.mjs.map +1 -0
  50. package/dist/browser-dev/analytics-schema-trekkie-storefront-page-view.mjs +58 -0
  51. package/dist/browser-dev/analytics-schema-trekkie-storefront-page-view.mjs.map +1 -0
  52. package/dist/browser-dev/analytics-utils.mjs +49 -0
  53. package/dist/browser-dev/analytics-utils.mjs.map +1 -0
  54. package/dist/browser-dev/analytics.mjs +159 -0
  55. package/dist/browser-dev/analytics.mjs.map +1 -0
  56. package/dist/browser-dev/cart-hooks.mjs +32 -34
  57. package/dist/browser-dev/cart-hooks.mjs.map +1 -1
  58. package/dist/browser-dev/cart-queries.mjs +50 -28
  59. package/dist/browser-dev/cart-queries.mjs.map +1 -1
  60. package/dist/browser-dev/codegen.helpers.mjs +1 -0
  61. package/dist/browser-dev/codegen.helpers.mjs.map +1 -1
  62. package/dist/browser-dev/cookies-utils.mjs +50 -0
  63. package/dist/browser-dev/cookies-utils.mjs.map +1 -0
  64. package/dist/browser-dev/flatten-connection.mjs +7 -5
  65. package/dist/browser-dev/flatten-connection.mjs.map +1 -1
  66. package/dist/browser-dev/image-size.mjs +8 -8
  67. package/dist/browser-dev/image-size.mjs.map +1 -1
  68. package/dist/browser-dev/index.mjs +24 -6
  69. package/dist/browser-dev/index.mjs.map +1 -1
  70. package/dist/browser-dev/load-script.mjs +3 -1
  71. package/dist/browser-dev/load-script.mjs.map +1 -1
  72. package/dist/browser-dev/node_modules/@xstate/fsm/es/index.mjs.map +1 -1
  73. package/dist/browser-dev/node_modules/@xstate/react/es/fsm.mjs +2 -2
  74. package/dist/browser-dev/node_modules/@xstate/react/es/fsm.mjs.map +1 -1
  75. package/dist/browser-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.mjs.map +1 -1
  76. package/dist/browser-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.mjs.map +1 -1
  77. package/dist/browser-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.mjs.map +1 -1
  78. package/dist/browser-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.mjs.map +1 -1
  79. package/dist/browser-dev/node_modules/use-sync-external-store/shim/index.mjs +3 -3
  80. package/dist/browser-dev/node_modules/use-sync-external-store/shim/with-selector.mjs +1 -1
  81. package/dist/browser-dev/{metafield-parser.mjs → parse-metafield.mjs} +20 -12
  82. package/dist/browser-dev/parse-metafield.mjs.map +1 -0
  83. package/dist/browser-dev/storefront-api-constants.mjs +1 -1
  84. package/dist/browser-dev/storefront-api-constants.mjs.map +1 -1
  85. package/dist/browser-dev/storefront-client.mjs +27 -27
  86. package/dist/browser-dev/storefront-client.mjs.map +1 -1
  87. package/dist/browser-dev/useCartAPIStateMachine.mjs +120 -80
  88. package/dist/browser-dev/useCartAPIStateMachine.mjs.map +1 -1
  89. package/dist/browser-dev/useCartActions.mjs +150 -109
  90. package/dist/browser-dev/useCartActions.mjs.map +1 -1
  91. package/dist/browser-dev/useMoney.mjs +63 -36
  92. package/dist/browser-dev/useMoney.mjs.map +1 -1
  93. package/dist/browser-dev/useShopifyCookies.mjs +41 -0
  94. package/dist/browser-dev/useShopifyCookies.mjs.map +1 -0
  95. package/dist/browser-prod/AddToCartButton.mjs +43 -40
  96. package/dist/browser-prod/AddToCartButton.mjs.map +1 -1
  97. package/dist/browser-prod/BaseButton.mjs +13 -15
  98. package/dist/browser-prod/BaseButton.mjs.map +1 -1
  99. package/dist/browser-prod/BuyNowButton.mjs +19 -17
  100. package/dist/browser-prod/BuyNowButton.mjs.map +1 -1
  101. package/dist/browser-prod/CartCheckoutButton.mjs +12 -15
  102. package/dist/browser-prod/CartCheckoutButton.mjs.map +1 -1
  103. package/dist/browser-prod/CartCost.mjs +25 -0
  104. package/dist/browser-prod/CartCost.mjs.map +1 -0
  105. package/dist/browser-prod/CartLinePrice.mjs +18 -0
  106. package/dist/browser-prod/CartLinePrice.mjs.map +1 -0
  107. package/dist/browser-prod/CartLineProvider.mjs +22 -0
  108. package/dist/browser-prod/CartLineProvider.mjs.map +1 -0
  109. package/dist/browser-prod/CartLineQuantity.mjs +12 -0
  110. package/dist/browser-prod/CartLineQuantity.mjs.map +1 -0
  111. package/dist/browser-prod/CartLineQuantityAdjustButton.mjs +48 -0
  112. package/dist/browser-prod/CartLineQuantityAdjustButton.mjs.map +1 -0
  113. package/dist/browser-prod/CartProvider.mjs +74 -68
  114. package/dist/browser-prod/CartProvider.mjs.map +1 -1
  115. package/dist/browser-prod/ExternalVideo.mjs +13 -11
  116. package/dist/browser-prod/ExternalVideo.mjs.map +1 -1
  117. package/dist/browser-prod/Image.mjs +35 -28
  118. package/dist/browser-prod/Image.mjs.map +1 -1
  119. package/dist/browser-prod/MediaFile.mjs +29 -21
  120. package/dist/browser-prod/MediaFile.mjs.map +1 -1
  121. package/dist/browser-prod/ModelViewer.mjs +135 -75
  122. package/dist/browser-prod/ModelViewer.mjs.map +1 -1
  123. package/dist/browser-prod/Money.mjs +12 -9
  124. package/dist/browser-prod/Money.mjs.map +1 -1
  125. package/dist/browser-prod/ProductPrice.mjs +12 -17
  126. package/dist/browser-prod/ProductPrice.mjs.map +1 -1
  127. package/dist/browser-prod/ProductProvider.mjs +102 -73
  128. package/dist/browser-prod/ProductProvider.mjs.map +1 -1
  129. package/dist/browser-prod/ShopPayButton.mjs +14 -24
  130. package/dist/browser-prod/ShopPayButton.mjs.map +1 -1
  131. package/dist/browser-prod/ShopifyProvider.mjs +22 -32
  132. package/dist/browser-prod/ShopifyProvider.mjs.map +1 -1
  133. package/dist/browser-prod/Video.mjs +30 -21
  134. package/dist/browser-prod/Video.mjs.map +1 -1
  135. package/dist/browser-prod/_virtual/index.mjs +11 -2
  136. package/dist/browser-prod/_virtual/index.mjs.map +1 -1
  137. package/dist/browser-prod/_virtual/with-selector.mjs +11 -2
  138. package/dist/browser-prod/_virtual/with-selector.mjs.map +1 -1
  139. package/dist/browser-prod/analytics-constants.mjs +43 -0
  140. package/dist/browser-prod/analytics-constants.mjs.map +1 -0
  141. package/dist/browser-prod/analytics-schema-custom-storefront-customer-tracking.mjs +145 -0
  142. package/dist/browser-prod/analytics-schema-custom-storefront-customer-tracking.mjs.map +1 -0
  143. package/dist/browser-prod/analytics-schema-trekkie-storefront-page-view.mjs +58 -0
  144. package/dist/browser-prod/analytics-schema-trekkie-storefront-page-view.mjs.map +1 -0
  145. package/dist/browser-prod/analytics-utils.mjs +49 -0
  146. package/dist/browser-prod/analytics-utils.mjs.map +1 -0
  147. package/dist/browser-prod/analytics.mjs +158 -0
  148. package/dist/browser-prod/analytics.mjs.map +1 -0
  149. package/dist/browser-prod/cart-hooks.mjs +32 -34
  150. package/dist/browser-prod/cart-hooks.mjs.map +1 -1
  151. package/dist/browser-prod/cart-queries.mjs +50 -28
  152. package/dist/browser-prod/cart-queries.mjs.map +1 -1
  153. package/dist/browser-prod/codegen.helpers.mjs +1 -0
  154. package/dist/browser-prod/codegen.helpers.mjs.map +1 -1
  155. package/dist/browser-prod/cookies-utils.mjs +50 -0
  156. package/dist/browser-prod/cookies-utils.mjs.map +1 -0
  157. package/dist/browser-prod/flatten-connection.mjs +7 -5
  158. package/dist/browser-prod/flatten-connection.mjs.map +1 -1
  159. package/dist/browser-prod/image-size.mjs +8 -8
  160. package/dist/browser-prod/image-size.mjs.map +1 -1
  161. package/dist/browser-prod/index.mjs +24 -6
  162. package/dist/browser-prod/index.mjs.map +1 -1
  163. package/dist/browser-prod/load-script.mjs +3 -1
  164. package/dist/browser-prod/load-script.mjs.map +1 -1
  165. package/dist/browser-prod/node_modules/@xstate/fsm/es/index.mjs.map +1 -1
  166. package/dist/browser-prod/node_modules/@xstate/react/es/fsm.mjs +2 -2
  167. package/dist/browser-prod/node_modules/@xstate/react/es/fsm.mjs.map +1 -1
  168. package/dist/browser-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.mjs.map +1 -1
  169. package/dist/browser-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.mjs.map +1 -1
  170. package/dist/browser-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.mjs.map +1 -1
  171. package/dist/browser-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.mjs.map +1 -1
  172. package/dist/browser-prod/node_modules/use-sync-external-store/shim/index.mjs +3 -3
  173. package/dist/browser-prod/node_modules/use-sync-external-store/shim/with-selector.mjs +1 -1
  174. package/dist/browser-prod/{metafield-parser.mjs → parse-metafield.mjs} +20 -12
  175. package/dist/browser-prod/parse-metafield.mjs.map +1 -0
  176. package/dist/browser-prod/storefront-api-constants.mjs +1 -1
  177. package/dist/browser-prod/storefront-api-constants.mjs.map +1 -1
  178. package/dist/browser-prod/storefront-client.mjs +27 -27
  179. package/dist/browser-prod/storefront-client.mjs.map +1 -1
  180. package/dist/browser-prod/useCartAPIStateMachine.mjs +120 -80
  181. package/dist/browser-prod/useCartAPIStateMachine.mjs.map +1 -1
  182. package/dist/browser-prod/useCartActions.mjs +150 -109
  183. package/dist/browser-prod/useCartActions.mjs.map +1 -1
  184. package/dist/browser-prod/useMoney.mjs +63 -36
  185. package/dist/browser-prod/useMoney.mjs.map +1 -1
  186. package/dist/browser-prod/useShopifyCookies.mjs +41 -0
  187. package/dist/browser-prod/useShopifyCookies.mjs.map +1 -0
  188. package/dist/node-dev/AddToCartButton.js +44 -41
  189. package/dist/node-dev/AddToCartButton.js.map +1 -1
  190. package/dist/node-dev/AddToCartButton.mjs +43 -40
  191. package/dist/node-dev/AddToCartButton.mjs.map +1 -1
  192. package/dist/node-dev/BaseButton.js +14 -16
  193. package/dist/node-dev/BaseButton.js.map +1 -1
  194. package/dist/node-dev/BaseButton.mjs +13 -15
  195. package/dist/node-dev/BaseButton.mjs.map +1 -1
  196. package/dist/node-dev/BuyNowButton.js +20 -18
  197. package/dist/node-dev/BuyNowButton.js.map +1 -1
  198. package/dist/node-dev/BuyNowButton.mjs +19 -17
  199. package/dist/node-dev/BuyNowButton.mjs.map +1 -1
  200. package/dist/node-dev/CartCheckoutButton.js +13 -16
  201. package/dist/node-dev/CartCheckoutButton.js.map +1 -1
  202. package/dist/node-dev/CartCheckoutButton.mjs +12 -15
  203. package/dist/node-dev/CartCheckoutButton.mjs.map +1 -1
  204. package/dist/node-dev/CartCost.js +25 -0
  205. package/dist/node-dev/CartCost.js.map +1 -0
  206. package/dist/node-dev/CartCost.mjs +25 -0
  207. package/dist/node-dev/CartCost.mjs.map +1 -0
  208. package/dist/node-dev/CartLinePrice.js +21 -0
  209. package/dist/node-dev/CartLinePrice.js.map +1 -0
  210. package/dist/node-dev/CartLinePrice.mjs +21 -0
  211. package/dist/node-dev/CartLinePrice.mjs.map +1 -0
  212. package/dist/node-dev/CartLineProvider.js +22 -0
  213. package/dist/node-dev/CartLineProvider.js.map +1 -0
  214. package/dist/node-dev/CartLineProvider.mjs +22 -0
  215. package/dist/node-dev/CartLineProvider.mjs.map +1 -0
  216. package/dist/node-dev/CartLineQuantity.js +12 -0
  217. package/dist/node-dev/CartLineQuantity.js.map +1 -0
  218. package/dist/node-dev/CartLineQuantity.mjs +12 -0
  219. package/dist/node-dev/CartLineQuantity.mjs.map +1 -0
  220. package/dist/node-dev/CartLineQuantityAdjustButton.js +48 -0
  221. package/dist/node-dev/CartLineQuantityAdjustButton.js.map +1 -0
  222. package/dist/node-dev/CartLineQuantityAdjustButton.mjs +48 -0
  223. package/dist/node-dev/CartLineQuantityAdjustButton.mjs.map +1 -0
  224. package/dist/node-dev/CartProvider.js +75 -69
  225. package/dist/node-dev/CartProvider.js.map +1 -1
  226. package/dist/node-dev/CartProvider.mjs +74 -68
  227. package/dist/node-dev/CartProvider.mjs.map +1 -1
  228. package/dist/node-dev/ExternalVideo.js +14 -12
  229. package/dist/node-dev/ExternalVideo.js.map +1 -1
  230. package/dist/node-dev/ExternalVideo.mjs +13 -11
  231. package/dist/node-dev/ExternalVideo.mjs.map +1 -1
  232. package/dist/node-dev/Image.js +42 -31
  233. package/dist/node-dev/Image.js.map +1 -1
  234. package/dist/node-dev/Image.mjs +41 -30
  235. package/dist/node-dev/Image.mjs.map +1 -1
  236. package/dist/node-dev/MediaFile.js +30 -22
  237. package/dist/node-dev/MediaFile.js.map +1 -1
  238. package/dist/node-dev/MediaFile.mjs +29 -21
  239. package/dist/node-dev/MediaFile.mjs.map +1 -1
  240. package/dist/node-dev/ModelViewer.js +139 -77
  241. package/dist/node-dev/ModelViewer.js.map +1 -1
  242. package/dist/node-dev/ModelViewer.mjs +138 -76
  243. package/dist/node-dev/ModelViewer.mjs.map +1 -1
  244. package/dist/node-dev/Money.js +13 -10
  245. package/dist/node-dev/Money.js.map +1 -1
  246. package/dist/node-dev/Money.mjs +12 -9
  247. package/dist/node-dev/Money.mjs.map +1 -1
  248. package/dist/node-dev/ProductPrice.js +13 -18
  249. package/dist/node-dev/ProductPrice.js.map +1 -1
  250. package/dist/node-dev/ProductPrice.mjs +12 -17
  251. package/dist/node-dev/ProductPrice.mjs.map +1 -1
  252. package/dist/node-dev/ProductProvider.js +103 -74
  253. package/dist/node-dev/ProductProvider.js.map +1 -1
  254. package/dist/node-dev/ProductProvider.mjs +102 -73
  255. package/dist/node-dev/ProductProvider.mjs.map +1 -1
  256. package/dist/node-dev/ShopPayButton.js +14 -24
  257. package/dist/node-dev/ShopPayButton.js.map +1 -1
  258. package/dist/node-dev/ShopPayButton.mjs +14 -24
  259. package/dist/node-dev/ShopPayButton.mjs.map +1 -1
  260. package/dist/node-dev/ShopifyProvider.js +23 -39
  261. package/dist/node-dev/ShopifyProvider.js.map +1 -1
  262. package/dist/node-dev/ShopifyProvider.mjs +22 -38
  263. package/dist/node-dev/ShopifyProvider.mjs.map +1 -1
  264. package/dist/node-dev/Video.js +31 -22
  265. package/dist/node-dev/Video.js.map +1 -1
  266. package/dist/node-dev/Video.mjs +30 -21
  267. package/dist/node-dev/Video.mjs.map +1 -1
  268. package/dist/node-dev/_virtual/index.js +11 -3
  269. package/dist/node-dev/_virtual/index.js.map +1 -1
  270. package/dist/node-dev/_virtual/index.mjs +11 -2
  271. package/dist/node-dev/_virtual/index.mjs.map +1 -1
  272. package/dist/node-dev/_virtual/use-sync-external-store-shim.development.js +1 -1
  273. package/dist/node-dev/_virtual/use-sync-external-store-shim.production.min.js +1 -1
  274. package/dist/node-dev/_virtual/with-selector.development.js +1 -1
  275. package/dist/node-dev/_virtual/with-selector.js +11 -3
  276. package/dist/node-dev/_virtual/with-selector.js.map +1 -1
  277. package/dist/node-dev/_virtual/with-selector.mjs +11 -2
  278. package/dist/node-dev/_virtual/with-selector.mjs.map +1 -1
  279. package/dist/node-dev/_virtual/with-selector.production.min.js +1 -1
  280. package/dist/node-dev/analytics-constants.js +43 -0
  281. package/dist/node-dev/analytics-constants.js.map +1 -0
  282. package/dist/node-dev/analytics-constants.mjs +43 -0
  283. package/dist/node-dev/analytics-constants.mjs.map +1 -0
  284. package/dist/node-dev/analytics-schema-custom-storefront-customer-tracking.js +145 -0
  285. package/dist/node-dev/analytics-schema-custom-storefront-customer-tracking.js.map +1 -0
  286. package/dist/node-dev/analytics-schema-custom-storefront-customer-tracking.mjs +145 -0
  287. package/dist/node-dev/analytics-schema-custom-storefront-customer-tracking.mjs.map +1 -0
  288. package/dist/node-dev/analytics-schema-trekkie-storefront-page-view.js +58 -0
  289. package/dist/node-dev/analytics-schema-trekkie-storefront-page-view.js.map +1 -0
  290. package/dist/node-dev/analytics-schema-trekkie-storefront-page-view.mjs +58 -0
  291. package/dist/node-dev/analytics-schema-trekkie-storefront-page-view.mjs.map +1 -0
  292. package/dist/node-dev/analytics-utils.js +49 -0
  293. package/dist/node-dev/analytics-utils.js.map +1 -0
  294. package/dist/node-dev/analytics-utils.mjs +49 -0
  295. package/dist/node-dev/analytics-utils.mjs.map +1 -0
  296. package/dist/node-dev/analytics.js +159 -0
  297. package/dist/node-dev/analytics.js.map +1 -0
  298. package/dist/node-dev/analytics.mjs +159 -0
  299. package/dist/node-dev/analytics.mjs.map +1 -0
  300. package/dist/node-dev/cart-constants.js +1 -1
  301. package/dist/node-dev/cart-hooks.js +32 -34
  302. package/dist/node-dev/cart-hooks.js.map +1 -1
  303. package/dist/node-dev/cart-hooks.mjs +32 -34
  304. package/dist/node-dev/cart-hooks.mjs.map +1 -1
  305. package/dist/node-dev/cart-queries.js +51 -29
  306. package/dist/node-dev/cart-queries.js.map +1 -1
  307. package/dist/node-dev/cart-queries.mjs +50 -28
  308. package/dist/node-dev/cart-queries.mjs.map +1 -1
  309. package/dist/node-dev/codegen.helpers.js +2 -1
  310. package/dist/node-dev/codegen.helpers.js.map +1 -1
  311. package/dist/node-dev/codegen.helpers.mjs +1 -0
  312. package/dist/node-dev/codegen.helpers.mjs.map +1 -1
  313. package/dist/node-dev/cookies-utils.js +50 -0
  314. package/dist/node-dev/cookies-utils.js.map +1 -0
  315. package/dist/node-dev/cookies-utils.mjs +50 -0
  316. package/dist/node-dev/cookies-utils.mjs.map +1 -0
  317. package/dist/node-dev/flatten-connection.js +8 -6
  318. package/dist/node-dev/flatten-connection.js.map +1 -1
  319. package/dist/node-dev/flatten-connection.mjs +7 -5
  320. package/dist/node-dev/flatten-connection.mjs.map +1 -1
  321. package/dist/node-dev/image-size.js +9 -9
  322. package/dist/node-dev/image-size.js.map +1 -1
  323. package/dist/node-dev/image-size.mjs +8 -8
  324. package/dist/node-dev/image-size.mjs.map +1 -1
  325. package/dist/node-dev/index.js +25 -7
  326. package/dist/node-dev/index.js.map +1 -1
  327. package/dist/node-dev/index.mjs +24 -6
  328. package/dist/node-dev/index.mjs.map +1 -1
  329. package/dist/node-dev/load-script.js +4 -2
  330. package/dist/node-dev/load-script.js.map +1 -1
  331. package/dist/node-dev/load-script.mjs +3 -1
  332. package/dist/node-dev/load-script.mjs.map +1 -1
  333. package/dist/node-dev/node_modules/@xstate/fsm/es/index.js +1 -1
  334. package/dist/node-dev/node_modules/@xstate/fsm/es/index.js.map +1 -1
  335. package/dist/node-dev/node_modules/@xstate/fsm/es/index.mjs.map +1 -1
  336. package/dist/node-dev/node_modules/@xstate/react/es/fsm.js +2 -2
  337. package/dist/node-dev/node_modules/@xstate/react/es/fsm.js.map +1 -1
  338. package/dist/node-dev/node_modules/@xstate/react/es/fsm.mjs +2 -2
  339. package/dist/node-dev/node_modules/@xstate/react/es/fsm.mjs.map +1 -1
  340. package/dist/node-dev/node_modules/@xstate/react/es/useConstant.js +2 -4
  341. package/dist/node-dev/node_modules/@xstate/react/es/useConstant.js.map +1 -1
  342. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.js +2 -4
  343. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.js.map +1 -1
  344. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.mjs.map +1 -1
  345. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js +2 -4
  346. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js.map +1 -1
  347. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.mjs.map +1 -1
  348. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js +2 -4
  349. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js.map +1 -1
  350. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.mjs.map +1 -1
  351. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js +2 -4
  352. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js.map +1 -1
  353. package/dist/node-dev/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.mjs.map +1 -1
  354. package/dist/node-dev/node_modules/use-sync-external-store/shim/index.js +4 -4
  355. package/dist/node-dev/node_modules/use-sync-external-store/shim/index.mjs +3 -3
  356. package/dist/node-dev/node_modules/use-sync-external-store/shim/with-selector.js +1 -1
  357. package/dist/node-dev/node_modules/use-sync-external-store/shim/with-selector.mjs +1 -1
  358. package/dist/node-dev/{metafield-parser.js → parse-metafield.js} +21 -13
  359. package/dist/node-dev/parse-metafield.js.map +1 -0
  360. package/dist/node-dev/{metafield-parser.mjs → parse-metafield.mjs} +20 -12
  361. package/dist/node-dev/parse-metafield.mjs.map +1 -0
  362. package/dist/node-dev/storefront-api-constants.js +2 -2
  363. package/dist/node-dev/storefront-api-constants.js.map +1 -1
  364. package/dist/node-dev/storefront-api-constants.mjs +1 -1
  365. package/dist/node-dev/storefront-api-constants.mjs.map +1 -1
  366. package/dist/node-dev/storefront-client.js +28 -28
  367. package/dist/node-dev/storefront-client.js.map +1 -1
  368. package/dist/node-dev/storefront-client.mjs +27 -27
  369. package/dist/node-dev/storefront-client.mjs.map +1 -1
  370. package/dist/node-dev/useCartAPIStateMachine.js +121 -81
  371. package/dist/node-dev/useCartAPIStateMachine.js.map +1 -1
  372. package/dist/node-dev/useCartAPIStateMachine.mjs +120 -80
  373. package/dist/node-dev/useCartAPIStateMachine.mjs.map +1 -1
  374. package/dist/node-dev/useCartActions.js +151 -110
  375. package/dist/node-dev/useCartActions.js.map +1 -1
  376. package/dist/node-dev/useCartActions.mjs +150 -109
  377. package/dist/node-dev/useCartActions.mjs.map +1 -1
  378. package/dist/node-dev/useMoney.js +64 -37
  379. package/dist/node-dev/useMoney.js.map +1 -1
  380. package/dist/node-dev/useMoney.mjs +63 -36
  381. package/dist/node-dev/useMoney.mjs.map +1 -1
  382. package/dist/node-dev/useShopifyCookies.js +41 -0
  383. package/dist/node-dev/useShopifyCookies.js.map +1 -0
  384. package/dist/node-dev/useShopifyCookies.mjs +41 -0
  385. package/dist/node-dev/useShopifyCookies.mjs.map +1 -0
  386. package/dist/node-prod/AddToCartButton.js +44 -41
  387. package/dist/node-prod/AddToCartButton.js.map +1 -1
  388. package/dist/node-prod/AddToCartButton.mjs +43 -40
  389. package/dist/node-prod/AddToCartButton.mjs.map +1 -1
  390. package/dist/node-prod/BaseButton.js +14 -16
  391. package/dist/node-prod/BaseButton.js.map +1 -1
  392. package/dist/node-prod/BaseButton.mjs +13 -15
  393. package/dist/node-prod/BaseButton.mjs.map +1 -1
  394. package/dist/node-prod/BuyNowButton.js +20 -18
  395. package/dist/node-prod/BuyNowButton.js.map +1 -1
  396. package/dist/node-prod/BuyNowButton.mjs +19 -17
  397. package/dist/node-prod/BuyNowButton.mjs.map +1 -1
  398. package/dist/node-prod/CartCheckoutButton.js +13 -16
  399. package/dist/node-prod/CartCheckoutButton.js.map +1 -1
  400. package/dist/node-prod/CartCheckoutButton.mjs +12 -15
  401. package/dist/node-prod/CartCheckoutButton.mjs.map +1 -1
  402. package/dist/node-prod/CartCost.js +25 -0
  403. package/dist/node-prod/CartCost.js.map +1 -0
  404. package/dist/node-prod/CartCost.mjs +25 -0
  405. package/dist/node-prod/CartCost.mjs.map +1 -0
  406. package/dist/node-prod/CartLinePrice.js +18 -0
  407. package/dist/node-prod/CartLinePrice.js.map +1 -0
  408. package/dist/node-prod/CartLinePrice.mjs +18 -0
  409. package/dist/node-prod/CartLinePrice.mjs.map +1 -0
  410. package/dist/node-prod/CartLineProvider.js +22 -0
  411. package/dist/node-prod/CartLineProvider.js.map +1 -0
  412. package/dist/node-prod/CartLineProvider.mjs +22 -0
  413. package/dist/node-prod/CartLineProvider.mjs.map +1 -0
  414. package/dist/node-prod/CartLineQuantity.js +12 -0
  415. package/dist/node-prod/CartLineQuantity.js.map +1 -0
  416. package/dist/node-prod/CartLineQuantity.mjs +12 -0
  417. package/dist/node-prod/CartLineQuantity.mjs.map +1 -0
  418. package/dist/node-prod/CartLineQuantityAdjustButton.js +48 -0
  419. package/dist/node-prod/CartLineQuantityAdjustButton.js.map +1 -0
  420. package/dist/node-prod/CartLineQuantityAdjustButton.mjs +48 -0
  421. package/dist/node-prod/CartLineQuantityAdjustButton.mjs.map +1 -0
  422. package/dist/node-prod/CartProvider.js +75 -69
  423. package/dist/node-prod/CartProvider.js.map +1 -1
  424. package/dist/node-prod/CartProvider.mjs +74 -68
  425. package/dist/node-prod/CartProvider.mjs.map +1 -1
  426. package/dist/node-prod/ExternalVideo.js +14 -12
  427. package/dist/node-prod/ExternalVideo.js.map +1 -1
  428. package/dist/node-prod/ExternalVideo.mjs +13 -11
  429. package/dist/node-prod/ExternalVideo.mjs.map +1 -1
  430. package/dist/node-prod/Image.js +36 -29
  431. package/dist/node-prod/Image.js.map +1 -1
  432. package/dist/node-prod/Image.mjs +35 -28
  433. package/dist/node-prod/Image.mjs.map +1 -1
  434. package/dist/node-prod/MediaFile.js +30 -22
  435. package/dist/node-prod/MediaFile.js.map +1 -1
  436. package/dist/node-prod/MediaFile.mjs +29 -21
  437. package/dist/node-prod/MediaFile.mjs.map +1 -1
  438. package/dist/node-prod/ModelViewer.js +136 -76
  439. package/dist/node-prod/ModelViewer.js.map +1 -1
  440. package/dist/node-prod/ModelViewer.mjs +135 -75
  441. package/dist/node-prod/ModelViewer.mjs.map +1 -1
  442. package/dist/node-prod/Money.js +13 -10
  443. package/dist/node-prod/Money.js.map +1 -1
  444. package/dist/node-prod/Money.mjs +12 -9
  445. package/dist/node-prod/Money.mjs.map +1 -1
  446. package/dist/node-prod/ProductPrice.js +13 -18
  447. package/dist/node-prod/ProductPrice.js.map +1 -1
  448. package/dist/node-prod/ProductPrice.mjs +12 -17
  449. package/dist/node-prod/ProductPrice.mjs.map +1 -1
  450. package/dist/node-prod/ProductProvider.js +103 -74
  451. package/dist/node-prod/ProductProvider.js.map +1 -1
  452. package/dist/node-prod/ProductProvider.mjs +102 -73
  453. package/dist/node-prod/ProductProvider.mjs.map +1 -1
  454. package/dist/node-prod/ShopPayButton.js +14 -24
  455. package/dist/node-prod/ShopPayButton.js.map +1 -1
  456. package/dist/node-prod/ShopPayButton.mjs +14 -24
  457. package/dist/node-prod/ShopPayButton.mjs.map +1 -1
  458. package/dist/node-prod/ShopifyProvider.js +23 -33
  459. package/dist/node-prod/ShopifyProvider.js.map +1 -1
  460. package/dist/node-prod/ShopifyProvider.mjs +22 -32
  461. package/dist/node-prod/ShopifyProvider.mjs.map +1 -1
  462. package/dist/node-prod/Video.js +31 -22
  463. package/dist/node-prod/Video.js.map +1 -1
  464. package/dist/node-prod/Video.mjs +30 -21
  465. package/dist/node-prod/Video.mjs.map +1 -1
  466. package/dist/node-prod/_virtual/index.js +11 -3
  467. package/dist/node-prod/_virtual/index.js.map +1 -1
  468. package/dist/node-prod/_virtual/index.mjs +11 -2
  469. package/dist/node-prod/_virtual/index.mjs.map +1 -1
  470. package/dist/node-prod/_virtual/use-sync-external-store-shim.development.js +1 -1
  471. package/dist/node-prod/_virtual/use-sync-external-store-shim.production.min.js +1 -1
  472. package/dist/node-prod/_virtual/with-selector.development.js +1 -1
  473. package/dist/node-prod/_virtual/with-selector.js +11 -3
  474. package/dist/node-prod/_virtual/with-selector.js.map +1 -1
  475. package/dist/node-prod/_virtual/with-selector.mjs +11 -2
  476. package/dist/node-prod/_virtual/with-selector.mjs.map +1 -1
  477. package/dist/node-prod/_virtual/with-selector.production.min.js +1 -1
  478. package/dist/node-prod/analytics-constants.js +43 -0
  479. package/dist/node-prod/analytics-constants.js.map +1 -0
  480. package/dist/node-prod/analytics-constants.mjs +43 -0
  481. package/dist/node-prod/analytics-constants.mjs.map +1 -0
  482. package/dist/node-prod/analytics-schema-custom-storefront-customer-tracking.js +145 -0
  483. package/dist/node-prod/analytics-schema-custom-storefront-customer-tracking.js.map +1 -0
  484. package/dist/node-prod/analytics-schema-custom-storefront-customer-tracking.mjs +145 -0
  485. package/dist/node-prod/analytics-schema-custom-storefront-customer-tracking.mjs.map +1 -0
  486. package/dist/node-prod/analytics-schema-trekkie-storefront-page-view.js +58 -0
  487. package/dist/node-prod/analytics-schema-trekkie-storefront-page-view.js.map +1 -0
  488. package/dist/node-prod/analytics-schema-trekkie-storefront-page-view.mjs +58 -0
  489. package/dist/node-prod/analytics-schema-trekkie-storefront-page-view.mjs.map +1 -0
  490. package/dist/node-prod/analytics-utils.js +49 -0
  491. package/dist/node-prod/analytics-utils.js.map +1 -0
  492. package/dist/node-prod/analytics-utils.mjs +49 -0
  493. package/dist/node-prod/analytics-utils.mjs.map +1 -0
  494. package/dist/node-prod/analytics.js +158 -0
  495. package/dist/node-prod/analytics.js.map +1 -0
  496. package/dist/node-prod/analytics.mjs +158 -0
  497. package/dist/node-prod/analytics.mjs.map +1 -0
  498. package/dist/node-prod/cart-constants.js +1 -1
  499. package/dist/node-prod/cart-hooks.js +32 -34
  500. package/dist/node-prod/cart-hooks.js.map +1 -1
  501. package/dist/node-prod/cart-hooks.mjs +32 -34
  502. package/dist/node-prod/cart-hooks.mjs.map +1 -1
  503. package/dist/node-prod/cart-queries.js +51 -29
  504. package/dist/node-prod/cart-queries.js.map +1 -1
  505. package/dist/node-prod/cart-queries.mjs +50 -28
  506. package/dist/node-prod/cart-queries.mjs.map +1 -1
  507. package/dist/node-prod/codegen.helpers.js +2 -1
  508. package/dist/node-prod/codegen.helpers.js.map +1 -1
  509. package/dist/node-prod/codegen.helpers.mjs +1 -0
  510. package/dist/node-prod/codegen.helpers.mjs.map +1 -1
  511. package/dist/node-prod/cookies-utils.js +50 -0
  512. package/dist/node-prod/cookies-utils.js.map +1 -0
  513. package/dist/node-prod/cookies-utils.mjs +50 -0
  514. package/dist/node-prod/cookies-utils.mjs.map +1 -0
  515. package/dist/node-prod/flatten-connection.js +8 -6
  516. package/dist/node-prod/flatten-connection.js.map +1 -1
  517. package/dist/node-prod/flatten-connection.mjs +7 -5
  518. package/dist/node-prod/flatten-connection.mjs.map +1 -1
  519. package/dist/node-prod/image-size.js +9 -9
  520. package/dist/node-prod/image-size.js.map +1 -1
  521. package/dist/node-prod/image-size.mjs +8 -8
  522. package/dist/node-prod/image-size.mjs.map +1 -1
  523. package/dist/node-prod/index.js +25 -7
  524. package/dist/node-prod/index.js.map +1 -1
  525. package/dist/node-prod/index.mjs +24 -6
  526. package/dist/node-prod/index.mjs.map +1 -1
  527. package/dist/node-prod/load-script.js +4 -2
  528. package/dist/node-prod/load-script.js.map +1 -1
  529. package/dist/node-prod/load-script.mjs +3 -1
  530. package/dist/node-prod/load-script.mjs.map +1 -1
  531. package/dist/node-prod/node_modules/@xstate/fsm/es/index.js +1 -1
  532. package/dist/node-prod/node_modules/@xstate/fsm/es/index.js.map +1 -1
  533. package/dist/node-prod/node_modules/@xstate/fsm/es/index.mjs.map +1 -1
  534. package/dist/node-prod/node_modules/@xstate/react/es/fsm.js +2 -2
  535. package/dist/node-prod/node_modules/@xstate/react/es/fsm.js.map +1 -1
  536. package/dist/node-prod/node_modules/@xstate/react/es/fsm.mjs +2 -2
  537. package/dist/node-prod/node_modules/@xstate/react/es/fsm.mjs.map +1 -1
  538. package/dist/node-prod/node_modules/@xstate/react/es/useConstant.js +2 -4
  539. package/dist/node-prod/node_modules/@xstate/react/es/useConstant.js.map +1 -1
  540. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.js +2 -4
  541. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.js.map +1 -1
  542. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.development.mjs.map +1 -1
  543. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js +2 -4
  544. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js.map +1 -1
  545. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.mjs.map +1 -1
  546. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js +2 -4
  547. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js.map +1 -1
  548. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.mjs.map +1 -1
  549. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js +2 -4
  550. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js.map +1 -1
  551. package/dist/node-prod/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.mjs.map +1 -1
  552. package/dist/node-prod/node_modules/use-sync-external-store/shim/index.js +4 -4
  553. package/dist/node-prod/node_modules/use-sync-external-store/shim/index.mjs +3 -3
  554. package/dist/node-prod/node_modules/use-sync-external-store/shim/with-selector.js +1 -1
  555. package/dist/node-prod/node_modules/use-sync-external-store/shim/with-selector.mjs +1 -1
  556. package/dist/node-prod/{metafield-parser.js → parse-metafield.js} +21 -13
  557. package/dist/node-prod/parse-metafield.js.map +1 -0
  558. package/dist/node-prod/{metafield-parser.mjs → parse-metafield.mjs} +20 -12
  559. package/dist/node-prod/parse-metafield.mjs.map +1 -0
  560. package/dist/node-prod/storefront-api-constants.js +2 -2
  561. package/dist/node-prod/storefront-api-constants.js.map +1 -1
  562. package/dist/node-prod/storefront-api-constants.mjs +1 -1
  563. package/dist/node-prod/storefront-api-constants.mjs.map +1 -1
  564. package/dist/node-prod/storefront-client.js +28 -28
  565. package/dist/node-prod/storefront-client.js.map +1 -1
  566. package/dist/node-prod/storefront-client.mjs +27 -27
  567. package/dist/node-prod/storefront-client.mjs.map +1 -1
  568. package/dist/node-prod/useCartAPIStateMachine.js +121 -81
  569. package/dist/node-prod/useCartAPIStateMachine.js.map +1 -1
  570. package/dist/node-prod/useCartAPIStateMachine.mjs +120 -80
  571. package/dist/node-prod/useCartAPIStateMachine.mjs.map +1 -1
  572. package/dist/node-prod/useCartActions.js +151 -110
  573. package/dist/node-prod/useCartActions.js.map +1 -1
  574. package/dist/node-prod/useCartActions.mjs +150 -109
  575. package/dist/node-prod/useCartActions.mjs.map +1 -1
  576. package/dist/node-prod/useMoney.js +64 -37
  577. package/dist/node-prod/useMoney.js.map +1 -1
  578. package/dist/node-prod/useMoney.mjs +63 -36
  579. package/dist/node-prod/useMoney.mjs.map +1 -1
  580. package/dist/node-prod/useShopifyCookies.js +41 -0
  581. package/dist/node-prod/useShopifyCookies.js.map +1 -0
  582. package/dist/node-prod/useShopifyCookies.mjs +41 -0
  583. package/dist/node-prod/useShopifyCookies.mjs.map +1 -0
  584. package/dist/types/AddToCartButton.d.ts +7 -3
  585. package/dist/types/BaseButton.d.ts +2 -2
  586. package/dist/types/BuyNowButton.d.ts +10 -4
  587. package/dist/types/CartCheckoutButton.d.ts +9 -6
  588. package/dist/types/CartCost.d.ts +10 -6
  589. package/dist/types/CartLinePrice.d.ts +19 -5
  590. package/dist/types/CartLineProvider.d.ts +18 -10
  591. package/dist/types/CartLineQuantity.d.ts +13 -0
  592. package/dist/types/CartLineQuantityAdjustButton.d.ts +13 -0
  593. package/dist/types/CartProvider.d.ts +13 -3
  594. package/dist/types/ExternalVideo.d.ts +2 -3
  595. package/dist/types/Image.d.ts +5 -3
  596. package/dist/types/MediaFile.d.ts +12 -11
  597. package/dist/types/ModelViewer.d.ts +2 -2
  598. package/dist/types/Money.d.ts +2 -3
  599. package/dist/types/ProductPrice.d.ts +4 -2
  600. package/dist/types/ProductProvider.d.ts +1 -1
  601. package/dist/types/ShopPayButton.d.ts +10 -10
  602. package/dist/types/ShopifyProvider.d.ts +42 -43
  603. package/dist/types/analytics-constants.d.ts +48 -0
  604. package/dist/types/analytics-schema-custom-storefront-customer-tracking.d.ts +3 -0
  605. package/dist/types/analytics-schema-trekkie-storefront-page-view.d.ts +2 -0
  606. package/dist/types/analytics-types.d.ts +157 -0
  607. package/dist/types/analytics-utils.d.ts +36 -0
  608. package/dist/types/analytics.d.ts +9 -0
  609. package/dist/types/cart-queries.d.ts +1 -1
  610. package/dist/types/cookies-utils.d.ts +4 -0
  611. package/dist/types/flatten-connection.d.ts +32 -8
  612. package/dist/types/image-size.d.ts +1 -1
  613. package/dist/types/index.d.cts +13 -4
  614. package/dist/types/index.d.ts +13 -4
  615. package/dist/types/{metafield-parser.d.ts → parse-metafield.d.ts} +11 -9
  616. package/dist/types/storefront-api-constants.d.ts +1 -1
  617. package/dist/types/storefront-api-response.types.d.ts +1 -1
  618. package/dist/types/storefront-api-types.d.ts +121 -2
  619. package/dist/types/storefront-client.d.ts +14 -14
  620. package/dist/types/useCartActions.d.ts +1 -1
  621. package/dist/types/useShopifyCookies.d.ts +14 -0
  622. package/dist/umd/hydrogen-react.dev.js +1714 -1382
  623. package/dist/umd/hydrogen-react.dev.js.map +1 -1
  624. package/dist/umd/hydrogen-react.prod.js +18 -25
  625. package/dist/umd/hydrogen-react.prod.js.map +1 -1
  626. package/package.json +34 -19
  627. package/storefront.schema.json +1 -1
  628. package/dist/browser-dev/Metafield.mjs +0 -301
  629. package/dist/browser-dev/Metafield.mjs.map +0 -1
  630. package/dist/browser-dev/metafield-parser.mjs.map +0 -1
  631. package/dist/browser-prod/Metafield.mjs +0 -288
  632. package/dist/browser-prod/Metafield.mjs.map +0 -1
  633. package/dist/browser-prod/metafield-parser.mjs.map +0 -1
  634. package/dist/node-dev/Metafield.js +0 -301
  635. package/dist/node-dev/Metafield.js.map +0 -1
  636. package/dist/node-dev/Metafield.mjs +0 -301
  637. package/dist/node-dev/Metafield.mjs.map +0 -1
  638. package/dist/node-dev/metafield-parser.js.map +0 -1
  639. package/dist/node-dev/metafield-parser.mjs.map +0 -1
  640. package/dist/node-prod/Metafield.js +0 -288
  641. package/dist/node-prod/Metafield.js.map +0 -1
  642. package/dist/node-prod/Metafield.mjs +0 -288
  643. package/dist/node-prod/Metafield.mjs.map +0 -1
  644. package/dist/node-prod/metafield-parser.js.map +0 -1
  645. package/dist/node-prod/metafield-parser.mjs.map +0 -1
  646. package/dist/types/Metafield.d.ts +0 -61
@@ -1 +1 @@
1
- {"version":3,"file":"Image.mjs","sources":["../../src/Image.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n getShopifyImageDimensions,\n shopifyImageLoader,\n addImageSizeParametersToUrl,\n IMG_SRC_SET_SIZES,\n} from './image-size.js';\nimport type {Image as ImageType} from './storefront-api-types.js';\nimport type {PartialDeep, Simplify} from 'type-fest';\n\ntype HtmlImageProps = React.ImgHTMLAttributes<HTMLImageElement>;\n\nexport type ShopifyLoaderOptions = {\n crop?: 'top' | 'bottom' | 'left' | 'right' | 'center';\n scale?: 2 | 3;\n width?: HtmlImageProps['width'] | ImageType['width'];\n height?: HtmlImageProps['height'] | ImageType['height'];\n};\nexport type ShopifyLoaderParams = Simplify<\n ShopifyLoaderOptions & {\n src: ImageType['url'];\n }\n>;\nexport type ShopifyImageProps = Omit<HtmlImageProps, 'src'> & {\n /** An object with fields that correspond to the Storefront API's\n * [Image object](https://shopify.dev/api/storefront/reference/common-objects/image).\n * The `data` prop is required.\n */\n data: PartialDeep<ImageType, {recurseIntoArrays: true}>;\n /** A custom function that generates the image URL. Parameters passed in\n * are `ShopifyLoaderParams`\n */\n loader?: (params: ShopifyLoaderParams) => string;\n /** An object of `loader` function options. For example, if the `loader` function\n * requires a `scale` option, then the value can be a property of the\n * `loaderOptions` object (for example, `{scale: 2}`). The object shape is `ShopifyLoaderOptions`.\n */\n loaderOptions?: ShopifyLoaderOptions;\n /**\n * `src` isn't used, and should instead be passed as part of the `data` object\n */\n src?: never;\n /**\n * An array of pixel widths to overwrite the default generated srcset. For example, `[300, 600, 800]`.\n */\n widths?: (HtmlImageProps['width'] | ImageType['width'])[];\n};\n\n/**\n * The `Image` component renders an image for the Storefront API's\n * [Image object](https://shopify.dev/api/storefront/reference/common-objects/image) by using the `data` prop. You can [customize this component](https://shopify.dev/api/hydrogen/components#customizing-hydrogen-components) using passthrough props.\n *\n * An image's width and height are determined using the following priority list:\n * 1. The width and height values for the `loaderOptions` prop\n * 2. The width and height values for bare props\n * 3. The width and height values for the `data` prop\n *\n * If only one of `width` or `height` are defined, then the other will attempt to be calculated based on the image's aspect ratio,\n * provided that both `data.width` and `data.height` are available. If `data.width` and `data.height` aren't available, then the aspect ratio cannot be determined and the missing\n * value will remain as `null`\n */\nexport function Image({\n data,\n width,\n height,\n loading,\n loader = shopifyImageLoader,\n loaderOptions,\n widths,\n decoding = 'async',\n ...rest\n}: ShopifyImageProps) {\n if (!data.url) {\n const missingUrlError = `<Image/>: the 'data' prop requires the 'url' property. Image: ${\n data.id ?? 'no ID provided'\n }`;\n\n if (__HYDROGEN_DEV__) {\n throw new Error(missingUrlError);\n } else {\n console.error(missingUrlError);\n }\n\n return null;\n }\n\n if (__HYDROGEN_DEV__ && !data.altText && !rest.alt) {\n console.warn(\n `<Image/>: the 'data' prop should have the 'altText' property, or the 'alt' prop, and one of them should not be empty. Image: ${\n data.id ?? data.url\n }`\n );\n }\n\n const {width: imgElementWidth, height: imgElementHeight} =\n getShopifyImageDimensions({\n data,\n loaderOptions,\n elementProps: {\n width,\n height,\n },\n });\n\n if (__HYDROGEN_DEV__ && (!imgElementWidth || !imgElementHeight)) {\n console.warn(\n `<Image/>: the 'data' prop requires either 'width' or 'data.width', and 'height' or 'data.height' properties. Image: ${\n data.id ?? data.url\n }`\n );\n }\n\n let finalSrc = data.url;\n\n if (loader) {\n finalSrc = loader({\n ...loaderOptions,\n src: data.url,\n width: imgElementWidth,\n height: imgElementHeight,\n });\n if (typeof finalSrc !== 'string' || !finalSrc) {\n throw new Error(\n `<Image/>: 'loader' did not return a valid string. Image: ${\n data.id ?? data.url\n }`\n );\n }\n }\n\n // determining what the intended width of the image is. For example, if the width is specified and lower than the image width, then that is the maximum image width\n // to prevent generating a srcset with widths bigger than needed or to generate images that would distort because of being larger than original\n const maxWidth =\n width && imgElementWidth && width < imgElementWidth\n ? width\n : imgElementWidth;\n const finalSrcset =\n rest.srcSet ??\n internalImageSrcSet({\n ...loaderOptions,\n widths,\n src: data.url,\n width: maxWidth,\n height: imgElementHeight,\n loader,\n });\n\n /* eslint-disable hydrogen/prefer-image-component */\n return (\n <img\n id={data.id ?? ''}\n alt={data.altText ?? rest.alt ?? ''}\n loading={loading ?? 'lazy'}\n {...rest}\n src={finalSrc}\n width={imgElementWidth ?? undefined}\n height={imgElementHeight ?? undefined}\n srcSet={finalSrcset}\n decoding={decoding}\n />\n );\n /* eslint-enable hydrogen/prefer-image-component */\n}\n\ntype InternalShopifySrcSetGeneratorsParams = Simplify<\n ShopifyLoaderOptions & {\n src: ImageType['url'];\n widths?: (HtmlImageProps['width'] | ImageType['width'])[];\n loader?: (params: ShopifyLoaderParams) => string;\n }\n>;\nfunction internalImageSrcSet({\n src,\n width,\n crop,\n scale,\n widths,\n loader,\n height,\n}: InternalShopifySrcSetGeneratorsParams) {\n const hasCustomWidths = widths && Array.isArray(widths);\n if (hasCustomWidths && widths.some((size) => isNaN(size as number))) {\n throw new Error(\n `<Image/>: the 'widths' must be an array of numbers. Image: ${src}`\n );\n }\n\n let aspectRatio = 1;\n if (width && height) {\n aspectRatio = Number(height) / Number(width);\n }\n\n let setSizes = hasCustomWidths ? widths : IMG_SRC_SET_SIZES;\n if (\n !hasCustomWidths &&\n width &&\n width < IMG_SRC_SET_SIZES[IMG_SRC_SET_SIZES.length - 1]\n ) {\n setSizes = IMG_SRC_SET_SIZES.filter((size) => size <= width);\n }\n const srcGenerator = loader ? loader : addImageSizeParametersToUrl;\n return setSizes\n .map(\n (size) =>\n `${srcGenerator({\n src,\n width: size,\n // height is not applied if there is no crop\n // if there is crop, then height is applied as a ratio of the original width + height aspect ratio * size\n height: crop ? Number(size) * aspectRatio : undefined,\n crop,\n scale,\n })} ${size}w`\n )\n .join(', ');\n}\n"],"names":["Image","data","width","height","loading","loader","shopifyImageLoader","loaderOptions","widths","decoding","rest","url","missingUrlError","id","Error","altText","alt","console","warn","imgElementWidth","imgElementHeight","getShopifyImageDimensions","elementProps","finalSrc","src","maxWidth","finalSrcset","srcSet","internalImageSrcSet","undefined","crop","scale","hasCustomWidths","Array","isArray","some","size","isNaN","aspectRatio","Number","setSizes","IMG_SRC_SET_SIZES","length","filter","srcGenerator","addImageSizeParametersToUrl","map","join"],"mappings":";;AA6DO,SAASA,MAAM;AAAA,EACpBC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC,SAASC;AAAAA,EACTC;AAAAA,EACAC;AAAAA,EACAC,WAAW;AAAA,KACRC;AACc,GAAG;;AAChB,MAAA,CAACT,KAAKU,KAAK;AACPC,UAAAA,kBAAmB,kEACvBX,UAAKY,OAALZ,YAAW;AAGS;AACd,YAAA,IAAIa,MAAMF,eAAe;AAAA,IAGjC;AAAA,EAGF;AAEA,MAAwB,CAACX,KAAKc,WAAW,CAACL,KAAKM,KAAK;AAClDC,YAAQC,KACL,iIACCjB,UAAKY,OAALZ,YAAWA,KAAKU,KAChB;AAAA,EAEN;AAEM,QAAA;AAAA,IAACT,OAAOiB;AAAAA,IAAiBhB,QAAQiB;AAAAA,MACrCC,0BAA0B;AAAA,IACxBpB;AAAAA,IACAM;AAAAA,IACAe,cAAc;AAAA,MACZpB;AAAAA,MACAC;AAAAA,IACF;AAAA,EAAA,CACD;AAEH,MAAyB,CAACgB,mBAAmB,CAACC,kBAAmB;AAC/DH,YAAQC,KACL,wHACCjB,UAAKY,OAALZ,YAAWA,KAAKU,KAChB;AAAA,EAEN;AAEA,MAAIY,WAAWtB,KAAKU;AAEpB,MAAIN,QAAQ;AACVkB,eAAWlB,OAAO;AAAA,MAChB,GAAGE;AAAAA,MACHiB,KAAKvB,KAAKU;AAAAA,MACVT,OAAOiB;AAAAA,MACPhB,QAAQiB;AAAAA,IAAAA,CACT;AACD,QAAI,OAAOG,aAAa,YAAY,CAACA,UAAU;AAC7C,YAAM,IAAIT,MACP,6DACCb,UAAKY,OAALZ,YAAWA,KAAKU,KAChB;AAAA,IAEN;AAAA,EACF;AAIA,QAAMc,WACJvB,SAASiB,mBAAmBjB,QAAQiB,kBAChCjB,QACAiB;AACAO,QAAAA,eACJhB,UAAKiB,WAALjB,YACAkB,oBAAoB;AAAA,IAClB,GAAGrB;AAAAA,IACHC;AAAAA,IACAgB,KAAKvB,KAAKU;AAAAA,IACVT,OAAOuB;AAAAA,IACPtB,QAAQiB;AAAAA,IACRf;AAAAA,EAAAA,CACD;AAGH,6BACE,OAAA;AAAA,IACE,KAAIJ,UAAKY,OAALZ,YAAW;AAAA,IACf,MAAKA,gBAAKc,YAALd,YAAgBS,KAAKM,QAArBf,YAA4B;AAAA,IACjC,SAASG,4BAAW;AAAA,IAAO,GACvBM;AAAAA,IACJ,KAAKa;AAAAA,IACL,OAAOJ,4CAAmBU;AAAAA,IAC1B,QAAQT,8CAAoBS;AAAAA,IAC5B,QAAQH;AAAAA,IACR;AAAA,EAAA,CACA;AAGN;AASA,SAASE,oBAAoB;AAAA,EAC3BJ;AAAAA,EACAtB;AAAAA,EACA4B;AAAAA,EACAC;AAAAA,EACAvB;AAAAA,EACAH;AAAAA,EACAF;AACqC,GAAG;AACxC,QAAM6B,kBAAkBxB,UAAUyB,MAAMC,QAAQ1B,MAAM;AACtD,MAAIwB,mBAAmBxB,OAAO2B,KAAMC,UAASC,MAAMD,IAAc,CAAC,GAAG;AAC7D,UAAA,IAAItB,MACP,8DAA6DU,KAAK;AAAA,EAEvE;AAEA,MAAIc,cAAc;AAClB,MAAIpC,SAASC,QAAQ;AACnBmC,kBAAcC,OAAOpC,MAAM,IAAIoC,OAAOrC,KAAK;AAAA,EAC7C;AAEIsC,MAAAA,WAAWR,kBAAkBxB,SAASiC;AAC1C,MACE,CAACT,mBACD9B,SACAA,QAAQuC,kBAAkBA,kBAAkBC,SAAS,IACrD;AACAF,eAAWC,kBAAkBE,OAAQP,CAASA,SAAAA,QAAQlC,KAAK;AAAA,EAC7D;AACM0C,QAAAA,eAAevC,SAASA,SAASwC;AACvC,SAAOL,SACJM,IACEV,CACE,SAAA,GAAEQ,aAAa;AAAA,IACdpB;AAAAA,IACAtB,OAAOkC;AAAAA,IAGPjC,QAAQ2B,OAAOS,OAAOH,IAAI,IAAIE,cAAcT;AAAAA,IAC5CC;AAAAA,IACAC;AAAAA,EAAAA,CACD,KAAKK,OAAO,EAEhBW,KAAK,IAAI;AACd;"}
1
+ {"version":3,"file":"Image.mjs","sources":["../../src/Image.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n getShopifyImageDimensions,\n shopifyImageLoader,\n addImageSizeParametersToUrl,\n IMG_SRC_SET_SIZES,\n} from './image-size.js';\nimport type {Image as ImageType} from './storefront-api-types.js';\nimport type {PartialDeep, Simplify} from 'type-fest';\n\ntype HtmlImageProps = React.ImgHTMLAttributes<HTMLImageElement>;\n\nexport type ShopifyLoaderOptions = {\n crop?: 'top' | 'bottom' | 'left' | 'right' | 'center';\n scale?: 2 | 3;\n width?: HtmlImageProps['width'] | ImageType['width'];\n height?: HtmlImageProps['height'] | ImageType['height'];\n};\nexport type ShopifyLoaderParams = Simplify<ShopifyLoaderOptions & ImageSrc>;\n\ntype ImageSrc = {\n src: ImageType['url'];\n};\n\nexport type ShopifyImageProps = Omit<HtmlImageProps, 'src'> &\n ShopifyImageBaseProps;\n\ntype ShopifyImageBaseProps = {\n /** An object with fields that correspond to the Storefront API's\n * [Image object](https://shopify.dev/api/storefront/reference/common-objects/image).\n * The `data` prop is required.\n */\n data: PartialDeep<ImageType, {recurseIntoArrays: true}>;\n /** A custom function that generates the image URL. Parameters passed in\n * are `ShopifyLoaderParams`\n */\n loader?: (params: ShopifyLoaderParams) => string;\n /** An object of `loader` function options. For example, if the `loader` function\n * requires a `scale` option, then the value can be a property of the\n * `loaderOptions` object (for example, `{scale: 2}`). The object shape is `ShopifyLoaderOptions`.\n */\n loaderOptions?: ShopifyLoaderOptions;\n /**\n * `src` isn't used, and should instead be passed as part of the `data` object\n */\n src?: never;\n /**\n * An array of pixel widths to overwrite the default generated srcset. For example, `[300, 600, 800]`.\n */\n widths?: (HtmlImageProps['width'] | ImageType['width'])[];\n};\n\n/**\n * The `Image` component renders an image for the Storefront API's\n * [Image object](https://shopify.dev/api/storefront/reference/common-objects/image) by using the `data` prop. You can [customize this component](https://shopify.dev/api/hydrogen/components#customizing-hydrogen-components) using passthrough props.\n *\n * An image's width and height are determined using the following priority list:\n * 1. The width and height values for the `loaderOptions` prop\n * 2. The width and height values for bare props\n * 3. The width and height values for the `data` prop\n *\n * If only one of `width` or `height` are defined, then the other will attempt to be calculated based on the image's aspect ratio,\n * provided that both `data.width` and `data.height` are available. If `data.width` and `data.height` aren't available, then the aspect ratio cannot be determined and the missing\n * value will remain as `null`\n */\nexport function Image({\n data,\n width,\n height,\n loading,\n loader = shopifyImageLoader,\n loaderOptions,\n widths,\n decoding = 'async',\n ...rest\n}: ShopifyImageProps): JSX.Element | null {\n if (!data.url) {\n const missingUrlError = `<Image/>: the 'data' prop requires the 'url' property. Image: ${\n data.id ?? 'no ID provided'\n }`;\n\n if (__HYDROGEN_DEV__) {\n throw new Error(missingUrlError);\n } else {\n console.error(missingUrlError);\n }\n\n return null;\n }\n\n if (__HYDROGEN_DEV__ && !data.altText && !rest.alt) {\n console.warn(\n `<Image/>: the 'data' prop should have the 'altText' property, or the 'alt' prop, and one of them should not be empty. Image: ${\n data.id ?? data.url\n }`\n );\n }\n\n const {width: imgElementWidth, height: imgElementHeight} =\n getShopifyImageDimensions({\n data,\n loaderOptions,\n elementProps: {\n width,\n height,\n },\n });\n\n if (__HYDROGEN_DEV__ && (!imgElementWidth || !imgElementHeight)) {\n console.warn(\n `<Image/>: the 'data' prop requires either 'width' or 'data.width', and 'height' or 'data.height' properties. Image: ${\n data.id ?? data.url\n }`\n );\n }\n\n let finalSrc = data.url;\n\n if (loader) {\n finalSrc = loader({\n ...loaderOptions,\n src: data.url,\n width: imgElementWidth,\n height: imgElementHeight,\n });\n if (typeof finalSrc !== 'string' || !finalSrc) {\n throw new Error(\n `<Image/>: 'loader' did not return a valid string. Image: ${\n data.id ?? data.url\n }`\n );\n }\n }\n\n // determining what the intended width of the image is. For example, if the width is specified and lower than the image width, then that is the maximum image width\n // to prevent generating a srcset with widths bigger than needed or to generate images that would distort because of being larger than original\n const maxWidth =\n width && imgElementWidth && width < imgElementWidth\n ? width\n : imgElementWidth;\n const finalSrcset =\n rest.srcSet ??\n internalImageSrcSet({\n ...loaderOptions,\n widths,\n src: data.url,\n width: maxWidth,\n height: imgElementHeight,\n loader,\n });\n\n /* eslint-disable hydrogen/prefer-image-component */\n return (\n <img\n id={data.id ?? ''}\n alt={data.altText ?? rest.alt ?? ''}\n loading={loading ?? 'lazy'}\n {...rest}\n src={finalSrc}\n width={imgElementWidth ?? undefined}\n height={imgElementHeight ?? undefined}\n srcSet={finalSrcset}\n decoding={decoding}\n />\n );\n /* eslint-enable hydrogen/prefer-image-component */\n}\n\ntype InternalShopifySrcSetGeneratorsParams = Simplify<\n ShopifyLoaderOptions & {\n src: ImageType['url'];\n widths?: (HtmlImageProps['width'] | ImageType['width'])[];\n loader?: (params: ShopifyLoaderParams) => string;\n }\n>;\nfunction internalImageSrcSet({\n src,\n width,\n crop,\n scale,\n widths,\n loader,\n height,\n}: InternalShopifySrcSetGeneratorsParams): string {\n const hasCustomWidths = widths && Array.isArray(widths);\n if (hasCustomWidths && widths.some((size) => isNaN(size as number))) {\n throw new Error(\n `<Image/>: the 'widths' must be an array of numbers. Image: ${src}`\n );\n }\n\n let aspectRatio = 1;\n if (width && height) {\n aspectRatio = Number(height) / Number(width);\n }\n\n let setSizes = hasCustomWidths ? widths : IMG_SRC_SET_SIZES;\n if (\n !hasCustomWidths &&\n width &&\n width < IMG_SRC_SET_SIZES[IMG_SRC_SET_SIZES.length - 1]\n ) {\n setSizes = IMG_SRC_SET_SIZES.filter((size) => size <= width);\n }\n const srcGenerator = loader ? loader : addImageSizeParametersToUrl;\n return setSizes\n .map(\n (size) =>\n `${srcGenerator({\n src,\n width: size,\n // height is not applied if there is no crop\n // if there is crop, then height is applied as a ratio of the original width + height aspect ratio * size\n height: crop ? Number(size) * aspectRatio : undefined,\n crop,\n scale,\n })} ${size ?? ''}w`\n )\n .join(', ');\n}\n"],"names":[],"mappings":";;AAiEO,SAAS,MAAM;AAAA,EACpB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,SAAS;AAAA,EACT;AAAA,EACA;AAAA,EACA,WAAW;AAAA,EACX,GAAG;AACL,GAA0C;AACpC,MAAA,CAAC,KAAK,KAAK;AACP,UAAA,kBAAkB,iEACtB,KAAK,MAAM;AAGS;AACd,YAAA,IAAI,MAAM,eAAe;AAAA,IAGjC;AAAA,EAGF;AAEA,MAAwB,CAAC,KAAK,WAAW,CAAC,KAAK,KAAK;AAC1C,YAAA;AAAA,MACN,gIACE,KAAK,MAAM,KAAK;AAAA,IAAA;AAAA,EAGtB;AAEA,QAAM,EAAC,OAAO,iBAAiB,QAAQ,iBAAA,IACrC,0BAA0B;AAAA,IACxB;AAAA,IACA;AAAA,IACA,cAAc;AAAA,MACZ;AAAA,MACA;AAAA,IACF;AAAA,EAAA,CACD;AAEH,MAAyB,CAAC,mBAAmB,CAAC,kBAAmB;AACvD,YAAA;AAAA,MACN,uHACE,KAAK,MAAM,KAAK;AAAA,IAAA;AAAA,EAGtB;AAEA,MAAI,WAAW,KAAK;AAEpB,MAAI,QAAQ;AACV,eAAW,OAAO;AAAA,MAChB,GAAG;AAAA,MACH,KAAK,KAAK;AAAA,MACV,OAAO;AAAA,MACP,QAAQ;AAAA,IAAA,CACT;AACD,QAAI,OAAO,aAAa,YAAY,CAAC,UAAU;AAC7C,YAAM,IAAI;AAAA,QACR,4DACE,KAAK,MAAM,KAAK;AAAA,MAAA;AAAA,IAGtB;AAAA,EACF;AAIA,QAAM,WACJ,SAAS,mBAAmB,QAAQ,kBAChC,QACA;AACA,QAAA,cACJ,KAAK,UACL,oBAAoB;AAAA,IAClB,GAAG;AAAA,IACH;AAAA,IACA,KAAK,KAAK;AAAA,IACV,OAAO;AAAA,IACP,QAAQ;AAAA,IACR;AAAA,EAAA,CACD;AAID,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAI,KAAK,MAAM;AAAA,MACf,KAAK,KAAK,WAAW,KAAK,OAAO;AAAA,MACjC,SAAS,WAAW;AAAA,MACnB,GAAG;AAAA,MACJ,KAAK;AAAA,MACL,OAAO,mBAAmB;AAAA,MAC1B,QAAQ,oBAAoB;AAAA,MAC5B,QAAQ;AAAA,MACR;AAAA,IAAA;AAAA,EAAA;AAIN;AASA,SAAS,oBAAoB;AAAA,EAC3B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAkD;AAChD,QAAM,kBAAkB,UAAU,MAAM,QAAQ,MAAM;AAClD,MAAA,mBAAmB,OAAO,KAAK,CAAC,SAAS,MAAM,IAAc,CAAC,GAAG;AACnE,UAAM,IAAI;AAAA,MACR,8DAA8D;AAAA,IAAA;AAAA,EAElE;AAEA,MAAI,cAAc;AAClB,MAAI,SAAS,QAAQ;AACnB,kBAAc,OAAO,MAAM,IAAI,OAAO,KAAK;AAAA,EAC7C;AAEI,MAAA,WAAW,kBAAkB,SAAS;AAExC,MAAA,CAAC,mBACD,SACA,QAAQ,kBAAkB,kBAAkB,SAAS,CAAC,GACtD;AACA,eAAW,kBAAkB,OAAO,CAAC,SAAS,QAAQ,KAAK;AAAA,EAC7D;AACM,QAAA,eAAe,SAAS,SAAS;AACvC,SAAO,SACJ;AAAA,IACC,CAAC,SACC,GAAG,aAAa;AAAA,MACd;AAAA,MACA,OAAO;AAAA;AAAA;AAAA,MAGP,QAAQ,OAAO,OAAO,IAAI,IAAI,cAAc;AAAA,MAC5C;AAAA,MACA;AAAA,IACD,CAAA,KAAK,QAAQ;AAAA,EAAA,EAEjB,KAAK,IAAI;AACd;"}
@@ -1,8 +1,8 @@
1
+ import { jsx } from "react/jsx-runtime";
1
2
  import { Image } from "./Image.mjs";
2
3
  import { Video } from "./Video.mjs";
3
4
  import { ExternalVideo } from "./ExternalVideo.mjs";
4
5
  import { ModelViewer } from "./ModelViewer.mjs";
5
- import { jsx } from "react/jsx-runtime";
6
6
  function MediaFile({
7
7
  data,
8
8
  mediaOptions,
@@ -16,32 +16,40 @@ function MediaFile({
16
16
  throw new Error(noDataImage);
17
17
  }
18
18
  }
19
- return /* @__PURE__ */ jsx(Image, {
20
- ...passthroughProps,
21
- ...mediaOptions == null ? void 0 : mediaOptions.image,
22
- data: data.image
23
- });
19
+ return /* @__PURE__ */ jsx(
20
+ Image,
21
+ {
22
+ ...passthroughProps,
23
+ ...mediaOptions == null ? void 0 : mediaOptions.image,
24
+ data: data.image
25
+ }
26
+ );
24
27
  }
25
28
  case "Video": {
26
- return /* @__PURE__ */ jsx(Video, {
27
- ...passthroughProps,
28
- ...mediaOptions == null ? void 0 : mediaOptions.video,
29
- data
30
- });
29
+ return /* @__PURE__ */ jsx(Video, { ...passthroughProps, ...mediaOptions == null ? void 0 : mediaOptions.video, data });
31
30
  }
32
31
  case "ExternalVideo": {
33
- return /* @__PURE__ */ jsx(ExternalVideo, {
34
- ...passthroughProps,
35
- ...mediaOptions == null ? void 0 : mediaOptions.externalVideo,
36
- data
37
- });
32
+ return /* @__PURE__ */ jsx(
33
+ ExternalVideo,
34
+ {
35
+ ...passthroughProps,
36
+ ...mediaOptions == null ? void 0 : mediaOptions.externalVideo,
37
+ data
38
+ }
39
+ );
38
40
  }
39
41
  case "Model3d": {
40
- return /* @__PURE__ */ jsx(ModelViewer, {
41
- ...passthroughProps,
42
- ...mediaOptions == null ? void 0 : mediaOptions.modelViewer,
43
- data
44
- });
42
+ return (
43
+ // @ts-expect-error There are issues with the inferred HTML attribute types here for ModelViewer (and contentEditable), but I think that's a little bit beyond me at the moment
44
+ /* @__PURE__ */ jsx(
45
+ ModelViewer,
46
+ {
47
+ ...passthroughProps,
48
+ ...mediaOptions == null ? void 0 : mediaOptions.modelViewer,
49
+ data
50
+ }
51
+ )
52
+ );
45
53
  }
46
54
  default: {
47
55
  const typenameMissingMessage = `<MediaFile /> requires the '__typename' property to exist on the 'data' prop in order to render the matching sub-component for this type of media.`;
@@ -1 +1 @@
1
- {"version":3,"file":"MediaFile.mjs","sources":["../../src/MediaFile.tsx"],"sourcesContent":["import {Image, type ShopifyImageProps} from './Image.js';\nimport {Video} from './Video.js';\nimport {ExternalVideo} from './ExternalVideo.js';\nimport {ModelViewer} from './ModelViewer.js';\nimport type {MediaEdge as MediaEdgeType} from './storefront-api-types.js';\nimport type {PartialDeep} from 'type-fest';\nimport type {ModelViewerElement} from '@google/model-viewer/lib/model-viewer.js';\n\ntype BaseProps = React.HTMLAttributes<\n HTMLImageElement | HTMLVideoElement | HTMLIFrameElement | ModelViewerElement\n>;\nexport interface MediaFileProps extends BaseProps {\n /** An object with fields that correspond to the Storefront API's [Media object](https://shopify.dev/api/storefront/reference/products/media). */\n data: PartialDeep<MediaEdgeType['node'], {recurseIntoArrays: true}>;\n /** The options for the `Image`, `Video`, or `ExternalVideo` components. */\n mediaOptions?: {\n /** Props that will only apply when an `<Image />` is rendered */\n image?: Omit<ShopifyImageProps, 'data'>;\n /** Props that will only apply when a `<Video />` is rendered */\n video?: Omit<React.ComponentProps<typeof Video>, 'data'>;\n /** Props that will only apply when an `<ExternalVideo />` is rendered */\n externalVideo?: Omit<\n React.ComponentProps<typeof ExternalVideo>['options'],\n 'data'\n >;\n /** Props that will only apply when a `<ModelViewer />` is rendered */\n modelViewer?: Omit<typeof ModelViewer, 'data'>;\n };\n}\n\n/**\n * The `MediaFile` component renders the media for the Storefront API's\n * [Media object](https://shopify.dev/api/storefront/reference/products/media). It renders an `Image`, a\n * `Video`, an `ExternalVideo`, or a `ModelViewer` depending on the `__typename` of the `data` prop.\n */\nexport function MediaFile({\n data,\n mediaOptions,\n ...passthroughProps\n}: MediaFileProps) {\n switch (data.__typename) {\n case 'MediaImage': {\n if (!data.image) {\n const noDataImage = `<MediaFile/>: 'data.image' does not exist for __typename of 'MediaImage'; rendering 'null' by default.`;\n if (__HYDROGEN_DEV__) {\n throw new Error(noDataImage);\n } else {\n console.warn(noDataImage);\n return null;\n }\n }\n\n return (\n <Image\n {...passthroughProps}\n {...mediaOptions?.image}\n data={data.image}\n />\n );\n }\n case 'Video': {\n return (\n <Video {...passthroughProps} {...mediaOptions?.video} data={data} />\n );\n }\n case 'ExternalVideo': {\n return (\n <ExternalVideo\n {...passthroughProps}\n {...mediaOptions?.externalVideo}\n data={data}\n />\n );\n }\n case 'Model3d': {\n return (\n // @ts-expect-error There are issues with the inferred HTML attribute types here for ModelViewer (and contentEditable), but I think that's a little bit beyond me at the moment\n <ModelViewer\n {...passthroughProps}\n {...mediaOptions?.modelViewer}\n data={data}\n />\n );\n }\n default: {\n const typenameMissingMessage = `<MediaFile /> requires the '__typename' property to exist on the 'data' prop in order to render the matching sub-component for this type of media.`;\n if (__HYDROGEN_DEV__) {\n throw new Error(typenameMissingMessage);\n } else {\n console.error(`${typenameMissingMessage} Rendering 'null' by default`);\n return null;\n }\n }\n }\n}\n"],"names":["MediaFile","data","mediaOptions","passthroughProps","__typename","image","noDataImage","Error","video","externalVideo","modelViewer","typenameMissingMessage"],"mappings":";;;;;AAmCO,SAASA,UAAU;AAAA,EACxBC;AAAAA,EACAC;AAAAA,KACGC;AACW,GAAG;AACjB,UAAQF,KAAKG,YAAU;AAAA,IACrB,KAAK,cAAc;AACb,UAAA,CAACH,KAAKI,OAAO;AACf,cAAMC,cAAe;AACC;AACd,gBAAA,IAAIC,MAAMD,WAAW;AAAA,QAI7B;AAAA,MACF;AAEA,iCACG,OAAK;AAAA,QAAA,GACAH;AAAAA,QAAgB,GAChBD,6CAAcG;AAAAA,QAClB,MAAMJ,KAAKI;AAAAA,MAAAA,CACX;AAAA,IAEN;AAAA,IACA,KAAK,SAAS;AACZ,iCACG,OAAK;AAAA,QAAA,GAAKF;AAAAA,QAAgB,GAAMD,6CAAcM;AAAAA,QAAO;AAAA,MAAA,CAAc;AAAA,IAExE;AAAA,IACA,KAAK,iBAAiB;AACpB,iCACG,eAAa;AAAA,QAAA,GACRL;AAAAA,QAAgB,GAChBD,6CAAcO;AAAAA,QAClB;AAAA,MAAA,CACA;AAAA,IAEN;AAAA,IACA,KAAK,WAAW;AACd,iCAEG,aAAW;AAAA,QAAA,GACNN;AAAAA,QAAgB,GAChBD,6CAAcQ;AAAAA,QAClB;AAAA,MAAA,CAAW;AAAA,IAGjB;AAAA,IACA,SAAS;AACP,YAAMC,yBAA0B;AACV;AACd,cAAA,IAAIJ,MAAMI,sBAAsB;AAAA,MAIxC;AAAA,IACF;AAAA,EAAC;AAEL;"}
1
+ {"version":3,"file":"MediaFile.mjs","sources":["../../src/MediaFile.tsx"],"sourcesContent":["import {Image, type ShopifyImageProps} from './Image.js';\nimport {Video} from './Video.js';\nimport {ExternalVideo} from './ExternalVideo.js';\nimport {ModelViewer} from './ModelViewer.js';\nimport type {MediaEdge as MediaEdgeType} from './storefront-api-types.js';\nimport type {PartialDeep} from 'type-fest';\nimport type {ModelViewerElement} from '@google/model-viewer/lib/model-viewer.js';\n\ntype BaseProps = React.HTMLAttributes<\n HTMLImageElement | HTMLVideoElement | HTMLIFrameElement | ModelViewerElement\n>;\nexport interface MediaFileProps extends BaseProps {\n /** An object with fields that correspond to the Storefront API's [Media object](https://shopify.dev/api/storefront/reference/products/media). */\n data: PartialDeep<MediaEdgeType['node'], {recurseIntoArrays: true}>;\n /** The options for the `Image`, `Video`, `ExternalVideo`, or `ModelViewer` components. */\n mediaOptions?: MediaOptions;\n}\n\ntype MediaOptions = {\n /** Props that will only apply when an `<Image />` is rendered */\n image?: Omit<ShopifyImageProps, 'data'>;\n /** Props that will only apply when a `<Video />` is rendered */\n video?: Omit<React.ComponentProps<typeof Video>, 'data'>;\n /** Props that will only apply when an `<ExternalVideo />` is rendered */\n externalVideo?: Omit<\n React.ComponentProps<typeof ExternalVideo>['options'],\n 'data'\n >;\n /** Props that will only apply when a `<ModelViewer />` is rendered */\n modelViewer?: Omit<typeof ModelViewer, 'data'>;\n};\n\n/**\n * The `MediaFile` component renders the media for the Storefront API's\n * [Media object](https://shopify.dev/api/storefront/reference/products/media). It renders an `Image`, a\n * `Video`, an `ExternalVideo`, or a `ModelViewer` depending on the `__typename` of the `data` prop.\n */\nexport function MediaFile({\n data,\n mediaOptions,\n ...passthroughProps\n}: MediaFileProps): JSX.Element | null {\n switch (data.__typename) {\n case 'MediaImage': {\n if (!data.image) {\n const noDataImage = `<MediaFile/>: 'data.image' does not exist for __typename of 'MediaImage'; rendering 'null' by default.`;\n if (__HYDROGEN_DEV__) {\n throw new Error(noDataImage);\n } else {\n console.warn(noDataImage);\n return null;\n }\n }\n\n return (\n <Image\n {...passthroughProps}\n {...mediaOptions?.image}\n data={data.image}\n />\n );\n }\n case 'Video': {\n return (\n <Video {...passthroughProps} {...mediaOptions?.video} data={data} />\n );\n }\n case 'ExternalVideo': {\n return (\n <ExternalVideo\n {...passthroughProps}\n {...mediaOptions?.externalVideo}\n data={data}\n />\n );\n }\n case 'Model3d': {\n return (\n // @ts-expect-error There are issues with the inferred HTML attribute types here for ModelViewer (and contentEditable), but I think that's a little bit beyond me at the moment\n <ModelViewer\n {...passthroughProps}\n {...mediaOptions?.modelViewer}\n data={data}\n />\n );\n }\n default: {\n const typenameMissingMessage = `<MediaFile /> requires the '__typename' property to exist on the 'data' prop in order to render the matching sub-component for this type of media.`;\n if (__HYDROGEN_DEV__) {\n throw new Error(typenameMissingMessage);\n } else {\n console.error(`${typenameMissingMessage} Rendering 'null' by default`);\n return null;\n }\n }\n }\n}\n"],"names":[],"mappings":";;;;;AAqCO,SAAS,UAAU;AAAA,EACxB;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAAuC;AACrC,UAAQ,KAAK,YAAY;AAAA,IACvB,KAAK,cAAc;AACb,UAAA,CAAC,KAAK,OAAO;AACf,cAAM,cAAc;AACE;AACd,gBAAA,IAAI,MAAM,WAAW;AAAA,QAI7B;AAAA,MACF;AAGE,aAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACE,GAAG;AAAA,UACH,GAAG,6CAAc;AAAA,UAClB,MAAM,KAAK;AAAA,QAAA;AAAA,MAAA;AAAA,IAGjB;AAAA,IACA,KAAK,SAAS;AACZ,iCACG,OAAO,EAAA,GAAG,kBAAmB,GAAG,6CAAc,OAAO,KAAY,CAAA;AAAA,IAEtE;AAAA,IACA,KAAK,iBAAiB;AAElB,aAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACE,GAAG;AAAA,UACH,GAAG,6CAAc;AAAA,UAClB;AAAA,QAAA;AAAA,MAAA;AAAA,IAGN;AAAA,IACA,KAAK,WAAW;AACd;AAAA;AAAA,QAEE;AAAA,UAAC;AAAA,UAAA;AAAA,YACE,GAAG;AAAA,YACH,GAAG,6CAAc;AAAA,YAClB;AAAA,UAAA;AAAA,QACF;AAAA;AAAA,IAEJ;AAAA,IACA,SAAS;AACP,YAAM,yBAAyB;AACT;AACd,cAAA,IAAI,MAAM,sBAAsB;AAAA,MAIxC;AAAA,IACF;AAAA,EACF;AACF;"}
@@ -1,21 +1,21 @@
1
+ import { jsx } from "react/jsx-runtime";
1
2
  import { useState, useCallback, useEffect } from "react";
2
3
  import { useLoadScript } from "./load-script.mjs";
3
- import { jsx } from "react/jsx-runtime";
4
4
  function ModelViewer(props) {
5
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
6
- const [modelViewer, setModelViewer] = useState(void 0);
5
+ var _a, _b, _c;
6
+ const [modelViewer, setModelViewer] = useState(
7
+ void 0
8
+ );
7
9
  const callbackRef = useCallback((node) => {
8
10
  setModelViewer(node);
9
11
  }, []);
10
- const {
11
- data,
12
- children,
13
- className,
14
- ...passthroughProps
15
- } = props;
16
- const modelViewerLoadedStatus = useLoadScript("https://unpkg.com/@google/model-viewer@v1.12.1/dist/model-viewer.min.js", {
17
- module: true
18
- });
12
+ const { data, children, className, ...passthroughProps } = props;
13
+ const modelViewerLoadedStatus = useLoadScript(
14
+ "https://unpkg.com/@google/model-viewer@v1.12.1/dist/model-viewer.min.js",
15
+ {
16
+ module: true
17
+ }
18
+ );
19
19
  useEffect(() => {
20
20
  if (!modelViewer) {
21
21
  return;
@@ -27,25 +27,43 @@ function ModelViewer(props) {
27
27
  if (passthroughProps.onPreload)
28
28
  modelViewer.addEventListener("preload", passthroughProps.onPreload);
29
29
  if (passthroughProps.onModelVisibility)
30
- modelViewer.addEventListener("model-visibility", passthroughProps.onModelVisibility);
30
+ modelViewer.addEventListener(
31
+ "model-visibility",
32
+ passthroughProps.onModelVisibility
33
+ );
31
34
  if (passthroughProps.onProgress)
32
35
  modelViewer.addEventListener("progress", passthroughProps.onProgress);
33
36
  if (passthroughProps.onArStatus)
34
37
  modelViewer.addEventListener("ar-status", passthroughProps.onArStatus);
35
38
  if (passthroughProps.onArTracking)
36
- modelViewer.addEventListener("ar-tracking", passthroughProps.onArTracking);
39
+ modelViewer.addEventListener(
40
+ "ar-tracking",
41
+ passthroughProps.onArTracking
42
+ );
37
43
  if (passthroughProps.onQuickLookButtonTapped)
38
- modelViewer.addEventListener("quick-look-button-tapped", passthroughProps.onQuickLookButtonTapped);
44
+ modelViewer.addEventListener(
45
+ "quick-look-button-tapped",
46
+ passthroughProps.onQuickLookButtonTapped
47
+ );
39
48
  if (passthroughProps.onCameraChange)
40
- modelViewer.addEventListener("camera-change", passthroughProps.onCameraChange);
49
+ modelViewer.addEventListener(
50
+ "camera-change",
51
+ passthroughProps.onCameraChange
52
+ );
41
53
  if (passthroughProps.onEnvironmentChange)
42
- modelViewer.addEventListener("environment-change", passthroughProps.onEnvironmentChange);
54
+ modelViewer.addEventListener(
55
+ "environment-change",
56
+ passthroughProps.onEnvironmentChange
57
+ );
43
58
  if (passthroughProps.onPlay)
44
59
  modelViewer.addEventListener("play", passthroughProps.onPlay);
45
60
  if (passthroughProps.onPause)
46
61
  modelViewer.addEventListener("ar-status", passthroughProps.onPause);
47
62
  if (passthroughProps.onSceneGraphReady)
48
- modelViewer.addEventListener("scene-graph-ready", passthroughProps.onSceneGraphReady);
63
+ modelViewer.addEventListener(
64
+ "scene-graph-ready",
65
+ passthroughProps.onSceneGraphReady
66
+ );
49
67
  return () => {
50
68
  if (modelViewer == null) {
51
69
  return;
@@ -57,27 +75,66 @@ function ModelViewer(props) {
57
75
  if (passthroughProps.onPreload)
58
76
  modelViewer.removeEventListener("preload", passthroughProps.onPreload);
59
77
  if (passthroughProps.onModelVisibility)
60
- modelViewer.removeEventListener("model-visibility", passthroughProps.onModelVisibility);
78
+ modelViewer.removeEventListener(
79
+ "model-visibility",
80
+ passthroughProps.onModelVisibility
81
+ );
61
82
  if (passthroughProps.onProgress)
62
- modelViewer.removeEventListener("progress", passthroughProps.onProgress);
83
+ modelViewer.removeEventListener(
84
+ "progress",
85
+ passthroughProps.onProgress
86
+ );
63
87
  if (passthroughProps.onArStatus)
64
- modelViewer.removeEventListener("ar-status", passthroughProps.onArStatus);
88
+ modelViewer.removeEventListener(
89
+ "ar-status",
90
+ passthroughProps.onArStatus
91
+ );
65
92
  if (passthroughProps.onArTracking)
66
- modelViewer.removeEventListener("ar-tracking", passthroughProps.onArTracking);
93
+ modelViewer.removeEventListener(
94
+ "ar-tracking",
95
+ passthroughProps.onArTracking
96
+ );
67
97
  if (passthroughProps.onQuickLookButtonTapped)
68
- modelViewer.removeEventListener("quick-look-button-tapped", passthroughProps.onQuickLookButtonTapped);
98
+ modelViewer.removeEventListener(
99
+ "quick-look-button-tapped",
100
+ passthroughProps.onQuickLookButtonTapped
101
+ );
69
102
  if (passthroughProps.onCameraChange)
70
- modelViewer.removeEventListener("camera-change", passthroughProps.onCameraChange);
103
+ modelViewer.removeEventListener(
104
+ "camera-change",
105
+ passthroughProps.onCameraChange
106
+ );
71
107
  if (passthroughProps.onEnvironmentChange)
72
- modelViewer.removeEventListener("environment-change", passthroughProps.onEnvironmentChange);
108
+ modelViewer.removeEventListener(
109
+ "environment-change",
110
+ passthroughProps.onEnvironmentChange
111
+ );
73
112
  if (passthroughProps.onPlay)
74
113
  modelViewer.removeEventListener("play", passthroughProps.onPlay);
75
114
  if (passthroughProps.onPause)
76
115
  modelViewer.removeEventListener("ar-status", passthroughProps.onPause);
77
116
  if (passthroughProps.onSceneGraphReady)
78
- modelViewer.removeEventListener("scene-graph-ready", passthroughProps.onSceneGraphReady);
117
+ modelViewer.removeEventListener(
118
+ "scene-graph-ready",
119
+ passthroughProps.onSceneGraphReady
120
+ );
79
121
  };
80
- }, [modelViewer, passthroughProps.onArStatus, passthroughProps.onArTracking, passthroughProps.onCameraChange, passthroughProps.onEnvironmentChange, passthroughProps.onError, passthroughProps.onLoad, passthroughProps.onModelVisibility, passthroughProps.onPause, passthroughProps.onPlay, passthroughProps.onPreload, passthroughProps.onProgress, passthroughProps.onQuickLookButtonTapped, passthroughProps.onSceneGraphReady]);
122
+ }, [
123
+ modelViewer,
124
+ passthroughProps.onArStatus,
125
+ passthroughProps.onArTracking,
126
+ passthroughProps.onCameraChange,
127
+ passthroughProps.onEnvironmentChange,
128
+ passthroughProps.onError,
129
+ passthroughProps.onLoad,
130
+ passthroughProps.onModelVisibility,
131
+ passthroughProps.onPause,
132
+ passthroughProps.onPlay,
133
+ passthroughProps.onPreload,
134
+ passthroughProps.onProgress,
135
+ passthroughProps.onQuickLookButtonTapped,
136
+ passthroughProps.onSceneGraphReady
137
+ ]);
81
138
  if (modelViewerLoadedStatus !== "done") {
82
139
  return null;
83
140
  }
@@ -88,56 +145,61 @@ function ModelViewer(props) {
88
145
  }
89
146
  }
90
147
  if (!data.alt) {
91
- console.warn(`<ModelViewer/> requires the 'data.alt' prop for accessibility`);
148
+ console.warn(
149
+ `<ModelViewer/> requires the 'data.alt' prop for accessibility`
150
+ );
92
151
  }
93
- return /* @__PURE__ */ jsx("model-viewer", {
94
- ref: callbackRef,
95
- ...passthroughProps,
96
- className,
97
- id: (_c = passthroughProps.id) != null ? _c : data.id,
98
- src: data.sources[0].url,
99
- alt: (_d = data.alt) != null ? _d : null,
100
- "camera-controls": (_e = passthroughProps.cameraControls) != null ? _e : true,
101
- poster: (_g = passthroughProps.poster || ((_f = data.previewImage) == null ? void 0 : _f.url)) != null ? _g : null,
102
- autoplay: (_h = passthroughProps.autoplay) != null ? _h : true,
103
- loading: passthroughProps.loading,
104
- reveal: passthroughProps.reveal,
105
- ar: passthroughProps.ar,
106
- "ar-modes": passthroughProps.arModes,
107
- "ar-scale": passthroughProps.arScale,
108
- "ar-placement": passthroughProps.arPlacement,
109
- "ios-src": passthroughProps.iosSrc,
110
- "touch-action": passthroughProps.touchAction,
111
- "disable-zoom": passthroughProps.disableZoom,
112
- "orbit-sensitivity": passthroughProps.orbitSensitivity,
113
- "auto-rotate": passthroughProps.autoRotate,
114
- "auto-rotate-delay": passthroughProps.autoRotateDelay,
115
- "rotation-per-second": passthroughProps.rotationPerSecond,
116
- "interaction-policy": passthroughProps.interactionPolicy,
117
- "interaction-prompt": passthroughProps.interactionPrompt,
118
- "interaction-prompt-style": passthroughProps.interactionPromptStyle,
119
- "interaction-prompt-threshold": passthroughProps.interactionPromptThreshold,
120
- "camera-orbit": passthroughProps.cameraOrbit,
121
- "camera-target": passthroughProps.cameraTarget,
122
- "field-of-view": passthroughProps.fieldOfView,
123
- "max-camera-orbit": passthroughProps.maxCameraOrbit,
124
- "min-camera-orbit": passthroughProps.minCameraOrbit,
125
- "max-field-of-view": passthroughProps.maxFieldOfView,
126
- "min-field-of-view": passthroughProps.minFieldOfView,
127
- bounds: passthroughProps.bounds,
128
- "interpolation-decay": (_i = passthroughProps.interpolationDecay) != null ? _i : 100,
129
- "skybox-image": passthroughProps.skyboxImage,
130
- "environment-image": passthroughProps.environmentImage,
131
- exposure: passthroughProps.exposure,
132
- "shadow-intensity": (_j = passthroughProps.shadowIntensity) != null ? _j : 0,
133
- "shadow-softness": (_k = passthroughProps.shadowSoftness) != null ? _k : 0,
134
- "animation-name": passthroughProps.animationName,
135
- "animation-crossfade-duration": passthroughProps.animationCrossfadeDuration,
136
- "variant-name": passthroughProps.variantName,
137
- orientation: passthroughProps.orientation,
138
- scale: passthroughProps.scale,
139
- children
140
- });
152
+ return /* @__PURE__ */ jsx(
153
+ "model-viewer",
154
+ {
155
+ ref: callbackRef,
156
+ ...passthroughProps,
157
+ className,
158
+ id: passthroughProps.id ?? data.id,
159
+ src: data.sources[0].url,
160
+ alt: data.alt ?? null,
161
+ "camera-controls": passthroughProps.cameraControls ?? true,
162
+ poster: (passthroughProps.poster || ((_c = data.previewImage) == null ? void 0 : _c.url)) ?? null,
163
+ autoplay: passthroughProps.autoplay ?? true,
164
+ loading: passthroughProps.loading,
165
+ reveal: passthroughProps.reveal,
166
+ ar: passthroughProps.ar,
167
+ "ar-modes": passthroughProps.arModes,
168
+ "ar-scale": passthroughProps.arScale,
169
+ "ar-placement": passthroughProps.arPlacement,
170
+ "ios-src": passthroughProps.iosSrc,
171
+ "touch-action": passthroughProps.touchAction,
172
+ "disable-zoom": passthroughProps.disableZoom,
173
+ "orbit-sensitivity": passthroughProps.orbitSensitivity,
174
+ "auto-rotate": passthroughProps.autoRotate,
175
+ "auto-rotate-delay": passthroughProps.autoRotateDelay,
176
+ "rotation-per-second": passthroughProps.rotationPerSecond,
177
+ "interaction-policy": passthroughProps.interactionPolicy,
178
+ "interaction-prompt": passthroughProps.interactionPrompt,
179
+ "interaction-prompt-style": passthroughProps.interactionPromptStyle,
180
+ "interaction-prompt-threshold": passthroughProps.interactionPromptThreshold,
181
+ "camera-orbit": passthroughProps.cameraOrbit,
182
+ "camera-target": passthroughProps.cameraTarget,
183
+ "field-of-view": passthroughProps.fieldOfView,
184
+ "max-camera-orbit": passthroughProps.maxCameraOrbit,
185
+ "min-camera-orbit": passthroughProps.minCameraOrbit,
186
+ "max-field-of-view": passthroughProps.maxFieldOfView,
187
+ "min-field-of-view": passthroughProps.minFieldOfView,
188
+ bounds: passthroughProps.bounds,
189
+ "interpolation-decay": passthroughProps.interpolationDecay ?? 100,
190
+ "skybox-image": passthroughProps.skyboxImage,
191
+ "environment-image": passthroughProps.environmentImage,
192
+ exposure: passthroughProps.exposure,
193
+ "shadow-intensity": passthroughProps.shadowIntensity ?? 0,
194
+ "shadow-softness": passthroughProps.shadowSoftness ?? 0,
195
+ "animation-name": passthroughProps.animationName,
196
+ "animation-crossfade-duration": passthroughProps.animationCrossfadeDuration,
197
+ "variant-name": passthroughProps.variantName,
198
+ orientation: passthroughProps.orientation,
199
+ scale: passthroughProps.scale,
200
+ children
201
+ }
202
+ );
141
203
  }
142
204
  export {
143
205
  ModelViewer
@@ -1 +1 @@
1
- {"version":3,"file":"ModelViewer.mjs","sources":["../../src/ModelViewer.tsx"],"sourcesContent":["import {useState, useEffect, useCallback} from 'react';\nimport {useLoadScript} from './load-script.js';\nimport type {Model3d} from './storefront-api-types.js';\nimport type {PartialDeep} from 'type-fest';\nimport type {ModelViewerElement} from '@google/model-viewer/lib/model-viewer.js';\n\ntype PropsWeControl = 'src';\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace JSX {\n interface IntrinsicElements {\n 'model-viewer': PartialDeep<\n ModelViewerElement,\n {recurseIntoArrays: true}\n >;\n }\n }\n}\n\ntype ModelViewerProps = Omit<\n PartialDeep<JSX.IntrinsicElements['model-viewer'], {recurseIntoArrays: true}>,\n PropsWeControl\n> & {\n /** An object with fields that correspond to the Storefront API's [Model3D object](https://shopify.dev/api/storefront/latest/objects/model3d). */\n data: PartialDeep<Model3d, {recurseIntoArrays: true}>;\n /** The callback to invoke when the 'error' event is triggered. Refer to [error in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-error). */\n onError?: (event: Event) => void;\n /** The callback to invoke when the `load` event is triggered. Refer to [load in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-load). */\n onLoad?: (event: Event) => void;\n /** The callback to invoke when the 'preload' event is triggered. Refer to [preload in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-preload). */\n onPreload?: (event: Event) => void;\n /** The callback to invoke when the 'model-visibility' event is triggered. Refer to [model-visibility in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-modelVisibility). */\n onModelVisibility?: (event: Event) => void;\n /** The callback to invoke when the 'progress' event is triggered. Refer to [progress in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-progress). */\n onProgress?: (event: Event) => void;\n /** The callback to invoke when the 'ar-status' event is triggered. Refer to [ar-status in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-events-arStatus). */\n onArStatus?: (event: Event) => void;\n /** The callback to invoke when the 'ar-tracking' event is triggered. Refer to [ar-tracking in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-events-arTracking). */\n onArTracking?: (event: Event) => void;\n /** The callback to invoke when the 'quick-look-button-tapped' event is triggered. Refer to [quick-look-button-tapped in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-events-quickLookButtonTapped). */\n onQuickLookButtonTapped?: (event: Event) => void;\n /** The callback to invoke when the 'camera-change' event is triggered. Refer to [camera-change in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-stagingandcameras-events-cameraChange). */\n onCameraChange?: (event: Event) => void;\n /** The callback to invoke when the 'environment-change' event is triggered. Refer to [environment-change in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-lightingandenv-events-environmentChange). */\n onEnvironmentChange?: (event: Event) => void;\n /** The callback to invoke when the 'play' event is triggered. Refer to [play in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-animation-events-play). */\n onPlay?: (event: Event) => void;\n /** The callback to invoke when the 'pause' event is triggered. Refer to [pause in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-animation-events-pause). */\n onPause?: (event: Event) => void;\n /** The callback to invoke when the 'scene-graph-ready' event is triggered. Refer to [scene-graph-ready in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-scenegraph-events-sceneGraphReady). */\n onSceneGraphReady?: (event: Event) => void;\n};\n\n/**\n * The `ModelViewer` component renders a 3D model (with the `model-viewer` custom element) for\n * the Storefront API's [Model3d object](https://shopify.dev/api/storefront/reference/products/model3d).\n *\n * The `model-viewer` custom element is lazily downloaded through a dynamically-injected `<script type=\"module\">` tag when the `<ModelViewer />` component is rendered\n *\n * ModelViewer is using version `1.21.1` of the `@google/model-viewer` library.\n */\nexport function ModelViewer(props: ModelViewerProps) {\n const [modelViewer, setModelViewer] = useState<undefined | HTMLElement>(\n undefined\n );\n const callbackRef = useCallback((node: HTMLElement) => {\n setModelViewer(node);\n }, []);\n const {data, children, className, ...passthroughProps} = props;\n\n const modelViewerLoadedStatus = useLoadScript(\n 'https://unpkg.com/@google/model-viewer@v1.12.1/dist/model-viewer.min.js',\n {\n module: true,\n }\n );\n\n useEffect(() => {\n if (!modelViewer) {\n return;\n }\n if (passthroughProps.onError)\n modelViewer.addEventListener('error', passthroughProps.onError);\n if (passthroughProps.onLoad)\n modelViewer.addEventListener('load', passthroughProps.onLoad);\n if (passthroughProps.onPreload)\n modelViewer.addEventListener('preload', passthroughProps.onPreload);\n if (passthroughProps.onModelVisibility)\n modelViewer.addEventListener(\n 'model-visibility',\n passthroughProps.onModelVisibility\n );\n if (passthroughProps.onProgress)\n modelViewer.addEventListener('progress', passthroughProps.onProgress);\n if (passthroughProps.onArStatus)\n modelViewer.addEventListener('ar-status', passthroughProps.onArStatus);\n if (passthroughProps.onArTracking)\n modelViewer.addEventListener(\n 'ar-tracking',\n passthroughProps.onArTracking\n );\n if (passthroughProps.onQuickLookButtonTapped)\n modelViewer.addEventListener(\n 'quick-look-button-tapped',\n passthroughProps.onQuickLookButtonTapped\n );\n if (passthroughProps.onCameraChange)\n modelViewer.addEventListener(\n 'camera-change',\n passthroughProps.onCameraChange\n );\n if (passthroughProps.onEnvironmentChange)\n modelViewer.addEventListener(\n 'environment-change',\n passthroughProps.onEnvironmentChange\n );\n if (passthroughProps.onPlay)\n modelViewer.addEventListener('play', passthroughProps.onPlay);\n if (passthroughProps.onPause)\n modelViewer.addEventListener('ar-status', passthroughProps.onPause);\n if (passthroughProps.onSceneGraphReady)\n modelViewer.addEventListener(\n 'scene-graph-ready',\n passthroughProps.onSceneGraphReady\n );\n\n return () => {\n if (modelViewer == null) {\n return;\n }\n if (passthroughProps.onError)\n modelViewer.removeEventListener('error', passthroughProps.onError);\n if (passthroughProps.onLoad)\n modelViewer.removeEventListener('load', passthroughProps.onLoad);\n if (passthroughProps.onPreload)\n modelViewer.removeEventListener('preload', passthroughProps.onPreload);\n if (passthroughProps.onModelVisibility)\n modelViewer.removeEventListener(\n 'model-visibility',\n passthroughProps.onModelVisibility\n );\n if (passthroughProps.onProgress)\n modelViewer.removeEventListener(\n 'progress',\n passthroughProps.onProgress\n );\n if (passthroughProps.onArStatus)\n modelViewer.removeEventListener(\n 'ar-status',\n passthroughProps.onArStatus\n );\n if (passthroughProps.onArTracking)\n modelViewer.removeEventListener(\n 'ar-tracking',\n passthroughProps.onArTracking\n );\n if (passthroughProps.onQuickLookButtonTapped)\n modelViewer.removeEventListener(\n 'quick-look-button-tapped',\n passthroughProps.onQuickLookButtonTapped\n );\n if (passthroughProps.onCameraChange)\n modelViewer.removeEventListener(\n 'camera-change',\n passthroughProps.onCameraChange\n );\n if (passthroughProps.onEnvironmentChange)\n modelViewer.removeEventListener(\n 'environment-change',\n passthroughProps.onEnvironmentChange\n );\n if (passthroughProps.onPlay)\n modelViewer.removeEventListener('play', passthroughProps.onPlay);\n if (passthroughProps.onPause)\n modelViewer.removeEventListener('ar-status', passthroughProps.onPause);\n if (passthroughProps.onSceneGraphReady)\n modelViewer.removeEventListener(\n 'scene-graph-ready',\n passthroughProps.onSceneGraphReady\n );\n };\n }, [\n modelViewer,\n passthroughProps.onArStatus,\n passthroughProps.onArTracking,\n passthroughProps.onCameraChange,\n passthroughProps.onEnvironmentChange,\n passthroughProps.onError,\n passthroughProps.onLoad,\n passthroughProps.onModelVisibility,\n passthroughProps.onPause,\n passthroughProps.onPlay,\n passthroughProps.onPreload,\n passthroughProps.onProgress,\n passthroughProps.onQuickLookButtonTapped,\n passthroughProps.onSceneGraphReady,\n ]);\n\n if (modelViewerLoadedStatus !== 'done') {\n // TODO: What do we want to display while the model-viewer library loads?\n return null;\n }\n\n if (!data.sources?.[0]?.url) {\n const sourcesUrlError = `<ModelViewer/> requires 'data.sources' prop to be an array, with an object that has a property 'url' on it. Rendering 'null'`;\n if (__HYDROGEN_DEV__) {\n throw new Error(sourcesUrlError);\n } else {\n console.error(sourcesUrlError);\n return null;\n }\n }\n\n if (__HYDROGEN_DEV__ && !data.alt) {\n console.warn(\n `<ModelViewer/> requires the 'data.alt' prop for accessibility`\n );\n }\n\n return (\n <model-viewer\n // @ts-expect-error ref should exist\n ref={callbackRef}\n {...passthroughProps}\n className={className}\n id={passthroughProps.id ?? data.id}\n src={data.sources[0].url}\n alt={data.alt ?? null}\n camera-controls={passthroughProps.cameraControls ?? true}\n poster={(passthroughProps.poster || data.previewImage?.url) ?? null}\n autoplay={passthroughProps.autoplay ?? true}\n loading={passthroughProps.loading}\n reveal={passthroughProps.reveal}\n ar={passthroughProps.ar}\n ar-modes={passthroughProps.arModes}\n ar-scale={passthroughProps.arScale}\n // @ts-expect-error arPlacement should exist as a type, not sure why it doesn't. https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-attributes-arPlacement\n ar-placement={passthroughProps.arPlacement}\n ios-src={passthroughProps.iosSrc}\n touch-action={passthroughProps.touchAction}\n disable-zoom={passthroughProps.disableZoom}\n orbit-sensitivity={passthroughProps.orbitSensitivity}\n auto-rotate={passthroughProps.autoRotate}\n auto-rotate-delay={passthroughProps.autoRotateDelay}\n // @ts-expect-error rotationPerSecond should exist as a type, not sure why it doesn't. https://modelviewer.dev/docs/index.html#entrydocs-stagingandcameras-attributes-rotationPerSecond\n rotation-per-second={passthroughProps.rotationPerSecond}\n interaction-policy={passthroughProps.interactionPolicy}\n interaction-prompt={passthroughProps.interactionPrompt}\n interaction-prompt-style={passthroughProps.interactionPromptStyle}\n interaction-prompt-threshold={passthroughProps.interactionPromptThreshold}\n camera-orbit={passthroughProps.cameraOrbit}\n camera-target={passthroughProps.cameraTarget}\n field-of-view={passthroughProps.fieldOfView}\n max-camera-orbit={passthroughProps.maxCameraOrbit}\n min-camera-orbit={passthroughProps.minCameraOrbit}\n max-field-of-view={passthroughProps.maxFieldOfView}\n min-field-of-view={passthroughProps.minFieldOfView}\n bounds={passthroughProps.bounds}\n interpolation-decay={passthroughProps.interpolationDecay ?? 100}\n skybox-image={passthroughProps.skyboxImage}\n environment-image={passthroughProps.environmentImage}\n exposure={passthroughProps.exposure}\n shadow-intensity={passthroughProps.shadowIntensity ?? 0}\n shadow-softness={passthroughProps.shadowSoftness ?? 0}\n animation-name={passthroughProps.animationName}\n animation-crossfade-duration={passthroughProps.animationCrossfadeDuration}\n variant-name={passthroughProps.variantName}\n orientation={passthroughProps.orientation}\n scale={passthroughProps.scale}\n >\n {children}\n </model-viewer>\n );\n}\n"],"names":["ModelViewer","props","modelViewer","setModelViewer","useState","undefined","callbackRef","useCallback","node","data","children","className","passthroughProps","modelViewerLoadedStatus","useLoadScript","module","useEffect","onError","addEventListener","onLoad","onPreload","onModelVisibility","onProgress","onArStatus","onArTracking","onQuickLookButtonTapped","onCameraChange","onEnvironmentChange","onPlay","onPause","onSceneGraphReady","removeEventListener","sources","url","sourcesUrlError","Error","__HYDROGEN_DEV__","alt","console","warn","id","cameraControls","poster","previewImage","autoplay","loading","reveal","ar","arModes","arScale","arPlacement","iosSrc","touchAction","disableZoom","orbitSensitivity","autoRotate","autoRotateDelay","rotationPerSecond","interactionPolicy","interactionPrompt","interactionPromptStyle","interactionPromptThreshold","cameraOrbit","cameraTarget","fieldOfView","maxCameraOrbit","minCameraOrbit","maxFieldOfView","minFieldOfView","bounds","interpolationDecay","skyboxImage","environmentImage","exposure","shadowIntensity","shadowSoftness","animationName","animationCrossfadeDuration","variantName","orientation","scale"],"mappings":"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"}
1
+ {"version":3,"file":"ModelViewer.mjs","sources":["../../src/ModelViewer.tsx"],"sourcesContent":["import {useState, useEffect, useCallback} from 'react';\nimport {useLoadScript} from './load-script.js';\nimport type {Model3d} from './storefront-api-types.js';\nimport type {PartialDeep} from 'type-fest';\nimport type {ModelViewerElement} from '@google/model-viewer/lib/model-viewer.js';\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace JSX {\n interface IntrinsicElements {\n 'model-viewer': PartialDeep<\n ModelViewerElement,\n {recurseIntoArrays: true}\n >;\n }\n }\n}\n\ntype ModelViewerProps = Omit<\n PartialDeep<JSX.IntrinsicElements['model-viewer'], {recurseIntoArrays: true}>,\n 'src'\n> &\n ModelViewerBaseProps;\n\ntype ModelViewerBaseProps = {\n /** An object with fields that correspond to the Storefront API's [Model3D object](https://shopify.dev/api/storefront/latest/objects/model3d). */\n data: PartialDeep<Model3d, {recurseIntoArrays: true}>;\n /** The callback to invoke when the 'error' event is triggered. Refer to [error in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-error). */\n onError?: (event: Event) => void;\n /** The callback to invoke when the `load` event is triggered. Refer to [load in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-load). */\n onLoad?: (event: Event) => void;\n /** The callback to invoke when the 'preload' event is triggered. Refer to [preload in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-preload). */\n onPreload?: (event: Event) => void;\n /** The callback to invoke when the 'model-visibility' event is triggered. Refer to [model-visibility in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-modelVisibility). */\n onModelVisibility?: (event: Event) => void;\n /** The callback to invoke when the 'progress' event is triggered. Refer to [progress in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-loading-events-progress). */\n onProgress?: (event: Event) => void;\n /** The callback to invoke when the 'ar-status' event is triggered. Refer to [ar-status in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-events-arStatus). */\n onArStatus?: (event: Event) => void;\n /** The callback to invoke when the 'ar-tracking' event is triggered. Refer to [ar-tracking in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-events-arTracking). */\n onArTracking?: (event: Event) => void;\n /** The callback to invoke when the 'quick-look-button-tapped' event is triggered. Refer to [quick-look-button-tapped in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-events-quickLookButtonTapped). */\n onQuickLookButtonTapped?: (event: Event) => void;\n /** The callback to invoke when the 'camera-change' event is triggered. Refer to [camera-change in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-stagingandcameras-events-cameraChange). */\n onCameraChange?: (event: Event) => void;\n /** The callback to invoke when the 'environment-change' event is triggered. Refer to [environment-change in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-lightingandenv-events-environmentChange). */\n onEnvironmentChange?: (event: Event) => void;\n /** The callback to invoke when the 'play' event is triggered. Refer to [play in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-animation-events-play). */\n onPlay?: (event: Event) => void;\n /** The callback to invoke when the 'pause' event is triggered. Refer to [pause in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-animation-events-pause). */\n onPause?: (event: Event) => void;\n /** The callback to invoke when the 'scene-graph-ready' event is triggered. Refer to [scene-graph-ready in the <model-viewer> documentation](https://modelviewer.dev/docs/index.html#entrydocs-scenegraph-events-sceneGraphReady). */\n onSceneGraphReady?: (event: Event) => void;\n};\n\n/**\n * The `ModelViewer` component renders a 3D model (with the `model-viewer` custom element) for\n * the Storefront API's [Model3d object](https://shopify.dev/api/storefront/reference/products/model3d).\n *\n * The `model-viewer` custom element is lazily downloaded through a dynamically-injected `<script type=\"module\">` tag when the `<ModelViewer />` component is rendered\n *\n * ModelViewer is using version `1.21.1` of the `@google/model-viewer` library.\n */\nexport function ModelViewer(props: ModelViewerProps): JSX.Element | null {\n const [modelViewer, setModelViewer] = useState<undefined | HTMLElement>(\n undefined\n );\n const callbackRef = useCallback((node: HTMLElement) => {\n setModelViewer(node);\n }, []);\n const {data, children, className, ...passthroughProps} = props;\n\n const modelViewerLoadedStatus = useLoadScript(\n 'https://unpkg.com/@google/model-viewer@v1.12.1/dist/model-viewer.min.js',\n {\n module: true,\n }\n );\n\n useEffect(() => {\n if (!modelViewer) {\n return;\n }\n if (passthroughProps.onError)\n modelViewer.addEventListener('error', passthroughProps.onError);\n if (passthroughProps.onLoad)\n modelViewer.addEventListener('load', passthroughProps.onLoad);\n if (passthroughProps.onPreload)\n modelViewer.addEventListener('preload', passthroughProps.onPreload);\n if (passthroughProps.onModelVisibility)\n modelViewer.addEventListener(\n 'model-visibility',\n passthroughProps.onModelVisibility\n );\n if (passthroughProps.onProgress)\n modelViewer.addEventListener('progress', passthroughProps.onProgress);\n if (passthroughProps.onArStatus)\n modelViewer.addEventListener('ar-status', passthroughProps.onArStatus);\n if (passthroughProps.onArTracking)\n modelViewer.addEventListener(\n 'ar-tracking',\n passthroughProps.onArTracking\n );\n if (passthroughProps.onQuickLookButtonTapped)\n modelViewer.addEventListener(\n 'quick-look-button-tapped',\n passthroughProps.onQuickLookButtonTapped\n );\n if (passthroughProps.onCameraChange)\n modelViewer.addEventListener(\n 'camera-change',\n passthroughProps.onCameraChange\n );\n if (passthroughProps.onEnvironmentChange)\n modelViewer.addEventListener(\n 'environment-change',\n passthroughProps.onEnvironmentChange\n );\n if (passthroughProps.onPlay)\n modelViewer.addEventListener('play', passthroughProps.onPlay);\n if (passthroughProps.onPause)\n modelViewer.addEventListener('ar-status', passthroughProps.onPause);\n if (passthroughProps.onSceneGraphReady)\n modelViewer.addEventListener(\n 'scene-graph-ready',\n passthroughProps.onSceneGraphReady\n );\n\n return () => {\n if (modelViewer == null) {\n return;\n }\n if (passthroughProps.onError)\n modelViewer.removeEventListener('error', passthroughProps.onError);\n if (passthroughProps.onLoad)\n modelViewer.removeEventListener('load', passthroughProps.onLoad);\n if (passthroughProps.onPreload)\n modelViewer.removeEventListener('preload', passthroughProps.onPreload);\n if (passthroughProps.onModelVisibility)\n modelViewer.removeEventListener(\n 'model-visibility',\n passthroughProps.onModelVisibility\n );\n if (passthroughProps.onProgress)\n modelViewer.removeEventListener(\n 'progress',\n passthroughProps.onProgress\n );\n if (passthroughProps.onArStatus)\n modelViewer.removeEventListener(\n 'ar-status',\n passthroughProps.onArStatus\n );\n if (passthroughProps.onArTracking)\n modelViewer.removeEventListener(\n 'ar-tracking',\n passthroughProps.onArTracking\n );\n if (passthroughProps.onQuickLookButtonTapped)\n modelViewer.removeEventListener(\n 'quick-look-button-tapped',\n passthroughProps.onQuickLookButtonTapped\n );\n if (passthroughProps.onCameraChange)\n modelViewer.removeEventListener(\n 'camera-change',\n passthroughProps.onCameraChange\n );\n if (passthroughProps.onEnvironmentChange)\n modelViewer.removeEventListener(\n 'environment-change',\n passthroughProps.onEnvironmentChange\n );\n if (passthroughProps.onPlay)\n modelViewer.removeEventListener('play', passthroughProps.onPlay);\n if (passthroughProps.onPause)\n modelViewer.removeEventListener('ar-status', passthroughProps.onPause);\n if (passthroughProps.onSceneGraphReady)\n modelViewer.removeEventListener(\n 'scene-graph-ready',\n passthroughProps.onSceneGraphReady\n );\n };\n }, [\n modelViewer,\n passthroughProps.onArStatus,\n passthroughProps.onArTracking,\n passthroughProps.onCameraChange,\n passthroughProps.onEnvironmentChange,\n passthroughProps.onError,\n passthroughProps.onLoad,\n passthroughProps.onModelVisibility,\n passthroughProps.onPause,\n passthroughProps.onPlay,\n passthroughProps.onPreload,\n passthroughProps.onProgress,\n passthroughProps.onQuickLookButtonTapped,\n passthroughProps.onSceneGraphReady,\n ]);\n\n if (modelViewerLoadedStatus !== 'done') {\n // TODO: What do we want to display while the model-viewer library loads?\n return null;\n }\n\n if (!data.sources?.[0]?.url) {\n const sourcesUrlError = `<ModelViewer/> requires 'data.sources' prop to be an array, with an object that has a property 'url' on it. Rendering 'null'`;\n if (__HYDROGEN_DEV__) {\n throw new Error(sourcesUrlError);\n } else {\n console.error(sourcesUrlError);\n return null;\n }\n }\n\n if (__HYDROGEN_DEV__ && !data.alt) {\n console.warn(\n `<ModelViewer/> requires the 'data.alt' prop for accessibility`\n );\n }\n\n return (\n <model-viewer\n // @ts-expect-error ref should exist\n ref={callbackRef}\n {...passthroughProps}\n className={className}\n id={passthroughProps.id ?? data.id}\n src={data.sources[0].url}\n alt={data.alt ?? null}\n camera-controls={passthroughProps.cameraControls ?? true}\n poster={(passthroughProps.poster || data.previewImage?.url) ?? null}\n autoplay={passthroughProps.autoplay ?? true}\n loading={passthroughProps.loading}\n reveal={passthroughProps.reveal}\n ar={passthroughProps.ar}\n ar-modes={passthroughProps.arModes}\n ar-scale={passthroughProps.arScale}\n // @ts-expect-error arPlacement should exist as a type, not sure why it doesn't. https://modelviewer.dev/docs/index.html#entrydocs-augmentedreality-attributes-arPlacement\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n ar-placement={passthroughProps.arPlacement}\n ios-src={passthroughProps.iosSrc}\n touch-action={passthroughProps.touchAction}\n disable-zoom={passthroughProps.disableZoom}\n orbit-sensitivity={passthroughProps.orbitSensitivity}\n auto-rotate={passthroughProps.autoRotate}\n auto-rotate-delay={passthroughProps.autoRotateDelay}\n // @ts-expect-error rotationPerSecond should exist as a type, not sure why it doesn't. https://modelviewer.dev/docs/index.html#entrydocs-stagingandcameras-attributes-rotationPerSecond\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n rotation-per-second={passthroughProps.rotationPerSecond}\n interaction-policy={passthroughProps.interactionPolicy}\n interaction-prompt={passthroughProps.interactionPrompt}\n interaction-prompt-style={passthroughProps.interactionPromptStyle}\n interaction-prompt-threshold={passthroughProps.interactionPromptThreshold}\n camera-orbit={passthroughProps.cameraOrbit}\n camera-target={passthroughProps.cameraTarget}\n field-of-view={passthroughProps.fieldOfView}\n max-camera-orbit={passthroughProps.maxCameraOrbit}\n min-camera-orbit={passthroughProps.minCameraOrbit}\n max-field-of-view={passthroughProps.maxFieldOfView}\n min-field-of-view={passthroughProps.minFieldOfView}\n bounds={passthroughProps.bounds}\n interpolation-decay={passthroughProps.interpolationDecay ?? 100}\n skybox-image={passthroughProps.skyboxImage}\n environment-image={passthroughProps.environmentImage}\n exposure={passthroughProps.exposure}\n shadow-intensity={passthroughProps.shadowIntensity ?? 0}\n shadow-softness={passthroughProps.shadowSoftness ?? 0}\n animation-name={passthroughProps.animationName}\n animation-crossfade-duration={passthroughProps.animationCrossfadeDuration}\n variant-name={passthroughProps.variantName}\n orientation={passthroughProps.orientation}\n scale={passthroughProps.scale}\n >\n {children}\n </model-viewer>\n );\n}\n"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { useMoney } from "./useMoney.mjs";
2
1
  import { jsxs, Fragment } from "react/jsx-runtime";
2
+ import { useMoney } from "./useMoney.mjs";
3
3
  function Money({
4
4
  data,
5
5
  as,
@@ -10,10 +10,12 @@ function Money({
10
10
  ...passthroughProps
11
11
  }) {
12
12
  if (!isMoney(data)) {
13
- throw new Error(`<Money/> needs a valid 'data' prop that has 'amount' and 'currencyCode'`);
13
+ throw new Error(
14
+ `<Money/> needs a valid 'data' prop that has 'amount' and 'currencyCode'`
15
+ );
14
16
  }
15
17
  const moneyObject = useMoney(data);
16
- const Wrapper = as != null ? as : "div";
18
+ const Wrapper = as ?? "div";
17
19
  let output = moneyObject.localizedString;
18
20
  if (withoutCurrency || withoutTrailingZeros) {
19
21
  if (withoutCurrency && !withoutTrailingZeros) {
@@ -24,12 +26,13 @@ function Money({
24
26
  output = moneyObject.withoutTrailingZerosAndCurrency;
25
27
  }
26
28
  }
27
- return /* @__PURE__ */ jsxs(Wrapper, {
28
- ...passthroughProps,
29
- children: [output, measurement && measurement.referenceUnit && /* @__PURE__ */ jsxs(Fragment, {
30
- children: [measurementSeparator, measurement.referenceUnit]
31
- })]
32
- });
29
+ return /* @__PURE__ */ jsxs(Wrapper, { ...passthroughProps, children: [
30
+ output,
31
+ measurement && measurement.referenceUnit && /* @__PURE__ */ jsxs(Fragment, { children: [
32
+ measurementSeparator,
33
+ measurement.referenceUnit
34
+ ] })
35
+ ] });
33
36
  }
34
37
  function isMoney(maybeMoney) {
35
38
  return typeof maybeMoney.amount === "string" && !!maybeMoney.amount && typeof maybeMoney.currencyCode === "string" && !!maybeMoney.currencyCode;
@@ -1 +1 @@
1
- {"version":3,"file":"Money.mjs","sources":["../../src/Money.tsx"],"sourcesContent":["import {type ReactNode} from 'react';\nimport {useMoney} from './useMoney.js';\nimport type {MoneyV2, UnitPriceMeasurement} from './storefront-api-types.js';\nimport type {PartialDeep} from 'type-fest';\n\ninterface CustomProps<ComponentGeneric extends React.ElementType> {\n /** An HTML tag or React Component to be rendered as the base element wrapper. The default is `div`. */\n as?: ComponentGeneric;\n /** An object with fields that correspond to the Storefront API's [MoneyV2 object](https://shopify.dev/api/storefront/reference/common-objects/moneyv2). */\n data: PartialDeep<MoneyV2, {recurseIntoArrays: true}>;\n /** Whether to remove the currency symbol from the output. */\n withoutCurrency?: boolean;\n /** Whether to remove trailing zeros (fractional money) from the output. */\n withoutTrailingZeros?: boolean;\n /** A [UnitPriceMeasurement object](https://shopify.dev/api/storefront/latest/objects/unitpricemeasurement). */\n measurement?: PartialDeep<UnitPriceMeasurement, {recurseIntoArrays: true}>;\n /** Customizes the separator between the money output and the measurement output. Used with the `measurement` prop. Defaults to `'/'`. */\n measurementSeparator?: ReactNode;\n}\n\n// This article helps understand the typing here https://www.benmvp.com/blog/polymorphic-react-components-typescript/ Ben is the best :)\nexport type MoneyProps<ComponentGeneric extends React.ElementType> =\n CustomProps<ComponentGeneric> &\n Omit<\n React.ComponentPropsWithoutRef<ComponentGeneric>,\n keyof CustomProps<ComponentGeneric>\n >;\n\n/**\n * The `Money` component renders a string of the Storefront API's\n * [MoneyV2 object](https://shopify.dev/api/storefront/reference/common-objects/moneyv2) according to the\n * `locale` in the `ShopifyProvider` component.\n */\nexport function Money<ComponentGeneric extends React.ElementType = 'div'>({\n data,\n as,\n withoutCurrency,\n withoutTrailingZeros,\n measurement,\n measurementSeparator = '/',\n ...passthroughProps\n}: MoneyProps<ComponentGeneric>) {\n if (!isMoney(data)) {\n throw new Error(\n `<Money/> needs a valid 'data' prop that has 'amount' and 'currencyCode'`\n );\n }\n const moneyObject = useMoney(data);\n const Wrapper = as ?? 'div';\n\n let output = moneyObject.localizedString;\n\n if (withoutCurrency || withoutTrailingZeros) {\n if (withoutCurrency && !withoutTrailingZeros) {\n output = moneyObject.amount;\n } else if (!withoutCurrency && withoutTrailingZeros) {\n output = moneyObject.withoutTrailingZeros;\n } else {\n // both\n output = moneyObject.withoutTrailingZerosAndCurrency;\n }\n }\n\n return (\n <Wrapper {...passthroughProps}>\n {output}\n {measurement && measurement.referenceUnit && (\n <>\n {measurementSeparator}\n {measurement.referenceUnit}\n </>\n )}\n </Wrapper>\n );\n}\n\n// required in order to narrow the money object down and make TS happy\nfunction isMoney(\n maybeMoney: PartialDeep<MoneyV2, {recurseIntoArrays: true}>\n): maybeMoney is MoneyV2 {\n return (\n typeof maybeMoney.amount === 'string' &&\n !!maybeMoney.amount &&\n typeof maybeMoney.currencyCode === 'string' &&\n !!maybeMoney.currencyCode\n );\n}\n"],"names":["Money","data","as","withoutCurrency","withoutTrailingZeros","measurement","measurementSeparator","passthroughProps","isMoney","Error","moneyObject","useMoney","Wrapper","output","localizedString","amount","withoutTrailingZerosAndCurrency","referenceUnit","_Fragment","maybeMoney","currencyCode"],"mappings":";;AAiCO,SAASA,MAA0D;AAAA,EACxEC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC,uBAAuB;AAAA,KACpBC;AACyB,GAAG;AAC3B,MAAA,CAACC,QAAQP,IAAI,GAAG;AACZ,UAAA,IAAIQ,MACP,yEAAwE;AAAA,EAE7E;AACMC,QAAAA,cAAcC,SAASV,IAAI;AACjC,QAAMW,UAAUV,kBAAM;AAEtB,MAAIW,SAASH,YAAYI;AAEzB,MAAIX,mBAAmBC,sBAAsB;AACvCD,QAAAA,mBAAmB,CAACC,sBAAsB;AAC5CS,eAASH,YAAYK;AAAAA,IAAAA,WACZ,CAACZ,mBAAmBC,sBAAsB;AACnDS,eAASH,YAAYN;AAAAA,IAAAA,OAChB;AAELS,eAASH,YAAYM;AAAAA,IACvB;AAAA,EACF;AAEA,8BACG,SAAO;AAAA,IAAA,GAAKT;AAAAA,IAAgB,UAAA,CAC1BM,QACAR,eAAeA,YAAYY,sCAC1BC,UAAA;AAAA,MAAA,UAAA,CACGZ,sBACAD,YAAYY,aAAa;AAAA,IAAA,CAE7B,CAAA;AAAA,EAAA,CACO;AAEd;AAGA,SAAST,QACPW,YACuB;AACvB,SACE,OAAOA,WAAWJ,WAAW,YAC7B,CAAC,CAACI,WAAWJ,UACb,OAAOI,WAAWC,iBAAiB,YACnC,CAAC,CAACD,WAAWC;AAEjB;"}
1
+ {"version":3,"file":"Money.mjs","sources":["../../src/Money.tsx"],"sourcesContent":["import {type ReactNode} from 'react';\nimport {useMoney} from './useMoney.js';\nimport type {MoneyV2, UnitPriceMeasurement} from './storefront-api-types.js';\nimport type {PartialDeep} from 'type-fest';\n\nexport interface MoneyPropsBase<ComponentGeneric extends React.ElementType> {\n /** An HTML tag or React Component to be rendered as the base element wrapper. The default is `div`. */\n as?: ComponentGeneric;\n /** An object with fields that correspond to the Storefront API's [MoneyV2 object](https://shopify.dev/api/storefront/reference/common-objects/moneyv2). */\n data: PartialDeep<MoneyV2, {recurseIntoArrays: true}>;\n /** Whether to remove the currency symbol from the output. */\n withoutCurrency?: boolean;\n /** Whether to remove trailing zeros (fractional money) from the output. */\n withoutTrailingZeros?: boolean;\n /** A [UnitPriceMeasurement object](https://shopify.dev/api/storefront/latest/objects/unitpricemeasurement). */\n measurement?: PartialDeep<UnitPriceMeasurement, {recurseIntoArrays: true}>;\n /** Customizes the separator between the money output and the measurement output. Used with the `measurement` prop. Defaults to `'/'`. */\n measurementSeparator?: ReactNode;\n}\n\n// This article helps understand the typing here https://www.benmvp.com/blog/polymorphic-react-components-typescript/ Ben is the best :)\nexport type MoneyProps<ComponentGeneric extends React.ElementType> =\n MoneyPropsBase<ComponentGeneric> &\n Omit<\n React.ComponentPropsWithoutRef<ComponentGeneric>,\n keyof MoneyPropsBase<ComponentGeneric>\n >;\n\n/**\n * The `Money` component renders a string of the Storefront API's\n * [MoneyV2 object](https://shopify.dev/api/storefront/reference/common-objects/moneyv2) according to the\n * `locale` in the `ShopifyProvider` component.\n */\nexport function Money<ComponentGeneric extends React.ElementType = 'div'>({\n data,\n as,\n withoutCurrency,\n withoutTrailingZeros,\n measurement,\n measurementSeparator = '/',\n ...passthroughProps\n}: MoneyProps<ComponentGeneric>): JSX.Element {\n if (!isMoney(data)) {\n throw new Error(\n `<Money/> needs a valid 'data' prop that has 'amount' and 'currencyCode'`\n );\n }\n const moneyObject = useMoney(data);\n const Wrapper = as ?? 'div';\n\n let output = moneyObject.localizedString;\n\n if (withoutCurrency || withoutTrailingZeros) {\n if (withoutCurrency && !withoutTrailingZeros) {\n output = moneyObject.amount;\n } else if (!withoutCurrency && withoutTrailingZeros) {\n output = moneyObject.withoutTrailingZeros;\n } else {\n // both\n output = moneyObject.withoutTrailingZerosAndCurrency;\n }\n }\n\n return (\n <Wrapper {...passthroughProps}>\n {output}\n {measurement && measurement.referenceUnit && (\n <>\n {measurementSeparator}\n {measurement.referenceUnit}\n </>\n )}\n </Wrapper>\n );\n}\n\n// required in order to narrow the money object down and make TS happy\nfunction isMoney(\n maybeMoney: PartialDeep<MoneyV2, {recurseIntoArrays: true}>\n): maybeMoney is MoneyV2 {\n return (\n typeof maybeMoney.amount === 'string' &&\n !!maybeMoney.amount &&\n typeof maybeMoney.currencyCode === 'string' &&\n !!maybeMoney.currencyCode\n );\n}\n"],"names":[],"mappings":";;AAiCO,SAAS,MAA0D;AAAA,EACxE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,uBAAuB;AAAA,EACvB,GAAG;AACL,GAA8C;AACxC,MAAA,CAAC,QAAQ,IAAI,GAAG;AAClB,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AACM,QAAA,cAAc,SAAS,IAAI;AACjC,QAAM,UAAU,MAAM;AAEtB,MAAI,SAAS,YAAY;AAEzB,MAAI,mBAAmB,sBAAsB;AACvC,QAAA,mBAAmB,CAAC,sBAAsB;AAC5C,eAAS,YAAY;AAAA,IAAA,WACZ,CAAC,mBAAmB,sBAAsB;AACnD,eAAS,YAAY;AAAA,IAAA,OAChB;AAEL,eAAS,YAAY;AAAA,IACvB;AAAA,EACF;AAGE,SAAA,qBAAC,SAAS,EAAA,GAAG,kBACV,UAAA;AAAA,IAAA;AAAA,IACA,eAAe,YAAY,iBAEvB,qBAAA,UAAA,EAAA,UAAA;AAAA,MAAA;AAAA,MACA,YAAY;AAAA,IAAA,GACf;AAAA,EAEJ,EAAA,CAAA;AAEJ;AAGA,SAAS,QACP,YACuB;AACvB,SACE,OAAO,WAAW,WAAW,YAC7B,CAAC,CAAC,WAAW,UACb,OAAO,WAAW,iBAAiB,YACnC,CAAC,CAAC,WAAW;AAEjB;"}