@akinon/next 1.14.0 → 1.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/.editorconfig +7 -7
  2. package/.eslintrc.js +40 -40
  3. package/.gitattributes +15 -0
  4. package/.prettierrc +13 -13
  5. package/CHANGELOG.md +14 -0
  6. package/api/auth.ts +231 -231
  7. package/api/cache.ts +44 -44
  8. package/api/client.ts +174 -174
  9. package/api/logout.ts +42 -42
  10. package/bin/pz-check-dependencies.js +98 -98
  11. package/bin/pz-install-plugins.js +33 -33
  12. package/bin/pz-install-theme.js +58 -58
  13. package/bin/pz-postbuild.js +1 -1
  14. package/bin/pz-postdev.js +1 -1
  15. package/bin/pz-postinstall.js +6 -6
  16. package/bin/pz-poststart.js +1 -1
  17. package/bin/pz-prebuild.js +4 -4
  18. package/bin/pz-predev.js +4 -4
  19. package/bin/pz-prestart.js +1 -1
  20. package/bin/run-script.js +44 -44
  21. package/components/accordion.tsx +52 -52
  22. package/components/button.tsx +46 -46
  23. package/components/client-root.tsx +19 -19
  24. package/components/icon.tsx +18 -18
  25. package/components/image.tsx +133 -133
  26. package/components/index.ts +1 -0
  27. package/components/input.tsx +110 -110
  28. package/components/lazy-component.tsx +33 -33
  29. package/components/loader-spinner.tsx +23 -23
  30. package/components/mobile-app-toggler.tsx +26 -26
  31. package/components/modal.tsx +66 -0
  32. package/components/oauth-login.tsx +24 -24
  33. package/components/plugin-module.tsx +5 -0
  34. package/components/price.tsx +55 -55
  35. package/components/pz-providers.tsx +24 -24
  36. package/components/pz-root.tsx +21 -21
  37. package/components/radio.tsx +18 -18
  38. package/components/react-portal.tsx +45 -45
  39. package/components/redirect-three-d/content/index.tsx +74 -74
  40. package/components/redirect-three-d/index.tsx +17 -17
  41. package/components/selected-payment-option-view.tsx +1 -1
  42. package/components/trans.tsx +39 -39
  43. package/data/client/account.ts +208 -208
  44. package/data/client/api.ts +85 -85
  45. package/data/client/basket.ts +82 -82
  46. package/data/client/misc.ts +101 -101
  47. package/data/client/product.ts +89 -89
  48. package/data/client/user.ts +99 -99
  49. package/data/client/wishlist.ts +118 -118
  50. package/data/server/category.ts +132 -132
  51. package/data/server/flatpage.ts +21 -21
  52. package/data/server/form.ts +22 -22
  53. package/data/server/index.ts +10 -10
  54. package/data/server/landingpage.ts +24 -24
  55. package/data/server/list.ts +67 -67
  56. package/data/server/menu.ts +35 -35
  57. package/data/server/product.ts +86 -86
  58. package/data/server/seo.ts +48 -48
  59. package/data/server/special-page.ts +47 -47
  60. package/data/server/widget.ts +27 -27
  61. package/data/urls.ts +221 -221
  62. package/hocs/client/index.ts +1 -1
  63. package/hocs/client/with-segment-defaults.tsx +25 -25
  64. package/hocs/server/index.ts +1 -1
  65. package/hocs/server/with-segment-defaults.tsx +85 -85
  66. package/hooks/index.ts +10 -10
  67. package/hooks/use-captcha.tsx +76 -76
  68. package/hooks/use-common-product-attributes.ts +36 -36
  69. package/hooks/use-debounce.ts +20 -20
  70. package/hooks/use-localization.ts +78 -78
  71. package/hooks/use-media-query.ts +36 -36
  72. package/hooks/use-mobile-iframe-handler.ts +23 -23
  73. package/hooks/use-on-click-outside.tsx +28 -28
  74. package/hooks/use-payment-options.ts +3 -1
  75. package/hooks/use-router.ts +45 -45
  76. package/hooks/use-translation.ts +14 -14
  77. package/lib/cache.ts +215 -215
  78. package/localization/index.ts +5 -5
  79. package/localization/provider.tsx +58 -58
  80. package/middlewares/complete-gpay.ts +159 -0
  81. package/middlewares/currency.ts +100 -100
  82. package/middlewares/default.ts +259 -256
  83. package/middlewares/index.ts +31 -29
  84. package/middlewares/locale.ts +68 -68
  85. package/middlewares/oauth-login.ts +79 -79
  86. package/middlewares/pretty-url.ts +104 -104
  87. package/middlewares/redirection-payment.ts +160 -160
  88. package/middlewares/three-d-redirection.ts +159 -159
  89. package/middlewares/url-redirection.ts +65 -65
  90. package/package.json +2 -2
  91. package/plugins.js +1 -0
  92. package/redux/hooks.ts +7 -7
  93. package/redux/middlewares/index.ts +50 -50
  94. package/redux/reducers/checkout.ts +184 -184
  95. package/redux/reducers/config.ts +28 -28
  96. package/redux/reducers/header.ts +59 -59
  97. package/redux/reducers/root.ts +61 -61
  98. package/sentry/index.ts +27 -27
  99. package/tailwind/rtl.js +137 -137
  100. package/types/commerce/account.ts +64 -64
  101. package/types/commerce/address.ts +94 -94
  102. package/types/commerce/basket.ts +43 -43
  103. package/types/commerce/category.ts +114 -114
  104. package/types/commerce/checkout.ts +143 -143
  105. package/types/commerce/flatpage.ts +7 -7
  106. package/types/commerce/form.ts +66 -66
  107. package/types/commerce/index.ts +12 -12
  108. package/types/commerce/landingpage.ts +7 -7
  109. package/types/commerce/misc.ts +127 -127
  110. package/types/commerce/order.ts +119 -119
  111. package/types/commerce/product.ts +109 -109
  112. package/types/commerce/widget.ts +28 -28
  113. package/types/gtm.ts +16 -16
  114. package/types/index.ts +274 -274
  115. package/types/metadata.ts +7 -7
  116. package/types/next-auth.d.ts +24 -24
  117. package/utils/app-fetch.ts +69 -69
  118. package/utils/deep-merge.js +24 -24
  119. package/utils/image-loader.ts +31 -31
  120. package/utils/index.ts +150 -150
  121. package/utils/localization.ts +29 -29
  122. package/utils/log.ts +138 -138
  123. package/utils/menu-generator.ts +27 -27
  124. package/utils/mobile-3d-iframe.ts +77 -77
  125. package/utils/server-translation.ts +57 -57
  126. package/utils/server-variables.ts +9 -9
  127. package/with-pz-config.js +94 -94
