@shopify/hydrogen 1.0.0-alpha.22 → 1.0.2

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 (773) hide show
  1. package/README.md +2 -2
  2. package/dist/esnext/FileSessionStorage.d.ts +1 -0
  3. package/dist/esnext/FileSessionStorage.js +1 -0
  4. package/dist/esnext/client.d.ts +14 -5
  5. package/dist/esnext/client.js +14 -5
  6. package/dist/esnext/components/AddToCartButton/AddToCartButton.client.d.ts +12 -7
  7. package/dist/esnext/components/AddToCartButton/AddToCartButton.client.js +40 -36
  8. package/dist/esnext/components/AddToCartButton/index.d.ts +1 -1
  9. package/dist/esnext/components/BaseButton/BaseButton.client.d.ts +14 -0
  10. package/dist/esnext/components/BaseButton/BaseButton.client.js +15 -0
  11. package/dist/esnext/components/BaseButton/index.d.ts +1 -0
  12. package/dist/esnext/components/BaseButton/index.js +1 -0
  13. package/dist/esnext/components/BuyNowButton/BuyNowButton.client.d.ts +15 -0
  14. package/dist/esnext/components/BuyNowButton/BuyNowButton.client.js +27 -0
  15. package/dist/esnext/components/BuyNowButton/index.d.ts +1 -1
  16. package/dist/esnext/components/BuyNowButton/index.js +1 -1
  17. package/dist/esnext/components/CartCheckoutButton/CartCheckoutButton.client.d.ts +7 -3
  18. package/dist/esnext/components/CartCheckoutButton/CartCheckoutButton.client.js +9 -6
  19. package/dist/esnext/components/CartCost/CartCost.client.d.ts +14 -0
  20. package/dist/esnext/components/CartCost/CartCost.client.js +29 -0
  21. package/dist/esnext/components/CartCost/index.d.ts +1 -0
  22. package/dist/esnext/components/CartCost/index.js +1 -0
  23. package/dist/esnext/components/CartLineImage/CartLineImage.client.d.ts +9 -6
  24. package/dist/esnext/components/CartLineImage/CartLineImage.client.js +6 -3
  25. package/dist/esnext/components/CartLinePrice/CartLinePrice.client.d.ts +10 -4
  26. package/dist/esnext/components/CartLinePrice/CartLinePrice.client.js +9 -8
  27. package/dist/esnext/components/CartLineProductTitle/CartLineProductTitle.client.d.ts +8 -3
  28. package/dist/esnext/components/CartLineProductTitle/CartLineProductTitle.client.js +4 -0
  29. package/dist/esnext/components/CartLineProvider/CartLineProvider.client.d.ts +5 -0
  30. package/dist/esnext/components/CartLineProvider/CartLineProvider.client.js +3 -0
  31. package/dist/esnext/components/CartLineProvider/context.d.ts +20 -10
  32. package/dist/esnext/components/CartLineProvider/index.d.ts +1 -1
  33. package/dist/esnext/components/CartLineProvider/index.js +1 -1
  34. package/dist/esnext/components/CartLineQuantity/CartLineQuantity.client.d.ts +8 -3
  35. package/dist/esnext/components/CartLineQuantity/CartLineQuantity.client.js +4 -0
  36. package/dist/esnext/components/CartLineQuantityAdjustButton/CartLineQuantityAdjustButton.d.ts +9 -4
  37. package/dist/esnext/components/CartLineQuantityAdjustButton/CartLineQuantityAdjustButton.js +22 -13
  38. package/dist/esnext/components/CartLines/CartLines.client.d.ts +15 -0
  39. package/dist/esnext/components/CartLines/{CartLines.js → CartLines.client.js} +7 -5
  40. package/dist/esnext/components/CartLines/index.d.ts +1 -1
  41. package/dist/esnext/components/CartLines/index.js +1 -1
  42. package/dist/esnext/components/CartProvider/CartProvider.client.d.ts +37 -3
  43. package/dist/esnext/components/CartProvider/CartProvider.client.js +474 -370
  44. package/dist/esnext/components/CartProvider/cart-queries.d.ts +10 -0
  45. package/dist/esnext/components/CartProvider/cart-queries.js +202 -0
  46. package/dist/esnext/components/CartProvider/constants.d.ts +1 -1
  47. package/dist/esnext/components/CartProvider/constants.js +1 -1
  48. package/dist/esnext/components/CartProvider/graphql/CartAttributesUpdateMutation.d.ts +82 -4
  49. package/dist/esnext/components/CartProvider/graphql/CartBuyerIdentityUpdateMutation.d.ts +82 -4
  50. package/dist/esnext/components/CartProvider/graphql/CartCreateMutation.d.ts +82 -4
  51. package/dist/esnext/components/CartProvider/graphql/CartDiscountCodesUpdateMutation.d.ts +83 -5
  52. package/dist/esnext/components/CartProvider/graphql/CartFragment.d.ts +22 -8
  53. package/dist/esnext/components/CartProvider/graphql/CartLineAddMutation.d.ts +82 -4
  54. package/dist/esnext/components/CartProvider/graphql/CartLineRemoveMutation.d.ts +82 -4
  55. package/dist/esnext/components/CartProvider/graphql/CartLineUpdateMutation.d.ts +82 -4
  56. package/dist/esnext/components/CartProvider/graphql/CartNoteUpdateMutation.d.ts +83 -5
  57. package/dist/esnext/components/CartProvider/graphql/CartQuery.d.ts +82 -4
  58. package/dist/esnext/components/CartProvider/hooks.client.d.ts +15 -0
  59. package/dist/esnext/components/CartProvider/hooks.client.js +71 -0
  60. package/dist/esnext/components/CartProvider/index.d.ts +3 -3
  61. package/dist/esnext/components/CartProvider/index.js +2 -3
  62. package/dist/esnext/components/CartProvider/types.d.ts +48 -49
  63. package/dist/esnext/components/CartShopPayButton/CartShopPayButton.client.d.ts +7 -2
  64. package/dist/esnext/components/CartShopPayButton/CartShopPayButton.client.js +11 -4
  65. package/dist/esnext/components/ExternalVideo/ExternalVideo.d.ts +16 -9
  66. package/dist/esnext/components/ExternalVideo/ExternalVideo.js +11 -6
  67. package/dist/esnext/components/ExternalVideo/index.d.ts +1 -1
  68. package/dist/esnext/components/Image/Image.d.ts +103 -12
  69. package/dist/esnext/components/Image/Image.js +142 -7
  70. package/dist/esnext/components/Image/index.d.ts +2 -1
  71. package/dist/esnext/components/Link/Link.client.d.ts +27 -0
  72. package/dist/esnext/components/Link/Link.client.js +145 -0
  73. package/dist/esnext/components/Link/index.d.ts +1 -0
  74. package/dist/esnext/components/Link/index.js +1 -0
  75. package/dist/esnext/components/LocalizationProvider/LocalizationClientProvider.client.d.ts +2 -2
  76. package/dist/esnext/components/LocalizationProvider/LocalizationClientProvider.client.js +3 -12
  77. package/dist/esnext/components/LocalizationProvider/LocalizationProvider.server.d.ts +20 -2
  78. package/dist/esnext/components/LocalizationProvider/LocalizationProvider.server.js +20 -5
  79. package/dist/esnext/components/LocalizationProvider/index.d.ts +0 -1
  80. package/dist/esnext/components/LocalizationProvider/index.js +0 -1
  81. package/dist/esnext/components/MediaFile/MediaFile.d.ts +18 -18
  82. package/dist/esnext/components/MediaFile/MediaFile.js +20 -10
  83. package/dist/esnext/components/MediaFile/index.d.ts +1 -1
  84. package/dist/esnext/components/Metafield/Metafield.client.d.ts +16 -7
  85. package/dist/esnext/components/Metafield/Metafield.client.js +83 -29
  86. package/dist/esnext/components/Metafield/components/StarRating/StarRating.d.ts +5 -5
  87. package/dist/esnext/components/Metafield/components/StarRating/StarRating.js +1 -1
  88. package/dist/esnext/components/Metafield/index.d.ts +1 -2
  89. package/dist/esnext/components/Metafield/types.d.ts +1 -1
  90. package/dist/esnext/components/ModelViewer/ModelViewer.client.d.ts +128 -0
  91. package/dist/esnext/components/ModelViewer/ModelViewer.client.js +104 -0
  92. package/dist/esnext/components/ModelViewer/index.d.ts +1 -0
  93. package/dist/esnext/components/ModelViewer/index.js +1 -0
  94. package/dist/esnext/components/Money/Money.client.d.ts +24 -6
  95. package/dist/esnext/components/Money/Money.client.js +36 -7
  96. package/dist/esnext/components/Money/index.d.ts +1 -1
  97. package/dist/esnext/components/ProductOptionsProvider/ProductOptionsProvider.client.d.ts +21 -0
  98. package/dist/esnext/components/ProductOptionsProvider/ProductOptionsProvider.client.js +133 -0
  99. package/dist/esnext/components/ProductOptionsProvider/context.d.ts +2 -0
  100. package/dist/esnext/components/ProductOptionsProvider/context.js +2 -0
  101. package/dist/esnext/components/ProductOptionsProvider/index.d.ts +1 -0
  102. package/dist/esnext/components/ProductOptionsProvider/index.js +1 -0
  103. package/dist/esnext/components/ProductPrice/ProductPrice.client.d.ts +15 -4
  104. package/dist/esnext/components/ProductPrice/ProductPrice.client.js +35 -13
  105. package/dist/esnext/components/Seo/CollectionSeo.client.d.ts +3 -0
  106. package/dist/esnext/components/Seo/CollectionSeo.client.js +14 -0
  107. package/dist/esnext/components/Seo/DefaultPageSeo.client.d.ts +3 -0
  108. package/dist/esnext/components/Seo/DefaultPageSeo.client.js +18 -0
  109. package/dist/esnext/components/Seo/DescriptionSeo.client.d.ts +4 -0
  110. package/dist/esnext/components/Seo/DescriptionSeo.client.js +10 -0
  111. package/dist/esnext/components/Seo/HomePageSeo.client.d.ts +2 -0
  112. package/dist/esnext/components/Seo/HomePageSeo.client.js +25 -0
  113. package/dist/esnext/components/Seo/ImageSeo.client.d.ts +3 -0
  114. package/dist/esnext/components/Seo/ImageSeo.client.js +10 -0
  115. package/dist/esnext/components/Seo/NoIndexSeo.client.d.ts +3 -0
  116. package/dist/esnext/components/Seo/NoIndexSeo.client.js +10 -0
  117. package/dist/esnext/components/Seo/PageSeo.client.d.ts +3 -0
  118. package/dist/esnext/components/Seo/PageSeo.client.js +12 -0
  119. package/dist/esnext/components/Seo/ProductSeo.client.d.ts +5 -0
  120. package/dist/esnext/components/Seo/ProductSeo.client.js +62 -0
  121. package/dist/esnext/components/Seo/Seo.client.d.ts +30 -0
  122. package/dist/esnext/components/Seo/Seo.client.js +31 -0
  123. package/dist/esnext/components/Seo/TitleSeo.client.d.ts +3 -0
  124. package/dist/esnext/components/Seo/TitleSeo.client.js +10 -0
  125. package/dist/esnext/components/Seo/TwitterSeo.client.d.ts +2 -0
  126. package/dist/esnext/components/Seo/TwitterSeo.client.js +9 -0
  127. package/dist/esnext/components/Seo/index.d.ts +1 -0
  128. package/dist/esnext/components/Seo/index.js +1 -0
  129. package/dist/esnext/components/Seo/seo-types.d.ts +18 -0
  130. package/dist/esnext/components/{ExternalVideo/ExternalVideoFragment.js → Seo/seo-types.js} +0 -0
  131. package/dist/esnext/components/ShopPayButton/ShopPayButton.client.d.ts +29 -4
  132. package/dist/esnext/components/ShopPayButton/ShopPayButton.client.js +50 -26
  133. package/dist/esnext/components/ShopPayButton/index.d.ts +1 -1
  134. package/dist/esnext/components/Video/Video.d.ts +13 -12
  135. package/dist/esnext/components/Video/Video.js +21 -6
  136. package/dist/esnext/components/Video/index.d.ts +1 -1
  137. package/dist/esnext/components/index.d.ts +27 -41
  138. package/dist/esnext/components/index.js +25 -87
  139. package/dist/esnext/components/types.d.ts +4 -6
  140. package/dist/esnext/components/types.js +1 -1
  141. package/dist/esnext/config.d.ts +7 -0
  142. package/dist/esnext/config.js +5 -0
  143. package/dist/esnext/constants.d.ts +13 -0
  144. package/dist/esnext/constants.js +13 -0
  145. package/dist/esnext/entry-client.js +145 -23
  146. package/dist/esnext/entry-server.d.ts +5 -2
  147. package/dist/esnext/entry-server.js +570 -247
  148. package/dist/esnext/foundation/Analytics/Analytics.client.d.ts +3 -0
  149. package/dist/esnext/foundation/Analytics/Analytics.client.js +30 -0
  150. package/dist/esnext/foundation/Analytics/Analytics.server.d.ts +1 -0
  151. package/dist/esnext/foundation/Analytics/Analytics.server.js +47 -0
  152. package/dist/esnext/foundation/Analytics/ClientAnalytics.d.ts +27 -0
  153. package/dist/esnext/foundation/Analytics/ClientAnalytics.js +99 -0
  154. package/dist/esnext/foundation/Analytics/ServerAnalyticsRoute.d.ts +4 -0
  155. package/dist/esnext/foundation/Analytics/ServerAnalyticsRoute.js +51 -0
  156. package/dist/esnext/foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetrics.client.d.ts +7 -0
  157. package/dist/esnext/foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetrics.client.js +81 -0
  158. package/dist/esnext/foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetricsDebug.client.d.ts +1 -0
  159. package/dist/esnext/foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetricsDebug.client.js +23 -0
  160. package/dist/esnext/foundation/Analytics/connectors/PerformanceMetrics/ServerAnalyticsConnector.d.ts +3 -0
  161. package/dist/esnext/foundation/Analytics/connectors/PerformanceMetrics/ServerAnalyticsConnector.js +7 -0
  162. package/dist/esnext/foundation/Analytics/connectors/Shopify/ServerAnalyticsConnector.d.ts +3 -0
  163. package/dist/esnext/foundation/Analytics/connectors/Shopify/ServerAnalyticsConnector.js +7 -0
  164. package/dist/esnext/foundation/Analytics/connectors/Shopify/ShopifyAnalytics.client.d.ts +3 -0
  165. package/dist/esnext/foundation/Analytics/connectors/Shopify/ShopifyAnalytics.client.js +182 -0
  166. package/dist/esnext/foundation/Analytics/connectors/Shopify/ShopifyAnalytics.server.d.ts +3 -0
  167. package/dist/esnext/foundation/Analytics/connectors/Shopify/ShopifyAnalytics.server.js +43 -0
  168. package/dist/esnext/foundation/Analytics/connectors/Shopify/const.d.ts +26 -0
  169. package/dist/esnext/foundation/Analytics/connectors/Shopify/const.js +49 -0
  170. package/dist/esnext/foundation/Analytics/connectors/Shopify/utils.d.ts +3 -0
  171. package/dist/esnext/foundation/Analytics/connectors/Shopify/utils.js +56 -0
  172. package/dist/esnext/foundation/Analytics/const.d.ts +9 -0
  173. package/dist/esnext/foundation/Analytics/const.js +9 -0
  174. package/dist/esnext/foundation/Analytics/hook.d.ts +1 -0
  175. package/dist/esnext/foundation/Analytics/hook.js +9 -0
  176. package/dist/esnext/foundation/Analytics/index.d.ts +1 -0
  177. package/dist/esnext/foundation/Analytics/index.js +1 -0
  178. package/dist/esnext/foundation/Analytics/types.d.ts +5 -0
  179. package/dist/esnext/{components/ProductProvider → foundation/Analytics}/types.js +0 -0
  180. package/dist/esnext/foundation/Analytics/utils.d.ts +3 -0
  181. package/dist/esnext/foundation/Analytics/utils.js +29 -0
  182. package/dist/esnext/foundation/AnalyticsErrorBoundary.client.d.ts +4 -0
  183. package/dist/esnext/foundation/AnalyticsErrorBoundary.client.js +8 -0
  184. package/dist/esnext/foundation/BuiltInRoutes/BuiltInRoutes.d.ts +2 -0
  185. package/dist/esnext/foundation/BuiltInRoutes/BuiltInRoutes.js +23 -0
  186. package/dist/esnext/foundation/BuiltInRoutes/healthCheck.d.ts +1 -0
  187. package/dist/esnext/foundation/BuiltInRoutes/healthCheck.js +3 -0
  188. package/dist/esnext/foundation/Cache/cache-sub-request.d.ts +17 -0
  189. package/dist/esnext/foundation/Cache/cache-sub-request.js +64 -0
  190. package/dist/esnext/foundation/Cache/cache.d.ts +17 -0
  191. package/dist/esnext/foundation/Cache/cache.js +127 -0
  192. package/dist/esnext/foundation/Cache/strategies/index.d.ts +7 -0
  193. package/dist/esnext/foundation/Cache/strategies/index.js +54 -0
  194. package/dist/esnext/foundation/Cookie/Cookie.d.ts +48 -0
  195. package/dist/esnext/foundation/Cookie/Cookie.js +72 -0
  196. package/dist/esnext/foundation/CookieSessionStorage/CookieSessionStorage.d.ts +5 -0
  197. package/dist/esnext/foundation/CookieSessionStorage/CookieSessionStorage.js +31 -0
  198. package/dist/esnext/foundation/DevTools/DevTools.client.d.ts +3 -0
  199. package/dist/esnext/foundation/DevTools/DevTools.client.js +17 -0
  200. package/dist/esnext/foundation/DevTools/DevTools.server.d.ts +1 -0
  201. package/dist/esnext/foundation/DevTools/DevTools.server.js +14 -0
  202. package/dist/esnext/foundation/DevTools/components/GraphQL.client.d.ts +1 -0
  203. package/dist/esnext/foundation/DevTools/components/GraphQL.client.js +25 -0
  204. package/dist/esnext/foundation/DevTools/components/Heading.d.ts +5 -0
  205. package/dist/esnext/foundation/DevTools/components/Heading.js +12 -0
  206. package/dist/esnext/foundation/DevTools/components/Interface.client.d.ts +11 -0
  207. package/dist/esnext/foundation/DevTools/components/Interface.client.js +47 -0
  208. package/dist/esnext/foundation/DevTools/components/Panels.d.ts +8 -0
  209. package/dist/esnext/foundation/DevTools/components/Panels.js +60 -0
  210. package/dist/esnext/foundation/DevTools/components/Performance.client.d.ts +14 -0
  211. package/dist/esnext/foundation/DevTools/components/Performance.client.js +26 -0
  212. package/dist/esnext/foundation/DevTools/components/Settings.client.d.ts +7 -0
  213. package/dist/esnext/foundation/DevTools/components/Settings.client.js +20 -0
  214. package/dist/esnext/foundation/DevTools/components/Table.d.ts +9 -0
  215. package/dist/esnext/foundation/DevTools/components/Table.js +7 -0
  216. package/dist/esnext/foundation/DevTools/components/icons.d.ts +2 -0
  217. package/dist/esnext/foundation/DevTools/components/icons.js +13 -0
  218. package/dist/esnext/foundation/DevTools/components/index.d.ts +2 -0
  219. package/dist/esnext/foundation/DevTools/components/index.js +2 -0
  220. package/dist/esnext/foundation/FileRoutes/FileRoutes.server.d.ts +22 -0
  221. package/dist/esnext/foundation/FileRoutes/FileRoutes.server.js +69 -0
  222. package/dist/esnext/foundation/FileSessionStorage/FileSessionStorage.d.ts +6 -0
  223. package/dist/esnext/foundation/FileSessionStorage/FileSessionStorage.js +149 -0
  224. package/dist/esnext/foundation/Head/Head.client.d.ts +5 -0
  225. package/dist/esnext/foundation/Head/Head.client.js +10 -0
  226. package/dist/esnext/foundation/Head/index.d.ts +1 -0
  227. package/dist/esnext/foundation/Head/index.js +1 -0
  228. package/dist/esnext/foundation/Html/Html.d.ts +13 -0
  229. package/dist/esnext/foundation/Html/Html.js +96 -0
  230. package/dist/esnext/foundation/HydrogenRequest/HydrogenRequest.server.d.ts +75 -0
  231. package/dist/esnext/foundation/HydrogenRequest/HydrogenRequest.server.js +210 -0
  232. package/dist/esnext/foundation/HydrogenResponse/HydrogenResponse.server.d.ts +21 -0
  233. package/dist/esnext/foundation/HydrogenResponse/HydrogenResponse.server.js +48 -0
  234. package/dist/esnext/foundation/MemorySessionStorage/MemorySessionStorage.d.ts +5 -0
  235. package/dist/esnext/foundation/MemorySessionStorage/MemorySessionStorage.js +53 -0
  236. package/dist/esnext/foundation/Redirect/Redirect.client.d.ts +5 -0
  237. package/dist/esnext/foundation/Redirect/Redirect.client.js +15 -0
  238. package/dist/esnext/foundation/Route/Route.server.d.ts +12 -0
  239. package/dist/esnext/foundation/Route/Route.server.js +28 -0
  240. package/dist/esnext/foundation/Router/BrowserRouter.client.d.ts +14 -0
  241. package/dist/esnext/foundation/Router/BrowserRouter.client.js +138 -0
  242. package/dist/esnext/foundation/Router/Router.server.d.ts +10 -0
  243. package/dist/esnext/foundation/Router/Router.server.js +8 -0
  244. package/dist/esnext/foundation/ServerPropsProvider/ServerPropsProvider.d.ts +41 -0
  245. package/dist/esnext/foundation/ServerPropsProvider/ServerPropsProvider.js +65 -0
  246. package/dist/esnext/foundation/ServerPropsProvider/index.d.ts +1 -0
  247. package/dist/esnext/foundation/ServerPropsProvider/index.js +1 -0
  248. package/dist/esnext/foundation/ServerRequestProvider/ServerRequestProvider.d.ts +23 -0
  249. package/dist/esnext/foundation/ServerRequestProvider/ServerRequestProvider.js +125 -0
  250. package/dist/esnext/foundation/ServerRequestProvider/index.d.ts +1 -0
  251. package/dist/esnext/foundation/ServerRequestProvider/index.js +1 -0
  252. package/dist/esnext/foundation/ServerStateProvider/ServerStateProvider.d.ts +30 -0
  253. package/dist/esnext/foundation/ServerStateProvider/ServerStateProvider.js +59 -0
  254. package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.client.d.ts +9 -0
  255. package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.client.js +10 -0
  256. package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.server.d.ts +18 -0
  257. package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.server.js +77 -0
  258. package/dist/esnext/foundation/ShopifyProvider/index.d.ts +1 -2
  259. package/dist/esnext/foundation/ShopifyProvider/index.js +1 -2
  260. package/dist/esnext/foundation/ShopifyProvider/types.d.ts +29 -10
  261. package/dist/esnext/foundation/constants.d.ts +2 -0
  262. package/dist/esnext/foundation/constants.js +4 -0
  263. package/dist/esnext/foundation/fetchSync/client/fetchSync.d.ts +10 -0
  264. package/dist/esnext/foundation/fetchSync/client/fetchSync.js +28 -0
  265. package/dist/esnext/foundation/fetchSync/server/fetchSync.d.ts +8 -0
  266. package/dist/esnext/foundation/fetchSync/server/fetchSync.js +32 -0
  267. package/dist/esnext/foundation/fetchSync/types.d.ts +5 -0
  268. package/dist/{worker → esnext/foundation/fetchSync}/types.js +0 -0
  269. package/dist/esnext/foundation/index.d.ts +3 -4
  270. package/dist/esnext/foundation/index.js +3 -4
  271. package/dist/esnext/foundation/runtime.d.ts +2 -0
  272. package/dist/esnext/foundation/runtime.js +6 -0
  273. package/dist/esnext/foundation/session/session.d.ts +27 -0
  274. package/dist/esnext/foundation/session/session.js +37 -0
  275. package/dist/esnext/foundation/ssr-interop.d.ts +29 -0
  276. package/dist/esnext/foundation/ssr-interop.js +35 -0
  277. package/dist/esnext/foundation/useNavigate/useNavigate.d.ts +17 -0
  278. package/dist/esnext/foundation/useNavigate/useNavigate.js +39 -0
  279. package/dist/esnext/foundation/useQuery/hooks.d.ts +37 -0
  280. package/dist/esnext/foundation/useQuery/hooks.js +105 -0
  281. package/dist/esnext/foundation/useQuery/index.d.ts +1 -0
  282. package/dist/esnext/foundation/useQuery/index.js +1 -0
  283. package/dist/esnext/foundation/useRequestContext/index.d.ts +15 -0
  284. package/dist/esnext/foundation/useRequestContext/index.js +23 -0
  285. package/dist/esnext/foundation/useRouteParams/RouteParamsProvider.client.d.ts +13 -0
  286. package/dist/esnext/foundation/useRouteParams/RouteParamsProvider.client.js +12 -0
  287. package/dist/esnext/foundation/useRouteParams/useRouteParams.d.ts +4 -0
  288. package/dist/esnext/foundation/useRouteParams/useRouteParams.js +9 -0
  289. package/dist/esnext/foundation/useServerProps/index.d.ts +1 -0
  290. package/dist/esnext/foundation/useServerProps/index.js +1 -0
  291. package/dist/esnext/foundation/useServerProps/use-server-props.d.ts +21 -0
  292. package/dist/esnext/foundation/useServerProps/use-server-props.js +35 -0
  293. package/dist/esnext/foundation/useSession/useSession.d.ts +2 -0
  294. package/dist/esnext/foundation/useSession/useSession.js +7 -0
  295. package/dist/esnext/foundation/useShop/index.d.ts +1 -0
  296. package/dist/esnext/foundation/useShop/index.js +1 -0
  297. package/dist/esnext/foundation/useShop/use-shop.d.ts +6 -0
  298. package/dist/esnext/foundation/useShop/use-shop.js +14 -0
  299. package/dist/esnext/foundation/useUrl/index.d.ts +1 -0
  300. package/dist/esnext/foundation/useUrl/index.js +1 -0
  301. package/dist/esnext/foundation/useUrl/useUrl.d.ts +4 -0
  302. package/dist/esnext/foundation/useUrl/useUrl.js +29 -0
  303. package/dist/esnext/framework/cache/in-memory.d.ts +17 -0
  304. package/dist/esnext/framework/cache/in-memory.js +80 -0
  305. package/dist/esnext/framework/graphiql.d.ts +1 -1
  306. package/dist/esnext/framework/graphiql.js +1 -2
  307. package/dist/esnext/framework/load-config.d.ts +5 -0
  308. package/dist/esnext/framework/load-config.js +7 -0
  309. package/dist/esnext/framework/middleware.d.ts +11 -7
  310. package/dist/esnext/framework/middleware.js +49 -68
  311. package/dist/esnext/framework/plugin.d.ts +8 -3
  312. package/dist/esnext/framework/plugin.js +23 -4
  313. package/dist/esnext/framework/plugins/vite-plugin-client-imports.d.ts +2 -0
  314. package/dist/esnext/framework/plugins/vite-plugin-client-imports.js +25 -0
  315. package/dist/esnext/framework/plugins/vite-plugin-css-modules-rsc.d.ts +2 -0
  316. package/dist/esnext/framework/plugins/vite-plugin-css-modules-rsc.js +98 -0
  317. package/dist/esnext/framework/plugins/vite-plugin-hydration-auto-import.d.ts +3 -0
  318. package/dist/esnext/framework/plugins/vite-plugin-hydration-auto-import.js +35 -0
  319. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-client-middleware.d.ts +9 -0
  320. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-client-middleware.js +36 -0
  321. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-config.d.ts +1 -1
  322. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-config.js +79 -20
  323. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-middleware.d.ts +10 -3
  324. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-middleware.js +47 -7
  325. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-rsc.d.ts +2 -0
  326. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-rsc.js +23 -0
  327. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-suppress-warnings.d.ts +3 -0
  328. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-suppress-warnings.js +19 -0
  329. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-virtual-files.d.ts +7 -0
  330. package/dist/esnext/framework/plugins/vite-plugin-hydrogen-virtual-files.js +101 -0
  331. package/dist/esnext/framework/plugins/vite-plugin-platform-entry.d.ts +3 -0
  332. package/dist/esnext/framework/plugins/vite-plugin-platform-entry.js +70 -0
  333. package/dist/esnext/framework/plugins/{vite-plugin-react-server-components-shim.d.ts → vite-plugin-purge-query-cache.d.ts} +0 -0
  334. package/dist/esnext/framework/plugins/vite-plugin-purge-query-cache.js +11 -0
  335. package/dist/{node/framework/plugins/vite-plugin-react-server-components-shim.d.ts → esnext/framework/plugins/vite-plugin-ssr-interop.d.ts} +0 -0
  336. package/dist/esnext/framework/plugins/vite-plugin-ssr-interop.js +16 -0
  337. package/dist/esnext/framework/types.d.ts +6 -0
  338. package/dist/esnext/{components/Image/ImageFragment.js → framework/types.js} +0 -0
  339. package/dist/esnext/framework/viteception.d.ts +5 -0
  340. package/dist/esnext/framework/viteception.js +16 -0
  341. package/dist/esnext/hooks/index.d.ts +6 -5
  342. package/dist/esnext/hooks/index.js +6 -5
  343. package/dist/esnext/hooks/useCart/index.d.ts +1 -0
  344. package/dist/esnext/hooks/useCart/index.js +1 -0
  345. package/dist/esnext/hooks/useCart/useCart.d.ts +4 -0
  346. package/dist/esnext/hooks/useCart/useCart.js +12 -0
  347. package/dist/esnext/hooks/useCartLine/index.d.ts +1 -0
  348. package/dist/esnext/hooks/useCartLine/index.js +1 -0
  349. package/dist/esnext/hooks/useCartLine/useCartLine.d.ts +39 -0
  350. package/dist/esnext/{components/CartLineProvider/hooks.js → hooks/useCartLine/useCartLine.js} +4 -1
  351. package/dist/esnext/hooks/useLoadScript/index.d.ts +1 -0
  352. package/dist/esnext/hooks/useLoadScript/index.js +1 -0
  353. package/dist/esnext/hooks/useLoadScript/useLoadScript.client.d.ts +8 -0
  354. package/dist/esnext/hooks/useLoadScript/useLoadScript.client.js +23 -0
  355. package/dist/esnext/hooks/useLocalization/useLocalization.d.ts +5 -0
  356. package/dist/esnext/hooks/useLocalization/useLocalization.js +9 -0
  357. package/dist/esnext/hooks/useMeasurement/hooks.js +2 -2
  358. package/dist/esnext/hooks/useMoney/hooks.d.ts +44 -1
  359. package/dist/esnext/hooks/useMoney/hooks.js +69 -22
  360. package/dist/esnext/hooks/useProductOptions/helpers.d.ts +6 -4
  361. package/dist/esnext/hooks/useProductOptions/helpers.js +9 -6
  362. package/dist/esnext/hooks/useProductOptions/index.d.ts +1 -1
  363. package/dist/esnext/hooks/useProductOptions/index.js +1 -1
  364. package/dist/esnext/hooks/useProductOptions/types.d.ts +42 -48
  365. package/dist/esnext/hooks/useProductOptions/useProductOptions.client.d.ts +1 -0
  366. package/dist/esnext/hooks/useProductOptions/useProductOptions.client.js +9 -0
  367. package/dist/esnext/hooks/useShopQuery/hooks.d.ts +22 -3
  368. package/dist/esnext/hooks/useShopQuery/hooks.js +163 -24
  369. package/dist/esnext/hooks/useShopQuery/index.d.ts +1 -1
  370. package/dist/esnext/hooks/useShopQuery/index.js +1 -1
  371. package/dist/esnext/index.d.ts +43 -9
  372. package/dist/esnext/index.js +39 -11
  373. package/dist/esnext/node.d.ts +1 -0
  374. package/dist/esnext/node.js +1 -0
  375. package/dist/esnext/platforms/node.d.ts +9 -0
  376. package/dist/esnext/platforms/node.js +41 -0
  377. package/dist/esnext/{components/LocalizationProvider/LocalizationQuery.js → platforms/worker-event.d.ts} +0 -0
  378. package/dist/esnext/platforms/worker-event.js +3 -0
  379. package/dist/esnext/platforms/worker.d.ts +14 -0
  380. package/dist/esnext/platforms/worker.js +25 -0
  381. package/dist/esnext/shared-types.d.ts +27 -0
  382. package/dist/esnext/shared-types.js +4 -0
  383. package/dist/esnext/{graphql/types/types.d.ts → storefront-api-types.d.ts} +2404 -1886
  384. package/dist/esnext/{graphql/types/types.js → storefront-api-types.js} +1079 -722
  385. package/dist/esnext/streaming.server.d.ts +16 -0
  386. package/dist/esnext/streaming.server.js +24 -0
  387. package/dist/esnext/types.d.ts +92 -39
  388. package/dist/esnext/types.js +1 -1
  389. package/dist/esnext/utilities/apiRoutes.d.ts +42 -0
  390. package/dist/esnext/utilities/apiRoutes.js +152 -0
  391. package/dist/esnext/utilities/bot-ua.d.ts +4 -0
  392. package/dist/esnext/utilities/bot-ua.js +61 -0
  393. package/dist/esnext/utilities/defer.d.ts +6 -0
  394. package/dist/esnext/utilities/defer.js +14 -0
  395. package/dist/esnext/utilities/devtools.d.ts +11 -0
  396. package/dist/esnext/utilities/devtools.js +11 -0
  397. package/dist/esnext/utilities/empty-hydrogen-config.d.ts +2 -0
  398. package/dist/esnext/utilities/empty-hydrogen-config.js +2 -0
  399. package/dist/esnext/utilities/error.d.ts +1 -0
  400. package/dist/esnext/utilities/error.js +6 -0
  401. package/dist/esnext/utilities/fetch.d.ts +9 -0
  402. package/dist/esnext/utilities/fetch.js +31 -0
  403. package/dist/esnext/utilities/flattenConnection/flattenConnection.d.ts +7 -0
  404. package/dist/esnext/utilities/flattenConnection/flattenConnection.js +18 -0
  405. package/dist/esnext/utilities/flattenConnection/index.d.ts +1 -0
  406. package/dist/esnext/utilities/flattenConnection/index.js +1 -0
  407. package/dist/esnext/utilities/graphql-tag.d.ts +1 -0
  408. package/dist/esnext/utilities/graphql-tag.js +6 -0
  409. package/dist/esnext/utilities/graphql-tracker.d.ts +17 -0
  410. package/dist/esnext/utilities/graphql-tracker.js +121 -0
  411. package/dist/esnext/utilities/hash.d.ts +2 -0
  412. package/dist/esnext/utilities/hash.js +30 -0
  413. package/dist/esnext/utilities/html-encoding.d.ts +1 -0
  414. package/dist/esnext/utilities/html-encoding.js +8 -0
  415. package/dist/esnext/utilities/image_size.d.ts +31 -14
  416. package/dist/esnext/utilities/image_size.js +81 -30
  417. package/dist/esnext/utilities/index.d.ts +10 -6
  418. package/dist/esnext/utilities/index.js +10 -6
  419. package/dist/esnext/utilities/isBrowser/index.d.ts +1 -0
  420. package/dist/esnext/utilities/isBrowser/index.js +1 -0
  421. package/dist/esnext/utilities/isBrowser/isBrowser.d.ts +4 -0
  422. package/dist/esnext/utilities/isBrowser/isBrowser.js +6 -0
  423. package/dist/esnext/utilities/isServer/index.d.ts +1 -0
  424. package/dist/esnext/utilities/isServer/index.js +1 -0
  425. package/dist/esnext/utilities/isServer/isServer.d.ts +4 -0
  426. package/dist/esnext/utilities/isServer/isServer.js +7 -0
  427. package/dist/esnext/utilities/{script_loader.d.ts → load_script.d.ts} +0 -0
  428. package/dist/esnext/utilities/{script_loader.js → load_script.js} +1 -1
  429. package/dist/esnext/utilities/log/index.d.ts +4 -0
  430. package/dist/esnext/utilities/log/index.js +4 -0
  431. package/dist/esnext/utilities/log/log-cache-api-status.d.ts +1 -0
  432. package/dist/esnext/utilities/log/log-cache-api-status.js +17 -0
  433. package/dist/esnext/utilities/log/log-cache-header.d.ts +10 -0
  434. package/dist/esnext/utilities/log/log-cache-header.js +30 -0
  435. package/dist/esnext/utilities/log/log-query-timeline.d.ts +12 -0
  436. package/dist/esnext/utilities/log/log-query-timeline.js +102 -0
  437. package/dist/esnext/utilities/log/log.d.ts +28 -0
  438. package/dist/esnext/utilities/log/log.js +74 -0
  439. package/dist/esnext/utilities/log/utils.d.ts +3 -0
  440. package/dist/esnext/utilities/log/utils.js +11 -0
  441. package/dist/esnext/utilities/matchPath.d.ts +10 -0
  442. package/dist/esnext/utilities/matchPath.js +54 -0
  443. package/dist/esnext/utilities/{meaurement.d.ts → measurement.d.ts} +0 -0
  444. package/dist/esnext/utilities/{meaurement.js → measurement.js} +0 -0
  445. package/dist/esnext/utilities/object.d.ts +5 -0
  446. package/dist/esnext/utilities/object.js +7 -0
  447. package/dist/esnext/utilities/parse.d.ts +1 -0
  448. package/dist/esnext/utilities/parse.js +9 -0
  449. package/dist/esnext/utilities/parseMetafield/index.d.ts +1 -0
  450. package/dist/esnext/utilities/parseMetafield/index.js +1 -0
  451. package/dist/esnext/utilities/parseMetafield/parseMetafield.d.ts +15 -0
  452. package/dist/esnext/utilities/parseMetafield/parseMetafield.js +62 -0
  453. package/dist/esnext/utilities/storefrontApi.d.ts +5 -0
  454. package/dist/esnext/utilities/storefrontApi.js +26 -0
  455. package/dist/esnext/utilities/suspense.d.ts +7 -2
  456. package/dist/esnext/utilities/suspense.js +32 -6
  457. package/dist/esnext/utilities/template.d.ts +9 -0
  458. package/dist/esnext/utilities/template.js +22 -0
  459. package/dist/esnext/utilities/timing.d.ts +7 -0
  460. package/dist/esnext/utilities/timing.js +14 -0
  461. package/dist/esnext/{components/MediaFile/MediaFileFragment.js → utilities/web-api-polyfill.d.ts} +0 -0
  462. package/dist/esnext/utilities/web-api-polyfill.js +25 -0
  463. package/dist/esnext/version.d.ts +1 -1
  464. package/dist/esnext/version.js +1 -1
  465. package/dist/node/framework/cache/in-memory.d.ts +17 -0
  466. package/dist/node/framework/cache/in-memory.js +84 -0
  467. package/dist/node/framework/graphiql.d.ts +1 -1
  468. package/dist/node/framework/graphiql.js +1 -2
  469. package/dist/node/framework/load-config.d.ts +5 -0
  470. package/dist/node/framework/load-config.js +11 -0
  471. package/dist/node/framework/middleware.d.ts +11 -7
  472. package/dist/node/framework/middleware.js +56 -73
  473. package/dist/node/framework/plugin.d.ts +5 -3
  474. package/dist/node/framework/plugin.js +27 -8
  475. package/dist/node/framework/plugins/vite-plugin-client-imports.d.ts +2 -0
  476. package/dist/node/framework/plugins/vite-plugin-client-imports.js +28 -0
  477. package/dist/node/framework/plugins/vite-plugin-css-modules-rsc.d.ts +2 -0
  478. package/dist/node/framework/plugins/vite-plugin-css-modules-rsc.js +104 -0
  479. package/dist/node/framework/plugins/vite-plugin-hydration-auto-import.d.ts +3 -0
  480. package/dist/node/framework/plugins/vite-plugin-hydration-auto-import.js +40 -0
  481. package/dist/node/framework/plugins/vite-plugin-hydrogen-client-middleware.d.ts +9 -0
  482. package/dist/node/framework/plugins/vite-plugin-hydrogen-client-middleware.js +38 -0
  483. package/dist/node/framework/plugins/vite-plugin-hydrogen-config.d.ts +1 -1
  484. package/dist/node/framework/plugins/vite-plugin-hydrogen-config.js +79 -20
  485. package/dist/node/framework/plugins/vite-plugin-hydrogen-middleware.d.ts +10 -3
  486. package/dist/node/framework/plugins/vite-plugin-hydrogen-middleware.js +48 -7
  487. package/dist/node/framework/plugins/vite-plugin-hydrogen-rsc.d.ts +2 -0
  488. package/dist/node/framework/plugins/vite-plugin-hydrogen-rsc.js +29 -0
  489. package/dist/node/framework/plugins/vite-plugin-hydrogen-suppress-warnings.d.ts +3 -0
  490. package/dist/node/framework/plugins/vite-plugin-hydrogen-suppress-warnings.js +21 -0
  491. package/dist/node/framework/plugins/vite-plugin-hydrogen-virtual-files.d.ts +7 -0
  492. package/dist/node/framework/plugins/vite-plugin-hydrogen-virtual-files.js +107 -0
  493. package/dist/node/framework/plugins/vite-plugin-platform-entry.d.ts +3 -0
  494. package/dist/node/framework/plugins/vite-plugin-platform-entry.js +75 -0
  495. package/dist/node/framework/plugins/vite-plugin-purge-query-cache.d.ts +3 -0
  496. package/dist/node/framework/plugins/vite-plugin-purge-query-cache.js +16 -0
  497. package/dist/node/framework/plugins/vite-plugin-ssr-interop.d.ts +3 -0
  498. package/dist/node/framework/plugins/vite-plugin-ssr-interop.js +18 -0
  499. package/dist/node/framework/types.d.ts +6 -0
  500. package/dist/node/{foundation/ShopifyProvider → framework}/types.js +0 -0
  501. package/dist/node/framework/viteception.d.ts +5 -0
  502. package/dist/node/framework/viteception.js +20 -0
  503. package/dist/node/shared-types.d.ts +27 -0
  504. package/dist/node/shared-types.js +5 -0
  505. package/dist/{esnext/components/Metafield/MetafieldFragment.js → node/utilities/web-api-polyfill.d.ts} +0 -0
  506. package/dist/node/utilities/web-api-polyfill.js +53 -0
  507. package/package.json +101 -56
  508. package/vendor/react-server-dom-vite/LICENSE +21 -0
  509. package/vendor/react-server-dom-vite/README.md +5 -0
  510. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite-plugin.js +600 -0
  511. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite-writer.browser.development.server.js +1808 -0
  512. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite-writer.browser.production.min.server.js +47 -0
  513. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite-writer.node.development.server.js +1882 -0
  514. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite-writer.node.production.min.server.js +47 -0
  515. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite.development.js +629 -0
  516. package/vendor/react-server-dom-vite/cjs/react-server-dom-vite.production.min.js +19 -0
  517. package/vendor/react-server-dom-vite/esm/package.json +3 -0
  518. package/vendor/react-server-dom-vite/esm/react-server-dom-vite-client-proxy.js +83 -0
  519. package/vendor/react-server-dom-vite/esm/react-server-dom-vite-plugin.js +596 -0
  520. package/vendor/react-server-dom-vite/esm/react-server-dom-vite-writer.browser.server.js +1800 -0
  521. package/vendor/react-server-dom-vite/esm/react-server-dom-vite-writer.node.server.js +1874 -0
  522. package/vendor/react-server-dom-vite/esm/react-server-dom-vite.js +619 -0
  523. package/vendor/react-server-dom-vite/index.js +7 -0
  524. package/vendor/react-server-dom-vite/package.json +67 -0
  525. package/vendor/react-server-dom-vite/plugin.js +3 -0
  526. package/vendor/react-server-dom-vite/writer.browser.server.js +7 -0
  527. package/vendor/react-server-dom-vite/writer.node.server.js +7 -0
  528. package/client.d.ts +0 -1
  529. package/client.js +0 -1
  530. package/dist/esnext/components/BuyNowButton/BuyNowButton.d.ts +0 -12
  531. package/dist/esnext/components/BuyNowButton/BuyNowButton.js +0 -29
  532. package/dist/esnext/components/CartContainer/CartContainer.client.d.ts +0 -9
  533. package/dist/esnext/components/CartContainer/CartContainer.client.js +0 -24
  534. package/dist/esnext/components/CartContainer/index.d.ts +0 -1
  535. package/dist/esnext/components/CartContainer/index.js +0 -1
  536. package/dist/esnext/components/CartLineAttributes/CartLineAttributes.client.d.ts +0 -10
  537. package/dist/esnext/components/CartLineAttributes/CartLineAttributes.client.js +0 -9
  538. package/dist/esnext/components/CartLineAttributes/index.d.ts +0 -1
  539. package/dist/esnext/components/CartLineAttributes/index.js +0 -1
  540. package/dist/esnext/components/CartLineProvider/hooks.d.ts +0 -26
  541. package/dist/esnext/components/CartLineSelectedOptions/CartLineSelectedOptions.client.d.ts +0 -10
  542. package/dist/esnext/components/CartLineSelectedOptions/CartLineSelectedOptions.client.js +0 -9
  543. package/dist/esnext/components/CartLineSelectedOptions/index.d.ts +0 -1
  544. package/dist/esnext/components/CartLineSelectedOptions/index.js +0 -1
  545. package/dist/esnext/components/CartLines/CartLines.d.ts +0 -7
  546. package/dist/esnext/components/CartProvider/CartServerProvider.server.d.ts +0 -11
  547. package/dist/esnext/components/CartProvider/CartServerProvider.server.js +0 -20
  548. package/dist/esnext/components/CartProvider/hooks.d.ts +0 -18
  549. package/dist/esnext/components/CartProvider/hooks.js +0 -79
  550. package/dist/esnext/components/CartToggle/CartToggle.client.d.ts +0 -8
  551. package/dist/esnext/components/CartToggle/CartToggle.client.js +0 -11
  552. package/dist/esnext/components/CartToggle/index.d.ts +0 -1
  553. package/dist/esnext/components/CartToggle/index.js +0 -1
  554. package/dist/esnext/components/CartTotal/CartTotal.client.d.ts +0 -3
  555. package/dist/esnext/components/CartTotal/CartTotal.client.js +0 -8
  556. package/dist/esnext/components/CartTotal/index.d.ts +0 -1
  557. package/dist/esnext/components/CartTotal/index.js +0 -1
  558. package/dist/esnext/components/CartUIProvider/CartUIProvider.client.d.ts +0 -5
  559. package/dist/esnext/components/CartUIProvider/CartUIProvider.client.js +0 -26
  560. package/dist/esnext/components/CartUIProvider/context.d.ts +0 -9
  561. package/dist/esnext/components/CartUIProvider/context.js +0 -2
  562. package/dist/esnext/components/CartUIProvider/hooks.d.ts +0 -1
  563. package/dist/esnext/components/CartUIProvider/hooks.js +0 -9
  564. package/dist/esnext/components/CartUIProvider/index.d.ts +0 -2
  565. package/dist/esnext/components/CartUIProvider/index.js +0 -2
  566. package/dist/esnext/components/ExternalVideo/ExternalVideoFragment.d.ts +0 -4
  567. package/dist/esnext/components/Image/ImageFragment.d.ts +0 -4
  568. package/dist/esnext/components/LocalizationProvider/LocalizationContext.client.d.ts +0 -8
  569. package/dist/esnext/components/LocalizationProvider/LocalizationContext.client.js +0 -2
  570. package/dist/esnext/components/LocalizationProvider/LocalizationQuery.d.ts +0 -18
  571. package/dist/esnext/components/LocalizationProvider/hooks.d.ts +0 -8
  572. package/dist/esnext/components/LocalizationProvider/hooks.js +0 -17
  573. package/dist/esnext/components/MediaFile/MediaFileFragment.d.ts +0 -22
  574. package/dist/esnext/components/Metafield/MetafieldFragment.d.ts +0 -4
  575. package/dist/esnext/components/Model3D/Model3D.client.d.ts +0 -25
  576. package/dist/esnext/components/Model3D/Model3D.client.js +0 -30
  577. package/dist/esnext/components/Model3D/Model3DFragment.d.ts +0 -11
  578. package/dist/esnext/components/Model3D/Model3DFragment.js +0 -1
  579. package/dist/esnext/components/Model3D/index.d.ts +0 -1
  580. package/dist/esnext/components/Model3D/index.js +0 -1
  581. package/dist/esnext/components/ProductDescription/ProductDescription.client.d.ts +0 -3
  582. package/dist/esnext/components/ProductDescription/ProductDescription.client.js +0 -10
  583. package/dist/esnext/components/ProductDescription/index.d.ts +0 -1
  584. package/dist/esnext/components/ProductDescription/index.js +0 -1
  585. package/dist/esnext/components/ProductMetafield/ProductMetafield.client.d.ts +0 -7
  586. package/dist/esnext/components/ProductMetafield/ProductMetafield.client.js +0 -16
  587. package/dist/esnext/components/ProductMetafield/index.d.ts +0 -1
  588. package/dist/esnext/components/ProductMetafield/index.js +0 -1
  589. package/dist/esnext/components/ProductProvider/ProductProvider.client.d.ts +0 -7
  590. package/dist/esnext/components/ProductProvider/ProductProvider.client.js +0 -35
  591. package/dist/esnext/components/ProductProvider/ProductProviderFragment.d.ts +0 -96
  592. package/dist/esnext/components/ProductProvider/ProductProviderFragment.js +0 -1
  593. package/dist/esnext/components/ProductProvider/context.d.ts +0 -13
  594. package/dist/esnext/components/ProductProvider/context.js +0 -2
  595. package/dist/esnext/components/ProductProvider/hooks.d.ts +0 -1
  596. package/dist/esnext/components/ProductProvider/hooks.js +0 -6
  597. package/dist/esnext/components/ProductProvider/index.d.ts +0 -2
  598. package/dist/esnext/components/ProductProvider/index.js +0 -2
  599. package/dist/esnext/components/ProductProvider/types.d.ts +0 -5
  600. package/dist/esnext/components/ProductTitle/ProductTitle.client.d.ts +0 -3
  601. package/dist/esnext/components/ProductTitle/ProductTitle.client.js +0 -11
  602. package/dist/esnext/components/ProductTitle/index.d.ts +0 -1
  603. package/dist/esnext/components/ProductTitle/index.js +0 -1
  604. package/dist/esnext/components/RawHtml/RawHtml.d.ts +0 -7
  605. package/dist/esnext/components/RawHtml/RawHtml.js +0 -13
  606. package/dist/esnext/components/RawHtml/index.d.ts +0 -1
  607. package/dist/esnext/components/RawHtml/index.js +0 -1
  608. package/dist/esnext/components/SelectedVariantAddToCartButton/SelectedVariantAddToCartButton.client.d.ts +0 -6
  609. package/dist/esnext/components/SelectedVariantAddToCartButton/SelectedVariantAddToCartButton.client.js +0 -12
  610. package/dist/esnext/components/SelectedVariantAddToCartButton/index.d.ts +0 -1
  611. package/dist/esnext/components/SelectedVariantAddToCartButton/index.js +0 -1
  612. package/dist/esnext/components/SelectedVariantBuyNowButton/SelectedVariantBuyNowButton.d.ts +0 -4
  613. package/dist/esnext/components/SelectedVariantBuyNowButton/SelectedVariantBuyNowButton.js +0 -12
  614. package/dist/esnext/components/SelectedVariantBuyNowButton/index.d.ts +0 -1
  615. package/dist/esnext/components/SelectedVariantBuyNowButton/index.js +0 -1
  616. package/dist/esnext/components/SelectedVariantImage/SelectedVariantImage.client.d.ts +0 -6
  617. package/dist/esnext/components/SelectedVariantImage/SelectedVariantImage.client.js +0 -12
  618. package/dist/esnext/components/SelectedVariantImage/index.d.ts +0 -1
  619. package/dist/esnext/components/SelectedVariantImage/index.js +0 -1
  620. package/dist/esnext/components/SelectedVariantMetafield/SelectedVariantMetafield.client.d.ts +0 -7
  621. package/dist/esnext/components/SelectedVariantMetafield/SelectedVariantMetafield.client.js +0 -15
  622. package/dist/esnext/components/SelectedVariantMetafield/index.d.ts +0 -1
  623. package/dist/esnext/components/SelectedVariantMetafield/index.js +0 -1
  624. package/dist/esnext/components/SelectedVariantPrice/SelectedVariantPrice.client.d.ts +0 -6
  625. package/dist/esnext/components/SelectedVariantPrice/SelectedVariantPrice.client.js +0 -18
  626. package/dist/esnext/components/SelectedVariantPrice/index.d.ts +0 -1
  627. package/dist/esnext/components/SelectedVariantPrice/index.js +0 -1
  628. package/dist/esnext/components/SelectedVariantShopPayButton/SelectedVariantShopPayButton.client.d.ts +0 -2
  629. package/dist/esnext/components/SelectedVariantShopPayButton/SelectedVariantShopPayButton.client.js +0 -12
  630. package/dist/esnext/components/SelectedVariantShopPayButton/index.d.ts +0 -1
  631. package/dist/esnext/components/SelectedVariantShopPayButton/index.js +0 -1
  632. package/dist/esnext/components/SelectedVariantUnitPrice/SelectedVariantUnitPrice.client.d.ts +0 -3
  633. package/dist/esnext/components/SelectedVariantUnitPrice/SelectedVariantUnitPrice.client.js +0 -12
  634. package/dist/esnext/components/SelectedVariantUnitPrice/index.d.ts +0 -1
  635. package/dist/esnext/components/SelectedVariantUnitPrice/index.js +0 -1
  636. package/dist/esnext/components/UnitPrice/UnitPrice.client.d.ts +0 -8
  637. package/dist/esnext/components/UnitPrice/UnitPrice.client.js +0 -16
  638. package/dist/esnext/components/UnitPrice/index.d.ts +0 -1
  639. package/dist/esnext/components/UnitPrice/index.js +0 -1
  640. package/dist/esnext/components/Video/VideoFragment.d.ts +0 -11
  641. package/dist/esnext/components/Video/VideoFragment.js +0 -1
  642. package/dist/esnext/foundation/ClientMarker/ClientMarker.d.ts +0 -10
  643. package/dist/esnext/foundation/ClientMarker/ClientMarker.js +0 -25
  644. package/dist/esnext/foundation/ClientMarker/index.d.ts +0 -1
  645. package/dist/esnext/foundation/ClientMarker/index.js +0 -1
  646. package/dist/esnext/foundation/Hydration/Cache.client.d.ts +0 -9
  647. package/dist/esnext/foundation/Hydration/Cache.client.js +0 -131
  648. package/dist/esnext/foundation/Hydration/ClientComponents.server.d.ts +0 -13
  649. package/dist/esnext/foundation/Hydration/ClientComponents.server.js +0 -18
  650. package/dist/esnext/foundation/Hydration/Html.d.ts +0 -5
  651. package/dist/esnext/foundation/Hydration/Html.js +0 -9
  652. package/dist/esnext/foundation/Hydration/HydrationContext.server.d.ts +0 -1
  653. package/dist/esnext/foundation/Hydration/HydrationContext.server.js +0 -2
  654. package/dist/esnext/foundation/Hydration/ServerComponentRequest.server.d.ts +0 -13
  655. package/dist/esnext/foundation/Hydration/ServerComponentRequest.server.js +0 -39
  656. package/dist/esnext/foundation/Hydration/ServerComponentResponse.server.d.ts +0 -18
  657. package/dist/esnext/foundation/Hydration/ServerComponentResponse.server.js +0 -35
  658. package/dist/esnext/foundation/Hydration/react-utils.d.ts +0 -5
  659. package/dist/esnext/foundation/Hydration/react-utils.js +0 -55
  660. package/dist/esnext/foundation/Hydration/wire.server.d.ts +0 -4
  661. package/dist/esnext/foundation/Hydration/wire.server.js +0 -75
  662. package/dist/esnext/foundation/Hydration/writer.server.d.ts +0 -14
  663. package/dist/esnext/foundation/Hydration/writer.server.js +0 -29
  664. package/dist/esnext/foundation/Router/DefaultRoutes.d.ts +0 -20
  665. package/dist/esnext/foundation/Router/DefaultRoutes.js +0 -54
  666. package/dist/esnext/foundation/Router/ServerStateRouter.client.d.ts +0 -6
  667. package/dist/esnext/foundation/Router/ServerStateRouter.client.js +0 -27
  668. package/dist/esnext/foundation/Router/index.d.ts +0 -1
  669. package/dist/esnext/foundation/Router/index.js +0 -1
  670. package/dist/esnext/foundation/ServerStateProvider/ServerStateProvider.client.d.ts +0 -11
  671. package/dist/esnext/foundation/ServerStateProvider/ServerStateProvider.client.js +0 -48
  672. package/dist/esnext/foundation/ServerStateProvider/index.d.ts +0 -1
  673. package/dist/esnext/foundation/ServerStateProvider/index.js +0 -1
  674. package/dist/esnext/foundation/ShopifyProvider/ShopifyContext.d.ts +0 -1
  675. package/dist/esnext/foundation/ShopifyProvider/ShopifyContext.js +0 -2
  676. package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.d.ts +0 -3
  677. package/dist/esnext/foundation/ShopifyProvider/ShopifyProvider.js +0 -11
  678. package/dist/esnext/foundation/ShopifyProvider/ShopifyServerProvider.server.d.ts +0 -8
  679. package/dist/esnext/foundation/ShopifyProvider/ShopifyServerProvider.server.js +0 -7
  680. package/dist/esnext/foundation/ShopifyProvider/hooks.d.ts +0 -2
  681. package/dist/esnext/foundation/ShopifyProvider/hooks.js +0 -9
  682. package/dist/esnext/framework/plugins/vite-plugin-react-server-components-shim.js +0 -123
  683. package/dist/esnext/framework/server-components.d.ts +0 -12
  684. package/dist/esnext/framework/server-components.js +0 -72
  685. package/dist/esnext/graphql/graphql-constants.d.ts +0 -1295
  686. package/dist/esnext/graphql/graphql-constants.js +0 -2482
  687. package/dist/esnext/handle-event.d.ts +0 -20
  688. package/dist/esnext/handle-event.js +0 -140
  689. package/dist/esnext/handle-worker-event.d.ts +0 -11
  690. package/dist/esnext/handle-worker-event.js +0 -14
  691. package/dist/esnext/hooks/useParsedMetafields/hooks.d.ts +0 -3
  692. package/dist/esnext/hooks/useParsedMetafields/hooks.js +0 -15
  693. package/dist/esnext/hooks/useParsedMetafields/index.d.ts +0 -1
  694. package/dist/esnext/hooks/useParsedMetafields/index.js +0 -1
  695. package/dist/esnext/hooks/useProductOptions/useProductOptions.d.ts +0 -23
  696. package/dist/esnext/hooks/useProductOptions/useProductOptions.js +0 -84
  697. package/dist/esnext/hooks/useQuery/QueryProvider.d.ts +0 -6
  698. package/dist/esnext/hooks/useQuery/QueryProvider.js +0 -13
  699. package/dist/esnext/hooks/useQuery/hooks.d.ts +0 -12
  700. package/dist/esnext/hooks/useQuery/hooks.js +0 -28
  701. package/dist/esnext/hooks/useQuery/index.d.ts +0 -2
  702. package/dist/esnext/hooks/useQuery/index.js +0 -2
  703. package/dist/esnext/utilities/connections.d.ts +0 -2
  704. package/dist/esnext/utilities/connections.js +0 -4
  705. package/dist/esnext/utilities/environment.d.ts +0 -2
  706. package/dist/esnext/utilities/environment.js +0 -2
  707. package/dist/esnext/utilities/metafields.d.ts +0 -2
  708. package/dist/esnext/utilities/metafields.js +0 -32
  709. package/dist/node/foundation/ClientMarker/ClientMarker.d.ts +0 -10
  710. package/dist/node/foundation/ClientMarker/ClientMarker.js +0 -48
  711. package/dist/node/foundation/ClientMarker/index.d.ts +0 -1
  712. package/dist/node/foundation/ClientMarker/index.js +0 -13
  713. package/dist/node/foundation/Hydration/HydrationContext.server.d.ts +0 -1
  714. package/dist/node/foundation/Hydration/HydrationContext.server.js +0 -5
  715. package/dist/node/foundation/Hydration/ServerComponentRequest.server.d.ts +0 -13
  716. package/dist/node/foundation/Hydration/ServerComponentRequest.server.js +0 -43
  717. package/dist/node/foundation/Hydration/ServerComponentResponse.server.d.ts +0 -18
  718. package/dist/node/foundation/Hydration/ServerComponentResponse.server.js +0 -39
  719. package/dist/node/foundation/Hydration/react-utils.d.ts +0 -5
  720. package/dist/node/foundation/Hydration/react-utils.js +0 -63
  721. package/dist/node/foundation/Router/DefaultRoutes.d.ts +0 -20
  722. package/dist/node/foundation/Router/DefaultRoutes.js +0 -78
  723. package/dist/node/foundation/Router/index.d.ts +0 -1
  724. package/dist/node/foundation/Router/index.js +0 -5
  725. package/dist/node/foundation/ShopifyProvider/ShopifyContext.d.ts +0 -1
  726. package/dist/node/foundation/ShopifyProvider/ShopifyContext.js +0 -5
  727. package/dist/node/foundation/ShopifyProvider/ShopifyProvider.d.ts +0 -3
  728. package/dist/node/foundation/ShopifyProvider/ShopifyProvider.js +0 -34
  729. package/dist/node/foundation/ShopifyProvider/ShopifyServerProvider.server.d.ts +0 -8
  730. package/dist/node/foundation/ShopifyProvider/ShopifyServerProvider.server.js +0 -14
  731. package/dist/node/foundation/ShopifyProvider/hooks.d.ts +0 -2
  732. package/dist/node/foundation/ShopifyProvider/hooks.js +0 -13
  733. package/dist/node/foundation/ShopifyProvider/index.d.ts +0 -2
  734. package/dist/node/foundation/ShopifyProvider/index.js +0 -8
  735. package/dist/node/foundation/ShopifyProvider/types.d.ts +0 -12
  736. package/dist/node/foundation/index.d.ts +0 -4
  737. package/dist/node/foundation/index.js +0 -13
  738. package/dist/node/framework/plugins/vite-plugin-react-server-components-shim.js +0 -128
  739. package/dist/node/framework/server-components.d.ts +0 -12
  740. package/dist/node/framework/server-components.js +0 -77
  741. package/dist/node/graphql/types/types.d.ts +0 -5583
  742. package/dist/node/graphql/types/types.js +0 -1417
  743. package/dist/node/handle-event.d.ts +0 -20
  744. package/dist/node/handle-event.js +0 -143
  745. package/dist/node/hooks/useQuery/QueryProvider.d.ts +0 -6
  746. package/dist/node/hooks/useQuery/QueryProvider.js +0 -20
  747. package/dist/node/hooks/useQuery/hooks.d.ts +0 -12
  748. package/dist/node/hooks/useQuery/hooks.js +0 -32
  749. package/dist/node/hooks/useQuery/index.d.ts +0 -2
  750. package/dist/node/hooks/useQuery/index.js +0 -14
  751. package/dist/node/types.d.ts +0 -62
  752. package/dist/node/types.js +0 -2
  753. package/dist/worker/foundation/Hydration/ServerComponentRequest.server.d.ts +0 -13
  754. package/dist/worker/foundation/Hydration/ServerComponentRequest.server.js +0 -39
  755. package/dist/worker/foundation/Hydration/ServerComponentResponse.server.d.ts +0 -18
  756. package/dist/worker/foundation/Hydration/ServerComponentResponse.server.js +0 -35
  757. package/dist/worker/graphql/types/types.d.ts +0 -5583
  758. package/dist/worker/graphql/types/types.js +0 -1414
  759. package/dist/worker/handle-event.d.ts +0 -20
  760. package/dist/worker/handle-event.js +0 -140
  761. package/dist/worker/handle-worker-event.d.ts +0 -11
  762. package/dist/worker/handle-worker-event.js +0 -14
  763. package/dist/worker/types.d.ts +0 -62
  764. package/entry-client.d.ts +0 -1
  765. package/entry-client.js +0 -1
  766. package/entry-server.d.ts +0 -1
  767. package/entry-server.js +0 -1
  768. package/marker.js +0 -1
  769. package/middleware.d.ts +0 -1
  770. package/middleware.js +0 -1
  771. package/plugin.d.ts +0 -1
  772. package/plugin.js +0 -1
  773. package/worker.js +0 -1
