@akinon/next 1.13.1 → 1.14.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 (133) hide show
  1. package/.editorconfig +7 -0
  2. package/.eslintrc.js +40 -40
  3. package/.prettierrc +13 -13
  4. package/CHANGELOG.md +13 -0
  5. package/api/auth.ts +231 -231
  6. package/api/cache.ts +44 -44
  7. package/api/client.ts +174 -174
  8. package/api/logout.ts +42 -42
  9. package/assets/styles/index.scss +28 -28
  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 -0
  22. package/components/button.tsx +46 -0
  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 +17 -1
  27. package/components/input.tsx +110 -0
  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/oauth-login.tsx +24 -24
  32. package/components/plugin-module.tsx +11 -8
  33. package/components/price.tsx +55 -0
  34. package/components/pz-providers.tsx +24 -24
  35. package/components/pz-root.tsx +21 -21
  36. package/components/radio.tsx +18 -18
  37. package/components/react-portal.tsx +45 -45
  38. package/components/redirect-three-d/content/index.tsx +74 -74
  39. package/components/redirect-three-d/index.tsx +17 -17
  40. package/components/selected-payment-option-view.tsx +7 -0
  41. package/components/trans.tsx +39 -39
  42. package/data/client/account.ts +208 -208
  43. package/data/client/address.ts +107 -107
  44. package/data/client/api.ts +85 -84
  45. package/data/client/b2b.ts +106 -106
  46. package/data/client/basket.ts +82 -82
  47. package/data/client/checkout.ts +516 -479
  48. package/data/client/misc.ts +101 -101
  49. package/data/client/product.ts +89 -89
  50. package/data/client/user.ts +99 -99
  51. package/data/client/wishlist.ts +118 -88
  52. package/data/server/category.ts +132 -128
  53. package/data/server/flatpage.ts +21 -21
  54. package/data/server/form.ts +22 -22
  55. package/data/server/index.ts +10 -10
  56. package/data/server/landingpage.ts +24 -24
  57. package/data/server/list.ts +67 -62
  58. package/data/server/menu.ts +35 -35
  59. package/data/server/product.ts +86 -86
  60. package/data/server/seo.ts +48 -48
  61. package/data/server/special-page.ts +47 -47
  62. package/data/server/widget.ts +27 -27
  63. package/data/urls.ts +221 -210
  64. package/hocs/client/index.ts +1 -1
  65. package/hocs/client/with-segment-defaults.tsx +25 -25
  66. package/hocs/server/index.ts +1 -1
  67. package/hocs/server/with-segment-defaults.tsx +85 -85
  68. package/hooks/index.ts +10 -10
  69. package/hooks/use-captcha.tsx +76 -76
  70. package/hooks/use-common-product-attributes.ts +36 -36
  71. package/hooks/use-debounce.ts +20 -20
  72. package/hooks/use-localization.ts +78 -78
  73. package/hooks/use-media-query.ts +36 -36
  74. package/hooks/use-mobile-iframe-handler.ts +23 -23
  75. package/hooks/use-on-click-outside.tsx +28 -28
  76. package/hooks/use-payment-options.ts +2 -1
  77. package/hooks/use-router.ts +45 -45
  78. package/hooks/use-translation.ts +14 -14
  79. package/lib/cache.ts +215 -215
  80. package/localization/index.ts +5 -5
  81. package/localization/provider.tsx +58 -58
  82. package/middlewares/currency.ts +100 -100
  83. package/middlewares/default.ts +256 -256
  84. package/middlewares/index.ts +29 -29
  85. package/middlewares/locale.ts +68 -68
  86. package/middlewares/oauth-login.ts +79 -79
  87. package/middlewares/pretty-url.ts +104 -104
  88. package/middlewares/redirection-payment.ts +160 -160
  89. package/middlewares/three-d-redirection.ts +159 -159
  90. package/middlewares/url-redirection.ts +65 -65
  91. package/package.json +2 -2
  92. package/plugins.js +2 -1
  93. package/redux/hooks.ts +7 -7
  94. package/redux/middlewares/checkout.ts +265 -260
  95. package/redux/middlewares/index.ts +50 -50
  96. package/redux/reducers/checkout.ts +184 -171
  97. package/redux/reducers/config.ts +28 -28
  98. package/redux/reducers/header.ts +59 -59
  99. package/redux/reducers/index.ts +14 -14
  100. package/redux/reducers/root.ts +61 -61
  101. package/sentry/index.ts +27 -27
  102. package/tailwind/rtl.js +137 -137
  103. package/types/commerce/account.ts +64 -64
  104. package/types/commerce/address.ts +94 -94
  105. package/types/commerce/b2b.ts +117 -117
  106. package/types/commerce/basket.ts +43 -43
  107. package/types/commerce/category.ts +114 -114
  108. package/types/commerce/checkout.ts +143 -136
  109. package/types/commerce/flatpage.ts +7 -7
  110. package/types/commerce/form.ts +66 -66
  111. package/types/commerce/index.ts +12 -12
  112. package/types/commerce/landingpage.ts +7 -7
  113. package/types/commerce/misc.ts +127 -127
  114. package/types/commerce/order.ts +119 -119
  115. package/types/commerce/product.ts +109 -109
  116. package/types/commerce/widget.ts +28 -28
  117. package/types/gtm.ts +16 -16
  118. package/types/index.ts +274 -237
  119. package/types/metadata.ts +7 -7
  120. package/types/next-auth.d.ts +24 -24
  121. package/utils/app-fetch.ts +69 -69
  122. package/utils/deep-merge.js +24 -24
  123. package/utils/generate-commerce-search-params.ts +22 -22
  124. package/utils/get-currency.ts +29 -29
  125. package/utils/image-loader.ts +31 -31
  126. package/utils/index.ts +150 -150
  127. package/utils/localization.ts +29 -29
  128. package/utils/log.ts +138 -138
  129. package/utils/menu-generator.ts +27 -27
  130. package/utils/mobile-3d-iframe.ts +77 -77
  131. package/utils/server-translation.ts +57 -57
  132. package/utils/server-variables.ts +9 -9
  133. package/with-pz-config.js +94 -94