@@ -1,65 +1,65 @@
1
- import { NextFetchEvent, NextMiddleware } from 'next/server';
2
- import settings from 'settings';
3
- import { PzNextRequest } from '.';
4
- import logger from '../utils/log';
5
- import { urlLocaleMatcherRegex } from '../utils';
6
- import { getUrlPathWithLocale } from '../utils/localization';
7
- import { ROUTES } from 'routes';
8
-
9
- // This middleware is used to handle url redirections set in Omnitron
10
-
11
- const withUrlRedirection =
12
- (middleware: NextMiddleware) =>
13
- async (req: PzNextRequest, event: NextFetchEvent) => {
14
- const url = req.nextUrl.clone();
15
- const ip = req.headers.get('x-forwarded-for') ?? '';
16
- const pathnameWithoutLocale = url.pathname.replace(
17
- urlLocaleMatcherRegex,
18
- ''
19
- );
20
-
21
- if (
22
- Object.entries(ROUTES).find(([, value]) =>
23
- new RegExp(`^${value}$`).test(pathnameWithoutLocale)
24
- ) ||
25
- pathnameWithoutLocale.startsWith('/orders')
26
- ) {
27
- return middleware(req, event);
28
- }
29
-
30
- try {
31
- const request = await fetch(
32
- `${settings.commerceUrl}${pathnameWithoutLocale}${url.search}`,
33
- {
34
- redirect: 'manual',
35
- next: {
36
- revalidate: 0
37
- }
38
- }
39
- );
40
-
41
- if (request.headers.get('location')) {
42
- const location = request.headers.get('location');
43
- const redirectUrl = new URL(
44
- request.headers.get('location'),
45
- location.startsWith('http') ? '' : process.env.NEXT_PUBLIC_URL
46
- );
47
-
48
- redirectUrl.pathname = getUrlPathWithLocale(
49
- redirectUrl.pathname,
50
- req.middlewareParams.rewrites.locale
51
- );
52
-
53
- return Response.redirect(redirectUrl.toString(), request.status);
54
- }
55
- } catch (error) {
56
- logger.error('withUrlRedirection error', {
57
- error,
58
- ip
59
- });
60
- }
61
-
62
- return middleware(req, event);
63
- };
64
-
65
- export default withUrlRedirection;
1
+ import { NextFetchEvent, NextMiddleware } from 'next/server';
2
+ import settings from 'settings';
3
+ import { PzNextRequest } from '.';
4
+ import logger from '../utils/log';
5
+ import { urlLocaleMatcherRegex } from '../utils';
6
+ import { getUrlPathWithLocale } from '../utils/localization';
7
+ import { ROUTES } from 'routes';
8
+
9
+ // This middleware is used to handle url redirections set in Omnitron
10
+
11
+ const withUrlRedirection =
12
+ (middleware: NextMiddleware) =>
13
+ async (req: PzNextRequest, event: NextFetchEvent) => {
14
+ const url = req.nextUrl.clone();
15
+ const ip = req.headers.get('x-forwarded-for') ?? '';
16
+ const pathnameWithoutLocale = url.pathname.replace(
17
+ urlLocaleMatcherRegex,
18
+ ''
19
+ );
20
+
21
+ if (
22
+ Object.entries(ROUTES).find(([, value]) =>
23
+ new RegExp(`^${value}$`).test(pathnameWithoutLocale)
24
+ ) ||
25
+ pathnameWithoutLocale.startsWith('/orders')
26
+ ) {
27
+ return middleware(req, event);
28
+ }
29
+
30
+ try {
31
+ const request = await fetch(
32
+ `${settings.commerceUrl}${pathnameWithoutLocale}${url.search}`,
33
+ {
34
+ redirect: 'manual',
35
+ next: {
36
+ revalidate: 0
37
+ }
38
+ }
39
+ );
40
+
41
+ if (request.headers.get('location')) {
42
+ const location = request.headers.get('location');
43
+ const redirectUrl = new URL(
44
+ request.headers.get('location'),
45
+ location.startsWith('http') ? '' : process.env.NEXT_PUBLIC_URL
46
+ );
47
+
48
+ redirectUrl.pathname = getUrlPathWithLocale(
49
+ redirectUrl.pathname,
50
+ req.middlewareParams.rewrites.locale
51
+ );
52
+
53
+ return Response.redirect(redirectUrl.toString(), request.status);
54
+ }
55
+ } catch (error) {
56
+ logger.error('withUrlRedirection error', {
57
+ error,
58
+ ip
59
+ });
60
+ }
61
+
62
+ return middleware(req, event);
63
+ };
64
+
65
+ export default withUrlRedirection;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@akinon/next",
3
3
  "description": "Core package for Project Zero Next",