package/README.md CHANGED
@@ -2,13 +2,13 @@
2
2
 
3
3
  Hydrogen is a React framework and SDK that you can use to build fast and dynamic Shopify custom storefronts.
4
4
 
5
- [Check out the docs](https://shopify.dev/beta/hydrogen)
5
+ [Check out the docs](https://shopify.dev/custom-storefronts/hydrogen)
6
6
 
7
7
  ## Getting started
8
8
 
9
9
  **Requirements:**
10
10
 
11
- - Node v14+
11
+ - Node.js version 16.5.0 or higher
12
12
  - Yarn
13
13
 
14
14
  ```bash
@@ -0,0 +1 @@
1
+ export { FileSessionStorage } from './foundation/FileSessionStorage/FileSessionStorage';
@@ -0,0 +1 @@
1
+ export { FileSessionStorage } from './foundation/FileSessionStorage/FileSessionStorage';
@@ -1,7 +1,16 @@
1
1
  export * from './components';
2
2
  export * from './hooks';
3
- export * from './foundation/ShopifyProvider';
4
- export { useServerResponse } from './foundation/Hydration/Cache.client';
5
- export * from './foundation/ServerStateProvider';
6
- export { ServerStateRouter } from './foundation/Router/ServerStateRouter.client';
7
- export { Helmet } from 'react-helmet-async';
3
+ export { useServerProps } from './foundation/useServerProps';
4
+ export { useShop } from './foundation/useShop';
5
+ export { ServerPropsProvider, ServerPropsContext, type ServerProps, type ServerPropsContextValue, } from './foundation/ServerPropsProvider';
6
+ export { useUrl } from './foundation/useUrl';
7
+ export { Head } from './foundation/Head';
8
+ export * from './utilities';
9
+ export { gql } from './utilities/graphql-tag';
10
+ export { ClientAnalytics } from './foundation/Analytics';
11
+ export { useRouteParams } from './foundation/useRouteParams/useRouteParams';
12
+ export { useNavigate } from './foundation/useNavigate/useNavigate';
13
+ export { fetchSync } from './foundation/fetchSync/client/fetchSync';
14
+ export { suspendFunction, preloadFunction } from './utilities/suspense';
15
+ export { PerformanceMetrics } from './foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetrics.client';
16
+ export { PerformanceMetricsDebug } from './foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetricsDebug.client';
@@ -1,7 +1,16 @@
1
1
  export * from './components';
2
2
  export * from './hooks';
3
- export * from './foundation/ShopifyProvider';
4
- export { useServerResponse } from './foundation/Hydration/Cache.client';
5
- export * from './foundation/ServerStateProvider';
6
- export { ServerStateRouter } from './foundation/Router/ServerStateRouter.client';
7
- export { Helmet } from 'react-helmet-async';
3
+ export { useServerProps } from './foundation/useServerProps';
4
+ export { useShop } from './foundation/useShop';
5
+ export { ServerPropsProvider, ServerPropsContext, } from './foundation/ServerPropsProvider';
6
+ export { useUrl } from './foundation/useUrl';
7
+ export { Head } from './foundation/Head';
8
+ export * from './utilities';
9
+ export { gql } from './utilities/graphql-tag';
10
+ export { ClientAnalytics } from './foundation/Analytics';
11
+ export { useRouteParams } from './foundation/useRouteParams/useRouteParams';
12
+ export { useNavigate } from './foundation/useNavigate/useNavigate';
13
+ export { fetchSync } from './foundation/fetchSync/client/fetchSync';
14
+ export { suspendFunction, preloadFunction } from './utilities/suspense';
15
+ export { PerformanceMetrics } from './foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetrics.client';
16
+ export { PerformanceMetricsDebug } from './foundation/Analytics/connectors/PerformanceMetrics/PerformanceMetricsDebug.client';
@@ -1,15 +1,20 @@
1
- import React, { ReactNode } from 'react';
2
- import { Props } from '../types';
3
- export interface AddToCartButtonProps {
1
+ import { BaseButtonProps } from '../BaseButton';
2
+ interface AddToCartButtonProps {
3
+ /** An array of cart line attributes that belong to the item being added to the cart. */
4
4
  attributes?: {
5
5
  key: string;
6
6
  value: string;
7
7
  }[];
8
- variantID: string;
8
+ /** The ID of the variant. */
9
+ variantId?: string | null;
10
+ /** The item quantity. */
9
11
  quantity?: number;
10
- children: ReactNode;
12
+ /** The text that is announced by the screen reader when the item is being added to the cart. Used for accessibility purposes only and not displayed on the page. */
11
13
  accessibleAddingToCartLabel?: string;
12
14
  }
13
- declare type PropsWeControl = 'onClick';
14
- export declare function AddToCartButton<TTag extends React.ElementType = 'button'>(props: Props<TTag, PropsWeControl> & AddToCartButtonProps): JSX.Element;
15
+ /**
16
+ * The `AddToCartButton` component renders a button that adds an item to the cart when pressed.
17
+ * It must be a descendent of the `CartProvider` component.
18
+ */
19
+ export declare function AddToCartButton(props: AddToCartButtonProps & BaseButtonProps): JSX.Element;
15
20
  export {};
@@ -1,44 +1,48 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { useCartLinesAddCallback, useCart, useCartCreateCallback, } from '../CartProvider';
3
- import { useCartUI } from '../CartUIProvider';
1
+ import React, { useCallback, useEffect, useState } from 'react';
2
+ import { useCart } from '../CartProvider';
3
+ import { useProductOptions } from '../../hooks/useProductOptions';
4
+ import { BaseButton } from '../BaseButton';
5
+ /**
6
+ * The `AddToCartButton` component renders a button that adds an item to the cart when pressed.
7
+ * It must be a descendent of the `CartProvider` component.
8
+ */
4
9
  export function AddToCartButton(props) {
5
- const cartUI = useCartUI();
6
10
  const [addingItem, setAddingItem] = useState(false);
7
- const { variantID, quantity = 1, attributes, children, onAdd, accessibleAddingToCartLabel, ...passthroughProps } = props;
8
- const { status, id } = useCart();
9
- const createCart = useCartCreateCallback();
10
- const addLines = useCartLinesAddCallback();
11
+ const { variantId: explicitVariantId, quantity = 1, attributes, onClick, children, accessibleAddingToCartLabel, ...passthroughProps } = props;
12
+ const { status, linesAdd } = useCart();
13
+ const { selectedVariant } = useProductOptions();
14
+ const variantId = explicitVariantId ?? selectedVariant?.id ?? '';
15
+ const disabled = explicitVariantId === null ||
16
+ variantId === '' ||
17
+ selectedVariant === null ||
18
+ addingItem ||
19
+ passthroughProps.disabled;
11
20
  useEffect(() => {
12
21
  if (addingItem && status === 'idle') {
13
22
  setAddingItem(false);
14
- cartUI === null || cartUI === void 0 ? void 0 : cartUI.openCart();
15
23
  }
16
- }, [status, addingItem, cartUI]);
24
+ }, [status, addingItem]);
25
+ const handleAddItem = useCallback(() => {
26
+ setAddingItem(true);
27
+ linesAdd([
28
+ {
29
+ quantity,
30
+ merchandiseId: variantId,
31
+ attributes,
32
+ },
33
+ ]);
34
+ }, [linesAdd, quantity, variantId, attributes]);
17
35
  return (React.createElement(React.Fragment, null,
18
- React.createElement("button", { ...passthroughProps, disabled: addingItem || passthroughProps.disabled, onClick: () => {
19
- setAddingItem(true);
20
- if (!id) {
21
- createCart({
22
- lines: [
23
- {
24
- quantity: quantity,
25
- merchandiseId: variantID,
26
- attributes: attributes,
27
- },
28
- ],
29
- });
30
- }
31
- else {
32
- addLines([
33
- {
34
- quantity: quantity,
35
- merchandiseId: variantID,
36
- attributes: attributes,
37
- },
38
- ]);
39
- }
40
- } }, children),
41
- React.createElement("p", { className: "sr-only", role: "alert", "aria-live": "assertive" }, addingItem
42
- ? accessibleAddingToCartLabel !== null && accessibleAddingToCartLabel !== void 0 ? accessibleAddingToCartLabel : 'Adding product to your cart'
43
- : null)));
36
+ React.createElement(BaseButton, { ...passthroughProps, disabled: disabled, onClick: onClick, defaultOnClick: handleAddItem }, children),
37
+ accessibleAddingToCartLabel ? (React.createElement("p", { style: {
38
+ position: 'absolute',
39
+ width: '1px',
40
+ height: '1px',
41
+ padding: '0',
42
+ margin: '-1px',
43
+ overflow: 'hidden',
44
+ clip: 'rect(0, 0, 0, 0)',
45
+ whiteSpace: 'nowrap',
46
+ borderWidth: '0',
47
+ }, role: "alert", "aria-live": "assertive" }, addingItem ? accessibleAddingToCartLabel : null)) : null));
44
48
  }
@@ -1 +1 @@
1
- export { AddToCartButton, AddToCartButtonProps } from './AddToCartButton.client';
1
+ export { AddToCartButton } from './AddToCartButton.client';
@@ -0,0 +1,14 @@
1
+ import React, { ReactNode, Ref } from 'react';
2
+ interface Props {
3
+ /** Any ReactNode elements. */
4
+ children: ReactNode;
5
+ /** Click event handler. Default behaviour triggers unless prevented */
6
+ onClick?: (event?: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void | boolean;
7
+ /** A default onClick behaviour */
8
+ defaultOnClick?: (event?: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void | boolean;
9
+ /** A ref to the underlying button */
10
+ buttonRef?: Ref<HTMLButtonElement>;
11
+ }
12
+ export declare type BaseButtonProps = Omit<JSX.IntrinsicElements['button'], 'onClick' | 'children'> & Props;
13
+ export declare function BaseButton({ onClick, defaultOnClick, children, buttonRef, ...passthroughProps }: BaseButtonProps): JSX.Element;
14
+ export {};
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import { useCallback } from 'react';
3
+ export function BaseButton({ onClick, defaultOnClick, children, buttonRef, ...passthroughProps }) {
4
+ const handleOnClick = useCallback((event) => {
5
+ if (onClick) {
6
+ const clickShouldContinue = onClick(event);
7
+ if ((typeof clickShouldContinue === 'boolean' &&
8
+ clickShouldContinue === false) ||
9
+ event?.defaultPrevented)
10
+ return;
11
+ }
12
+ defaultOnClick?.(event);
13
+ }, [defaultOnClick, onClick]);
14
+ return (React.createElement("button", { ...passthroughProps, ref: buttonRef, onClick: handleOnClick }, children));
15
+ }
@@ -0,0 +1 @@
1
+ export { BaseButton, BaseButtonProps } from './BaseButton.client';
@@ -0,0 +1 @@
1
+ export { BaseButton } from './BaseButton.client';
@@ -0,0 +1,15 @@
1
+ import { BaseButtonProps } from '../BaseButton';
2
+ interface BuyNowButtonProps {
3
+ /** The item quantity. Defaults to 1. */
4
+ quantity?: number;
5
+ /** The ID of the variant. */
6
+ variantId: string;
7
+ /** An array of cart line attributes that belong to the item being added to the cart. */
8
+ attributes?: {
9
+ key: string;
10
+ value: string;
11
+ }[];
12
+ }
13
+ /** The `BuyNowButton` component renders a button that adds an item to the cart and redirects the customer to checkout. */
14
+ export declare function BuyNowButton(props: BuyNowButtonProps & BaseButtonProps): JSX.Element;
15
+ export {};
@@ -0,0 +1,27 @@
1
+ import React, { useEffect, useState, useCallback } from 'react';
2
+ import { useInstantCheckout } from '../CartProvider';
3
+ import { BaseButton } from '../BaseButton';
4
+ /** The `BuyNowButton` component renders a button that adds an item to the cart and redirects the customer to checkout. */
5
+ export function BuyNowButton(props) {
6
+ const { createInstantCheckout, checkoutUrl } = useInstantCheckout();
7
+ const [loading, setLoading] = useState(false);
8
+ const { quantity, variantId, onClick, attributes, children, ...passthroughProps } = props;
9
+ useEffect(() => {
10
+ if (checkoutUrl) {
11
+ window.location.href = checkoutUrl;
12
+ }
13
+ }, [checkoutUrl]);
14
+ const handleBuyNow = useCallback(() => {
15
+ setLoading(true);
16
+ createInstantCheckout({
17
+ lines: [
18
+ {
19
+ quantity: quantity ?? 1,
20
+ merchandiseId: variantId,
21
+ attributes,
22
+ },
23
+ ],
24
+ });
25
+ }, [createInstantCheckout, quantity, variantId, attributes]);
26
+ return (React.createElement(BaseButton, { disabled: loading ?? passthroughProps.disabled, ...passthroughProps, onClick: onClick, defaultOnClick: handleBuyNow }, children));
27
+ }
@@ -1 +1 @@
1
- export { BuyNowButton, BuyNowButtonProps, BuyNowButtonPropsWeControl, } from './BuyNowButton';
1
+ export { BuyNowButton } from './BuyNowButton.client';
@@ -1 +1 @@
1
- export { BuyNowButton, } from './BuyNowButton';
1
+ export { BuyNowButton } from './BuyNowButton.client';
@@ -1,7 +1,11 @@
1
- import React, { ReactNode } from 'react';
2
- import { Props } from '../types';
1
+ import { ReactNode } from 'react';
3
2
  declare type PropsWeControl = 'onClick';
4
- export declare function CartCheckoutButton<TTag extends React.ElementType = 'a'>(props: Props<TTag, PropsWeControl> & {
3
+ /**
4
+ * The `CartCheckoutButton` component renders a button that redirects to the checkout URL for the cart.
5
+ * It must be a descendent of a `CartProvider` component.
6
+ */
7
+ export declare function CartCheckoutButton(props: Omit<JSX.IntrinsicElements['button'], PropsWeControl> & {
8
+ /** A `ReactNode` element. */
5
9
  children: ReactNode;
6
10
  }): JSX.Element;
7
11
  export {};
@@ -1,14 +1,17 @@
1
1
  import React, { useEffect, useState } from 'react';
2
- import { useCart, useCartCheckoutUrl } from '../CartProvider';
2
+ import { useCart } from '../CartProvider';
3
+ /**
4
+ * The `CartCheckoutButton` component renders a button that redirects to the checkout URL for the cart.
5
+ * It must be a descendent of a `CartProvider` component.
6
+ */
3
7
  export function CartCheckoutButton(props) {
4
8
  const [requestedCheckout, setRequestedCheckout] = useState(false);
5
- const { status } = useCart();
6
- const url = useCartCheckoutUrl();
9
+ const { status, checkoutUrl } = useCart();
7
10
  const { children, ...passthroughProps } = props;
8
11
  useEffect(() => {
9
- if (requestedCheckout && url && status === 'idle') {
10
- window.location.href = url;
12
+ if (requestedCheckout && checkoutUrl && status === 'idle') {
13
+ window.location.href = checkoutUrl;
11
14
  }
12
- }, [requestedCheckout, status, url]);
15
+ }, [requestedCheckout, status, checkoutUrl]);
13
16
  return (React.createElement("button", { ...passthroughProps, disabled: requestedCheckout || passthroughProps.disabled, onClick: () => setRequestedCheckout(true) }, children));
14
17
  }
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ import { Money } from '../Money';
3
+ export interface CartCostProps {
4
+ /** A string type that defines the type of cost needed. Valid values: `total`, `subtotal`, `tax`, or `duty`. */
5
+ amountType?: 'total' | 'subtotal' | 'tax' | 'duty';
6
+ /** A function that takes an object return by the `useMoney` hook and returns a `ReactNode`. */
7
+ children?: React.ReactNode;
8
+ }
9
+ /**
10
+ * The `CartCost` component renders a `Money` component with the
11
+ * cost associated with the `amountType` prop. If no `amountType` prop is specified, then it defaults to `totalAmount`.
12
+ * If `children` is a function, then it will pass down the render props provided by the parent component.
13
+ */
14
+ export declare function CartCost(props: Omit<React.ComponentProps<typeof Money>, 'data'> & CartCostProps): JSX.Element | null;
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import { useCart } from '../CartProvider';
3
+ import { Money } from '../Money';
4
+ /**
5
+ * The `CartCost` component renders a `Money` component with the
6
+ * cost associated with the `amountType` prop. If no `amountType` prop is specified, then it defaults to `totalAmount`.
7
+ * If `children` is a function, then it will pass down the render props provided by the parent component.
8
+ */
9
+ export function CartCost(props) {
10
+ const { cost } = useCart();
11
+ const { amountType = 'total', children, ...passthroughProps } = props;
12
+ let amount;
13
+ if (amountType == 'total') {
14
+ amount = cost?.totalAmount;
15
+ }
16
+ else if (amountType == 'subtotal') {
17
+ amount = cost?.subtotalAmount;
18
+ }
19
+ else if (amountType == 'tax') {
20
+ amount = cost?.totalTaxAmount;
21
+ }
22
+ else if (amountType == 'duty') {
23
+ amount = cost?.totalDutyAmount;
24
+ }
25
+ if (amount == null) {
26
+ return null;
27
+ }
28
+ return (React.createElement(Money, { ...passthroughProps, data: amount }, children));
29
+ }
@@ -0,0 +1 @@
1
+ export { CartCost } from './CartCost.client';
@@ -0,0 +1 @@
1
+ export { CartCost } from './CartCost.client';
@@ -1,6 +1,9 @@
1
- import { ElementType } from 'react';
2
- import { Props } from '../types';
3
- import { ImageSizeOptions } from '../../utilities';
4
- export declare function CartLineImage<TTag extends ElementType = 'img'>(props: Props<TTag> & {
5
- options?: ImageSizeOptions;
6
- }): JSX.Element | null;
1
+ import { type ShopifyImageProps } from '../Image';
2
+ import type { Simplify } from 'type-fest';
3
+ declare type PropsWeControl = 'data';
4
+ /**
5
+ * The `CartLineImage` component renders an `Image` component for the cart line merchandise's image.
6
+ * It must be a descendent of a `CartLineProvider` component.
7
+ */
8
+ export declare function CartLineImage(props: Simplify<Omit<ShopifyImageProps, PropsWeControl>>): JSX.Element | null;
9
+ export {};
@@ -1,8 +1,11 @@
1
1
  import React from 'react';
2
2
  import { useCartLine } from '../CartLineProvider';
3
- import { Image as ImageComponent } from '../Image';
3
+ import { Image } from '../Image';
4
+ /**
5
+ * The `CartLineImage` component renders an `Image` component for the cart line merchandise's image.
6
+ * It must be a descendent of a `CartLineProvider` component.
7
+ */
4
8
  export function CartLineImage(props) {
5
9
  const cartLine = useCartLine();
6
- const { options, ...passthroughProps } = props;
7
- return cartLine.merchandise.image ? (React.createElement(ImageComponent, { ...passthroughProps, image: cartLine.merchandise.image, options: options })) : null;
10
+ return cartLine.merchandise.image ? (React.createElement(Image, { ...props, data: cartLine.merchandise.image })) : null;
8
11
  }
@@ -1,6 +1,12 @@
1
- import { ElementType } from 'react';
2
- import { Props } from '../types';
3
- export interface CartLinePriceProps {
1
+ import React from 'react';
2
+ import { Money } from '../Money';
3
+ interface CartLinePriceProps {
4
+ /** The type of price. Valid values:`regular` (default) or `compareAt`. */
4
5
  priceType?: 'regular' | 'compareAt';
5
6
  }
6
- export declare function CartLinePrice<TTag extends ElementType>(props: Props<TTag> & CartLinePriceProps): JSX.Element | null;
7
+ /**
8
+ * The `CartLinePrice` component renders a `Money` component for the cart line merchandise's price or
9
+ * compare at price. It must be a descendent of a `CartLineProvider` component.
10
+ */
11
+ export declare function CartLinePrice(props: Omit<React.ComponentProps<typeof Money>, 'data'> & CartLinePriceProps): JSX.Element | null;
12
+ export {};
@@ -1,17 +1,18 @@
1
1
  import React from 'react';
2
2
  import { useCartLine } from '../CartLineProvider';
3
3
  import { Money } from '../Money';
4
+ /**
5
+ * The `CartLinePrice` component renders a `Money` component for the cart line merchandise's price or
6
+ * compare at price. It must be a descendent of a `CartLineProvider` component.
7
+ */
4
8
  export function CartLinePrice(props) {
5
9
  const cartLine = useCartLine();
6
10
  const { priceType = 'regular', ...passthroughProps } = props;
7
- const price = priceType === 'regular'
8
- ? cartLine.merchandise.priceV2
9
- : cartLine.merchandise.compareAtPriceV2;
10
- if (price == null) {
11
+ const moneyV2 = priceType === 'regular'
12
+ ? cartLine.cost.totalAmount
13
+ : cartLine.cost.compareAtAmountPerQuantity;
14
+ if (moneyV2 == null) {
11
15
  return null;
12
16
  }
13
- return (React.createElement(Money, { ...passthroughProps, money: {
14
- amount: price.amount * cartLine.quantity,
15
- currencyCode: price.currencyCode,
16
- } }, props.children));
17
+ return React.createElement(Money, { ...passthroughProps, data: moneyV2 });
17
18
  }
@@ -1,3 +1,8 @@
1
- import { ElementType } from 'react';
2
- import { Props } from '../types';
3
- export declare function CartLineProductTitle<TTag extends ElementType>(props: Props<TTag>): JSX.Element;
1
+ /**
2
+ * The `CartLineProductTitle` component renders a `span` element (or the type of HTML element specified by
3
+ * the `as` prop) with the cart line merchandise's title. It must be a descendent of a `CartLineProvider` component.
4
+ */
5
+ export declare function CartLineProductTitle<TTag extends keyof JSX.IntrinsicElements = 'span'>(props: JSX.IntrinsicElements[TTag] & {
6
+ /** An HTML tag to be rendered as the base element wrapper. The default is `span`. */
7
+ as?: TTag;
8
+ }): JSX.Element;
@@ -1,5 +1,9 @@
1
1
  import React from 'react';
2
2
  import { useCartLine } from '../CartLineProvider';
3
+ /**
4
+ * The `CartLineProductTitle` component renders a `span` element (or the type of HTML element specified by
5
+ * the `as` prop) with the cart line merchandise's title. It must be a descendent of a `CartLineProvider` component.
6
+ */
3
7
  export function CartLineProductTitle(props) {
4
8
  const cartLine = useCartLine();
5
9
  const { as, ...passthroughProps } = props;
@@ -1,6 +1,11 @@
1
1
  import { ReactNode } from 'react';
2
2
  import { Cart } from '../CartProvider';
3
+ /**
4
+ * The `CartLineProvider` component creates a context for using a cart line.
5
+ */
3
6
  export declare function CartLineProvider({ children, line, }: {
7
+ /** Any `ReactNode` elements. */
4
8
  children: ReactNode;
9
+ /** A cart line object. */
5
10
  line: Cart['lines'][1];
6
11
  }): JSX.Element;
@@ -1,5 +1,8 @@
1
1
  import React from 'react';
2
2
  import { CartLineContext } from './context';
3
+ /**
4
+ * The `CartLineProvider` component creates a context for using a cart line.
5
+ */
3
6
  export function CartLineProvider({ children, line, }) {
4
7
  return (React.createElement(CartLineContext.Provider, { value: line }, children));
5
8
  }
@@ -1,26 +1,36 @@
1
1
  export declare const CartLineContext: import("react").Context<({
2
2
  __typename?: "CartLine" | undefined;
3
- } & Pick<import("../../graphql/types/types").CartLine, "id" | "quantity"> & {
3
+ } & Pick<import("../../storefront-api-types").CartLine, "id" | "quantity"> & {
4
4
  attributes: ({
5
5
  __typename?: "Attribute" | undefined;
6
- } & Pick<import("../../graphql/types/types").Attribute, "key" | "value">)[];
6
+ } & Pick<import("../../storefront-api-types").Attribute, "key" | "value">)[];
7
+ cost: {
8
+ __typename?: "CartLineCost" | undefined;
9
+ } & {
10
+ totalAmount: {
11
+ __typename?: "MoneyV2" | undefined;
12
+ } & Pick<import("../../storefront-api-types").MoneyV2, "currencyCode" | "amount">;
13
+ compareAtAmountPerQuantity?: import("../../storefront-api-types").Maybe<{
14
+ __typename?: "MoneyV2" | undefined;
15
+ } & Pick<import("../../storefront-api-types").MoneyV2, "currencyCode" | "amount">> | undefined;
16
+ };
7
17
  merchandise: {
8
18
  __typename?: "ProductVariant" | undefined;
9
- } & Pick<import("../../graphql/types/types").ProductVariant, "title" | "id" | "availableForSale" | "requiresShipping"> & {
10
- compareAtPriceV2?: import("../../graphql/types/types").Maybe<{
19
+ } & Pick<import("../../storefront-api-types").ProductVariant, "id" | "title" | "availableForSale" | "requiresShipping"> & {
20
+ compareAtPriceV2?: import("../../storefront-api-types").Maybe<{
11
21
  __typename?: "MoneyV2" | undefined;
12
- } & Pick<import("../../graphql/types/types").MoneyV2, "amount" | "currencyCode">> | undefined;
22
+ } & Pick<import("../../storefront-api-types").MoneyV2, "currencyCode" | "amount">> | undefined;
13
23
  priceV2: {
14
24
  __typename?: "MoneyV2" | undefined;
15
- } & Pick<import("../../graphql/types/types").MoneyV2, "amount" | "currencyCode">;
16
- image?: import("../../graphql/types/types").Maybe<{
25
+ } & Pick<import("../../storefront-api-types").MoneyV2, "currencyCode" | "amount">;
26
+ image?: import("../../storefront-api-types").Maybe<{
17
27
  __typename?: "Image" | undefined;
18
- } & Pick<import("../../graphql/types/types").Image, "altText" | "originalSrc">> | undefined;
28
+ } & Pick<import("../../storefront-api-types").Image, "id" | "height" | "width" | "url" | "altText">> | undefined;
19
29
  product: {
20
30
  __typename?: "Product" | undefined;
21
- } & Pick<import("../../graphql/types/types").Product, "title" | "handle">;
31
+ } & Pick<import("../../storefront-api-types").Product, "title" | "handle">;
22
32
  selectedOptions: ({
23
33
  __typename?: "SelectedOption" | undefined;
24
- } & Pick<import("../../graphql/types/types").SelectedOption, "value" | "name">)[];
34
+ } & Pick<import("../../storefront-api-types").SelectedOption, "name" | "value">)[];
25
35
  };
26
36
  }) | null>;
@@ -1,2 +1,2 @@
1
1
  export { CartLineProvider } from './CartLineProvider.client';
2
- export { useCartLine } from './hooks';
2
+ export { useCartLine } from '../../hooks/useCartLine';
@@ -1,2 +1,2 @@
1
1
  export { CartLineProvider } from './CartLineProvider.client';
2
- export { useCartLine } from './hooks';
2
+ export { useCartLine } from '../../hooks/useCartLine';
@@ -1,3 +1,8 @@
1
- import { ElementType } from 'react';
2
- import { Props } from '../types';
3
- export declare function CartLineQuantity<TTag extends ElementType>(props: Props<TTag>): JSX.Element;
1
+ /**
2
+ * The `CartLineQuantity` component renders a `span` element (or the type of HTML element
3
+ * specified by the `as` prop) with the cart line's quantity. It must be a descendent of a `CartLineProvider` component.
4
+ */
5
+ export declare function CartLineQuantity<TTag extends keyof JSX.IntrinsicElements = 'span'>(props: JSX.IntrinsicElements[TTag] & {
6
+ /** An HTML tag to be rendered as the base element wrapper. The default is `div`. */
7
+ as?: TTag;
8
+ }): JSX.Element;
@@ -1,5 +1,9 @@
1
1
  import React from 'react';
2
2
  import { useCartLine } from '../CartLineProvider';
3
+ /**
4
+ * The `CartLineQuantity` component renders a `span` element (or the type of HTML element
5
+ * specified by the `as` prop) with the cart line's quantity. It must be a descendent of a `CartLineProvider` component.
6
+ */
3
7
  export function CartLineQuantity(props) {
4
8
  const cartLine = useCartLine();
5
9
  const { as, ...passthroughProps } = props;
@@ -1,8 +1,13 @@
1
- import { ReactNode, ElementType } from 'react';
1
+ import { ElementType } from 'react';
2
2
  import { Props } from '../types';
3
- declare type PropsWeControl = 'onClick' | 'adjust';
3
+ import { BaseButtonProps } from '../BaseButton';
4
+ declare type PropsWeControl = 'adjust';
5
+ /**
6
+ * The `CartLineQuantityAdjustButton` component renders a button that adjusts the cart line's quantity when pressed.
7
+ * It must be a descendent of a `CartLineProvider` component.
8
+ */
4
9
  export declare function CartLineQuantityAdjustButton<TTag extends ElementType = 'button'>(props: Props<TTag, PropsWeControl> & {
5
- children: ReactNode;
10
+ /** The adjustment for a cart line's quantity. Valid values: `increase` (default), `decrease`, or `remove`. */
6
11
  adjust?: 'increase' | 'decrease' | 'remove';
7
- }): JSX.Element;
12
+ } & BaseButtonProps): JSX.Element;
8
13
  export {};