@rebuy/rebuy-hydrogen 3.0.0-beta.2 → 3.0.0-beta.20

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 (307) hide show
  1. package/README.md +988 -16
  2. package/dist/assets/Close.d.ts +2 -0
  3. package/dist/assets/Close.d.ts.map +1 -0
  4. package/dist/components/AddToCartBtn/AddToCartBtn.d.ts +1 -1
  5. package/dist/components/AddToCartBtn/AddToCartBtn.d.ts.map +1 -1
  6. package/dist/components/AddToCartBtn/HydrogenAddToCartBtn.d.ts +1 -1
  7. package/dist/components/AddToCartBtn/HydrogenAddToCartBtn.d.ts.map +1 -1
  8. package/dist/components/AddToCartBtn/HydrogenReactAddToCartBtn.d.ts +1 -1
  9. package/dist/components/AddToCartBtn/HydrogenReactAddToCartBtn.d.ts.map +1 -1
  10. package/dist/components/AddToCartBtn/types.d.ts +5 -0
  11. package/dist/components/AddToCartBtn/types.d.ts.map +1 -1
  12. package/dist/components/ProductCard/ProductCard.d.ts +1 -1
  13. package/dist/components/ProductCard/ProductCard.d.ts.map +1 -1
  14. package/dist/components/ProductCard/defaultSettings.d.ts +3 -0
  15. package/dist/components/ProductCard/defaultSettings.d.ts.map +1 -0
  16. package/dist/components/ProductCard/index.d.ts +1 -0
  17. package/dist/components/ProductCard/index.d.ts.map +1 -1
  18. package/dist/components/ProductCard/types.d.ts +46 -0
  19. package/dist/components/ProductCard/types.d.ts.map +1 -1
  20. package/dist/components/ProductCarousel/ProductCarousel.d.ts +3 -0
  21. package/dist/components/ProductCarousel/ProductCarousel.d.ts.map +1 -0
  22. package/dist/components/ProductCarousel/index.d.ts +2 -0
  23. package/dist/components/ProductCarousel/index.d.ts.map +1 -0
  24. package/dist/components/ProductCarousel/types.d.ts +18 -0
  25. package/dist/components/ProductCarousel/types.d.ts.map +1 -0
  26. package/dist/components/ProductPrice/ProductPrice.d.ts +2 -4
  27. package/dist/components/ProductPrice/ProductPrice.d.ts.map +1 -1
  28. package/dist/components/ProductPrice/types.d.ts +23 -0
  29. package/dist/components/ProductPrice/types.d.ts.map +1 -0
  30. package/dist/components/QuantityInput/QuantityInput.d.ts +3 -0
  31. package/dist/components/QuantityInput/QuantityInput.d.ts.map +1 -0
  32. package/dist/components/QuantityInput/index.d.ts +3 -0
  33. package/dist/components/QuantityInput/index.d.ts.map +1 -0
  34. package/dist/components/QuantityInput/types.d.ts +7 -0
  35. package/dist/components/QuantityInput/types.d.ts.map +1 -0
  36. package/dist/components/RebuyLink/RebuyLink.d.ts +3 -0
  37. package/dist/components/RebuyLink/RebuyLink.d.ts.map +1 -0
  38. package/dist/components/RebuyLink/index.d.ts +2 -0
  39. package/dist/components/RebuyLink/index.d.ts.map +1 -0
  40. package/dist/components/RebuyLink/types.d.ts +10 -0
  41. package/dist/components/RebuyLink/types.d.ts.map +1 -0
  42. package/dist/components/Timer/Timer.d.ts +3 -0
  43. package/dist/components/Timer/Timer.d.ts.map +1 -0
  44. package/dist/components/Timer/index.d.ts +3 -0
  45. package/dist/components/Timer/index.d.ts.map +1 -0
  46. package/dist/components/Timer/types.d.ts +20 -0
  47. package/dist/components/Timer/types.d.ts.map +1 -0
  48. package/dist/components/Title/Title.d.ts +1 -1
  49. package/dist/components/Title/Title.d.ts.map +1 -1
  50. package/dist/components/Title/types.d.ts +1 -0
  51. package/dist/components/Title/types.d.ts.map +1 -1
  52. package/dist/components/VariantSelect/VariantSelect.d.ts +1 -1
  53. package/dist/components/VariantSelect/VariantSelect.d.ts.map +1 -1
  54. package/dist/components/VariantSelect/types.d.ts +2 -0
  55. package/dist/components/VariantSelect/types.d.ts.map +1 -1
  56. package/dist/constants/api.d.ts +2 -0
  57. package/dist/constants/api.d.ts.map +1 -0
  58. package/dist/constants/debug.d.ts +28 -0
  59. package/dist/constants/debug.d.ts.map +1 -0
  60. package/dist/context/RebuyConfigContext.d.ts +23 -0
  61. package/dist/context/RebuyConfigContext.d.ts.map +1 -0
  62. package/dist/context/RebuyWidgetContext.d.ts +7 -0
  63. package/dist/context/RebuyWidgetContext.d.ts.map +1 -0
  64. package/dist/hooks/titleLevel.d.ts.map +1 -1
  65. package/dist/hooks/useBFCacheReset.d.ts +7 -0
  66. package/dist/hooks/useBFCacheReset.d.ts.map +1 -0
  67. package/dist/hooks/useBreakpoint.d.ts +5 -0
  68. package/dist/hooks/useBreakpoint.d.ts.map +1 -0
  69. package/dist/hooks/usePopupTrigger.d.ts +3 -0
  70. package/dist/hooks/usePopupTrigger.d.ts.map +1 -0
  71. package/dist/index.css +2680 -99
  72. package/dist/index.css.map +4 -4
  73. package/dist/index.d.ts +9 -0
  74. package/dist/index.d.ts.map +1 -1
  75. package/dist/index.js +9756 -1461
  76. package/dist/index.js.map +4 -4
  77. package/dist/index.mjs +9768 -1482
  78. package/dist/index.mjs.map +4 -4
  79. package/dist/providers/RebuyHydrogenContextProvider.d.ts +1 -1
  80. package/dist/providers/RebuyHydrogenContextProvider.d.ts.map +1 -1
  81. package/dist/providers/RebuyHydrogenReactContextProvider.d.ts +6 -1
  82. package/dist/providers/RebuyHydrogenReactContextProvider.d.ts.map +1 -1
  83. package/dist/providers/types.d.ts +29 -14
  84. package/dist/providers/types.d.ts.map +1 -1
  85. package/dist/queries/cart.queries.d.ts +4 -4
  86. package/dist/queries/cart.queries.d.ts.map +1 -1
  87. package/dist/smart-cart/RebuySmartCart.d.ts +10 -0
  88. package/dist/smart-cart/RebuySmartCart.d.ts.map +1 -0
  89. package/dist/smart-cart/components/AnnouncementBar/AnnouncementBar.d.ts +10 -0
  90. package/dist/smart-cart/components/AnnouncementBar/AnnouncementBar.d.ts.map +1 -0
  91. package/dist/smart-cart/components/CartItem/CartItem.d.ts +7 -0
  92. package/dist/smart-cart/components/CartItem/CartItem.d.ts.map +1 -0
  93. package/dist/smart-cart/components/CartItemList/CartItemList.d.ts +10 -0
  94. package/dist/smart-cart/components/CartItemList/CartItemList.d.ts.map +1 -0
  95. package/dist/smart-cart/components/CartNoteInput/CartNoteInput.d.ts +10 -0
  96. package/dist/smart-cart/components/CartNoteInput/CartNoteInput.d.ts.map +1 -0
  97. package/dist/smart-cart/components/CartSubtotal/CartSubtotal.d.ts +11 -0
  98. package/dist/smart-cart/components/CartSubtotal/CartSubtotal.d.ts.map +1 -0
  99. package/dist/smart-cart/components/CartTitleBar/CartTitleBar.d.ts +7 -0
  100. package/dist/smart-cart/components/CartTitleBar/CartTitleBar.d.ts.map +1 -0
  101. package/dist/smart-cart/components/CheckoutArea/CheckoutArea.d.ts +10 -0
  102. package/dist/smart-cart/components/CheckoutArea/CheckoutArea.d.ts.map +1 -0
  103. package/dist/smart-cart/components/CrossSell/CrossSell.d.ts +10 -0
  104. package/dist/smart-cart/components/CrossSell/CrossSell.d.ts.map +1 -0
  105. package/dist/smart-cart/components/CustomCode/CustomCodeBlock.d.ts +21 -0
  106. package/dist/smart-cart/components/CustomCode/CustomCodeBlock.d.ts.map +1 -0
  107. package/dist/smart-cart/components/DebugPanel/DebugPanel.d.ts +13 -0
  108. package/dist/smart-cart/components/DebugPanel/DebugPanel.d.ts.map +1 -0
  109. package/dist/smart-cart/components/DebugPanel/index.d.ts +11 -0
  110. package/dist/smart-cart/components/DebugPanel/index.d.ts.map +1 -0
  111. package/dist/smart-cart/components/DiscountCodeInput/DiscountCodeInput.d.ts +10 -0
  112. package/dist/smart-cart/components/DiscountCodeInput/DiscountCodeInput.d.ts.map +1 -0
  113. package/dist/smart-cart/components/EmptyCart/EmptyCart.d.ts +3 -0
  114. package/dist/smart-cart/components/EmptyCart/EmptyCart.d.ts.map +1 -0
  115. package/dist/smart-cart/components/LoginButton/LoginButton.d.ts +3 -0
  116. package/dist/smart-cart/components/LoginButton/LoginButton.d.ts.map +1 -0
  117. package/dist/smart-cart/components/ScreenReaderText/ScreenReaderText.d.ts +8 -0
  118. package/dist/smart-cart/components/ScreenReaderText/ScreenReaderText.d.ts.map +1 -0
  119. package/dist/smart-cart/components/SmartCartApp/SmartCartApp.d.ts +20 -0
  120. package/dist/smart-cart/components/SmartCartApp/SmartCartApp.d.ts.map +1 -0
  121. package/dist/smart-cart/components/SmartCartContainer/SmartCartContainer.d.ts +8 -0
  122. package/dist/smart-cart/components/SmartCartContainer/SmartCartContainer.d.ts.map +1 -0
  123. package/dist/smart-cart/components/TieredProgressBar/Icons.d.ts +5 -0
  124. package/dist/smart-cart/components/TieredProgressBar/Icons.d.ts.map +1 -0
  125. package/dist/smart-cart/components/TieredProgressBar/TPBGiftItem.d.ts +21 -0
  126. package/dist/smart-cart/components/TieredProgressBar/TPBGiftItem.d.ts.map +1 -0
  127. package/dist/smart-cart/components/TieredProgressBar/TieredProgressBar.d.ts +11 -0
  128. package/dist/smart-cart/components/TieredProgressBar/TieredProgressBar.d.ts.map +1 -0
  129. package/dist/smart-cart/components/TieredProgressBar/progressBarUtils.d.ts +173 -0
  130. package/dist/smart-cart/components/TieredProgressBar/progressBarUtils.d.ts.map +1 -0
  131. package/dist/smart-cart/components/TieredProgressBar/types.d.ts +261 -0
  132. package/dist/smart-cart/components/TieredProgressBar/types.d.ts.map +1 -0
  133. package/dist/smart-cart/components/_Layouts/AnchorSlot.d.ts +13 -0
  134. package/dist/smart-cart/components/_Layouts/AnchorSlot.d.ts.map +1 -0
  135. package/dist/smart-cart/components/_Layouts/DoubleColumnLayout.d.ts +9 -0
  136. package/dist/smart-cart/components/_Layouts/DoubleColumnLayout.d.ts.map +1 -0
  137. package/dist/smart-cart/components/_Layouts/SingleColumnLayout.d.ts +8 -0
  138. package/dist/smart-cart/components/_Layouts/SingleColumnLayout.d.ts.map +1 -0
  139. package/dist/smart-cart/components/componentRegistry.d.ts +3 -0
  140. package/dist/smart-cart/components/componentRegistry.d.ts.map +1 -0
  141. package/dist/smart-cart/constants.d.ts +58 -0
  142. package/dist/smart-cart/constants.d.ts.map +1 -0
  143. package/dist/smart-cart/context/SmartCartContext.d.ts +62 -0
  144. package/dist/smart-cart/context/SmartCartContext.d.ts.map +1 -0
  145. package/dist/smart-cart/context/StorefrontCartContext.d.ts +32 -0
  146. package/dist/smart-cart/context/StorefrontCartContext.d.ts.map +1 -0
  147. package/dist/smart-cart/hooks/useCartItemFeatures.d.ts +84 -0
  148. package/dist/smart-cart/hooks/useCartItemFeatures.d.ts.map +1 -0
  149. package/dist/smart-cart/hooks/useDiscountManager.d.ts +28 -0
  150. package/dist/smart-cart/hooks/useDiscountManager.d.ts.map +1 -0
  151. package/dist/smart-cart/hooks/useGeolocation.d.ts +12 -0
  152. package/dist/smart-cart/hooks/useGeolocation.d.ts.map +1 -0
  153. package/dist/smart-cart/hooks/useIsScrolled.d.ts +14 -0
  154. package/dist/smart-cart/hooks/useIsScrolled.d.ts.map +1 -0
  155. package/dist/smart-cart/hooks/useSmartCartApps.d.ts +17 -0
  156. package/dist/smart-cart/hooks/useSmartCartApps.d.ts.map +1 -0
  157. package/dist/smart-cart/store/tieredProgressBarStore.d.ts +76 -0
  158. package/dist/smart-cart/store/tieredProgressBarStore.d.ts.map +1 -0
  159. package/dist/smart-cart/types/rebuy-storefront-cart.d.ts +142 -0
  160. package/dist/smart-cart/types/rebuy-storefront-cart.d.ts.map +1 -0
  161. package/dist/smart-cart/types/rebuy.d.ts +15 -0
  162. package/dist/smart-cart/types/rebuy.d.ts.map +1 -0
  163. package/dist/smart-cart/types/shop.d.ts +26 -0
  164. package/dist/smart-cart/types/shop.d.ts.map +1 -0
  165. package/dist/smart-cart/types/smart-cart-app.d.ts +103 -0
  166. package/dist/smart-cart/types/smart-cart-app.d.ts.map +1 -0
  167. package/dist/smart-cart/types/smart-cart-component.d.ts +1350 -0
  168. package/dist/smart-cart/types/smart-cart-component.d.ts.map +1 -0
  169. package/dist/smart-cart/types/smart-cart.d.ts +82 -0
  170. package/dist/smart-cart/types/smart-cart.d.ts.map +1 -0
  171. package/dist/smart-cart/utils/cartItemUtils.d.ts +292 -0
  172. package/dist/smart-cart/utils/cartItemUtils.d.ts.map +1 -0
  173. package/dist/smart-cart/utils/debugLog.d.ts +77 -0
  174. package/dist/smart-cart/utils/debugLog.d.ts.map +1 -0
  175. package/dist/smart-cart/utils/debugStyles.d.ts +3342 -0
  176. package/dist/smart-cart/utils/debugStyles.d.ts.map +1 -0
  177. package/dist/smart-cart/utils/executeScriptsInContainer.d.ts +14 -0
  178. package/dist/smart-cart/utils/executeScriptsInContainer.d.ts.map +1 -0
  179. package/dist/smart-cart/utils/imageUtils.d.ts +2 -0
  180. package/dist/smart-cart/utils/imageUtils.d.ts.map +1 -0
  181. package/dist/smart-cart/utils/mapHydrogenCartToStorefrontCartData.d.ts +14 -0
  182. package/dist/smart-cart/utils/mapHydrogenCartToStorefrontCartData.d.ts.map +1 -0
  183. package/dist/smart-cart/utils/moneyUtils.d.ts +24 -0
  184. package/dist/smart-cart/utils/moneyUtils.d.ts.map +1 -0
  185. package/dist/smart-cart/utils/safeJsonParse.d.ts +2 -0
  186. package/dist/smart-cart/utils/safeJsonParse.d.ts.map +1 -0
  187. package/dist/types/common.d.ts +16 -0
  188. package/dist/types/common.d.ts.map +1 -1
  189. package/dist/types/rebuyCustom.d.ts +133 -17
  190. package/dist/types/rebuyCustom.d.ts.map +1 -1
  191. package/dist/types/shopify.d.ts +1 -2
  192. package/dist/types/shopify.d.ts.map +1 -1
  193. package/dist/types/widgets.d.ts +20078 -7
  194. package/dist/types/widgets.d.ts.map +1 -1
  195. package/dist/utils/convertToRebuyProduct.d.ts.map +1 -1
  196. package/dist/utils/createContextParameters.d.ts +1 -1
  197. package/dist/utils/createContextParameters.d.ts.map +1 -1
  198. package/dist/utils/filterContextUtils.d.ts +3 -0
  199. package/dist/utils/filterContextUtils.d.ts.map +1 -0
  200. package/dist/utils/getEncodedAttributes.d.ts.map +1 -1
  201. package/dist/utils/getRebuyConfig.d.ts +1 -1
  202. package/dist/utils/getRebuyConfig.d.ts.map +1 -1
  203. package/dist/utils/nonceManager.d.ts +10 -0
  204. package/dist/utils/nonceManager.d.ts.map +1 -0
  205. package/dist/utils/theme.d.ts +20 -0
  206. package/dist/utils/theme.d.ts.map +1 -0
  207. package/dist/widgetContainer/RebuyWidgetContainer.d.ts +1 -1
  208. package/dist/widgetContainer/RebuyWidgetContainer.d.ts.map +1 -1
  209. package/dist/widgets/RebuyCompleteTheLook/RebuyCompleteTheLook.d.ts.map +1 -1
  210. package/dist/widgets/RebuyDynamicBundleProducts/BundleImages.d.ts.map +1 -1
  211. package/dist/widgets/RebuyDynamicBundleProducts/BundlePrice.d.ts.map +1 -1
  212. package/dist/widgets/RebuyDynamicBundleProducts/BundleSelection.d.ts +1 -1
  213. package/dist/widgets/RebuyDynamicBundleProducts/BundleSelection.d.ts.map +1 -1
  214. package/dist/widgets/RebuyDynamicBundleProducts/RebuyDynamicBundleProducts.d.ts.map +1 -1
  215. package/dist/widgets/RebuyDynamicBundleProducts/Select.d.ts.map +1 -1
  216. package/dist/widgets/RebuyGiftWithPurchase/RebuyGiftWithPurchase.d.ts +11 -0
  217. package/dist/widgets/RebuyGiftWithPurchase/RebuyGiftWithPurchase.d.ts.map +1 -0
  218. package/dist/widgets/RebuyGiftWithPurchase/index.d.ts +3 -0
  219. package/dist/widgets/RebuyGiftWithPurchase/index.d.ts.map +1 -0
  220. package/dist/widgets/RebuyGiftWithPurchase/store/giftWithPurchaseStore.d.ts +31 -0
  221. package/dist/widgets/RebuyGiftWithPurchase/store/giftWithPurchaseStore.d.ts.map +1 -0
  222. package/dist/widgets/RebuyGiftWithPurchase/types.d.ts +12 -0
  223. package/dist/widgets/RebuyGiftWithPurchase/types.d.ts.map +1 -0
  224. package/dist/widgets/RebuyGiftWithPurchase/utils.d.ts +35 -0
  225. package/dist/widgets/RebuyGiftWithPurchase/utils.d.ts.map +1 -0
  226. package/dist/widgets/RebuyProductAddOns/RebuyProductAddOnCard.d.ts.map +1 -1
  227. package/dist/widgets/RebuyProductAddOns/RebuyProductAddOns.d.ts.map +1 -1
  228. package/dist/widgets/RebuyProductAddOns/types.d.ts.map +1 -1
  229. package/dist/widgets/RebuyProductRecommendations/RebuyProductRecommendations.d.ts.map +1 -1
  230. package/dist/widgets/RebuyProductViewed/RebuyProductViewed.d.ts +3 -0
  231. package/dist/widgets/RebuyProductViewed/RebuyProductViewed.d.ts.map +1 -0
  232. package/dist/widgets/RebuyProductViewed/index.d.ts +2 -0
  233. package/dist/widgets/RebuyProductViewed/index.d.ts.map +1 -0
  234. package/dist/widgets/RebuyProductViewed/types.d.ts +8 -0
  235. package/dist/widgets/RebuyProductViewed/types.d.ts.map +1 -0
  236. package/dist/widgets/RebuyRecentlyViewedProducts/RebuyRecentlyViewedProducts.d.ts +3 -0
  237. package/dist/widgets/RebuyRecentlyViewedProducts/RebuyRecentlyViewedProducts.d.ts.map +1 -0
  238. package/dist/widgets/RebuyRecentlyViewedProducts/index.d.ts +2 -0
  239. package/dist/widgets/RebuyRecentlyViewedProducts/index.d.ts.map +1 -0
  240. package/dist/widgets/RebuyRecentlyViewedProducts/types.d.ts +11 -0
  241. package/dist/widgets/RebuyRecentlyViewedProducts/types.d.ts.map +1 -0
  242. package/dist/widgets/RebuyWidget/RebuyWidget.d.ts +3 -0
  243. package/dist/widgets/RebuyWidget/RebuyWidget.d.ts.map +1 -0
  244. package/dist/widgets/RebuyWidget/WidgetContent.d.ts +3 -0
  245. package/dist/widgets/RebuyWidget/WidgetContent.d.ts.map +1 -0
  246. package/dist/widgets/RebuyWidget/index.d.ts +2 -0
  247. package/dist/widgets/RebuyWidget/index.d.ts.map +1 -0
  248. package/dist/widgets/RebuyWidget/types.d.ts +28 -0
  249. package/dist/widgets/RebuyWidget/types.d.ts.map +1 -0
  250. package/dist/zustandStores/productViewed.d.ts +9 -0
  251. package/dist/zustandStores/productViewed.d.ts.map +1 -0
  252. package/package.json +57 -41
  253. package/dist/types/rebuySmartCart.d.ts +0 -184
  254. package/dist/types/rebuySmartCart.d.ts.map +0 -1
  255. package/src/components/AddToCartBtn/AddToCartBtn.tsx +0 -45
  256. package/src/components/AddToCartBtn/HydrogenAddToCartBtn.tsx +0 -43
  257. package/src/components/AddToCartBtn/HydrogenReactAddToCartBtn.tsx +0 -35
  258. package/src/components/AddToCartBtn/index.ts +0 -1
  259. package/src/components/AddToCartBtn/types.ts +0 -27
  260. package/src/components/ProductCard/ProductCard.tsx +0 -70
  261. package/src/components/ProductCard/index.ts +0 -1
  262. package/src/components/ProductCard/types.ts +0 -10
  263. package/src/components/ProductPrice/ProductPrice.tsx +0 -49
  264. package/src/components/ProductPrice/index.ts +0 -1
  265. package/src/components/Title/Title.tsx +0 -19
  266. package/src/components/Title/index.ts +0 -1
  267. package/src/components/Title/types.ts +0 -7
  268. package/src/components/VariantSelect/VariantSelect.tsx +0 -45
  269. package/src/components/VariantSelect/index.ts +0 -1
  270. package/src/components/VariantSelect/types.ts +0 -6
  271. package/src/context/RebuyContext.tsx +0 -9
  272. package/src/hooks/titleLevel.tsx +0 -42
  273. package/src/index.ts +0 -7
  274. package/src/providers/RebuyHydrogenContextProvider.tsx +0 -112
  275. package/src/providers/RebuyHydrogenReactContextProvider.tsx +0 -192
  276. package/src/providers/types.ts +0 -58
  277. package/src/queries/cart.queries.ts +0 -467
  278. package/src/types/common.ts +0 -8
  279. package/src/types/css.d.ts +0 -11
  280. package/src/types/env.d.ts +0 -12
  281. package/src/types/rebuy.d.ts +0 -31
  282. package/src/types/rebuyCustom.ts +0 -263
  283. package/src/types/rebuySmartCart.ts +0 -188
  284. package/src/types/shopify.ts +0 -142
  285. package/src/types/widgets.ts +0 -29
  286. package/src/utils/convertToRebuyProduct.tsx +0 -319
  287. package/src/utils/createContextParameters.ts +0 -142
  288. package/src/utils/getEncodedAttributes.ts +0 -11
  289. package/src/utils/getRebuyConfig.ts +0 -31
  290. package/src/widgetContainer/RebuyWidgetContainer.tsx +0 -183
  291. package/src/widgets/RebuyCompleteTheLook/RebuyCompleteTheLook.tsx +0 -50
  292. package/src/widgets/RebuyCompleteTheLook/index.ts +0 -1
  293. package/src/widgets/RebuyCompleteTheLook/types.ts +0 -5
  294. package/src/widgets/RebuyDynamicBundleProducts/BundleImages.tsx +0 -62
  295. package/src/widgets/RebuyDynamicBundleProducts/BundlePrice.tsx +0 -93
  296. package/src/widgets/RebuyDynamicBundleProducts/BundleSelection.tsx +0 -65
  297. package/src/widgets/RebuyDynamicBundleProducts/RebuyDynamicBundleProducts.tsx +0 -118
  298. package/src/widgets/RebuyDynamicBundleProducts/Select.tsx +0 -41
  299. package/src/widgets/RebuyDynamicBundleProducts/index.ts +0 -1
  300. package/src/widgets/RebuyDynamicBundleProducts/types.ts +0 -23
  301. package/src/widgets/RebuyProductAddOns/RebuyProductAddOnCard.tsx +0 -66
  302. package/src/widgets/RebuyProductAddOns/RebuyProductAddOns.tsx +0 -218
  303. package/src/widgets/RebuyProductAddOns/index.ts +0 -1
  304. package/src/widgets/RebuyProductAddOns/types.ts +0 -24
  305. package/src/widgets/RebuyProductRecommendations/RebuyProductRecommendations.tsx +0 -50
  306. package/src/widgets/RebuyProductRecommendations/index.ts +0 -1
  307. package/src/widgets/RebuyProductRecommendations/types.ts +0 -5