4
- "version": "1.14.0",
4
+ "version": "1.15.0",
5
5
  "private": false,
6
6
  "license": "MIT",
7
7
  "bin": {
@@ -26,7 +26,7 @@
26
26
  "@typescript-eslint/eslint-plugin": "6.7.4",
27
27
  "@typescript-eslint/parser": "6.7.4",
28
28
  "eslint": "^8.14.0",
29
- "@akinon/eslint-plugin-projectzero": "1.14.0",
29
+ "@akinon/eslint-plugin-projectzero": "1.15.0",
30
30
  "eslint-config-prettier": "8.5.0"
31
31
  }
32
32
  }
package/plugins.js CHANGED
@@ -7,5 +7,6 @@ module.exports = [
7
7
  'pz-gpay',
8
8
  'pz-otp',
9
9
  'pz-bkm',
10
+ 'pz-credit-payment',
10
11
  'pz-masterpass'
11
12
  ];
package/redux/hooks.ts CHANGED
@@ -1,7 +1,7 @@
1
- 'use client';
2
-
3
- import { TypedUseSelectorHook, useDispatch, useSelector } from 'react-redux';
4
- import type { RootState, TypedDispatch } from 'redux/store';
5
-
6
- export const useAppDispatch = () => useDispatch<TypedDispatch>();
7
- export const useAppSelector: TypedUseSelectorHook<RootState> = useSelector;
1
+ 'use client';
2
+
3
+ import { TypedUseSelectorHook, useDispatch, useSelector } from 'react-redux';
4
+ import type { RootState, TypedDispatch } from 'redux/store';
5
+
6
+ export const useAppDispatch = () => useDispatch<TypedDispatch>();
7
+ export const useAppSelector: TypedUseSelectorHook<RootState> = useSelector;
@@ -1,50 +1,50 @@
1
- 'use client';
2
-
3
- import { signOut } from 'next-auth/react';
4
- import { ROUTES } from 'routes';
5
- import type { Middleware } from '@reduxjs/toolkit';
6
- import {
7
- errorMiddleware,
8
- contextListMiddleware,
9
- preOrderMiddleware
10
- } from './checkout';
11
- import { api } from '../../data/client/api';
12
- import logger from '@akinon/next/utils/log';
13
-
14
- export const rtkQueryResponseHandler: Middleware =
15
- ({ dispatch }) =>
16
- (next) =>
17
- (action) => {
18
- return next(action);
19
- };
20
-
21
- export const rtkQueryErrorHandler: Middleware =
22
- () => (next) => async (action) => {
23
- if (action?.payload?.status === 401) {
24
- await signOut({
25
- callbackUrl: `${ROUTES.AUTH}?callbackUrl=${window.location.pathname}`
26
- });
27
- logger.debug('Session expired: 401');
28
-
29
- return;
30
- }
31
-
32
- if (action?.payload?.status === 404) {
33
- logger.warn(
34
- `404 - Not Found. Endpoint: ${action.meta.arg.endpointName}, url: ${action.meta.baseQueryMeta.request.url}`
35
- );
36
- }
37
-
38
- return next(action);
39
- };
40
-
41
- const middlewares = [
42
- api.middleware,
43
- rtkQueryResponseHandler,
44
- rtkQueryErrorHandler,
45
- errorMiddleware,
46
- preOrderMiddleware,
47
- contextListMiddleware
48
- ];
49
-
50
- export default middlewares;
1
+ 'use client';
2
+
3
+ import { signOut } from 'next-auth/react';
4
+ import { ROUTES } from 'routes';
5
+ import type { Middleware } from '@reduxjs/toolkit';
6
+ import {
7
+ errorMiddleware,
8
+ contextListMiddleware,
9
+ preOrderMiddleware
10
+ } from './checkout';
11
+ import { api } from '../../data/client/api';
12
+ import logger from '@akinon/next/utils/log';
13
+
14
+ export const rtkQueryResponseHandler: Middleware =
15
+ ({ dispatch }) =>
16
+ (next) =>
17
+ (action) => {
18
+ return next(action);
19
+ };
20
+
21
+ export const rtkQueryErrorHandler: Middleware =
22
+ () => (next) => async (action) => {
23
+ if (action?.payload?.status === 401) {
24
+ await signOut({
25
+ callbackUrl: `${ROUTES.AUTH}?callbackUrl=${window.location.pathname}`
26
+ });
27
+ logger.debug('Session expired: 401');
28
+
29
+ return;
30
+ }
31
+
32
+ if (action?.payload?.status === 404) {
33
+ logger.warn(
34
+ `404 - Not Found. Endpoint: ${action.meta.arg.endpointName}, url: ${action.meta.baseQueryMeta.request.url}`
35
+ );
36
+ }
37
+
38
+ return next(action);
39
+ };
40
+
41
+ const middlewares = [
42
+ api.middleware,
43
+ rtkQueryResponseHandler,
44
+ rtkQueryErrorHandler,
45
+ errorMiddleware,
46
+ preOrderMiddleware,
47
+ contextListMiddleware
48
+ ];
49
+
50
+ export default middlewares;
@@ -1,184 +1,184 @@
1
- 'use client';
2
-
3
- import { createSlice } from '@reduxjs/toolkit';
4
-
5
- import {
6
- Address,
7
- BankAccount,
8
- CheckoutStep,
9
- CreditCardType,
10
- DeliveryOption,
11
- InstallmentOption,
12
- PaymentChoice,
13
- PaymentOption,
14
- CheckoutCreditPaymentOption,
15
- PreOrder,
16
- RetailStore,
17
- ShippingOption
18
- } from '../../types';
19
-
20
- export interface CheckoutState {
21
- // TODO: Add types
22
- errors: any;
23
- hasGiftBox: boolean;
24
- canGuestPurchase: boolean;
25
- steps: {
26
- current: CheckoutStep;
27
- shipping: {
28
- completed: boolean;
29
- busy: boolean;
30
- };
31
- payment: {
32
- completed: boolean;
33
- busy: boolean;
34
- };
35
- };
36
- preOrder: PreOrder;
37
- addressList: Address[];
38
- deliveryOptions: DeliveryOption[];
39
- shippingOptions: ShippingOption[];
40
- paymentOptions: PaymentOption[];
41
- creditPaymentOptions: CheckoutCreditPaymentOption[];
42
- selectedCreditPaymentPk: number;
43
- paymentChoices: PaymentChoice[];
44
- cardType: CreditCardType;
45
- installmentOptions: InstallmentOption[];
46
- bankAccounts: BankAccount[];
47
- selectedBankAccountPk: number;
48
- loyaltyBalance?: string;
49
- retailStores: RetailStore[];
50
- }
51
-
52
- const initialState: CheckoutState = {
53
- errors: null,
54
- hasGiftBox: false,
55
- canGuestPurchase: false,
56
- steps: {
57
- current: CheckoutStep.Shipping,
58
- shipping: {
59
- completed: false,
60
- busy: false
61
- },
62
- payment: {
63
- completed: false,
64
- busy: false
65
- }
66
- },
67
- preOrder: null,
68
- addressList: [],
69
- deliveryOptions: [],
70
- shippingOptions: [],
71
- paymentOptions: [],
72
- creditPaymentOptions: [],
73
- selectedCreditPaymentPk: null,
74
- paymentChoices: [],
75
- cardType: null,
76
- installmentOptions: [],
77
- bankAccounts: [],
78
- selectedBankAccountPk: null,
79
- retailStores: []
80
- };
81
-
82
- const checkoutSlice = createSlice({
83
- name: 'checkout',
84
- initialState,
85
- reducers: {
86
- resetCheckoutState() {
87
- return initialState;
88
- },
89
- setErrors(state, { payload }) {
90
- state.errors = payload;
91
- },
92
- setHasGiftBox(state, { payload }) {
93
- state.hasGiftBox = payload;
94
- },
95
- setCanGuestPurchase(state, { payload }) {
96
- state.canGuestPurchase = payload;
97
- },
98
- setCurrentStep(state, { payload }) {
99
- state.steps.current = payload;
100
- },
101
- setShippingStepCompleted(state, { payload }) {
102
- state.steps.shipping.completed = payload;
103
- },
104
- setShippingStepBusy(state, { payload }) {
105
- state.steps.shipping.busy = payload;
106
- },
107
- setPaymentStepCompleted(state, { payload }) {
108
- state.steps.payment.completed = payload;
109
- },
110
- setPaymentStepBusy(state, { payload }) {
111
- state.steps.payment.busy = payload;
112
- },
113
- setPreOrder(state, { payload }) {
114
- state.preOrder = payload;
115
- },
116
- setAddressList(state, { payload }) {
117
- state.addressList = payload;
118
- },
119
- setDeliveryOptions(state, { payload }) {
120
- state.deliveryOptions = payload;
121
- },
122
- setShippingOptions(state, { payload }) {
123
- state.shippingOptions = payload;
124
- },
125
- setPaymentOptions(state, { payload }) {
126
- state.paymentOptions = payload;
127
- },
128
- setPaymentChoices(state, { payload }) {
129
- state.paymentChoices = payload;
130
- },
131
- setCreditPaymentOptions(state, { payload }) {
132
- state.creditPaymentOptions = payload;
133
- },
134
- setSelectedCreditPaymentPk(state, { payload }) {
135
- state.selectedCreditPaymentPk = payload;
136
- },
137
- setCardType(state, { payload }) {
138
- state.cardType = payload;
139
- },
140
- setInstallmentOptions(state, { payload }) {
141
- state.installmentOptions = payload;
142
- },
143
- setBankAccounts(state, { payload }) {
144
- state.bankAccounts = payload;
145
- },
146
- setSelectedBankAccountPk(state, { payload }) {
147
- state.selectedBankAccountPk = payload;
148
- },
149
- setLoyaltyBalance(state, { payload }) {
150
- state.loyaltyBalance = payload;
151
- },
152
- setRetailStores(state, { payload }) {
153
- state.retailStores = payload;
154
- }
155
- }
156
- });
157
-
158
- export const {
159
- resetCheckoutState,
160
- setErrors,
161
- setHasGiftBox,
162
- setCanGuestPurchase,
163
- setCurrentStep,
164
- setShippingStepCompleted,
165
- setShippingStepBusy,
166
- setPaymentStepCompleted,
167
- setPaymentStepBusy,
168
- setPreOrder,
169
- setAddressList,
170
- setDeliveryOptions,
171
- setShippingOptions,
172
- setPaymentOptions,
173
- setCreditPaymentOptions,
174
- setSelectedCreditPaymentPk,
175
- setPaymentChoices,
176
- setCardType,
177
- setInstallmentOptions,
178
- setBankAccounts,
179
- setSelectedBankAccountPk,
180
- setLoyaltyBalance,
181
- setRetailStores
182
- } = checkoutSlice.actions;
183
-
184
- export default checkoutSlice.reducer;
1
+ 'use client';
2
+
3
+ import { createSlice } from '@reduxjs/toolkit';
4
+
5
+ import {
6
+ Address,
7
+ BankAccount,
8
+ CheckoutStep,
9
+ CreditCardType,
10
+ DeliveryOption,
11
+ InstallmentOption,
12
+ PaymentChoice,
13
+ PaymentOption,
14
+ CheckoutCreditPaymentOption,
15
+ PreOrder,
16
+ RetailStore,
17
+ ShippingOption
18
+ } from '../../types';
19
+
20
+ export interface CheckoutState {
21
+ // TODO: Add types
22
+ errors: any;
23
+ hasGiftBox: boolean;
24
+ canGuestPurchase: boolean;
25
+ steps: {
26
+ current: CheckoutStep;
27
+ shipping: {
28
+ completed: boolean;
29
+ busy: boolean;
30
+ };
31
+ payment: {
32
+ completed: boolean;
33
+ busy: boolean;
34
+ };
35
+ };
36
+ preOrder: PreOrder;
37
+ addressList: Address[];
38
+ deliveryOptions: DeliveryOption[];
39
+ shippingOptions: ShippingOption[];
40
+ paymentOptions: PaymentOption[];
41
+ creditPaymentOptions: CheckoutCreditPaymentOption[];
42
+ selectedCreditPaymentPk: number;
43
+ paymentChoices: PaymentChoice[];
44
+ cardType: CreditCardType;
45
+ installmentOptions: InstallmentOption[];
46
+ bankAccounts: BankAccount[];
47
+ selectedBankAccountPk: number;
48
+ loyaltyBalance?: string;
49
+ retailStores: RetailStore[];
50
+ }
51
+
52
+ const initialState: CheckoutState = {
53
+ errors: null,
54
+ hasGiftBox: false,
55
+ canGuestPurchase: false,
56
+ steps: {
57
+ current: CheckoutStep.Shipping,
58
+ shipping: {
59
+ completed: false,
60
+ busy: false
61
+ },
62
+ payment: {
63
+ completed: false,
64
+ busy: false
65
+ }
66
+ },
67
+ preOrder: null,
68
+ addressList: [],
69
+ deliveryOptions: [],
70
+ shippingOptions: [],
71
+ paymentOptions: [],
72
+ creditPaymentOptions: [],
73
+ selectedCreditPaymentPk: null,
74
+ paymentChoices: [],
75
+ cardType: null,
76
+ installmentOptions: [],
77
+ bankAccounts: [],
78
+ selectedBankAccountPk: null,
79
+ retailStores: []
80
+ };
81
+
82
+ const checkoutSlice = createSlice({
83
+ name: 'checkout',
84
+ initialState,
85
+ reducers: {
86
+ resetCheckoutState() {
87
+ return initialState;
88
+ },
89
+ setErrors(state, { payload }) {
90
+ state.errors = payload;
91
+ },
92
+ setHasGiftBox(state, { payload }) {
93
+ state.hasGiftBox = payload;
94
+ },
95
+ setCanGuestPurchase(state, { payload }) {
96
+ state.canGuestPurchase = payload;
97
+ },
98
+ setCurrentStep(state, { payload }) {
99
+ state.steps.current = payload;
100
+ },
101
+ setShippingStepCompleted(state, { payload }) {
102
+ state.steps.shipping.completed = payload;
103
+ },
104
+ setShippingStepBusy(state, { payload }) {
105
+ state.steps.shipping.busy = payload;
106
+ },
107
+ setPaymentStepCompleted(state, { payload }) {
108
+ state.steps.payment.completed = payload;
109
+ },
110
+ setPaymentStepBusy(state, { payload }) {
111
+ state.steps.payment.busy = payload;
112
+ },
113
+ setPreOrder(state, { payload }) {
114
+ state.preOrder = payload;
115
+ },
116
+ setAddressList(state, { payload }) {
117
+ state.addressList = payload;
118
+ },
119
+ setDeliveryOptions(state, { payload }) {
120
+ state.deliveryOptions = payload;
121
+ },
122
+ setShippingOptions(state, { payload }) {
123
+ state.shippingOptions = payload;
124
+ },
125
+ setPaymentOptions(state, { payload }) {
126
+ state.paymentOptions = payload;
127
+ },
128
+ setPaymentChoices(state, { payload }) {
129
+ state.paymentChoices = payload;
130
+ },
131
+ setCreditPaymentOptions(state, { payload }) {
132
+ state.creditPaymentOptions = payload;
133
+ },
134
+ setSelectedCreditPaymentPk(state, { payload }) {
135
+ state.selectedCreditPaymentPk = payload;
136
+ },
137
+ setCardType(state, { payload }) {
138
+ state.cardType = payload;
139
+ },
140
+ setInstallmentOptions(state, { payload }) {
141
+ state.installmentOptions = payload;
142
+ },
143
+ setBankAccounts(state, { payload }) {
144
+ state.bankAccounts = payload;
145
+ },
146
+ setSelectedBankAccountPk(state, { payload }) {
147
+ state.selectedBankAccountPk = payload;
148
+ },
149
+ setLoyaltyBalance(state, { payload }) {
150
+ state.loyaltyBalance = payload;
151
+ },
152
+ setRetailStores(state, { payload }) {
153
+ state.retailStores = payload;
154
+ }
155
+ }
156
+ });
157
+
158
+ export const {
159
+ resetCheckoutState,
160
+ setErrors,
161
+ setHasGiftBox,
162
+ setCanGuestPurchase,
163
+ setCurrentStep,
164
+ setShippingStepCompleted,
165
+ setShippingStepBusy,
166
+ setPaymentStepCompleted,
167
+ setPaymentStepBusy,
168
+ setPreOrder,
169
+ setAddressList,
170
+ setDeliveryOptions,
171
+ setShippingOptions,
172
+ setPaymentOptions,
173
+ setCreditPaymentOptions,
174
+ setSelectedCreditPaymentPk,
175
+ setPaymentChoices,
176
+ setCardType,
177
+ setInstallmentOptions,
178
+ setBankAccounts,
179
+ setSelectedBankAccountPk,
180
+ setLoyaltyBalance,
181
+ setRetailStores
182
+ } = checkoutSlice.actions;
183
+
184
+ export default checkoutSlice.reducer;