@jetshop/core 5.13.2 → 5.13.10-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,464 +1,464 @@
1
- import { act, renderHook } from '@testing-library/react-hooks';
2
- import { useReducer } from 'react';
3
- import { reducer, init } from './product-list-reducer';
4
- import {
5
- productListMapToArray,
6
- PRODUCT_LISTS_KEY
7
- } from '@jetshop/core/hooks/ProductList';
8
- import { LocalStorageMock } from '@react-mock/localstorage';
9
- import { render } from '@testing-library/react';
10
- import React from 'react';
11
-
12
- const MOCK_LIST_ITEMS = {
13
- 6952315: {
14
- options: { quantity: 1 },
15
- variants: {
16
- '6952315-170-white': {
17
- options: {
18
- quantity: 1
19
- },
20
- parentArticleNumber: '6952315'
21
- }
22
- }
23
- },
24
- 502935480: {
25
- variants: null,
26
- options: {
27
- quantity: 1
28
- }
29
- },
30
- '441922-Classic-16': {
31
- variants: null,
32
- options: {
33
- quantity: 1
34
- }
35
- },
36
- 'without-base': {
37
- options: null,
38
- variants: {
39
- 'with-variant': {
40
- options: {
41
- quantity: 1
42
- },
43
- parentArticleNumber: 'without-base'
44
- }
45
- }
46
- }
47
- };
48
-
49
- describe('reducer init method', () => {
50
- it('defaults the list to localStorage', () => {
51
- const obj = {
52
- key: 'value'
53
- };
54
- const listId = 'test';
55
-
56
- function Parent({ children }) {
57
- const mockList = new Map([[listId, obj]]);
58
- const localStorage = {};
59
- localStorage[PRODUCT_LISTS_KEY] = JSON.stringify(
60
- productListMapToArray(mockList)
61
- );
62
- return (
63
- <LocalStorageMock items={localStorage}>{children}</LocalStorageMock>
64
- );
65
- }
66
- function Child() {
67
- const initialState = { loggedIn: false, lists: new Map() };
68
- const state = init(initialState);
69
-
70
- return (
71
- <div>
72
- <span>{state.lists.get(listId).key}</span>
73
- <span>{state.loggedIn ? 'logged in' : 'not logged in'}</span>
74
- </div>
75
- );
76
- }
77
-
78
- const { getByText } = render(
79
- <Parent>
80
- <Child />
81
- </Parent>
82
- );
83
-
84
- expect(getByText('not logged in'));
85
- expect(getByText('value'));
86
- });
87
- });
88
-
89
- describe('reducer', () => {
90
- const initialState = {
91
- loggedIn: false,
92
- lists: new Map([[null, { name: null, items: MOCK_LIST_ITEMS }]])
93
- };
94
-
95
- it('sets logged in and payload when LOGIN is called', () => {
96
- const { result, dispatch } = setup();
97
-
98
- // We should only test listId null, logged out users shouldn't have lists with IDs.
99
- // We could remove the listId from the payload to make null implicit
100
- const payload = {
101
- listId: null,
102
- list: {
103
- name: null,
104
- items: {
105
- test: 'one'
106
- }
107
- }
108
- };
109
-
110
- act(() => dispatch({ type: 'LOGIN', payload }));
111
-
112
- const [state] = result.current;
113
-
114
- expect(state.loggedIn).toBe(true);
115
- expect(state.lists.get(null).items).toMatchObject(payload.list.items);
116
- });
117
- it('sets loggedIn and resets list on LOGOUT', () => {
118
- const initialState = {
119
- loggedIn: true,
120
- lists: new Map([
121
- [
122
- null,
123
- {
124
- name: null,
125
- items: { 234523423: { options: { quantity: 1, description: '' } } }
126
- }
127
- ]
128
- ])
129
- };
130
-
131
- const { result, dispatch } = setup(initialState);
132
-
133
- {
134
- const [state] = result.current;
135
- expect(state).toBe(initialState);
136
- }
137
-
138
- act(() => dispatch({ type: 'LOGOUT' }));
139
-
140
- const [state] = result.current;
141
-
142
- expect(state.loggedIn).toBe(false);
143
- expect(state.lists).toMatchObject(
144
- new Map([[null, { name: null, items: {} }]])
145
- );
146
- });
147
- describe('UPDATE action', () => {
148
- it('can replace a base product with one of its variants', () => {
149
- const { result, dispatch } = setup(initialState);
150
-
151
- act(() =>
152
- dispatch({
153
- type: 'UPDATE',
154
- payload: {
155
- listId: null,
156
- articleNumber: '502935480',
157
- variantArticleNumber: '502935480-sparkles',
158
- options: {
159
- quantity: 1
160
- }
161
- }
162
- })
163
- );
164
-
165
- const [state] = result.current;
166
-
167
- const baseProduct = state.lists.get(null).items['502935480'];
168
-
169
- expect(baseProduct.variants['502935480-sparkles'].options.quantity).toBe(
170
- 1
171
- );
172
- // Removing the base product options effectively removes it from the list
173
- expect(baseProduct.options).toBe(null);
174
- });
175
- it('can replace a variant with another variant', () => {
176
- const { result, dispatch } = setup(initialState);
177
-
178
- act(() =>
179
- dispatch({
180
- type: 'UPDATE',
181
- payload: {
182
- listId: null,
183
- articleNumber: '6952315',
184
- variantArticleNumber: '6952315-170-pink',
185
- options: {
186
- quantity: 1
187
- },
188
- variantToReplace: '6952315-170-white'
189
- }
190
- })
191
- );
192
-
193
- const [state] = result.current;
194
- const list = state.lists.get(null);
195
-
196
- expect(
197
- list.items['6952315'].variants['6952315-170-pink'].options.quantity
198
- ).toBe(1);
199
- expect(
200
- list.items['6952315'].variants['6952315-170-white']
201
- ).not.toBeDefined();
202
- });
203
- });
204
- describe('ADD action', () => {
205
- it('can add a base product to the list', () => {
206
- const { result, dispatch } = setup(initialState);
207
-
208
- act(() =>
209
- dispatch({
210
- type: 'ADD',
211
- payload: {
212
- listId: null,
213
- articleNumber: 'boogie',
214
- options: {
215
- quantity: 1
216
- }
217
- }
218
- })
219
- );
220
-
221
- const [state] = result.current;
222
-
223
- expect(state.lists.get(null).items['boogie'].options.quantity).toBe(1);
224
- });
225
- it('can add a variant to the list when there is no existing base product', () => {
226
- const { result, dispatch } = setup(initialState);
227
-
228
- act(() =>
229
- dispatch({
230
- type: 'ADD',
231
- payload: {
232
- listId: null,
233
- articleNumber: 'boogie',
234
- variantArticleNumber: 'boogie-woogie',
235
- options: {
236
- quantity: 1
237
- }
238
- }
239
- })
240
- );
241
-
242
- const [state] = result.current;
243
- const list = state.lists.get(null);
244
-
245
- expect(list.items['boogie'].options).toBe(null);
246
- expect(
247
- list.items['boogie'].variants['boogie-woogie'].options.quantity
248
- ).toBe(1);
249
- });
250
- it('can add a variant to the list when there is an existing base product', () => {
251
- const { result, dispatch } = setup(initialState);
252
-
253
- act(() =>
254
- dispatch({
255
- type: 'ADD',
256
- payload: {
257
- listId: null,
258
- articleNumber: '502935480',
259
- variantArticleNumber: 'boogie-woogie',
260
- options: {
261
- quantity: 1
262
- }
263
- }
264
- })
265
- );
266
-
267
- const [state] = result.current;
268
- const list = state.lists.get(null);
269
-
270
- expect(list.items['502935480'].options).not.toBe(null);
271
- expect(
272
- list.items['502935480'].variants['boogie-woogie'].options.quantity
273
- ).toBe(1);
274
- });
275
- it('can add a variant to the list when there is a base product with variants', () => {
276
- const { result, dispatch } = setup(initialState);
277
-
278
- act(() =>
279
- dispatch({
280
- type: 'ADD',
281
- payload: {
282
- listId: null,
283
- articleNumber: '6952315',
284
- variantArticleNumber: 'boogie-woogie',
285
- options: {
286
- quantity: 1
287
- }
288
- }
289
- })
290
- );
291
-
292
- const [state] = result.current;
293
- const list = state.lists.get(null);
294
-
295
- expect(list.items['6952315'].options).not.toBe(null);
296
- expect(
297
- list.items['6952315'].variants['boogie-woogie'].options.quantity
298
- ).toBe(1);
299
- expect(list.items['6952315'].variants['6952315-170-white']).toMatchObject(
300
- MOCK_LIST_ITEMS['6952315'].variants['6952315-170-white']
301
- );
302
- });
303
- });
304
- describe('REMOVE action', () => {
305
- it('will entirely remove a base product with no variants', () => {
306
- const { result, dispatch } = setup(initialState);
307
-
308
- act(() =>
309
- dispatch({
310
- type: 'REMOVE',
311
- payload: {
312
- listId: null,
313
- articleNumber: '502935480'
314
- }
315
- })
316
- );
317
-
318
- const [state] = result.current;
319
- const list = state.lists.get(null);
320
-
321
- expect(list.items['502935480']).not.toBeDefined();
322
- });
323
- it('will entirely remove an item if the variant is removed and there is no base product', () => {
324
- const { result, dispatch } = setup(initialState);
325
-
326
- act(() =>
327
- dispatch({
328
- type: 'REMOVE',
329
- payload: {
330
- listId: null,
331
- articleNumber: 'without-base',
332
- variantArticleNumber: 'with-variant'
333
- }
334
- })
335
- );
336
-
337
- const [state] = result.current;
338
- const list = state.lists.get(null);
339
-
340
- expect(list['without-base']).not.toBeDefined();
341
- });
342
- it('will keep the variant if one exists', () => {
343
- const { result, dispatch } = setup(initialState);
344
- const articleToRemove = '6952315';
345
-
346
- act(() =>
347
- dispatch({
348
- type: 'REMOVE',
349
- payload: {
350
- listId: null,
351
- articleNumber: articleToRemove
352
- }
353
- })
354
- );
355
-
356
- const [state] = result.current;
357
- const list = state.lists.get(null);
358
-
359
- expect(list.items[articleToRemove].options).toBe(null);
360
- expect(list.items[articleToRemove].variants).toBeDefined();
361
- });
362
- it('will remove the variant but keep the base product', () => {
363
- const { result, dispatch } = setup(initialState);
364
-
365
- const parent = '6952315';
366
- const articleToRemove = '6952315-170-white';
367
-
368
- act(() =>
369
- dispatch({
370
- type: 'REMOVE',
371
- payload: {
372
- listId: null,
373
- articleNumber: parent,
374
- variantArticleNumber: articleToRemove
375
- }
376
- })
377
- );
378
-
379
- const [state] = result.current;
380
- const list = state.lists.get(null);
381
-
382
- expect(list.items[parent].variants[articleToRemove]).not.toBeDefined();
383
- expect(list.items[parent].options).toBeDefined();
384
- });
385
- });
386
-
387
- describe('DELETE_LIST action', () => {
388
- it('can delete a product list', () => {
389
- const listId = '12345';
390
- const initialState = {
391
- loggedIn: false,
392
- lists: new Map([[listId, MOCK_LIST_ITEMS]])
393
- };
394
-
395
- const { result, dispatch } = setup(initialState);
396
- const [state] = result.current;
397
-
398
- expect(state.lists.get(listId)).toBeDefined;
399
-
400
- act(() =>
401
- dispatch({
402
- type: 'DELETE_LIST',
403
- payload: { listId }
404
- })
405
- );
406
-
407
- expect(state.lists.get(listId)).toBeUndefined;
408
- });
409
- });
410
-
411
- describe('CREATE_LIST action', () => {
412
- it('can create a new product list', () => {
413
- const listId = '12345';
414
- const { result, dispatch } = setup();
415
- const name = 'My Stuff';
416
-
417
- act(() =>
418
- dispatch({
419
- type: 'CREATE_LIST',
420
- payload: { listId, list: { name } }
421
- })
422
- );
423
-
424
- const [state] = result.current;
425
- expect(state.lists.has(listId)).toBe(true);
426
- expect(state.lists.get(listId).name).toBe(name);
427
- });
428
- });
429
-
430
- describe('CLEAR_ITEMS action', () => {
431
- it('can clear items on a product list', () => {
432
- const { result, dispatch } = setup(initialState);
433
- const listId = null;
434
-
435
- act(() =>
436
- dispatch({
437
- type: 'CLEAR_ITEMS',
438
- payload: { listId }
439
- })
440
- );
441
-
442
- const [state] = result.current;
443
- const list = state.lists.get(listId);
444
- expect(list.items).toMatchObject({});
445
- });
446
- });
447
- });
448
-
449
- function setup(initialState) {
450
- const { result } = renderHook(() => useProductListReducer({ initialState }));
451
-
452
- const [, dispatch] = result.current;
453
-
454
- return { result, dispatch };
455
- }
456
-
457
- function useProductListReducer({ initialState }) {
458
- const [state, dispatch] = useReducer(
459
- reducer,
460
- initialState || { loggedIn: false, lists: new Map() }
461
- );
462
-
463
- return [state, dispatch];
464
- }
1
+ import { act, renderHook } from '@testing-library/react-hooks';
2
+ import { useReducer } from 'react';
3
+ import { reducer, init } from './product-list-reducer';
4
+ import {
5
+ productListMapToArray,
6
+ PRODUCT_LISTS_KEY
7
+ } from '@jetshop/core/hooks/ProductList';
8
+ import { LocalStorageMock } from '@react-mock/localstorage';
9
+ import { render } from '@testing-library/react';
10
+ import React from 'react';
11
+
12
+ const MOCK_LIST_ITEMS = {
13
+ 6952315: {
14
+ options: { quantity: 1 },
15
+ variants: {
16
+ '6952315-170-white': {
17
+ options: {
18
+ quantity: 1
19
+ },
20
+ parentArticleNumber: '6952315'
21
+ }
22
+ }
23
+ },
24
+ 502935480: {
25
+ variants: null,
26
+ options: {
27
+ quantity: 1
28
+ }
29
+ },
30
+ '441922-Classic-16': {
31
+ variants: null,
32
+ options: {
33
+ quantity: 1
34
+ }
35
+ },
36
+ 'without-base': {
37
+ options: null,
38
+ variants: {
39
+ 'with-variant': {
40
+ options: {
41
+ quantity: 1
42
+ },
43
+ parentArticleNumber: 'without-base'
44
+ }
45
+ }
46
+ }
47
+ };
48
+
49
+ describe('reducer init method', () => {
50
+ it('defaults the list to localStorage', () => {
51
+ const obj = {
52
+ key: 'value'
53
+ };
54
+ const listId = 'test';
55
+
56
+ function Parent({ children }) {
57
+ const mockList = new Map([[listId, obj]]);
58
+ const localStorage = {};
59
+ localStorage[PRODUCT_LISTS_KEY] = JSON.stringify(
60
+ productListMapToArray(mockList)
61
+ );
62
+ return (
63
+ <LocalStorageMock items={localStorage}>{children}</LocalStorageMock>
64
+ );
65
+ }
66
+ function Child() {
67
+ const initialState = { loggedIn: false, lists: new Map() };
68
+ const state = init(initialState);
69
+
70
+ return (
71
+ <div>
72
+ <span>{state.lists.get(listId).key}</span>
73
+ <span>{state.loggedIn ? 'logged in' : 'not logged in'}</span>
74
+ </div>
75
+ );
76
+ }
77
+
78
+ const { getByText } = render(
79
+ <Parent>
80
+ <Child />
81
+ </Parent>
82
+ );
83
+
84
+ expect(getByText('not logged in'));
85
+ expect(getByText('value'));
86
+ });
87
+ });
88
+
89
+ describe('reducer', () => {
90
+ const initialState = {
91
+ loggedIn: false,
92
+ lists: new Map([[null, { name: null, items: MOCK_LIST_ITEMS }]])
93
+ };
94
+
95
+ it('sets logged in and payload when LOGIN is called', () => {
96
+ const { result, dispatch } = setup();
97
+
98
+ // We should only test listId null, logged out users shouldn't have lists with IDs.
99
+ // We could remove the listId from the payload to make null implicit
100
+ const payload = {
101
+ listId: null,
102
+ list: {
103
+ name: null,
104
+ items: {
105
+ test: 'one'
106
+ }
107
+ }
108
+ };
109
+
110
+ act(() => dispatch({ type: 'LOGIN', payload }));
111
+
112
+ const [state] = result.current;
113
+
114
+ expect(state.loggedIn).toBe(true);
115
+ expect(state.lists.get(null).items).toMatchObject(payload.list.items);
116
+ });
117
+ it('sets loggedIn and resets list on LOGOUT', () => {
118
+ const initialState = {
119
+ loggedIn: true,
120
+ lists: new Map([
121
+ [
122
+ null,
123
+ {
124
+ name: null,
125
+ items: { 234523423: { options: { quantity: 1, description: '' } } }
126
+ }
127
+ ]
128
+ ])
129
+ };
130
+
131
+ const { result, dispatch } = setup(initialState);
132
+
133
+ {
134
+ const [state] = result.current;
135
+ expect(state).toBe(initialState);
136
+ }
137
+
138
+ act(() => dispatch({ type: 'LOGOUT' }));
139
+
140
+ const [state] = result.current;
141
+
142
+ expect(state.loggedIn).toBe(false);
143
+ expect(state.lists).toMatchObject(
144
+ new Map([[null, { name: null, items: {} }]])
145
+ );
146
+ });
147
+ describe('UPDATE action', () => {
148
+ it('can replace a base product with one of its variants', () => {
149
+ const { result, dispatch } = setup(initialState);
150
+
151
+ act(() =>
152
+ dispatch({
153
+ type: 'UPDATE',
154
+ payload: {
155
+ listId: null,
156
+ articleNumber: '502935480',
157
+ variantArticleNumber: '502935480-sparkles',
158
+ options: {
159
+ quantity: 1
160
+ }
161
+ }
162
+ })
163
+ );
164
+
165
+ const [state] = result.current;
166
+
167
+ const baseProduct = state.lists.get(null).items['502935480'];
168
+
169
+ expect(baseProduct.variants['502935480-sparkles'].options.quantity).toBe(
170
+ 1
171
+ );
172
+ // Removing the base product options effectively removes it from the list
173
+ expect(baseProduct.options).toBe(null);
174
+ });
175
+ it('can replace a variant with another variant', () => {
176
+ const { result, dispatch } = setup(initialState);
177
+
178
+ act(() =>
179
+ dispatch({
180
+ type: 'UPDATE',
181
+ payload: {
182
+ listId: null,
183
+ articleNumber: '6952315',
184
+ variantArticleNumber: '6952315-170-pink',
185
+ options: {
186
+ quantity: 1
187
+ },
188
+ variantToReplace: '6952315-170-white'
189
+ }
190
+ })
191
+ );
192
+
193
+ const [state] = result.current;
194
+ const list = state.lists.get(null);
195
+
196
+ expect(
197
+ list.items['6952315'].variants['6952315-170-pink'].options.quantity
198
+ ).toBe(1);
199
+ expect(
200
+ list.items['6952315'].variants['6952315-170-white']
201
+ ).not.toBeDefined();
202
+ });
203
+ });
204
+ describe('ADD action', () => {
205
+ it('can add a base product to the list', () => {
206
+ const { result, dispatch } = setup(initialState);
207
+
208
+ act(() =>
209
+ dispatch({
210
+ type: 'ADD',
211
+ payload: {
212
+ listId: null,
213
+ articleNumber: 'boogie',
214
+ options: {
215
+ quantity: 1
216
+ }
217
+ }
218
+ })
219
+ );
220
+
221
+ const [state] = result.current;
222
+
223
+ expect(state.lists.get(null).items['boogie'].options.quantity).toBe(1);
224
+ });
225
+ it('can add a variant to the list when there is no existing base product', () => {
226
+ const { result, dispatch } = setup(initialState);
227
+
228
+ act(() =>
229
+ dispatch({
230
+ type: 'ADD',
231
+ payload: {
232
+ listId: null,
233
+ articleNumber: 'boogie',
234
+ variantArticleNumber: 'boogie-woogie',
235
+ options: {
236
+ quantity: 1
237
+ }
238
+ }
239
+ })
240
+ );
241
+
242
+ const [state] = result.current;
243
+ const list = state.lists.get(null);
244
+
245
+ expect(list.items['boogie'].options).toBe(null);
246
+ expect(
247
+ list.items['boogie'].variants['boogie-woogie'].options.quantity
248
+ ).toBe(1);
249
+ });
250
+ it('can add a variant to the list when there is an existing base product', () => {
251
+ const { result, dispatch } = setup(initialState);
252
+
253
+ act(() =>
254
+ dispatch({
255
+ type: 'ADD',
256
+ payload: {
257
+ listId: null,
258
+ articleNumber: '502935480',
259
+ variantArticleNumber: 'boogie-woogie',
260
+ options: {
261
+ quantity: 1
262
+ }
263
+ }
264
+ })
265
+ );
266
+
267
+ const [state] = result.current;
268
+ const list = state.lists.get(null);
269
+
270
+ expect(list.items['502935480'].options).not.toBe(null);
271
+ expect(
272
+ list.items['502935480'].variants['boogie-woogie'].options.quantity
273
+ ).toBe(1);
274
+ });
275
+ it('can add a variant to the list when there is a base product with variants', () => {
276
+ const { result, dispatch } = setup(initialState);
277
+
278
+ act(() =>
279
+ dispatch({
280
+ type: 'ADD',
281
+ payload: {
282
+ listId: null,
283
+ articleNumber: '6952315',
284
+ variantArticleNumber: 'boogie-woogie',
285
+ options: {
286
+ quantity: 1
287
+ }
288
+ }
289
+ })
290
+ );
291
+
292
+ const [state] = result.current;
293
+ const list = state.lists.get(null);
294
+
295
+ expect(list.items['6952315'].options).not.toBe(null);
296
+ expect(
297
+ list.items['6952315'].variants['boogie-woogie'].options.quantity
298
+ ).toBe(1);
299
+ expect(list.items['6952315'].variants['6952315-170-white']).toMatchObject(
300
+ MOCK_LIST_ITEMS['6952315'].variants['6952315-170-white']
301
+ );
302
+ });
303
+ });
304
+ describe('REMOVE action', () => {
305
+ it('will entirely remove a base product with no variants', () => {
306
+ const { result, dispatch } = setup(initialState);
307
+
308
+ act(() =>
309
+ dispatch({
310
+ type: 'REMOVE',
311
+ payload: {
312
+ listId: null,
313
+ articleNumber: '502935480'
314
+ }
315
+ })
316
+ );
317
+
318
+ const [state] = result.current;
319
+ const list = state.lists.get(null);
320
+
321
+ expect(list.items['502935480']).not.toBeDefined();
322
+ });
323
+ it('will entirely remove an item if the variant is removed and there is no base product', () => {
324
+ const { result, dispatch } = setup(initialState);
325
+
326
+ act(() =>
327
+ dispatch({
328
+ type: 'REMOVE',
329
+ payload: {
330
+ listId: null,
331
+ articleNumber: 'without-base',
332
+ variantArticleNumber: 'with-variant'
333
+ }
334
+ })
335
+ );
336
+
337
+ const [state] = result.current;
338
+ const list = state.lists.get(null);
339
+
340
+ expect(list['without-base']).not.toBeDefined();
341
+ });
342
+ it('will keep the variant if one exists', () => {
343
+ const { result, dispatch } = setup(initialState);
344
+ const articleToRemove = '6952315';
345
+
346
+ act(() =>
347
+ dispatch({
348
+ type: 'REMOVE',
349
+ payload: {
350
+ listId: null,
351
+ articleNumber: articleToRemove
352
+ }
353
+ })
354
+ );
355
+
356
+ const [state] = result.current;
357
+ const list = state.lists.get(null);
358
+
359
+ expect(list.items[articleToRemove].options).toBe(null);
360
+ expect(list.items[articleToRemove].variants).toBeDefined();
361
+ });
362
+ it('will remove the variant but keep the base product', () => {
363
+ const { result, dispatch } = setup(initialState);
364
+
365
+ const parent = '6952315';
366
+ const articleToRemove = '6952315-170-white';
367
+
368
+ act(() =>
369
+ dispatch({
370
+ type: 'REMOVE',
371
+ payload: {
372
+ listId: null,
373
+ articleNumber: parent,
374
+ variantArticleNumber: articleToRemove
375
+ }
376
+ })
377
+ );
378
+
379
+ const [state] = result.current;
380
+ const list = state.lists.get(null);
381
+
382
+ expect(list.items[parent].variants[articleToRemove]).not.toBeDefined();
383
+ expect(list.items[parent].options).toBeDefined();
384
+ });
385
+ });
386
+
387
+ describe('DELETE_LIST action', () => {
388
+ it('can delete a product list', () => {
389
+ const listId = '12345';
390
+ const initialState = {
391
+ loggedIn: false,
392
+ lists: new Map([[listId, MOCK_LIST_ITEMS]])
393
+ };
394
+
395
+ const { result, dispatch } = setup(initialState);
396
+ const [state] = result.current;
397
+
398
+ expect(state.lists.get(listId)).toBeDefined;
399
+
400
+ act(() =>
401
+ dispatch({
402
+ type: 'DELETE_LIST',
403
+ payload: { listId }
404
+ })
405
+ );
406
+
407
+ expect(state.lists.get(listId)).toBeUndefined;
408
+ });
409
+ });
410
+
411
+ describe('CREATE_LIST action', () => {
412
+ it('can create a new product list', () => {
413
+ const listId = '12345';
414
+ const { result, dispatch } = setup();
415
+ const name = 'My Stuff';
416
+
417
+ act(() =>
418
+ dispatch({
419
+ type: 'CREATE_LIST',
420
+ payload: { listId, list: { name } }
421
+ })
422
+ );
423
+
424
+ const [state] = result.current;
425
+ expect(state.lists.has(listId)).toBe(true);
426
+ expect(state.lists.get(listId).name).toBe(name);
427
+ });
428
+ });
429
+
430
+ describe('CLEAR_ITEMS action', () => {
431
+ it('can clear items on a product list', () => {
432
+ const { result, dispatch } = setup(initialState);
433
+ const listId = null;
434
+
435
+ act(() =>
436
+ dispatch({
437
+ type: 'CLEAR_ITEMS',
438
+ payload: { listId }
439
+ })
440
+ );
441
+
442
+ const [state] = result.current;
443
+ const list = state.lists.get(listId);
444
+ expect(list.items).toMatchObject({});
445
+ });
446
+ });
447
+ });
448
+
449
+ function setup(initialState) {
450
+ const { result } = renderHook(() => useProductListReducer({ initialState }));
451
+
452
+ const [, dispatch] = result.current;
453
+
454
+ return { result, dispatch };
455
+ }
456
+
457
+ function useProductListReducer({ initialState }) {
458
+ const [state, dispatch] = useReducer(
459
+ reducer,
460
+ initialState || { loggedIn: false, lists: new Map() }
461
+ );
462
+
463
+ return [state, dispatch];
464
+ }