@@ -1,50 +0,0 @@
1
- import styles from '~/widgets/RebuyCompleteTheLook/RebuyCompleteTheLook.module.css';
2
-
3
- import type { RebuyCompleteTheLookProps } from './types';
4
-
5
- import { ProductCard } from '~/components/ProductCard';
6
- import { Title } from '~/components/Title';
7
- import { getTitleLevel } from '~/hooks/titleLevel';
8
-
9
- // Component implementation
10
- export const RebuyCompleteTheLook = (props: RebuyCompleteTheLookProps) => {
11
- const {
12
- addToCartBtnText = 'Add to cart',
13
- addToCartCallback,
14
- customTitle = `These pair with ${props.product?.title}`,
15
- customTitleLevel = 'h2',
16
- customTitleStyle,
17
- products = [],
18
- } = props;
19
-
20
- if (products.length === 0) {
21
- console.log('RebuyCompleteTheLook: No products found');
22
- return null;
23
- }
24
-
25
- return (
26
- <section className={styles.container}>
27
- <Title
28
- level={getTitleLevel(customTitleLevel)}
29
- style={customTitleStyle}
30
- text={customTitle}
31
- />
32
- <ul className={styles.productGrid}>
33
- {products.map((product) => (
34
- <li className={styles.productItem} key={product.id}>
35
- <ProductCard
36
- addToCartBtnText={addToCartBtnText}
37
- addToCartCallback={addToCartCallback}
38
- isHydrogenReact={props.isHydrogenReact}
39
- product={product}
40
- productCardTitleLevel={getTitleLevel(
41
- customTitleLevel,
42
- true
43
- )}
44
- />
45
- </li>
46
- ))}
47
- </ul>
48
- </section>
49
- );
50
- };
@@ -1 +0,0 @@
1
- export * from './RebuyCompleteTheLook';
@@ -1,5 +0,0 @@
1
- import type { WidgetChildProps } from '~/types/widgets';
2
-
3
- export type RebuyCompleteTheLookProps = {
4
- addToCartBtnText?: string;
5
- } & WidgetChildProps;
@@ -1,62 +0,0 @@
1
- import { Link } from '@remix-run/react';
2
- import { Image } from '@shopify/hydrogen';
3
- import { Fragment } from 'react';
4
-
5
- import styles from '~/widgets/RebuyDynamicBundleProducts/RebuyDynamicBundleProducts.module.css';
6
-
7
- import type { BundleProduct } from '~/widgets/RebuyDynamicBundleProducts/types';
8
-
9
- export const BundleImages = ({ products }: { products: BundleProduct[] }) => {
10
- const selected = products.filter((product) => product.selected);
11
-
12
- return (
13
- <ul className={styles.bundleImages}>
14
- {products.map((product, index) => {
15
- const image = product.selectedVariant?.image;
16
- const productImage = image ? (
17
- <Image
18
- alt={image.altText || `Picture of ${product.title}`}
19
- className={styles.bundleImage}
20
- data={image}
21
- height={80}
22
- title={product.title}
23
- width={80}
24
- />
25
- ) : (
26
- // No image defined
27
- product.title
28
- );
29
- // Hide delimiter for first selected item
30
- const showDelimiter = selected[0]?.id !== product.id;
31
-
32
- return (
33
- <Fragment key={product.id + '-BundleImages-' + index}>
34
- {product.selected && (
35
- <>
36
- {showDelimiter && (
37
- <li className={styles.bundleImageDelimiter}>
38
- <span>+</span>
39
- </li>
40
- )}
41
- <li className="flex items-center">
42
- {product.default ? (
43
- // Already on product page
44
- productImage
45
- ) : (
46
- // Link to product
47
- <Link
48
- title={product.title}
49
- to={`/products/${product.handle}`}
50
- >
51
- {productImage}
52
- </Link>
53
- )}
54
- </li>
55
- </>
56
- )}
57
- </Fragment>
58
- );
59
- })}
60
- </ul>
61
- );
62
- };
@@ -1,93 +0,0 @@
1
- import { Money } from '@shopify/hydrogen';
2
-
3
- import styles from './RebuyDynamicBundleProducts.module.css';
4
-
5
- import type {
6
- CurrencyCode,
7
- MoneyV2,
8
- } from '@shopify/hydrogen-react/storefront-api-types';
9
- import type { BundleProduct } from '~/widgets/RebuyDynamicBundleProducts/types';
10
-
11
- export const BundlePrice = ({ products }: { products: BundleProduct[] }) => {
12
- const isDisabled =
13
- products.filter((product) => product.selected).length < 1;
14
-
15
- const totalBundlePrice = () => {
16
- let total = 0;
17
- let currencyCode = 'USD' as CurrencyCode;
18
-
19
- for (const product of products) {
20
- if (product.selected && product.selectedVariant) {
21
- const { priceV2: price } = product.selectedVariant;
22
-
23
- total += Number(price?.amount);
24
- currencyCode = (price?.currencyCode || 'USD') as CurrencyCode;
25
- }
26
- }
27
-
28
- return {
29
- amount: String(total),
30
- currencyCode,
31
- };
32
- };
33
-
34
- const totalBundleCompareAtPrice = () => {
35
- let compareAtTotal = 0;
36
- let currencyCode = 'USD' as CurrencyCode;
37
-
38
- for (const product of products) {
39
- if (product.selected && product.selectedVariant) {
40
- const { compareAtPriceV2: compareAtPrice, priceV2: price } =
41
- product.selectedVariant;
42
-
43
- currencyCode = (price?.currencyCode || 'USD') as CurrencyCode;
44
- compareAtTotal += Number((compareAtPrice || price)?.amount);
45
- }
46
- }
47
-
48
- return {
49
- amount: String(compareAtTotal),
50
- currencyCode,
51
- };
52
- };
53
- const isDiscounted = (
54
- price: { amount: string; currencyCode: string } | null,
55
- compareAtPrice: { amount: string; currencyCode: string } | null
56
- ) => Number(compareAtPrice?.amount) > Number(price?.amount);
57
-
58
- const price = totalBundlePrice();
59
- const compareAtPrice = totalBundleCompareAtPrice();
60
-
61
- const CompareAtPrice = ({
62
- data: compareAtPrice,
63
- }: {
64
- data: MoneyV2 | null;
65
- }) => {
66
- return (
67
- compareAtPrice && (
68
- <Money
69
- as="span"
70
- className={styles.compareAtPrice}
71
- data={compareAtPrice}
72
- withoutTrailingZeros
73
- />
74
- )
75
- );
76
- };
77
-
78
- return (
79
- products.length > 0 && (
80
- <div className="flex items-center flex-col">
81
- {!isDisabled && (
82
- <p className="flex items-center gap-2 mb-2">
83
- <span>Total Price:</span>
84
- <Money as="span" data={price} withoutTrailingZeros />
85
- {isDiscounted(price, compareAtPrice) && (
86
- <CompareAtPrice data={compareAtPrice} />
87
- )}
88
- </p>
89
- )}
90
- </div>
91
- )
92
- );
93
- };
@@ -1,65 +0,0 @@
1
- import styles from '~/widgets/RebuyDynamicBundleProducts/RebuyDynamicBundleProducts.module.css';
2
-
3
- import type { BundleSelectionProps } from '~/widgets/RebuyDynamicBundleProducts/types';
4
-
5
- import { RebuyProductPrice } from '~/components/ProductPrice';
6
- import { Select } from '~/widgets/RebuyDynamicBundleProducts/Select';
7
-
8
- export const BundleSelection = ({
9
- onSelectVariant,
10
- onToggleBundleItem,
11
- products,
12
- }: BundleSelectionProps) => {
13
- return (
14
- <ul>
15
- {products.map((product, index) => {
16
- const { availableForSale } = product.selectedVariant;
17
- const isOutOfStock = !availableForSale;
18
-
19
- return (
20
- <li
21
- className={`${styles.bundleItemRowContainer} ${
22
- !product.selected && styles.unselected
23
- }`}
24
- key={product.id + '-BundleSelection' + index}
25
- >
26
- <div className={styles.bundleItemRow}>
27
- <input
28
- checked={product.selected && availableForSale}
29
- className="mt-1 rounded-sm accent-black cursor-pointer"
30
- disabled={isOutOfStock}
31
- id={`${product.id}-toggle`}
32
- onChange={() => onToggleBundleItem(product)}
33
- type="checkbox"
34
- value={product.id}
35
- />
36
- <div className={styles.bundleItemInput}>
37
- <label
38
- className={styles.bundleItemLabel}
39
- htmlFor={`${product.id}-toggle`}
40
- >
41
- {isOutOfStock && <b>SOLD OUT</b>}
42
- {product.default && <b>This item:</b>}
43
- {product.title}
44
-
45
- <RebuyProductPrice
46
- selectedVariant={
47
- product.selectedVariant
48
- }
49
- />
50
- </label>
51
-
52
- {product.variants.nodes.length > 1 && (
53
- <Select
54
- onSelectVariant={onSelectVariant}
55
- product={product}
56
- />
57
- )}
58
- </div>
59
- </div>
60
- </li>
61
- );
62
- })}
63
- </ul>
64
- );
65
- };
@@ -1,118 +0,0 @@
1
- import { useCallback, useEffect, useState } from 'react';
2
-
3
- import { BundlePrice } from './BundlePrice';
4
-
5
- import styles from './RebuyDynamicBundleProducts.module.css';
6
-
7
- import type {
8
- BundleProduct,
9
- RebuyDynamicBundleProductsProps,
10
- } from '~/widgets/RebuyDynamicBundleProducts/types';
11
-
12
- import { AddToCartBtn } from '~/components/AddToCartBtn';
13
- import { Title } from '~/components/Title';
14
- import { getTitleLevel } from '~/hooks/titleLevel';
15
- import { convertToRebuyProduct } from '~/utils/convertToRebuyProduct';
16
- import { BundleImages } from '~/widgets/RebuyDynamicBundleProducts/BundleImages';
17
- import { BundleSelection } from '~/widgets/RebuyDynamicBundleProducts/BundleSelection';
18
-
19
- export const RebuyDynamicBundleProducts = (
20
- props: RebuyDynamicBundleProductsProps
21
- ) => {
22
- const {
23
- addToCartBtnText = 'Add to cart',
24
- addToCartCallback,
25
- customTitle = `These pair with ${props.product?.title}`,
26
- customTitleLevel = 'h2',
27
- customTitleStyle,
28
- isHydrogenReact,
29
- product,
30
- products = [],
31
- } = props;
32
- const [bundleProducts, setBundleProducts] = useState<BundleProduct[]>([]);
33
-
34
- // Initializiation
35
- useEffect(() => {
36
- const mainProduct: BundleProduct = convertToRebuyProduct(
37
- isHydrogenReact || false,
38
- product
39
- );
40
-
41
- const formattedProducts = products.map((product) => {
42
- return {
43
- ...product,
44
- selected: true,
45
- selectedVariant: product.variants.nodes[0],
46
- };
47
- });
48
-
49
- setBundleProducts([mainProduct, ...formattedProducts]);
50
- }, [product, products, isHydrogenReact]);
51
-
52
- const onToggleBundleItem = useCallback(
53
- (product: BundleProduct) => {
54
- product.selected = !product.selected;
55
-
56
- setBundleProducts([...bundleProducts]);
57
- },
58
- [bundleProducts]
59
- );
60
-
61
- const onSelectVariant = useCallback(
62
- (product: BundleProduct, variant_id: string) => {
63
- const variant = product.variants.nodes.find(
64
- ({ id }) => id === variant_id
65
- );
66
-
67
- if (variant) {
68
- product.selectedVariant = variant;
69
- product.selected = variant.availableForSale || false;
70
-
71
- setBundleProducts([...bundleProducts]);
72
- }
73
- },
74
- [bundleProducts]
75
- );
76
-
77
- if (products.length === 0) {
78
- console.log('RebuyDynamicBundleProducts: No products found');
79
- return null;
80
- }
81
-
82
- return (
83
- <section className={styles.container}>
84
- <Title
85
- level={getTitleLevel(customTitleLevel)}
86
- style={customTitleStyle}
87
- text={customTitle}
88
- />
89
- <div className={styles.bundleContainer}>
90
- <BundleImages products={bundleProducts} />
91
- <BundlePrice products={bundleProducts} />
92
-
93
- <div className={styles.addCartBtnContainer}>
94
- <AddToCartBtn
95
- addToCartBtnText={addToCartBtnText}
96
- addToCartCallback={addToCartCallback}
97
- disabled={
98
- bundleProducts.filter((product) => product.selected)
99
- .length === 0
100
- }
101
- isHydrogenReact={isHydrogenReact}
102
- selectedVariants={bundleProducts
103
- .filter((product) => product.selected)
104
- .map((product) => {
105
- return product.selectedVariant;
106
- })}
107
- />
108
- </div>
109
-
110
- <BundleSelection
111
- onSelectVariant={onSelectVariant}
112
- onToggleBundleItem={onToggleBundleItem}
113
- products={bundleProducts}
114
- />
115
- </div>
116
- </section>
117
- );
118
- };
@@ -1,41 +0,0 @@
1
- import styles from '~/widgets/RebuyDynamicBundleProducts/RebuyDynamicBundleProducts.module.css';
2
-
3
- import type {
4
- BundleProduct,
5
- BundleSelectProps,
6
- } from '~/widgets/RebuyDynamicBundleProducts/types';
7
-
8
- export const Select = ({ onSelectVariant, product }: BundleSelectProps) => {
9
- const getOptionsLabel = (product: BundleProduct) => {
10
- const options = product.variants.nodes[0].selectedOptions;
11
- const optionsFromKeys = options ? Object.keys(options[0]) : [];
12
- const optionsFromValues = options
13
- ? options.map((option) => option.name)
14
- : [];
15
- const useValues = optionsFromKeys.every((key) =>
16
- ['name', 'value'].includes(key)
17
- );
18
-
19
- // Return delimited label for available option(s) e.g. Color / Size, Scent, etc
20
- return (useValues ? optionsFromValues : optionsFromKeys).join(' / ');
21
- };
22
-
23
- return (
24
- product && (
25
- <select
26
- aria-label="select variant"
27
- className={styles.select}
28
- onChange={(e) => onSelectVariant(product, e.target.value)}
29
- value={product.selectedVariant.id}
30
- >
31
- <optgroup label={getOptionsLabel(product)}>
32
- {product.variants.nodes.map(({ id, title }) => (
33
- <option key={id + '-BundleVariant'} value={id}>
34
- {title}
35
- </option>
36
- ))}
37
- </optgroup>
38
- </select>
39
- )
40
- );
41
- };
@@ -1 +0,0 @@
1
- export * from './RebuyDynamicBundleProducts';
@@ -1,23 +0,0 @@
1
- import type { RebuyProduct } from '~/types/rebuyCustom';
2
- import type { WidgetChildProps } from '~/types/widgets';
3
-
4
- export type BundleProductOptions = {
5
- default?: boolean;
6
- };
7
-
8
- export type BundleProduct = RebuyProduct & BundleProductOptions;
9
-
10
- export type BundleSelectionProps = {
11
- onSelectVariant: (product: BundleProduct, variantId: string) => void;
12
- onToggleBundleItem: (product: BundleProduct) => void;
13
- products: BundleProduct[];
14
- };
15
-
16
- export type BundleSelectProps = {
17
- onSelectVariant: (product: BundleProduct, variantId: string) => void;
18
- product: BundleProduct;
19
- };
20
-
21
- export type RebuyDynamicBundleProductsProps = {
22
- addToCartBtnText?: string;
23
- } & WidgetChildProps;
@@ -1,66 +0,0 @@
1
- import { Link } from '@remix-run/react';
2
- import { Image } from '@shopify/hydrogen';
3
-
4
- import styles from './RebuyProductAddOns.module.css';
5
-
6
- import type { RebuyProductAddOnCardProps } from './types';
7
-
8
- import { RebuyProductPrice } from '~/components/ProductPrice';
9
- import { Title } from '~/components/Title';
10
-
11
- export const RebuyProductAddOnCard = ({
12
- handleChange,
13
- learnMoreText,
14
- outOfStockText,
15
- product,
16
- titleLevel,
17
- }: RebuyProductAddOnCardProps) => {
18
- const { availableForSale, image } = product.selectedVariant || {};
19
-
20
- return (
21
- <label className={styles.addOnCard} htmlFor={product.id}>
22
- <div className={styles.addOnCardContent}>
23
- <input
24
- checked={Boolean(product.selected)}
25
- className={styles.addOnCardInput}
26
- disabled={!product.variants.nodes[0].availableForSale}
27
- id={product.id}
28
- name={product.title}
29
- onChange={(event) => handleChange(event, product)}
30
- type="checkbox"
31
- value=""
32
- />
33
- <div className={styles.addOnCardContentImage}>
34
- {image && (
35
- <Image
36
- alt={image.altText || `Picture of ${product.title}`}
37
- data={image}
38
- height={150}
39
- width={300}
40
- />
41
- )}
42
- </div>
43
-
44
- <div className={styles.addOnCardTextContent}>
45
- {!availableForSale && (
46
- <p className={styles.addOnCardOutOfStock}>
47
- {outOfStockText}
48
- </p>
49
- )}
50
-
51
- <Title level={titleLevel} text={product.title} />
52
-
53
- <RebuyProductPrice
54
- selectedVariant={product.selectedVariant}
55
- />
56
- <Link
57
- className={styles.addOnCardLearnMore}
58
- to={`/products/${product.handle}`}
59
- >
60
- {learnMoreText}
61
- </Link>
62
- </div>
63
- </div>
64
- </label>
65
- );
66
- };