@jetshop/core 5.13.2 → 5.13.12-0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (543) hide show
  1. package/ChannelHandler/CategoryPathnameRedirectQuery.gql +9 -9
  2. package/ChannelHandler/ChannelHandler.d.ts +50 -50
  3. package/ChannelHandler/ChannelHandler.js +108 -108
  4. package/ChannelHandler/PagePathnameRedirectQuery.gql +9 -9
  5. package/ChannelHandler/PreserveRedirectRouteQuery.gql +19 -19
  6. package/ChannelHandler/ProductPathnameRedirectQuery.gql +9 -9
  7. package/ChannelHandler/StartPagePathnameRedirectQuery.gql +9 -9
  8. package/ChannelHandler/channelUtils.d.ts +68 -68
  9. package/ChannelHandler/channelUtils.js +266 -266
  10. package/ChannelHandler/redirectUtils.d.ts +4 -4
  11. package/ChannelHandler/redirectUtils.js +49 -49
  12. package/ChannelHandler/redirectUtils.test.js +538 -538
  13. package/analytics/Analytics.d.ts +18 -18
  14. package/analytics/Analytics.js +56 -56
  15. package/analytics/Analytics.js.map +1 -1
  16. package/analytics/AnalyticsProvider.d.ts +42 -42
  17. package/analytics/AnalyticsProvider.js +177 -177
  18. package/analytics/deprecatedTracking.d.ts +17 -17
  19. package/analytics/deprecatedTracking.js +32 -32
  20. package/analytics/integrations/ga4.d.ts +23 -23
  21. package/analytics/integrations/ga4.js +145 -145
  22. package/analytics/integrations/gtag/gtag.d.ts +8 -8
  23. package/analytics/integrations/gtag/gtag.js +180 -180
  24. package/analytics/integrations/gtag/index.d.ts +1 -1
  25. package/analytics/integrations/gtag/index.js +1 -1
  26. package/analytics/integrations/gtm/index.d.ts +12 -12
  27. package/analytics/integrations/gtm/index.js +200 -200
  28. package/analytics/integrations/gtm/referrerModifier.d.ts +1 -1
  29. package/analytics/integrations/gtm/referrerModifier.js +61 -61
  30. package/analytics/integrations/releware/index.d.ts +3 -3
  31. package/analytics/integrations/releware/index.js +38 -38
  32. package/analytics/integrations/unslugify.d.ts +1 -1
  33. package/analytics/integrations/unslugify.js +17 -17
  34. package/analytics/trackerRegistry.d.ts +101 -101
  35. package/analytics/trackerRegistry.js +219 -219
  36. package/analytics/trackerRegistry.test.js +160 -160
  37. package/analytics/tracking.d.ts +14 -14
  38. package/analytics/tracking.js +71 -71
  39. package/analytics/utils/breadcrumbsWithoutProduct.d.ts +1 -1
  40. package/analytics/utils/breadcrumbsWithoutProduct.js +8 -8
  41. package/analytics/utils/script.d.ts +8 -8
  42. package/analytics/utils/script.js +39 -39
  43. package/analytics/webVitals.d.ts +5 -5
  44. package/analytics/webVitals.js +38 -38
  45. package/boot/AuthHandler.d.ts +14 -14
  46. package/boot/AuthHandler.js +38 -38
  47. package/boot/ChannelsQuery.gql +7 -7
  48. package/boot/PreviewHandler.d.ts +7 -7
  49. package/boot/PreviewHandler.js +13 -13
  50. package/boot/SharedTree.d.ts +25 -25
  51. package/boot/SharedTree.js +28 -28
  52. package/boot/addMissingConfig.d.ts +5 -5
  53. package/boot/addMissingConfig.js +33 -33
  54. package/boot/apollo.d.ts +21 -21
  55. package/boot/apollo.js +197 -197
  56. package/boot/client/entrypoint.d.ts +1 -1
  57. package/boot/client/entrypoint.js +4 -4
  58. package/boot/client/index.d.ts +1 -1
  59. package/boot/client/index.js +1 -1
  60. package/boot/client/startClient.d.ts +4 -4
  61. package/boot/client/startClient.js +142 -142
  62. package/boot/client-schema.gql +59 -59
  63. package/boot/server/IntervalQuery.d.ts +32 -32
  64. package/boot/server/IntervalQuery.js +94 -94
  65. package/boot/server/IntervalQuery.test.js +280 -280
  66. package/boot/server/PersistedApolloClient.d.ts +20 -20
  67. package/boot/server/PersistedApolloClient.js +39 -39
  68. package/boot/server/PersistedApolloClient.test.js +233 -233
  69. package/boot/server/asyncErrorHandler.d.ts +3 -3
  70. package/boot/server/asyncErrorHandler.js +4 -4
  71. package/boot/server/breakpointMiddleware.d.ts +3 -3
  72. package/boot/server/breakpointMiddleware.js +9 -9
  73. package/boot/server/createApolloServer.d.ts +28 -28
  74. package/boot/server/createApolloServer.js +143 -143
  75. package/boot/server/createApolloServer.test.js +114 -114
  76. package/boot/server/createDevServer.d.ts +14 -14
  77. package/boot/server/createDevServer.js +29 -29
  78. package/boot/server/createRenderer.d.ts +28 -28
  79. package/boot/server/createRenderer.js +235 -235
  80. package/boot/server/createServer.d.ts +14 -14
  81. package/boot/server/createServer.js +41 -41
  82. package/boot/server/entrypoint.d.ts +1 -1
  83. package/boot/server/entrypoint.js +35 -35
  84. package/boot/server/getPrefetchFiles.d.ts +10 -10
  85. package/boot/server/getPrefetchFiles.js +19 -19
  86. package/boot/server/getPreloadAssets.d.ts +10 -10
  87. package/boot/server/getPreloadAssets.js +17 -17
  88. package/boot/server/getPreloadAssets.test.js +133 -133
  89. package/boot/server/index.d.ts +9 -9
  90. package/boot/server/index.js +122 -122
  91. package/boot/server/listen.d.ts +13 -13
  92. package/boot/server/listen.js +16 -16
  93. package/boot/server/overwriteServerIntl.js +1 -1
  94. package/boot/server/persistedQueries/PersistedClient.d.ts +22 -22
  95. package/boot/server/persistedQueries/PersistedClient.js +57 -57
  96. package/boot/server/persistedQueries/__tests__/getPersistedQueriesForRequest.test.js +201 -201
  97. package/boot/server/persistedQueries/__tests__/mockQuery.gql +6 -6
  98. package/boot/server/persistedQueries/getPersistedQueriesForRequest.d.ts +3 -3
  99. package/boot/server/persistedQueries/getPersistedQueriesForRequest.js +26 -26
  100. package/boot/server/saleSource.test.js +39 -39
  101. package/boot/server/salesSource.d.ts +8 -8
  102. package/boot/server/salesSource.js +15 -15
  103. package/boot/utils/__tests__/uid.js +47 -47
  104. package/boot/utils/createIntOptions.d.ts +6 -6
  105. package/boot/utils/createIntOptions.js +18 -18
  106. package/boot/utils/queryLoggingMiddleware.d.ts +2 -2
  107. package/boot/utils/queryLoggingMiddleware.js +14 -14
  108. package/boot/utils/uid.d.ts +3 -3
  109. package/boot/utils/uid.js +19 -19
  110. package/cart/AddToCartFormik.d.ts +42 -42
  111. package/cart/AddToCartFormik.js +76 -76
  112. package/cart/useAddToCart.d.ts +88 -88
  113. package/cart/useAddToCart.js +117 -117
  114. package/ci/.gitlab-ci.yml +3 -3
  115. package/components/Auth/CustomerUpdateForm.d.ts +32 -32
  116. package/components/Auth/CustomerUpdateForm.js +121 -121
  117. package/components/Auth/ForgotPasswordProvider.d.ts +71 -71
  118. package/components/Auth/ForgotPasswordProvider.js +56 -56
  119. package/components/Auth/ResetPasswordProvider.d.ts +88 -88
  120. package/components/Auth/ResetPasswordProvider.js +77 -77
  121. package/components/Auth/SSN.d.ts +12 -12
  122. package/components/Auth/SSN.js +34 -34
  123. package/components/Auth/SSNLookupContainer.d.ts +15 -15
  124. package/components/Auth/SSNLookupContainer.js +19 -19
  125. package/components/Auth/SignupFormContainer.d.ts +19 -19
  126. package/components/Auth/SignupFormContainer.js +81 -81
  127. package/components/Auth/UpdatePasswordForm.d.ts +44 -44
  128. package/components/Auth/UpdatePasswordForm.js +97 -97
  129. package/components/Auth/formFieldsFromSettings.d.ts +65 -65
  130. package/components/Auth/formFieldsFromSettings.js +76 -76
  131. package/components/Auth/formatSignupInput.d.ts +8 -8
  132. package/components/Auth/formatSignupInput.js +42 -42
  133. package/components/Auth/signup-context.d.ts +36 -36
  134. package/components/Auth/signup-context.js +71 -71
  135. package/components/Auth/signup-field-translations.d.ts +3 -3
  136. package/components/Auth/signup-field-translations.js +43 -43
  137. package/components/Auth/signupSubmit.d.ts +6 -6
  138. package/components/Auth/signupSubmit.js +56 -56
  139. package/components/Auth/useAddressFields.d.ts +22 -22
  140. package/components/Auth/useAddressFields.js +32 -32
  141. package/components/Auth/useAddressFields.test.js +294 -294
  142. package/components/Auth/useCustomer.d.ts +70 -70
  143. package/components/Auth/useCustomer.js +167 -167
  144. package/components/Auth/useLoginFields.d.ts +20 -20
  145. package/components/Auth/useLoginFields.js +20 -20
  146. package/components/Auth/useSignupForm.d.ts +7 -7
  147. package/components/Auth/useSignupForm.js +14 -14
  148. package/components/AuthContext/AuthContext.d.ts +8 -8
  149. package/components/AuthContext/AuthContext.js +8 -8
  150. package/components/AuthContext/AuthProvider.d.ts +6 -6
  151. package/components/AuthContext/AuthProvider.js +84 -84
  152. package/components/AuthContext/AuthProvider.test.js +66 -66
  153. package/components/AuthContext/LogOut.d.ts +5 -5
  154. package/components/AuthContext/LogOut.js +14 -14
  155. package/components/AuthContext/googleUserIdQuery.gql +6 -6
  156. package/components/AuthContext/useAuth.d.ts +6 -6
  157. package/components/AuthContext/useAuth.js +20 -20
  158. package/components/BreakpointProvider.d.ts +21 -21
  159. package/components/BreakpointProvider.js +23 -23
  160. package/components/Cart/CartIdContext.d.ts +11 -11
  161. package/components/Cart/CartIdContext.js +60 -60
  162. package/components/Cart/CartIdContext.test.js +87 -87
  163. package/components/ChannelContext/ChannelContext.d.ts +20 -20
  164. package/components/ChannelContext/ChannelContext.js +3 -3
  165. package/components/ChannelContext/ChannelProvider.d.ts +10 -10
  166. package/components/ChannelContext/ChannelProvider.js +42 -42
  167. package/components/ChannelContext/ChannelProvider.test.js +112 -112
  168. package/components/ChannelContext/CountrySettingsQuery.gql +34 -34
  169. package/components/ChannelContext/index.d.ts +2 -2
  170. package/components/ChannelContext/index.js +2 -2
  171. package/components/ChannelContext/useCountrySettings.d.ts +8 -8
  172. package/components/ChannelContext/useCountrySettings.js +23 -23
  173. package/components/ConfigProvider.d.ts +108 -108
  174. package/components/ConfigProvider.js +19 -19
  175. package/components/DynamicRoute/ActiveFiltersQuery.gql +21 -21
  176. package/components/DynamicRoute/CategoryRoute.d.ts +13 -13
  177. package/components/DynamicRoute/CategoryRoute.js +55 -55
  178. package/components/DynamicRoute/ContentRoute.d.ts +14 -14
  179. package/components/DynamicRoute/ContentRoute.js +27 -27
  180. package/components/DynamicRoute/PreviewRoute.d.ts +17 -17
  181. package/components/DynamicRoute/PreviewRoute.js +57 -57
  182. package/components/DynamicRoute/ProductByArticlenumber.d.ts +5 -5
  183. package/components/DynamicRoute/ProductByArticlenumber.gql +16 -16
  184. package/components/DynamicRoute/ProductByArticlenumber.js +21 -21
  185. package/components/DynamicRoute/ProductRoute.d.ts +15 -15
  186. package/components/DynamicRoute/ProductRoute.js +57 -57
  187. package/components/DynamicRoute/RouteResolver.d.ts +22 -22
  188. package/components/DynamicRoute/RouteResolver.js +64 -64
  189. package/components/DynamicRoute/Status.d.ts +14 -14
  190. package/components/DynamicRoute/Status.js +19 -19
  191. package/components/DynamicRoute/index.d.ts +17 -17
  192. package/components/DynamicRoute/index.js +95 -95
  193. package/components/Filters/index.d.ts +1 -1
  194. package/components/Filters/index.js +1 -1
  195. package/components/Filters/toggleActiveListItem.gql +15 -15
  196. package/components/Filters/utils/replaceInSearch.d.ts +14 -14
  197. package/components/Filters/utils/replaceInSearch.js +22 -22
  198. package/components/Filters/utils/replaceInSearch.test.js +184 -184
  199. package/components/Filters/utils/updateHistory.d.ts +25 -25
  200. package/components/Filters/utils/updateHistory.js +29 -29
  201. package/components/Filters/utils/updateHistory.test.js +102 -102
  202. package/components/Fonts/CustomFont.d.ts +14 -14
  203. package/components/Fonts/CustomFont.js +16 -16
  204. package/components/Fonts/GoogleFont.d.ts +10 -10
  205. package/components/Fonts/GoogleFont.js +34 -34
  206. package/components/Fonts/TypekitFont.d.ts +16 -16
  207. package/components/Fonts/TypekitFont.js +24 -24
  208. package/components/Fonts/injectFont.d.ts +11 -11
  209. package/components/Fonts/injectFont.js +29 -29
  210. package/components/Head.d.ts +11 -11
  211. package/components/Head.js +74 -74
  212. package/components/Mutation/AddToCart/addToCartUtils.d.ts +18 -18
  213. package/components/Mutation/AddToCart/addToCartUtils.js +51 -51
  214. package/components/Mutation/AddToCartFormik.d.ts +53 -53
  215. package/components/Mutation/AddToCartFormik.js +171 -171
  216. package/components/Mutation/DecrementQuantity.d.ts +4 -4
  217. package/components/Mutation/DecrementQuantity.js +34 -34
  218. package/components/Mutation/IncrementQuantity.d.ts +4 -4
  219. package/components/Mutation/IncrementQuantity.js +34 -34
  220. package/components/Mutation/RemoveFromCart.d.ts +5 -5
  221. package/components/Mutation/RemoveFromCart.js +51 -51
  222. package/components/Mutation/SetQuantity.d.ts +4 -4
  223. package/components/Mutation/SetQuantity.js +36 -36
  224. package/components/Mutation/SubscribeToNewsletter.d.ts +4 -4
  225. package/components/Mutation/SubscribeToNewsletter.js +29 -29
  226. package/components/Mutation/SubscribeToStockNotifications.d.ts +4 -4
  227. package/components/Mutation/SubscribeToStockNotifications.js +30 -30
  228. package/components/Mutation/cartMutationUtils.d.ts +28 -28
  229. package/components/Mutation/cartMutationUtils.js +108 -108
  230. package/components/Mutation/cartMutationUtils.spec.js +142 -142
  231. package/components/Mutation/useDecrementQuantity.d.ts +11 -11
  232. package/components/Mutation/useDecrementQuantity.js +53 -53
  233. package/components/Mutation/useIncrementQuantity.d.ts +11 -11
  234. package/components/Mutation/useIncrementQuantity.js +53 -53
  235. package/components/Mutation/useRemoveFromCart.d.ts +13 -13
  236. package/components/Mutation/useRemoveFromCart.js +49 -49
  237. package/components/Mutation/useSetQuantity.d.ts +12 -12
  238. package/components/Mutation/useSetQuantity.js +37 -37
  239. package/components/Notifications/Notifications.d.ts +15 -15
  240. package/components/Notifications/Notifications.js +26 -26
  241. package/components/Notifications/index.d.ts +2 -2
  242. package/components/Notifications/index.js +2 -2
  243. package/components/Notifications/notificationMachine.d.ts +30 -30
  244. package/components/Notifications/notificationMachine.js +73 -73
  245. package/components/Notifications/notificationsMachine.d.ts +37 -37
  246. package/components/Notifications/notificationsMachine.js +65 -65
  247. package/components/Notifications/useNotification.d.ts +9 -9
  248. package/components/Notifications/useNotification.js +26 -26
  249. package/components/OpenGraph/OpenGraph.test.js +180 -180
  250. package/components/OpenGraph/OpenGraphGeneralPageData.d.ts +25 -25
  251. package/components/OpenGraph/OpenGraphGeneralPageData.js +36 -36
  252. package/components/OpenGraph/OpenGraphProductData.d.ts +25 -25
  253. package/components/OpenGraph/OpenGraphProductData.js +48 -48
  254. package/components/OpenGraph/index.d.ts +2 -2
  255. package/components/OpenGraph/index.js +2 -2
  256. package/components/Pagination/PaginationContainer.d.ts +2 -2
  257. package/components/Pagination/PaginationContainer.js +4 -4
  258. package/components/Pagination/PaginationContext.d.ts +14 -14
  259. package/components/Pagination/PaginationContext.js +3 -3
  260. package/components/Pagination/PaginationProvider.d.ts +19 -19
  261. package/components/Pagination/PaginationProvider.js +94 -94
  262. package/components/Pagination/PaginationProvider.test.js +282 -282
  263. package/components/PreviewContext.d.ts +10 -10
  264. package/components/PreviewContext.js +26 -26
  265. package/components/ProductConfigurationProvider/ConfigPrice.gql +22 -22
  266. package/components/ProductConfigurationProvider/ProductConfigurationContext.d.ts +13 -13
  267. package/components/ProductConfigurationProvider/ProductConfigurationContext.js +4 -4
  268. package/components/ProductConfigurationProvider/ProductConfigurationProvider.d.ts +6 -6
  269. package/components/ProductConfigurationProvider/ProductConfigurationProvider.js +49 -49
  270. package/components/Query/CartProvider.d.ts +22 -22
  271. package/components/Query/CartProvider.js +67 -67
  272. package/components/SortOrder/SortOrderContainer.d.ts +40 -40
  273. package/components/SortOrder/SortOrderContainer.js +101 -101
  274. package/components/SortOrder/SortOrderContainer.js.map +1 -1
  275. package/components/SortOrder/SortOrderContext.d.ts +9 -9
  276. package/components/SortOrder/SortOrderContext.js +8 -8
  277. package/components/StructuredData/SiteLinksSearchStructuredData.d.ts +3 -3
  278. package/components/StructuredData/SiteLinksSearchStructuredData.js +24 -24
  279. package/components/StructuredData/StructuredBreadcrumbData.d.ts +12 -12
  280. package/components/StructuredData/StructuredBreadcrumbData.js +54 -54
  281. package/components/StructuredData/StructuredCategoryData.d.ts +16 -16
  282. package/components/StructuredData/StructuredCategoryData.js +17 -17
  283. package/components/StructuredData/StructuredData.d.ts +9 -9
  284. package/components/StructuredData/StructuredData.js +6 -6
  285. package/components/StructuredData/StructuredPageData.d.ts +16 -16
  286. package/components/StructuredData/StructuredPageData.js +16 -16
  287. package/components/StructuredData/StructuredProductData.d.ts +18 -18
  288. package/components/StructuredData/StructuredProductData.js +42 -42
  289. package/components/StructuredData/StructuredProductData.test.js +130 -130
  290. package/components/StructuredData/index.d.ts +5 -5
  291. package/components/StructuredData/index.js +5 -5
  292. package/data/cache.d.ts +3 -3
  293. package/data/cache.js +20 -20
  294. package/data/fragmentTypes.d.ts +8 -8
  295. package/data/fragmentTypes.js +83 -83
  296. package/data/fragments/BadgeFragment.gql +7 -7
  297. package/data/fragments/CartCoreFragment.gql +89 -89
  298. package/data/fragments/ChannelsFragment.gql +58 -58
  299. package/data/fragments/CommentsFragment.gql +6 -6
  300. package/data/fragments/HeadFragment.gql +9 -9
  301. package/data/fragments/PriceFragment.gql +5 -5
  302. package/data/fragments/ProductCampaignFragment.gql +10 -10
  303. package/data/fragments/ProductConfigurationsFragment.gql +24 -24
  304. package/data/fragments/ProductListsFragments.gql +94 -94
  305. package/data/fragments/ProductMetadataFragment.gql +20 -20
  306. package/data/fragments/ProductPriceFragment.gql +10 -10
  307. package/data/fragments/ProductVariantPriceFragment.gql +10 -10
  308. package/data/fragments/RouteCrumbFragment.gql +20 -20
  309. package/data/fragments/RouteMetaFragment.gql +18 -18
  310. package/data/fragments/StockStatusFragment.gql +7 -7
  311. package/data/fragments/index.d.ts +1 -1
  312. package/data/fragments/index.js +1 -1
  313. package/data/mutations/accountMutations.gql +28 -28
  314. package/data/mutations/cartMutations.gql +41 -41
  315. package/data/mutations/productListMutations.gql +18 -18
  316. package/data/mutations/signup.gql +7 -7
  317. package/data/mutations/subscribeToNewsletter.gql +3 -3
  318. package/data/mutations/subscribeToStockNotifications.gql +6 -6
  319. package/data/mutations/updateCustomer.gql +5 -5
  320. package/data/mutations/updatePassword.gql +5 -5
  321. package/data/queries/CartMutationQuery.gql +36 -36
  322. package/data/queries/CartQuery.gql +7 -7
  323. package/data/queries/GetCustomerCountryCode.gql +9 -9
  324. package/data/queries/PersonLookupQuery.gql +28 -28
  325. package/data/queries/ProductLists.gql +8 -8
  326. package/dependencies.d.ts +104 -104
  327. package/errorReporting.browser.d.ts +3 -3
  328. package/errorReporting.browser.js +11 -11
  329. package/errorReporting.d.ts +3 -3
  330. package/errorReporting.js +19 -19
  331. package/errorReporting.server.d.ts +3 -3
  332. package/errorReporting.server.js +11 -11
  333. package/errorReporting.shared.d.ts +5 -5
  334. package/errorReporting.shared.js +16 -16
  335. package/experiments/ExperimentsProvider.d.ts +4 -4
  336. package/experiments/ExperimentsProvider.js +28 -28
  337. package/experiments/ExperimentsProvider.test.js +105 -105
  338. package/experiments/integration.test.js +76 -76
  339. package/experiments/selectExperimentVariant.d.ts +3 -3
  340. package/experiments/selectExperimentVariant.js +34 -34
  341. package/experiments/selectExperimentVariant.test.js +64 -64
  342. package/experiments/useExperiment.d.ts +2 -2
  343. package/experiments/useExperiment.js +10 -10
  344. package/experiments/useExperiment.test.js +100 -100
  345. package/global.d.ts +1 -1
  346. package/helpers/decodeUrlQuery.d.ts +9 -9
  347. package/helpers/decodeUrlQuery.js +26 -26
  348. package/helpers/decodeUrlQuery.test.js +54 -54
  349. package/helpers/distance.d.ts +7 -7
  350. package/helpers/distance.js +12 -12
  351. package/helpers/encodeVariant.d.ts +3 -3
  352. package/helpers/encodeVariant.js +24 -24
  353. package/helpers/getBreakpointsFromValues.d.ts +6 -6
  354. package/helpers/getBreakpointsFromValues.js +14 -14
  355. package/helpers/getBreakpointsFromValues.test.js +47 -47
  356. package/helpers/getCartItemVariant.d.ts +7 -7
  357. package/helpers/getCartItemVariant.js +8 -8
  358. package/helpers/getErrorDetail.d.ts +7 -7
  359. package/helpers/getErrorDetail.js +11 -11
  360. package/helpers/getErrorDetail.test.js +44 -44
  361. package/helpers/getHeaders.d.ts +6 -6
  362. package/helpers/getHeaders.js +3 -3
  363. package/helpers/isRelativeUrl.d.ts +1 -1
  364. package/helpers/isRelativeUrl.js +3 -3
  365. package/helpers/logError.d.ts +1 -1
  366. package/helpers/logError.js +16 -16
  367. package/helpers/logWarningInDev.d.ts +1 -1
  368. package/helpers/logWarningInDev.js +6 -6
  369. package/helpers/throwErrorInDev.d.ts +6 -6
  370. package/helpers/throwErrorInDev.js +14 -14
  371. package/helpers/uniqueId.d.ts +5 -5
  372. package/helpers/uniqueId.js +9 -9
  373. package/hooks/CartCheckoutQuery.gql +5 -5
  374. package/hooks/Channels/useChannelSettings.d.ts +7 -7
  375. package/hooks/Channels/useChannelSettings.js +11 -11
  376. package/hooks/Channels/useChannelSettings.test.js +51 -51
  377. package/hooks/Filters/useBooleanFilter.d.ts +8 -8
  378. package/hooks/Filters/useBooleanFilter.js +20 -20
  379. package/hooks/Filters/useFilters.d.ts +3 -3
  380. package/hooks/Filters/useFilters.js +15 -15
  381. package/hooks/Filters/useListFilter.d.ts +10 -10
  382. package/hooks/Filters/useListFilter.js +37 -37
  383. package/hooks/Filters/useMultiFilter.d.ts +13 -13
  384. package/hooks/Filters/useMultiFilter.js +49 -49
  385. package/hooks/Filters/useRangeFilter.d.ts +10 -10
  386. package/hooks/Filters/useRangeFilter.js +35 -35
  387. package/hooks/Filters/useSortOrder.d.ts +11 -11
  388. package/hooks/Filters/useSortOrder.js +21 -21
  389. package/hooks/FreeShippingQuery.gql +16 -16
  390. package/hooks/PackageProducts/index.d.ts +2 -2
  391. package/hooks/PackageProducts/index.js +2 -2
  392. package/hooks/PackageProducts/packagePriceQuery.gql +29 -29
  393. package/hooks/PackageProducts/usePackageProductItem.d.ts +17 -17
  394. package/hooks/PackageProducts/usePackageProductItem.js +26 -26
  395. package/hooks/PackageProducts/usePackageProducts.d.ts +19 -19
  396. package/hooks/PackageProducts/usePackageProducts.js +345 -345
  397. package/hooks/PackageProducts/usePackageProducts.test.js +383 -383
  398. package/hooks/Product/index.d.ts +1 -1
  399. package/hooks/Product/index.js +1 -1
  400. package/hooks/Product/useStockStatus.d.ts +9 -9
  401. package/hooks/Product/useStockStatus.js +25 -25
  402. package/hooks/Product/useSwitchToVariantImage.d.ts +9 -9
  403. package/hooks/Product/useSwitchToVariantImage.js +20 -20
  404. package/hooks/ProductList/ProductListContext.d.ts +7 -7
  405. package/hooks/ProductList/ProductListContext.js +110 -110
  406. package/hooks/ProductList/action-creators.d.ts +46 -46
  407. package/hooks/ProductList/action-creators.js +296 -296
  408. package/hooks/ProductList/index.d.ts +118 -118
  409. package/hooks/ProductList/index.js +21 -21
  410. package/hooks/ProductList/list-transforms.d.ts +73 -73
  411. package/hooks/ProductList/list-transforms.js +106 -106
  412. package/hooks/ProductList/list-transforms.test.js +489 -489
  413. package/hooks/ProductList/product-list-reducer.d.ts +76 -76
  414. package/hooks/ProductList/product-list-reducer.js +197 -197
  415. package/hooks/ProductList/product-list-reducer.test.js +464 -464
  416. package/hooks/ProductList/useProductList.d.ts +13 -13
  417. package/hooks/ProductList/useProductList.js +93 -93
  418. package/hooks/ProductList/useProductListItems.d.ts +10 -10
  419. package/hooks/ProductList/useProductListItems.js +48 -48
  420. package/hooks/ProductList/validate-product.d.ts +6 -6
  421. package/hooks/ProductList/validate-product.js +40 -40
  422. package/hooks/Subscriptions/useNewsletterSubscription.d.ts +38 -38
  423. package/hooks/Subscriptions/useNewsletterSubscription.js +41 -41
  424. package/hooks/Subscriptions/useStockNotifications.d.ts +36 -36
  425. package/hooks/Subscriptions/useStockNotifications.js +37 -37
  426. package/hooks/Subscriptions/useStoreSubscriptions.d.ts +48 -48
  427. package/hooks/Subscriptions/useStoreSubscriptions.js +150 -150
  428. package/hooks/Subscriptions/useStoresubscriptions.test.js +179 -179
  429. package/hooks/useAddMultipleToCart.d.ts +27 -27
  430. package/hooks/useAddMultipleToCart.js +113 -113
  431. package/hooks/useAddMultipleToCart.test.js +181 -181
  432. package/hooks/useChannelBanner.js +22 -22
  433. package/hooks/useChannelBanner.test.js +77 -77
  434. package/hooks/useCustomerOrders.test.js +176 -176
  435. package/hooks/useCustomerOrdersQuery.d.ts +21 -21
  436. package/hooks/useCustomerOrdersQuery.js +20 -20
  437. package/hooks/useDeleteAccountMutation.d.ts +15 -15
  438. package/hooks/useDeleteAccountMutation.js +38 -38
  439. package/hooks/useDynamicPrice.d.ts +3 -3
  440. package/hooks/useDynamicPrice.js +24 -24
  441. package/hooks/useFreeShippingCheck.d.ts +15 -15
  442. package/hooks/useFreeShippingCheck.js +30 -30
  443. package/hooks/useGeolocation.d.ts +11 -11
  444. package/hooks/useGeolocation.js +33 -33
  445. package/hooks/useInfinitePagination.d.ts +37 -37
  446. package/hooks/useInfinitePagination.js +138 -138
  447. package/hooks/useLogError.d.ts +1 -1
  448. package/hooks/useLogError.js +7 -7
  449. package/hooks/useLoginMutation.d.ts +12 -12
  450. package/hooks/useLoginMutation.js +14 -14
  451. package/hooks/useLoginRedirect.d.ts +4 -4
  452. package/hooks/useLoginRedirect.js +36 -36
  453. package/hooks/useOrderDetailQuery.d.ts +20 -20
  454. package/hooks/useOrderDetailQuery.js +28 -28
  455. package/hooks/usePreconnectLinks.d.ts +10 -10
  456. package/hooks/usePreconnectLinks.js +29 -29
  457. package/hooks/usePreconnectLinks.test.js +95 -95
  458. package/hooks/usePrice.d.ts +39 -39
  459. package/hooks/usePrice.js +71 -71
  460. package/hooks/usePrice.test.js +171 -171
  461. package/hooks/useProductVariants/index.d.ts +1 -1
  462. package/hooks/useProductVariants/index.js +1 -1
  463. package/hooks/useProductVariants/useProductVariants.d.ts +19 -19
  464. package/hooks/useProductVariants/useProductVariants.js +202 -202
  465. package/hooks/useProductVariants/useProductVariants.test.js +415 -415
  466. package/hooks/useProductVariants/useVariantFromUrl.d.ts +5 -5
  467. package/hooks/useProductVariants/useVariantFromUrl.js +15 -15
  468. package/hooks/useProductVariants/useVariantFromUrl.test.js +79 -79
  469. package/hooks/useRoutePreload.d.ts +24 -24
  470. package/hooks/useRoutePreload.js +39 -39
  471. package/hooks/useShopConfig.d.ts +1 -1
  472. package/hooks/useShopConfig.js +10 -10
  473. package/hooks/useThrowErrorInDev.d.ts +1 -1
  474. package/hooks/useThrowErrorInDev.js +7 -7
  475. package/hooks/useThunkReducer.d.ts +7 -7
  476. package/hooks/useThunkReducer.js +23 -23
  477. package/hooks/useWarningInDev.d.ts +1 -1
  478. package/hooks/useWarningInDev.js +9 -9
  479. package/inServer.d.ts +1 -1
  480. package/inServer.js +2 -2
  481. package/index.d.ts +1 -1
  482. package/index.js +1 -1
  483. package/integrations/addwishSchemaExtension.d.ts +35 -35
  484. package/integrations/addwishSchemaExtension.js +140 -140
  485. package/integrations/nostoSchemaExtension.d.ts +5 -5
  486. package/integrations/nostoSchemaExtension.js +76 -76
  487. package/integrations/sluggishSchemaExtension.d.ts +2 -2
  488. package/integrations/sluggishSchemaExtension.js +26 -26
  489. package/package.json +1 -1
  490. package/polyfills.d.ts +1 -1
  491. package/polyfills.js +37 -37
  492. package/registerServiceWorker.js +110 -110
  493. package/resolvers/filters/boolFilter.d.ts +3 -3
  494. package/resolvers/filters/boolFilter.js +84 -84
  495. package/resolvers/filters/defaultActiveFilters.d.ts +3 -3
  496. package/resolvers/filters/defaultActiveFilters.js +8 -8
  497. package/resolvers/filters/filterParams.d.ts +3 -3
  498. package/resolvers/filters/filterParams.js +84 -84
  499. package/resolvers/filters/filters.d.ts +5 -5
  500. package/resolvers/filters/filters.js +78 -78
  501. package/resolvers/filters/index.d.ts +27 -27
  502. package/resolvers/filters/index.js +7 -7
  503. package/resolvers/filters/listFilter.d.ts +7 -7
  504. package/resolvers/filters/listFilter.js +73 -73
  505. package/resolvers/filters/listFilterItem.d.ts +3 -3
  506. package/resolvers/filters/listFilterItem.js +122 -122
  507. package/resolvers/filters/multiListFilter.d.ts +5 -5
  508. package/resolvers/filters/multiListFilter.js +195 -195
  509. package/resolvers/filters/multiListFilterList.d.ts +3 -3
  510. package/resolvers/filters/multiListFilterList.js +55 -55
  511. package/resolvers/filters/rangeFilter.d.ts +5 -5
  512. package/resolvers/filters/rangeFilter.js +137 -137
  513. package/resolvers/filters/updateQueryString.d.ts +12 -12
  514. package/resolvers/filters/updateQueryString.js +116 -116
  515. package/resolvers/index.d.ts +37 -37
  516. package/resolvers/index.js +37 -37
  517. package/scripts/dev-apolloServer.js +31 -31
  518. package/sentry/client.d.ts +1 -1
  519. package/sentry/client.js +29 -29
  520. package/sentry/common.d.ts +1 -1
  521. package/sentry/common.js +4 -4
  522. package/sentry/server.d.ts +1 -1
  523. package/sentry/server.js +19 -19
  524. package/sentry/utils.d.ts +1 -1
  525. package/sentry/utils.js +1 -1
  526. package/server/graphql.d.ts +20 -20
  527. package/server/graphql.js +118 -118
  528. package/server/graphql.test.js +123 -123
  529. package/server/index.d.ts +2 -2
  530. package/server/index.js +2 -2
  531. package/server/tracking/facebook.d.ts +5 -5
  532. package/server/tracking/facebook.js +132 -132
  533. package/server/tracking/middleware.d.ts +8 -8
  534. package/server/tracking/middleware.js +14 -14
  535. package/server/tracking/types.d.ts +33 -33
  536. package/setupTests.js +2 -2
  537. package/test-utils/ProviderPyramid.js +45 -45
  538. package/test-utils/mockShopConfig.js +26 -26
  539. package/test-utils/mockedProduct.js +253 -253
  540. package/test-utils/renderWithRouter.js +20 -20
  541. package/test-utils/variables.js +1231 -1231
  542. package/time.d.ts +1 -1
  543. package/time.js +5 -5
