@akinon/next 1.14.0 → 1.14.1

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 (119) hide show
  1. package/.eslintrc.js +40 -40
  2. package/.prettierrc +13 -13
  3. package/CHANGELOG.md +6 -0
  4. package/api/auth.ts +231 -231
  5. package/api/cache.ts +44 -44
  6. package/api/client.ts +174 -174
  7. package/api/logout.ts +42 -42
  8. package/bin/pz-check-dependencies.js +98 -98
  9. package/bin/pz-install-plugins.js +33 -33
  10. package/bin/pz-install-theme.js +58 -58
  11. package/bin/pz-postbuild.js +1 -1
  12. package/bin/pz-postdev.js +1 -1
  13. package/bin/pz-postinstall.js +6 -6
  14. package/bin/pz-poststart.js +1 -1
  15. package/bin/pz-prebuild.js +4 -4
  16. package/bin/pz-predev.js +4 -4
  17. package/bin/pz-prestart.js +1 -1
  18. package/bin/run-script.js +44 -44
  19. package/components/accordion.tsx +52 -52
  20. package/components/button.tsx +46 -46
  21. package/components/client-root.tsx +19 -19
  22. package/components/icon.tsx +18 -18
  23. package/components/image.tsx +133 -133
  24. package/components/index.ts +17 -17
  25. package/components/input.tsx +110 -110
  26. package/components/lazy-component.tsx +33 -33
  27. package/components/loader-spinner.tsx +23 -23
  28. package/components/mobile-app-toggler.tsx +26 -26
  29. package/components/oauth-login.tsx +24 -24
  30. package/components/price.tsx +55 -55
  31. package/components/pz-providers.tsx +24 -24
  32. package/components/pz-root.tsx +21 -21
  33. package/components/radio.tsx +18 -18
  34. package/components/react-portal.tsx +45 -45
  35. package/components/redirect-three-d/content/index.tsx +74 -74
  36. package/components/redirect-three-d/index.tsx +17 -17
  37. package/components/trans.tsx +39 -39
  38. package/data/client/account.ts +208 -208
  39. package/data/client/api.ts +85 -85
  40. package/data/client/basket.ts +82 -82
  41. package/data/client/misc.ts +101 -101
  42. package/data/client/product.ts +89 -89
  43. package/data/client/user.ts +99 -99
  44. package/data/client/wishlist.ts +118 -118
  45. package/data/server/category.ts +132 -132
  46. package/data/server/flatpage.ts +21 -21
  47. package/data/server/form.ts +22 -22
  48. package/data/server/index.ts +10 -10
  49. package/data/server/landingpage.ts +24 -24
  50. package/data/server/list.ts +67 -67
  51. package/data/server/menu.ts +35 -35
  52. package/data/server/product.ts +86 -86
  53. package/data/server/seo.ts +48 -48
  54. package/data/server/special-page.ts +47 -47
  55. package/data/server/widget.ts +27 -27
  56. package/data/urls.ts +221 -221
  57. package/hocs/client/index.ts +1 -1
  58. package/hocs/client/with-segment-defaults.tsx +25 -25
  59. package/hocs/server/index.ts +1 -1
  60. package/hocs/server/with-segment-defaults.tsx +85 -85
  61. package/hooks/index.ts +10 -10
  62. package/hooks/use-captcha.tsx +76 -76
  63. package/hooks/use-common-product-attributes.ts +36 -36
  64. package/hooks/use-debounce.ts +20 -20
  65. package/hooks/use-localization.ts +78 -78
  66. package/hooks/use-media-query.ts +36 -36
  67. package/hooks/use-mobile-iframe-handler.ts +23 -23
  68. package/hooks/use-on-click-outside.tsx +28 -28
  69. package/hooks/use-router.ts +45 -45
  70. package/hooks/use-translation.ts +14 -14
  71. package/lib/cache.ts +215 -215
  72. package/localization/index.ts +5 -5
  73. package/localization/provider.tsx +58 -58
  74. package/middlewares/currency.ts +100 -100
  75. package/middlewares/default.ts +256 -256
  76. package/middlewares/index.ts +29 -29
  77. package/middlewares/locale.ts +68 -68
  78. package/middlewares/oauth-login.ts +79 -79
  79. package/middlewares/pretty-url.ts +104 -104
  80. package/middlewares/redirection-payment.ts +160 -160
  81. package/middlewares/three-d-redirection.ts +159 -159
  82. package/middlewares/url-redirection.ts +65 -65
  83. package/package.json +2 -2
  84. package/redux/hooks.ts +7 -7
  85. package/redux/middlewares/index.ts +50 -50
  86. package/redux/reducers/checkout.ts +184 -184
  87. package/redux/reducers/config.ts +28 -28
  88. package/redux/reducers/header.ts +59 -59
  89. package/redux/reducers/root.ts +61 -61
  90. package/sentry/index.ts +27 -27
  91. package/tailwind/rtl.js +137 -137
  92. package/types/commerce/account.ts +64 -64
  93. package/types/commerce/address.ts +94 -94
  94. package/types/commerce/basket.ts +43 -43
  95. package/types/commerce/category.ts +114 -114
  96. package/types/commerce/checkout.ts +143 -143
  97. package/types/commerce/flatpage.ts +7 -7
  98. package/types/commerce/form.ts +66 -66
  99. package/types/commerce/index.ts +12 -12
  100. package/types/commerce/landingpage.ts +7 -7
  101. package/types/commerce/misc.ts +127 -127
  102. package/types/commerce/order.ts +119 -119
  103. package/types/commerce/product.ts +109 -109
  104. package/types/commerce/widget.ts +28 -28
  105. package/types/gtm.ts +16 -16
  106. package/types/index.ts +274 -274
  107. package/types/metadata.ts +7 -7
  108. package/types/next-auth.d.ts +24 -24
  109. package/utils/app-fetch.ts +69 -69
  110. package/utils/deep-merge.js +24 -24
  111. package/utils/image-loader.ts +31 -31
  112. package/utils/index.ts +150 -150
  113. package/utils/localization.ts +29 -29
  114. package/utils/log.ts +138 -138
  115. package/utils/menu-generator.ts +27 -27
  116. package/utils/mobile-3d-iframe.ts +77 -77
  117. package/utils/server-translation.ts +57 -57
  118. package/utils/server-variables.ts +9 -9
  119. 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;