@@ -1,88 +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 GetFavoritesResponse {
18
- count: number;
19
- results: FavoriteItem[];
20
- }
21
-
22
- interface AddFavoriteResponse {
23
- pk: number;
24
- product: number;
25
- }
26
-
27
- interface RemoteFavoriteResponse {
28
- success: boolean;
29
- }
30
-
31
- interface AddStockAlertRequest {
32
- productPk: number;
33
- email?: string;
34
- }
35
-
36
- interface AddStockAlertResponse {
37
- pk: number;
38
- product: number;
39
- }
40
-
41
- export const wishlistApi = api.injectEndpoints({
42
- endpoints: (build) => ({
43
- getFavorites: build.query<GetFavoritesResponse, GetFavoritesParams>({
44
- query: ({ limit, page }) =>
45
- buildClientRequestUrl(wishlist.getFavorites({ page, limit })),
46
- providesTags: ['Favorite']
47
- }),
48
- addFavorite: build.mutation<AddFavoriteResponse, number>({
49
- query: (productPk: number) => ({
50
- url: buildClientRequestUrl(wishlist.addFavorite, {
51
- useFormData: true
52
- }),
53
- method: 'POST',
54
- body: {
55
- product: productPk
56
- }
57
- }),
58
- invalidatesTags: ['Favorite']
59
- }),
60
- removeFavorite: build.mutation<RemoteFavoriteResponse, number>({
61
- query: (favPk: number) => ({
62
- url: buildClientRequestUrl(wishlist.removeFavorite(favPk)),
63
- method: 'DELETE'
64
- }),
65
- invalidatesTags: ['Favorite']
66
- }),
67
- addStockAlert: build.mutation<AddStockAlertResponse, AddStockAlertRequest>({
68
- query: ({ productPk, email }) => ({
69
- url: buildClientRequestUrl(wishlist.addStockAlert, {
70
- useFormData: true
71
- }),
72
- method: 'POST',
73
- body: {
74
- product: productPk,
75
- ...(email ? { email } : {})
76
- }
77
- })
78
- })
79
- }),
80
- overrideExisting: true
81
- });
82
-
83
- export const {
84
- useGetFavoritesQuery,
85
- useAddFavoriteMutation,
86
- useRemoveFavoriteMutation,
87
- useAddStockAlertMutation
88
- } = 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;
@@ -1,128 +1,132 @@
1
- import { GetCategoryResponse } from '../../types';
2
- import { generateCommerceSearchParams } from '../../utils';
3
- import appFetch, { FetchResponseType } from '../../utils/app-fetch';
4
- import { category, product } from '../urls';
5
- import { Cache, CacheKey } from '../../lib/cache';
6
- import { parse } from 'lossless-json';
7
- import logger from '../../utils/log';
8
-
9
- function getCategoryDataHandler(
10
- pk: number,
11
- searchParams?: URLSearchParams,
12
- headers?: Record<string, string>
13
- ) {
14
- return async function () {
15
- const params = generateCommerceSearchParams(searchParams);
16
-
17
- const rawData = await appFetch<string>(
18
- `${category.getCategoryByPk(pk)}${params ? params : ''}`,
19
- {
20
- headers: {
21
- Accept: 'application/json',
22
- 'Content-Type': 'application/json',
23
- ...(headers ?? {})
24
- }
25
- },
26
- FetchResponseType.TEXT
27
- );
28
-
29
- let data: GetCategoryResponse;
30
-
31
- try {
32
- const numberValueParser = (value) => {
33
- return String(value);
34
- };
35
-
36
- data = parse(
37
- rawData,
38
- undefined,
39
- numberValueParser
40
- ) as GetCategoryResponse;
41
- } catch (error) {
42
- logger.error('Error while parsing category data', {
43
- handler: 'getCategoryDataHandler',
44
- error,
45
- rawData
46
- });
47
- }
48
-
49
- const menuItemModel = data?.category?.menuitemmodel;
50
-
51
- const breadcrumbData = await appFetch<any>(
52
- product.breadcrumbUrl(menuItemModel),
53
- {
54
- headers: {
55
- Accept: 'application/json',
56
- 'Content-Type': 'application/json'
57
- }
58
- }
59
- );
60
-
61
- return { data, breadcrumbData: breadcrumbData?.menu };
62
- };
63
- }
64
-
65
- export const getCategoryData = ({
66
- pk,
67
- searchParams,
68
- headers
69
- }: {
70
- pk: number;
71
- searchParams?: URLSearchParams;
72
- headers?: Record<string, string>;
73
- }) => {
74
- return Cache.wrap(
75
- CacheKey.Category(pk, searchParams, headers),
76
- getCategoryDataHandler(pk, searchParams, headers),
77
- {
78
- expire: 300
79
- }
80
- );
81
- };
82
-
83
- function getCategoryBySlugDataHandler(slug: string) {
84
- return async function () {
85
- const rawData = await appFetch<string>(
86
- category.getCategoryBySlug(slug),
87
- {
88
- headers: {
89
- Accept: 'application/json',
90
- 'Content-Type': 'application/json'
91
- }
92
- },
93
- FetchResponseType.TEXT
94
- );
95
-
96
- let data: GetCategoryResponse;
97
-
98
- try {
99
- const numberValueParser = (value) => {
100
- return String(value);
101
- };
102
-
103
- data = parse(
104
- rawData,
105
- undefined,
106
- numberValueParser
107
- ) as GetCategoryResponse;
108
- } catch (error) {
109
- logger.error('Error while parsing category data', {
110
- handler: 'getCategoryBySlugDataHandler',
111
- error,
112
- rawData
113
- });
114
- }
115
-
116
- return data;
117
- };
118
- }
119
-
120
- export const getCategoryBySlugData = async ({ slug }) => {
121
- return Cache.wrap(
122
- CacheKey.CategorySlug(slug),
123
- getCategoryBySlugDataHandler(slug),
124
- {
125
- expire: 300
126
- }
127
- );
128
- };
1
+ import { GetCategoryResponse } from '../../types';
2
+ import { generateCommerceSearchParams } from '../../utils';
3
+ import appFetch, { FetchResponseType } from '../../utils/app-fetch';
4
+ import { category, product } from '../urls';
5
+ import { Cache, CacheKey } from '../../lib/cache';
6
+ import { parse } from 'lossless-json';
7
+ import logger from '../../utils/log';
8
+
9
+ function getCategoryDataHandler(
10
+ pk: number,
11
+ searchParams?: URLSearchParams,
12
+ headers?: Record<string, string>
13
+ ) {
14
+ return async function () {
15
+ const params = generateCommerceSearchParams(searchParams);
16
+
17
+ const rawData = await appFetch<string>(
18
+ `${category.getCategoryByPk(pk)}${params ? params : ''}`,
19
+ {
20
+ headers: {
21
+ Accept: 'application/json',
22
+ 'Content-Type': 'application/json',
23
+ ...(headers ?? {})
24
+ }
25
+ },
26
+ FetchResponseType.TEXT
27
+ );
28
+
29
+ let data: GetCategoryResponse;
30
+
31
+ try {
32
+ const numberValueParser = (value) => {
33
+ return String(value);
34
+ };
35
+
36
+ data = parse(
37
+ rawData,
38
+ undefined,
39
+ numberValueParser
40
+ ) as GetCategoryResponse;
41
+ } catch (error) {
42
+ logger.error('Error while parsing category data', {
43
+ handler: 'getCategoryDataHandler',
44
+ error,
45
+ rawData: rawData.startsWith('<!DOCTYPE html>')
46
+ ? `${rawData.substring(0, 50)}...`
47
+ : rawData
48
+ });
49
+ }
50
+
51
+ const menuItemModel = data?.category?.menuitemmodel;
52
+
53
+ const breadcrumbData = await appFetch<any>(
54
+ product.breadcrumbUrl(menuItemModel),
55
+ {
56
+ headers: {
57
+ Accept: 'application/json',
58
+ 'Content-Type': 'application/json'
59
+ }
60
+ }
61
+ );
62
+
63
+ return { data, breadcrumbData: breadcrumbData?.menu };
64
+ };
65
+ }
66
+
67
+ export const getCategoryData = ({
68
+ pk,
69
+ searchParams,
70
+ headers
71
+ }: {
72
+ pk: number;
73
+ searchParams?: URLSearchParams;
74
+ headers?: Record<string, string>;
75
+ }) => {
76
+ return Cache.wrap(
77
+ CacheKey.Category(pk, searchParams, headers),
78
+ getCategoryDataHandler(pk, searchParams, headers),
79
+ {
80
+ expire: 300
81
+ }
82
+ );
83
+ };
84
+
85
+ function getCategoryBySlugDataHandler(slug: string) {
86
+ return async function () {
87
+ const rawData = await appFetch<string>(
88
+ category.getCategoryBySlug(slug),
89
+ {
90
+ headers: {
91
+ Accept: 'application/json',
92
+ 'Content-Type': 'application/json'
93
+ }
94
+ },
95
+ FetchResponseType.TEXT
96
+ );
97
+
98
+ let data: GetCategoryResponse;
99
+
100
+ try {
101
+ const numberValueParser = (value) => {
102
+ return String(value);
103
+ };
104
+
105
+ data = parse(
106
+ rawData,
107
+ undefined,
108
+ numberValueParser
109
+ ) as GetCategoryResponse;
110
+ } catch (error) {
111
+ logger.error('Error while parsing category data', {
112
+ handler: 'getCategoryBySlugDataHandler',
113
+ error,
114
+ rawData: rawData.startsWith('<!DOCTYPE html>')
115
+ ? `${rawData.substring(0, 50)}...`
116
+ : rawData
117
+ });
118
+ }
119
+
120
+ return data;
121
+ };
122
+ }
123
+
124
+ export const getCategoryBySlugData = async ({ slug }) => {
125
+ return Cache.wrap(
126
+ CacheKey.CategorySlug(slug),
127
+ getCategoryBySlugDataHandler(slug),
128
+ {
129
+ expire: 300
130
+ }
131
+ );
132
+ };
@@ -1,21 +1,21 @@
1
- import { flatpage } from '../urls';
2
- import { FlatPage } from '../../types';
3
- import appFetch from '../../utils/app-fetch';
4
- import { Cache, CacheKey } from '../../lib/cache';
5
-
6
- const getFlatPageDataHandler = (pk: number) => {
7
- return async function () {
8
- const data = await appFetch<FlatPage>(flatpage.getFlatPageByPk(pk), {
9
- headers: {
10
- Accept: 'application/json',
11
- 'Content-Type': 'application/json'
12
- }
13
- });
14
-
15
- return data;
16
- };
17
- };
18
-
19
- export const getFlatPageData = ({ pk }: { pk: number }) => {
20
- return Cache.wrap(CacheKey.FlatPage(pk), getFlatPageDataHandler(pk));
21
- };
1
+ import { flatpage } from '../urls';
2
+ import { FlatPage } from '../../types';
3
+ import appFetch from '../../utils/app-fetch';
4
+ import { Cache, CacheKey } from '../../lib/cache';
5
+
6
+ const getFlatPageDataHandler = (pk: number) => {
7
+ return async function () {
8
+ const data = await appFetch<FlatPage>(flatpage.getFlatPageByPk(pk), {
9
+ headers: {
10
+ Accept: 'application/json',
11
+ 'Content-Type': 'application/json'
12
+ }
13
+ });
14
+
15
+ return data;
16
+ };
17
+ };
18
+
19
+ export const getFlatPageData = ({ pk }: { pk: number }) => {
20
+ return Cache.wrap(CacheKey.FlatPage(pk), getFlatPageDataHandler(pk));
21
+ };
@@ -1,22 +1,22 @@
1
- import { Cache, CacheKey } from "../../lib/cache";
2
- import { FormType } from "../../types/commerce/form";
3
-
4
- import appFetch from "../../utils/app-fetch";
5
- import { form } from "../urls";
6
-
7
- const getFormDataHandler = (pk: number) => {
8
- return async function () {
9
- const data = await appFetch<FormType>(form.getForm(pk), {
10
- headers: {
11
- Accept: 'application/json',
12
- 'Content-Type': 'application/json'
13
- }
14
- });
15
-
16
- return data;
17
- };
18
- };
19
-
20
- export const getFormData = ({ pk }: { pk: number }) => {
21
- return Cache.wrap(CacheKey.Form(pk), getFormDataHandler(pk));
22
- };
1
+ import { Cache, CacheKey } from "../../lib/cache";
2
+ import { FormType } from "../../types/commerce/form";
3
+
4
+ import appFetch from "../../utils/app-fetch";
5
+ import { form } from "../urls";
6
+
7
+ const getFormDataHandler = (pk: number) => {
8
+ return async function () {
9
+ const data = await appFetch<FormType>(form.getForm(pk), {
10
+ headers: {
11
+ Accept: 'application/json',
12
+ 'Content-Type': 'application/json'
13
+ }
14
+ });
15
+
16
+ return data;
17
+ };
18
+ };
19
+
20
+ export const getFormData = ({ pk }: { pk: number }) => {
21
+ return Cache.wrap(CacheKey.Form(pk), getFormDataHandler(pk));
22
+ };
@@ -1,10 +1,10 @@
1
- export * from './list';
2
- export * from './category';
3
- export * from './product';
4
- export * from './flatpage';
5
- export * from './special-page';
6
- export * from './widget';
7
- export * from './seo';
8
- export * from './menu';
9
- export * from './landingpage';
10
- export * from './form';
1
+ export * from './list';
2
+ export * from './category';
3
+ export * from './product';
4
+ export * from './flatpage';
5
+ export * from './special-page';
6
+ export * from './widget';
7
+ export * from './seo';
8
+ export * from './menu';
9
+ export * from './landingpage';
10
+ export * from './form';
@@ -1,24 +1,24 @@
1
- import { landingpage } from '../urls';
2
- import { LandingPage } from '../../types/commerce/landingpage';
3
- import appFetch from '../../utils/app-fetch';
4
- import { Cache, CacheKey } from '../../lib/cache';
5
-
6
- const getLandingPageHandler = (pk: number) => {
7
- return async function () {
8
- const data = await appFetch<LandingPage>(
9
- landingpage.getLandingPageByPk(pk),
10
- {
11
- headers: {
12
- Accept: 'application/json',
13
- 'Content-Type': 'application/json'
14
- }
15
- }
16
- );
17
-
18
- return data;
19
- };
20
- };
21
-
22
- export const getLandingPageData = ({ pk }: { pk: number }) => {
23
- return Cache.wrap(CacheKey.LandingPage(pk), getLandingPageHandler(pk));
24
- };
1
+ import { landingpage } from '../urls';
2
+ import { LandingPage } from '../../types/commerce/landingpage';
3
+ import appFetch from '../../utils/app-fetch';
4
+ import { Cache, CacheKey } from '../../lib/cache';
5
+
6
+ const getLandingPageHandler = (pk: number) => {
7
+ return async function () {
8
+ const data = await appFetch<LandingPage>(
9
+ landingpage.getLandingPageByPk(pk),
10
+ {
11
+ headers: {
12
+ Accept: 'application/json',
13
+ 'Content-Type': 'application/json'
14
+ }
15
+ }
16
+ );
17
+
18
+ return data;
19
+ };
20
+ };
21
+
22
+ export const getLandingPageData = ({ pk }: { pk: number }) => {
23
+ return Cache.wrap(CacheKey.LandingPage(pk), getLandingPageHandler(pk));
24
+ };