@@ -1,346 +1,346 @@
1
- import { useApolloClient, useQuery } from '@apollo/react-hooks';
2
- import { useMachine } from '@xstate/react';
3
- import produce from 'immer';
4
- import { useCallback, useEffect, useMemo, useRef } from 'react';
5
- import { assign, Machine } from 'xstate';
6
- import { useAddMultipleToCart } from '../useAddMultipleToCart';
7
- import packagePriceQuery from './packagePriceQuery.gql';
8
- // defaults to valid state if items have no variants
9
- // defaults to invalid if items have variants or are out of stock
10
- // selecting a variant triggers validate
11
- // (validate GUARD validates all items)
12
- // if valid, move to fetching_price state
13
- // once resolved, move to buyable state
14
- // if invalid, remain in invalid state
15
- //
16
- function itemHasVariants(item) {
17
- return item.product.hasVariants;
18
- }
19
- function itemIsOutOfStock(item) {
20
- return !item.product.stockStatus.buyable;
21
- }
22
- const stateMachine = Machine({
23
- id: 'package',
24
- initial: 'loading',
25
- context: { packageProduct: null, items: {}, price: {}, error: null },
26
- on: {
27
- UPDATE_ITEM: {
28
- actions: 'updateItems',
29
- target: 'validating',
30
- cond: context => Object.keys(context.items).length > 0
31
- }
32
- },
33
- states: {
34
- loading: {
35
- // During SSR, we already have the package and can head right on to
36
- // validating.
37
- always: [
38
- {
39
- target: 'validating',
40
- actions: assign({
41
- items: context => {
42
- return getInitialState(context.packageProduct).items;
43
- },
44
- price: context => {
45
- return getInitialState(context.packageProduct).price;
46
- }
47
- }),
48
- cond: context => {
49
- return !!context.packageProduct.package;
50
- }
51
- }
52
- ],
53
- on: {
54
- // On the client, we need to wait for the LOADED event to tell us
55
- // that the package has been retrieved
56
- LOADED: {
57
- target: 'validating',
58
- actions: assign({
59
- items: (_, event) => {
60
- return getInitialState(event.packageProduct).items;
61
- },
62
- price: (_, event) => {
63
- return getInitialState(event.packageProduct).price;
64
- },
65
- packageProduct: (_, event) => {
66
- return event.packageProduct;
67
- }
68
- })
69
- }
70
- }
71
- },
72
- invalid: {},
73
- validating: {
74
- always: [
75
- {
76
- target: 'valid',
77
- cond: context => {
78
- return deriveStatus(context.items) === 'valid';
79
- }
80
- },
81
- {
82
- target: 'invalid',
83
- cond: context => {
84
- return deriveStatus(context.items) !== 'valid';
85
- }
86
- }
87
- ]
88
- },
89
- valid: {
90
- initial: 'fetchingPrice',
91
- states: {
92
- fetchingPrice: {
93
- invoke: {
94
- id: 'fetchPrice',
95
- src: 'fetchPrice',
96
- onDone: {
97
- target: 'buyable',
98
- actions: assign({
99
- price: (_, event) => {
100
- return event.data;
101
- }
102
- })
103
- },
104
- onError: {
105
- target: 'error',
106
- actions: assign({
107
- error: (_, event) => {
108
- const errors = event.data;
109
- return {
110
- fromState: 'fetchingPrice',
111
- messages: errors
112
- .map((err) => err.message)
113
- .filter(Boolean)
114
- };
115
- }
116
- })
117
- }
118
- }
119
- },
120
- buyable: {
121
- on: {
122
- ADD_TO_CART: 'adding',
123
- ERROR: 'error'
124
- }
125
- },
126
- adding: {
127
- invoke: {
128
- id: 'add-to-cart',
129
- src: 'addToCart',
130
- onDone: 'added',
131
- onError: {
132
- target: 'error',
133
- actions: assign({
134
- error: (_, event) => {
135
- const errors = event.data;
136
- return {
137
- fromState: 'adding',
138
- messages: errors
139
- .map((err) => err.message)
140
- .filter(Boolean)
141
- };
142
- }
143
- })
144
- }
145
- }
146
- },
147
- added: {
148
- invoke: {
149
- id: 'added-refetch',
150
- src: () => {
151
- return new Promise(resolve => {
152
- setTimeout(() => {
153
- resolve(400);
154
- }, 800);
155
- });
156
- },
157
- onDone: {
158
- target: '#package.validating'
159
- }
160
- }
161
- },
162
- error: {
163
- on: {
164
- RETRY: '#package.validating'
165
- }
166
- }
167
- }
168
- }
169
- }
170
- }, {
171
- actions: {
172
- updateItems: assign({
173
- items: (context, event) => {
174
- if (event.type === 'UPDATE_ITEM') {
175
- const item = context.items[event.articleNumber];
176
- if (!item) {
177
- throw new Error('article does not exist in package');
178
- }
179
- if (event.variantArticleNumber) {
180
- const match = item.variants.includes(event.variantArticleNumber);
181
- if (!match) {
182
- throw new Error('variant does not exist on article');
183
- }
184
- }
185
- const { articleNumber, valid, variantArticleNumber } = event;
186
- const items = produce(context.items, draft => {
187
- draft[articleNumber] = Object.assign(Object.assign({}, draft[articleNumber]), { valid,
188
- variantArticleNumber });
189
- });
190
- return items;
191
- }
192
- }
193
- })
194
- }
195
- });
196
- function getInitialState(packageProduct) {
197
- var _a, _b;
198
- const items = (_b = (_a = packageProduct === null || packageProduct === void 0 ? void 0 : packageProduct.package) === null || _a === void 0 ? void 0 : _a.items) === null || _b === void 0 ? void 0 : _b.reduce((dict, item) => {
199
- var _a;
200
- dict[item.product.articleNumber] = {
201
- product: item.product,
202
- articleNumber: item.product.articleNumber,
203
- hasVariants: item.product.hasVariants,
204
- variantArticleNumber: null,
205
- variants: item.product.hasVariants
206
- ? (_a = item.product.variants) === null || _a === void 0 ? void 0 : _a.values.map(variant => variant.articleNumber)
207
- : null,
208
- valid: !itemHasVariants(item) && !itemIsOutOfStock(item),
209
- quantity: item.minQuantity
210
- };
211
- return dict;
212
- }, {});
213
- const price = packageProduct.package;
214
- return { items, price };
215
- }
216
- function flattenItems(items) {
217
- // perhaps we need the rest of the product detail?
218
- // Or otherwise the types need to be changed
219
- return Object.entries(items).map(entry => {
220
- const { articleNumber, variantArticleNumber, quantity, product } = entry[1];
221
- return Object.assign(Object.assign({}, product), { articleNumber: variantArticleNumber || articleNumber, quantity });
222
- });
223
- }
224
- function deriveStatus(packageItems) {
225
- const packageIsValid = Object.values(packageItems).every(item => item.valid);
226
- if (packageIsValid) {
227
- return 'valid';
228
- }
229
- return 'invalid';
230
- }
231
- function fetchPrice(packageArticleNumber, items, opts) {
232
- return opts.apolloClient
233
- .query({
234
- query: opts.query || packagePriceQuery,
235
- variables: {
236
- articleNumber: packageArticleNumber,
237
- products: Object.entries(items).map(entry => {
238
- // This should be cleaned up - we have to transform to the structure
239
- // that the API expects
240
- const { articleNumber, variantArticleNumber } = entry[1];
241
- return {
242
- product: articleNumber,
243
- // if you want to test error handling, just pass a random string for variant
244
- // variant: 'sdfgsdfg'
245
- variant: variantArticleNumber
246
- };
247
- })
248
- }
249
- })
250
- .then(({ data }) => {
251
- return data.product.package;
252
- }, err => {
253
- return Promise.reject(err.graphQLErrors);
254
- });
255
- }
256
- export function usePackageProduct({ product, packageProductQuery, priceQuery }) {
257
- const mounted = useRef(false);
258
- useEffect(() => {
259
- mounted.current = true;
260
- }, []);
261
- const client = useApolloClient();
262
- const { data } = useQuery(packageProductQuery, {
263
- variables: { articleNumber: product.articleNumber }
264
- });
265
- const [current, send] = useMachine(stateMachine, {
266
- // During SSR, data.product will have resolved, and we can initialise with
267
- // it. Otherwise, use the product passed in
268
- context: { packageProduct: (data === null || data === void 0 ? void 0 : data.product) || product },
269
- services: {
270
- fetchPrice: context => {
271
- return fetchPrice(product.articleNumber, context.items, {
272
- apolloClient: client,
273
- query: priceQuery
274
- });
275
- },
276
- addToCart: (_, event) => {
277
- // eslint-disable-next-line
278
- return addToCartMutation(event.queries).then(result => {
279
- if (result.errors) {
280
- return Promise.reject(result.errors);
281
- }
282
- else {
283
- return result;
284
- }
285
- });
286
- }
287
- }
288
- });
289
- useEffect(() => {
290
- // On the client we send the LOADED event once the package query resolves
291
- if (current.value !== 'loading')
292
- return;
293
- if (!(data === null || data === void 0 ? void 0 : data.product))
294
- return;
295
- send({ type: 'LOADED', packageProduct: data.product });
296
- }, [current.value, data, send]);
297
- const [addToCartMutation] = useAddMultipleToCart(flattenItems(current.context.items));
298
- const addPackageToCart = (queries) => {
299
- // invokes addToCart
300
- send({ type: 'ADD_TO_CART', queries });
301
- };
302
- const updatePackageItem = useCallback(function updatePackageItem(articleNumber, variantArticleNumber, valid) {
303
- send({
304
- type: 'UPDATE_ITEM',
305
- articleNumber,
306
- variantArticleNumber,
307
- valid
308
- });
309
- }, [send]);
310
- // Just doing this to simplify the status we expose
311
- const status = useMemo(() => {
312
- switch (true) {
313
- case current.matches({ valid: 'fetchingPrice' }):
314
- return 'fetching_price';
315
- case current.matches({ valid: 'buyable' }):
316
- return 'buyable';
317
- case current.matches({ valid: 'adding' }):
318
- return 'adding';
319
- case current.matches({ valid: 'added' }):
320
- return 'added';
321
- case current.matches({ valid: 'error' }):
322
- return 'error';
323
- case current.matches('loading'):
324
- return 'loading';
325
- default:
326
- return 'invalid';
327
- }
328
- }, [current]);
329
- const retry = useCallback(function retry() {
330
- if (status === 'error') {
331
- send({
332
- type: 'RETRY'
333
- });
334
- }
335
- }, [send, status]);
336
- return {
337
- status,
338
- price: current.context.price,
339
- addPackageToCart,
340
- updatePackageItem,
341
- packageProduct: current.context.packageProduct,
342
- error: current.context.error,
343
- retry
344
- };
345
- }
1
+ import { useApolloClient, useQuery } from '@apollo/react-hooks';
2
+ import { useMachine } from '@xstate/react';
3
+ import produce from 'immer';
4
+ import { useCallback, useEffect, useMemo, useRef } from 'react';
5
+ import { assign, Machine } from 'xstate';
6
+ import { useAddMultipleToCart } from '../useAddMultipleToCart';
7
+ import packagePriceQuery from './packagePriceQuery.gql';
8
+ // defaults to valid state if items have no variants
9
+ // defaults to invalid if items have variants or are out of stock
10
+ // selecting a variant triggers validate
11
+ // (validate GUARD validates all items)
12
+ // if valid, move to fetching_price state
13
+ // once resolved, move to buyable state
14
+ // if invalid, remain in invalid state
15
+ //
16
+ function itemHasVariants(item) {
17
+ return item.product.hasVariants;
18
+ }
19
+ function itemIsOutOfStock(item) {
20
+ return !item.product.stockStatus.buyable;
21
+ }
22
+ const stateMachine = Machine({
23
+ id: 'package',
24
+ initial: 'loading',
25
+ context: { packageProduct: null, items: {}, price: {}, error: null },
26
+ on: {
27
+ UPDATE_ITEM: {
28
+ actions: 'updateItems',
29
+ target: 'validating',
30
+ cond: context => Object.keys(context.items).length > 0
31
+ }
32
+ },
33
+ states: {
34
+ loading: {
35
+ // During SSR, we already have the package and can head right on to
36
+ // validating.
37
+ always: [
38
+ {
39
+ target: 'validating',
40
+ actions: assign({
41
+ items: context => {
42
+ return getInitialState(context.packageProduct).items;
43
+ },
44
+ price: context => {
45
+ return getInitialState(context.packageProduct).price;
46
+ }
47
+ }),
48
+ cond: context => {
49
+ return !!context.packageProduct.package;
50
+ }
51
+ }
52
+ ],
53
+ on: {
54
+ // On the client, we need to wait for the LOADED event to tell us
55
+ // that the package has been retrieved
56
+ LOADED: {
57
+ target: 'validating',
58
+ actions: assign({
59
+ items: (_, event) => {
60
+ return getInitialState(event.packageProduct).items;
61
+ },
62
+ price: (_, event) => {
63
+ return getInitialState(event.packageProduct).price;
64
+ },
65
+ packageProduct: (_, event) => {
66
+ return event.packageProduct;
67
+ }
68
+ })
69
+ }
70
+ }
71
+ },
72
+ invalid: {},
73
+ validating: {
74
+ always: [
75
+ {
76
+ target: 'valid',
77
+ cond: context => {
78
+ return deriveStatus(context.items) === 'valid';
79
+ }
80
+ },
81
+ {
82
+ target: 'invalid',
83
+ cond: context => {
84
+ return deriveStatus(context.items) !== 'valid';
85
+ }
86
+ }
87
+ ]
88
+ },
89
+ valid: {
90
+ initial: 'fetchingPrice',
91
+ states: {
92
+ fetchingPrice: {
93
+ invoke: {
94
+ id: 'fetchPrice',
95
+ src: 'fetchPrice',
96
+ onDone: {
97
+ target: 'buyable',
98
+ actions: assign({
99
+ price: (_, event) => {
100
+ return event.data;
101
+ }
102
+ })
103
+ },
104
+ onError: {
105
+ target: 'error',
106
+ actions: assign({
107
+ error: (_, event) => {
108
+ const errors = event.data;
109
+ return {
110
+ fromState: 'fetchingPrice',
111
+ messages: errors
112
+ .map((err) => err.message)
113
+ .filter(Boolean)
114
+ };
115
+ }
116
+ })
117
+ }
118
+ }
119
+ },
120
+ buyable: {
121
+ on: {
122
+ ADD_TO_CART: 'adding',
123
+ ERROR: 'error'
124
+ }
125
+ },
126
+ adding: {
127
+ invoke: {
128
+ id: 'add-to-cart',
129
+ src: 'addToCart',
130
+ onDone: 'added',
131
+ onError: {
132
+ target: 'error',
133
+ actions: assign({
134
+ error: (_, event) => {
135
+ const errors = event.data;
136
+ return {
137
+ fromState: 'adding',
138
+ messages: errors
139
+ .map((err) => err.message)
140
+ .filter(Boolean)
141
+ };
142
+ }
143
+ })
144
+ }
145
+ }
146
+ },
147
+ added: {
148
+ invoke: {
149
+ id: 'added-refetch',
150
+ src: () => {
151
+ return new Promise(resolve => {
152
+ setTimeout(() => {
153
+ resolve(400);
154
+ }, 800);
155
+ });
156
+ },
157
+ onDone: {
158
+ target: '#package.validating'
159
+ }
160
+ }
161
+ },
162
+ error: {
163
+ on: {
164
+ RETRY: '#package.validating'
165
+ }
166
+ }
167
+ }
168
+ }
169
+ }
170
+ }, {
171
+ actions: {
172
+ updateItems: assign({
173
+ items: (context, event) => {
174
+ if (event.type === 'UPDATE_ITEM') {
175
+ const item = context.items[event.articleNumber];
176
+ if (!item) {
177
+ throw new Error('article does not exist in package');
178
+ }
179
+ if (event.variantArticleNumber) {
180
+ const match = item.variants.includes(event.variantArticleNumber);
181
+ if (!match) {
182
+ throw new Error('variant does not exist on article');
183
+ }
184
+ }
185
+ const { articleNumber, valid, variantArticleNumber } = event;
186
+ const items = produce(context.items, draft => {
187
+ draft[articleNumber] = Object.assign(Object.assign({}, draft[articleNumber]), { valid,
188
+ variantArticleNumber });
189
+ });
190
+ return items;
191
+ }
192
+ }
193
+ })
194
+ }
195
+ });
196
+ function getInitialState(packageProduct) {
197
+ var _a, _b;
198
+ const items = (_b = (_a = packageProduct === null || packageProduct === void 0 ? void 0 : packageProduct.package) === null || _a === void 0 ? void 0 : _a.items) === null || _b === void 0 ? void 0 : _b.reduce((dict, item) => {
199
+ var _a;
200
+ dict[item.product.articleNumber] = {
201
+ product: item.product,
202
+ articleNumber: item.product.articleNumber,
203
+ hasVariants: item.product.hasVariants,
204
+ variantArticleNumber: null,
205
+ variants: item.product.hasVariants
206
+ ? (_a = item.product.variants) === null || _a === void 0 ? void 0 : _a.values.map(variant => variant.articleNumber)
207
+ : null,
208
+ valid: !itemHasVariants(item) && !itemIsOutOfStock(item),
209
+ quantity: item.minQuantity
210
+ };
211
+ return dict;
212
+ }, {});
213
+ const price = packageProduct.package;
214
+ return { items, price };
215
+ }
216
+ function flattenItems(items) {
217
+ // perhaps we need the rest of the product detail?
218
+ // Or otherwise the types need to be changed
219
+ return Object.entries(items).map(entry => {
220
+ const { articleNumber, variantArticleNumber, quantity, product } = entry[1];
221
+ return Object.assign(Object.assign({}, product), { articleNumber: variantArticleNumber || articleNumber, quantity });
222
+ });
223
+ }
224
+ function deriveStatus(packageItems) {
225
+ const packageIsValid = Object.values(packageItems).every(item => item.valid);
226
+ if (packageIsValid) {
227
+ return 'valid';
228
+ }
229
+ return 'invalid';
230
+ }
231
+ function fetchPrice(packageArticleNumber, items, opts) {
232
+ return opts.apolloClient
233
+ .query({
234
+ query: opts.query || packagePriceQuery,
235
+ variables: {
236
+ articleNumber: packageArticleNumber,
237
+ products: Object.entries(items).map(entry => {
238
+ // This should be cleaned up - we have to transform to the structure
239
+ // that the API expects
240
+ const { articleNumber, variantArticleNumber } = entry[1];
241
+ return {
242
+ product: articleNumber,
243
+ // if you want to test error handling, just pass a random string for variant
244
+ // variant: 'sdfgsdfg'
245
+ variant: variantArticleNumber
246
+ };
247
+ })
248
+ }
249
+ })
250
+ .then(({ data }) => {
251
+ return data.product.package;
252
+ }, err => {
253
+ return Promise.reject(err.graphQLErrors);
254
+ });
255
+ }
256
+ export function usePackageProduct({ product, packageProductQuery, priceQuery }) {
257
+ const mounted = useRef(false);
258
+ useEffect(() => {
259
+ mounted.current = true;
260
+ }, []);
261
+ const client = useApolloClient();
262
+ const { data } = useQuery(packageProductQuery, {
263
+ variables: { articleNumber: product.articleNumber }
264
+ });
265
+ const [current, send] = useMachine(stateMachine, {
266
+ // During SSR, data.product will have resolved, and we can initialise with
267
+ // it. Otherwise, use the product passed in
268
+ context: { packageProduct: (data === null || data === void 0 ? void 0 : data.product) || product },
269
+ services: {
270
+ fetchPrice: context => {
271
+ return fetchPrice(product.articleNumber, context.items, {
272
+ apolloClient: client,
273
+ query: priceQuery
274
+ });
275
+ },
276
+ addToCart: (_, event) => {
277
+ // eslint-disable-next-line
278
+ return addToCartMutation(event.queries).then(result => {
279
+ if (result.errors) {
280
+ return Promise.reject(result.errors);
281
+ }
282
+ else {
283
+ return result;
284
+ }
285
+ });
286
+ }
287
+ }
288
+ });
289
+ useEffect(() => {
290
+ // On the client we send the LOADED event once the package query resolves
291
+ if (current.value !== 'loading')
292
+ return;
293
+ if (!(data === null || data === void 0 ? void 0 : data.product))
294
+ return;
295
+ send({ type: 'LOADED', packageProduct: data.product });
296
+ }, [current.value, data, send]);
297
+ const [addToCartMutation] = useAddMultipleToCart(flattenItems(current.context.items));
298
+ const addPackageToCart = (queries) => {
299
+ // invokes addToCart
300
+ send({ type: 'ADD_TO_CART', queries });
301
+ };
302
+ const updatePackageItem = useCallback(function updatePackageItem(articleNumber, variantArticleNumber, valid) {
303
+ send({
304
+ type: 'UPDATE_ITEM',
305
+ articleNumber,
306
+ variantArticleNumber,
307
+ valid
308
+ });
309
+ }, [send]);
310
+ // Just doing this to simplify the status we expose
311
+ const status = useMemo(() => {
312
+ switch (true) {
313
+ case current.matches({ valid: 'fetchingPrice' }):
314
+ return 'fetching_price';
315
+ case current.matches({ valid: 'buyable' }):
316
+ return 'buyable';
317
+ case current.matches({ valid: 'adding' }):
318
+ return 'adding';
319
+ case current.matches({ valid: 'added' }):
320
+ return 'added';
321
+ case current.matches({ valid: 'error' }):
322
+ return 'error';
323
+ case current.matches('loading'):
324
+ return 'loading';
325
+ default:
326
+ return 'invalid';
327
+ }
328
+ }, [current]);
329
+ const retry = useCallback(function retry() {
330
+ if (status === 'error') {
331
+ send({
332
+ type: 'RETRY'
333
+ });
334
+ }
335
+ }, [send, status]);
336
+ return {
337
+ status,
338
+ price: current.context.price,
339
+ addPackageToCart,
340
+ updatePackageItem,
341
+ packageProduct: current.context.packageProduct,
342
+ error: current.context.error,
343
+ retry
344
+ };
345
+ }
346
346
  //# sourceMappingURL=usePackageProducts.js.map