@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,99 +1,99 @@
1
- import { api } from './api';
2
- import { user } from '../urls';
3
- import { ForgotPasswordFormType } from '../../types';
4
- import { buildClientRequestUrl } from '../../utils';
5
-
6
- interface GetCaptchaResponse {
7
- siteKey: string;
8
- csrfToken: string;
9
- }
10
-
11
- interface ValidateCaptchaRequest {
12
- captchaResponse: string;
13
- csrfToken: string;
14
- }
15
-
16
- interface ValidateCaptchaResponse {
17
- success: boolean;
18
- }
19
-
20
- const userApi = api.injectEndpoints({
21
- endpoints: (build) => ({
22
- getCaptcha: build.query<GetCaptchaResponse, void>({
23
- query: () => buildClientRequestUrl(user.captcha),
24
- transformResponse: (response: { html: string }) => {
25
- const siteKeyMatch = response.html.match(/sitekey=["|']\w+/gi);
26
- const csrfTokenMatch = response.html.match(
27
- /name=['|"]csrfmiddlewaretoken['|"] value=['|"]\w+/gi
28
- );
29
- const siteKey = siteKeyMatch?.[0].replace(/sitekey=["|']/, '') || '';
30
- const csrfToken =
31
- csrfTokenMatch?.[0].replace(
32
- /name=['|"]csrfmiddlewaretoken['|"] value=['|"]/gi,
33
- ''
34
- ) || '';
35
-
36
- return {
37
- siteKey,
38
- csrfToken
39
- };
40
- }
41
- }),
42
- validateCaptcha: build.mutation<
43
- ValidateCaptchaResponse,
44
- ValidateCaptchaRequest
45
- >({
46
- query: (body) => ({
47
- url: buildClientRequestUrl(user.captcha, {
48
- useFormData: true
49
- }),
50
- method: 'POST',
51
- body: {
52
- 'g-recaptcha-response': body.captchaResponse
53
- }
54
- }),
55
- transformResponse: (response: { location: string }) => ({
56
- success: response.location === '/'
57
- })
58
- }),
59
- logout: build.mutation<string, void>({
60
- query: () => ({
61
- url: '/api/logout',
62
- method: 'POST'
63
- })
64
- }),
65
- forgotPassword: build.mutation<void, ForgotPasswordFormType>({
66
- query: (body) => ({
67
- url: buildClientRequestUrl(user.forgotPassword, {
68
- contentType: 'application/json'
69
- }),
70
- method: 'POST',
71
- body
72
- })
73
- }),
74
- changeEmailVerification: build.query<void, string>({
75
- query: (token) => ({
76
- url: buildClientRequestUrl(user.changeEmailVerification(token), {
77
- contentType: 'application/json'
78
- })
79
- })
80
- }),
81
- confirmEmailVerification: build.query<void, string>({
82
- query: (token) => ({
83
- url: buildClientRequestUrl(user.confirmEmailVerification(token), {
84
- contentType: 'application/json'
85
- })
86
- })
87
- })
88
- }),
89
- overrideExisting: false
90
- });
91
-
92
- export const {
93
- useGetCaptchaQuery,
94
- useChangeEmailVerificationQuery,
95
- useConfirmEmailVerificationQuery,
96
- useValidateCaptchaMutation,
97
- useLogoutMutation,
98
- useForgotPasswordMutation
99
- } = userApi;
1
+ import { api } from './api';
2
+ import { user } from '../urls';
3
+ import { ForgotPasswordFormType } from '../../types';
4
+ import { buildClientRequestUrl } from '../../utils';
5
+
6
+ interface GetCaptchaResponse {
7
+ siteKey: string;
8
+ csrfToken: string;
9
+ }
10
+
11
+ interface ValidateCaptchaRequest {
12
+ captchaResponse: string;
13
+ csrfToken: string;
14
+ }
15
+
16
+ interface ValidateCaptchaResponse {
17
+ success: boolean;
18
+ }
19
+
20
+ const userApi = api.injectEndpoints({
21
+ endpoints: (build) => ({
22
+ getCaptcha: build.query<GetCaptchaResponse, void>({
23
+ query: () => buildClientRequestUrl(user.captcha),
24
+ transformResponse: (response: { html: string }) => {
25
+ const siteKeyMatch = response.html.match(/sitekey=["|']\w+/gi);
26
+ const csrfTokenMatch = response.html.match(
27
+ /name=['|"]csrfmiddlewaretoken['|"] value=['|"]\w+/gi
28
+ );
29
+ const siteKey = siteKeyMatch?.[0].replace(/sitekey=["|']/, '') || '';
30
+ const csrfToken =
31
+ csrfTokenMatch?.[0].replace(
32
+ /name=['|"]csrfmiddlewaretoken['|"] value=['|"]/gi,
33
+ ''
34
+ ) || '';
35
+
36
+ return {
37
+ siteKey,
38
+ csrfToken
39
+ };
40
+ }
41
+ }),
42
+ validateCaptcha: build.mutation<
43
+ ValidateCaptchaResponse,
44
+ ValidateCaptchaRequest
45
+ >({
46
+ query: (body) => ({
47
+ url: buildClientRequestUrl(user.captcha, {
48
+ useFormData: true
49
+ }),
50
+ method: 'POST',
51
+ body: {
52
+ 'g-recaptcha-response': body.captchaResponse
53
+ }
54
+ }),
55
+ transformResponse: (response: { location: string }) => ({
56
+ success: response.location === '/'
57
+ })
58
+ }),
59
+ logout: build.mutation<string, void>({
60
+ query: () => ({
61
+ url: '/api/logout',
62
+ method: 'POST'
63
+ })
64
+ }),
65
+ forgotPassword: build.mutation<void, ForgotPasswordFormType>({
66
+ query: (body) => ({
67
+ url: buildClientRequestUrl(user.forgotPassword, {
68
+ contentType: 'application/json'
69
+ }),
70
+ method: 'POST',
71
+ body
72
+ })
73
+ }),
74
+ changeEmailVerification: build.query<void, string>({
75
+ query: (token) => ({
76
+ url: buildClientRequestUrl(user.changeEmailVerification(token), {
77
+ contentType: 'application/json'
78
+ })
79
+ })
80
+ }),
81
+ confirmEmailVerification: build.query<void, string>({
82
+ query: (token) => ({
83
+ url: buildClientRequestUrl(user.confirmEmailVerification(token), {
84
+ contentType: 'application/json'
85
+ })
86
+ })
87
+ })
88
+ }),
89
+ overrideExisting: false
90
+ });
91
+
92
+ export const {
93
+ useGetCaptchaQuery,
94
+ useChangeEmailVerificationQuery,
95
+ useConfirmEmailVerificationQuery,
96
+ useValidateCaptchaMutation,
97
+ useLogoutMutation,
98
+ useForgotPasswordMutation
99
+ } = userApi;
@@ -1,118 +1,118 @@
1
- import { FavoriteItem } from '../../types';
2
- import { buildClientRequestUrl } from '../../utils';
3
- import { api } from './api';
4
- import { wishlist } from '../urls';
5
-
6
- export type AddProductRequest = {
7
- product: number;
8
- quantity: number;
9
- attributes: any;
10
- };
11
-
12
- interface GetFavoritesParams {
13
- limit?: number;
14
- page?: number;
15
- }
16
-
17
- interface GetStockParams {
18
- limit?: number;
19
- page?: number;
20
- }
21
-
22
- interface GetFavoritesResponse {
23
- count: number;
24
- results: FavoriteItem[];
25
- }
26
-
27
- interface AddFavoriteResponse {
28
- pk: number;
29
- product: number;
30
- }
31
-
32
- interface RemoteFavoriteResponse {
33
- success: boolean;
34
- }
35
-
36
- interface AddStockAlertRequest {
37
- productPk: number;
38
- email?: string;
39
- }
40
-
41
- interface AddStockAlertResponse {
42
- pk: number;
43
- product: number;
44
- }
45
-
46
- interface GetStockAlertsResponse {
47
- count: number;
48
- results: FavoriteItem[];
49
- next?: string | null;
50
- previous?: string | null;
51
- }
52
-
53
- interface DeleteStockAlertResponse {
54
- success: boolean;
55
- }
56
-
57
- export const wishlistApi = api.injectEndpoints({
58
- endpoints: (build) => ({
59
- getFavorites: build.query<GetFavoritesResponse, GetFavoritesParams>({
60
- query: ({ limit, page }) =>
61
- buildClientRequestUrl(wishlist.getFavorites({ page, limit })),
62
- providesTags: ['Favorite']
63
- }),
64
- addFavorite: build.mutation<AddFavoriteResponse, number>({
65
- query: (productPk: number) => ({
66
- url: buildClientRequestUrl(wishlist.addFavorite, {
67
- useFormData: true
68
- }),
69
- method: 'POST',
70
- body: {
71
- product: productPk
72
- }
73
- }),
74
- invalidatesTags: ['Favorite']
75
- }),
76
- removeFavorite: build.mutation<RemoteFavoriteResponse, number>({
77
- query: (favPk: number) => ({
78
- url: buildClientRequestUrl(wishlist.removeFavorite(favPk)),
79
- method: 'DELETE'
80
- }),
81
- invalidatesTags: ['Favorite']
82
- }),
83
- addStockAlert: build.mutation<AddStockAlertResponse, AddStockAlertRequest>({
84
- query: ({ productPk, email }) => ({
85
- url: buildClientRequestUrl(wishlist.addStockAlert, {
86
- useFormData: true
87
- }),
88
- method: 'POST',
89
- body: {
90
- product: productPk,
91
- ...(email ? { email } : {})
92
- }
93
- })
94
- }),
95
- getStockAlerts: build.query<GetStockAlertsResponse, GetStockParams>({
96
- query: ({ page, limit }) =>
97
- buildClientRequestUrl(wishlist.getStockAlerts({ page, limit })),
98
- providesTags: ['StockAlert']
99
- }),
100
- deleteStockAlert: build.mutation<DeleteStockAlertResponse, number>({
101
- query: (alertPk: number) => ({
102
- url: buildClientRequestUrl(wishlist.deleteStockAlert(alertPk)),
103
- method: 'DELETE'
104
- }),
105
- invalidatesTags: ['StockAlert']
106
- })
107
- }),
108
- overrideExisting: true
109
- });
110
-
111
- export const {
112
- useGetFavoritesQuery,
113
- useAddFavoriteMutation,
114
- useRemoveFavoriteMutation,
115
- useAddStockAlertMutation,
116
- useGetStockAlertsQuery,
117
- useDeleteStockAlertMutation
118
- } = wishlistApi;
1
+ import { FavoriteItem } from '../../types';
2
+ import { buildClientRequestUrl } from '../../utils';
3
+ import { api } from './api';
4
+ import { wishlist } from '../urls';
5
+
6
+ export type AddProductRequest = {
7
+ product: number;
8
+ quantity: number;
9
+ attributes: any;
10
+ };
11
+
12
+ interface GetFavoritesParams {
13
+ limit?: number;
14
+ page?: number;
15
+ }
16
+
17
+ interface GetStockParams {
18
+ limit?: number;
19
+ page?: number;
20
+ }
21
+
22
+ interface GetFavoritesResponse {
23
+ count: number;
24
+ results: FavoriteItem[];
25
+ }
26
+
27
+ interface AddFavoriteResponse {
28
+ pk: number;
29
+ product: number;
30
+ }
31
+
32
+ interface RemoteFavoriteResponse {
33
+ success: boolean;
34
+ }
35
+
36
+ interface AddStockAlertRequest {
37
+ productPk: number;
38
+ email?: string;
39
+ }
40
+
41
+ interface AddStockAlertResponse {
42
+ pk: number;
43
+ product: number;
44
+ }
45
+
46
+ interface GetStockAlertsResponse {
47
+ count: number;
48
+ results: FavoriteItem[];
49
+ next?: string | null;
50
+ previous?: string | null;
51
+ }
52
+
53
+ interface DeleteStockAlertResponse {
54
+ success: boolean;
55
+ }
56
+
57
+ export const wishlistApi = api.injectEndpoints({
58
+ endpoints: (build) => ({
59
+ getFavorites: build.query<GetFavoritesResponse, GetFavoritesParams>({
60
+ query: ({ limit, page }) =>
61
+ buildClientRequestUrl(wishlist.getFavorites({ page, limit })),
62
+ providesTags: ['Favorite']
63
+ }),
64
+ addFavorite: build.mutation<AddFavoriteResponse, number>({
65
+ query: (productPk: number) => ({
66
+ url: buildClientRequestUrl(wishlist.addFavorite, {
67
+ useFormData: true
68
+ }),
69
+ method: 'POST',
70
+ body: {
71
+ product: productPk
72
+ }
73
+ }),
74
+ invalidatesTags: ['Favorite']
75
+ }),
76
+ removeFavorite: build.mutation<RemoteFavoriteResponse, number>({
77
+ query: (favPk: number) => ({
78
+ url: buildClientRequestUrl(wishlist.removeFavorite(favPk)),
79
+ method: 'DELETE'
80
+ }),
81
+ invalidatesTags: ['Favorite']
82
+ }),
83
+ addStockAlert: build.mutation<AddStockAlertResponse, AddStockAlertRequest>({
84
+ query: ({ productPk, email }) => ({
85
+ url: buildClientRequestUrl(wishlist.addStockAlert, {
86
+ useFormData: true
87
+ }),
88
+ method: 'POST',
89
+ body: {
90
+ product: productPk,
91
+ ...(email ? { email } : {})
92
+ }
93
+ })
94
+ }),
95
+ getStockAlerts: build.query<GetStockAlertsResponse, GetStockParams>({
96
+ query: ({ page, limit }) =>
97
+ buildClientRequestUrl(wishlist.getStockAlerts({ page, limit })),
98
+ providesTags: ['StockAlert']
99
+ }),
100
+ deleteStockAlert: build.mutation<DeleteStockAlertResponse, number>({
101
+ query: (alertPk: number) => ({
102
+ url: buildClientRequestUrl(wishlist.deleteStockAlert(alertPk)),
103
+ method: 'DELETE'
104
+ }),
105
+ invalidatesTags: ['StockAlert']
106
+ })
107
+ }),
108
+ overrideExisting: true
109
+ });
110
+
111
+ export const {
112
+ useGetFavoritesQuery,
113
+ useAddFavoriteMutation,
114
+ useRemoveFavoriteMutation,
115
+ useAddStockAlertMutation,
116
+ useGetStockAlertsQuery,
117
+ useDeleteStockAlertMutation
118
+ } = wishlistApi;