@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,132 +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: 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
+ 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
+ };
@@ -1,67 +1,67 @@
1
- import { Cache, CacheKey } from '../../lib/cache';
2
- import { category } from '../urls';
3
- import { GetCategoryResponse } from '../../types';
4
- import { generateCommerceSearchParams } from '../../utils';
5
- import appFetch, { FetchResponseType } from '../../utils/app-fetch';
6
- import { parse } from 'lossless-json';
7
- import logger from '../../utils/log';
8
-
9
- const getListDataHandler = (
10
- searchParams: URLSearchParams,
11
- headers?: Record<string, string>
12
- ) => {
13
- return async function () {
14
- const params = generateCommerceSearchParams(searchParams);
15
-
16
- const rawData = await appFetch<string>(
17
- `${category.list}${params}`,
18
- {
19
- headers: {
20
- Accept: 'application/json',
21
- 'Content-Type': 'application/json',
22
- ...(headers ?? {})
23
- }
24
- },
25
- FetchResponseType.TEXT
26
- );
27
-
28
- let data: GetCategoryResponse;
29
-
30
- try {
31
- const numberValueParser = (value) => {
32
- return String(value);
33
- };
34
-
35
- data = parse(
36
- rawData,
37
- undefined,
38
- numberValueParser
39
- ) as GetCategoryResponse;
40
- } catch (error) {
41
- logger.error('Error while parsing list data', {
42
- error,
43
- rawData: rawData.startsWith('<!DOCTYPE html>')
44
- ? `${rawData.substring(0, 50)}...`
45
- : rawData
46
- });
47
- }
48
-
49
- return data;
50
- };
51
- };
52
-
53
- export const getListData = async ({
54
- searchParams,
55
- headers
56
- }: {
57
- searchParams: URLSearchParams;
58
- headers?: Record<string, string>;
59
- }) => {
60
- return Cache.wrap(
61
- CacheKey.List(searchParams, headers),
62
- getListDataHandler(searchParams, headers),
63
- {
64
- expire: 300
65
- }
66
- );
67
- };
1
+ import { Cache, CacheKey } from '../../lib/cache';
2
+ import { category } from '../urls';
3
+ import { GetCategoryResponse } from '../../types';
4
+ import { generateCommerceSearchParams } from '../../utils';
5
+ import appFetch, { FetchResponseType } from '../../utils/app-fetch';
6
+ import { parse } from 'lossless-json';
7
+ import logger from '../../utils/log';
8
+
9
+ const getListDataHandler = (
10
+ searchParams: URLSearchParams,
11
+ headers?: Record<string, string>
12
+ ) => {
13
+ return async function () {
14
+ const params = generateCommerceSearchParams(searchParams);
15
+
16
+ const rawData = await appFetch<string>(
17
+ `${category.list}${params}`,
18
+ {
19
+ headers: {
20
+ Accept: 'application/json',
21
+ 'Content-Type': 'application/json',
22
+ ...(headers ?? {})
23
+ }
24
+ },
25
+ FetchResponseType.TEXT
26
+ );
27
+
28
+ let data: GetCategoryResponse;
29
+
30
+ try {
31
+ const numberValueParser = (value) => {
32
+ return String(value);
33
+ };
34
+
35
+ data = parse(
36
+ rawData,
37
+ undefined,
38
+ numberValueParser
39
+ ) as GetCategoryResponse;
40
+ } catch (error) {
41
+ logger.error('Error while parsing list data', {
42
+ error,
43
+ rawData: rawData.startsWith('<!DOCTYPE html>')
44
+ ? `${rawData.substring(0, 50)}...`
45
+ : rawData
46
+ });
47
+ }
48
+
49
+ return data;
50
+ };
51
+ };
52
+
53
+ export const getListData = async ({
54
+ searchParams,
55
+ headers
56
+ }: {
57
+ searchParams: URLSearchParams;
58
+ headers?: Record<string, string>;
59
+ }) => {
60
+ return Cache.wrap(
61
+ CacheKey.List(searchParams, headers),
62
+ getListDataHandler(searchParams, headers),
63
+ {
64
+ expire: 300
65
+ }
66
+ );
67
+ };
@@ -1,35 +1,35 @@
1
- import { Cache, CacheKey } from '../../lib/cache';
2
- import { MenuItemType } from '../../types';
3
- import appFetch from '../../utils/app-fetch';
4
- import { misc } from '../urls';
5
-
6
- interface MenuResponse {
7
- menu: MenuItemType[];
8
- }
9
-
10
- interface MenuHandlerParams {
11
- depth?: number;
12
- parent?: string;
13
- }
14
-
15
- const DEFAULT_DEPTH = 3;
16
-
17
- const getMenuHandler =
18
- ({ depth, parent }: MenuHandlerParams = { depth: DEFAULT_DEPTH }) =>
19
- async () => {
20
- const response = await appFetch<MenuResponse>(misc.menus(depth, parent));
21
-
22
- return response?.menu;
23
- };
24
-
25
- /**
26
- * Returns menu data.
27
- *
28
- * Default depth is 3
29
- */
30
- export const getMenu = async (params?: MenuHandlerParams) => {
31
- return Cache.wrap(
32
- CacheKey.Menu(params?.depth ?? DEFAULT_DEPTH, params?.parent),
33
- getMenuHandler(params)
34
- );
35
- };
1
+ import { Cache, CacheKey } from '../../lib/cache';
2
+ import { MenuItemType } from '../../types';
3
+ import appFetch from '../../utils/app-fetch';
4
+ import { misc } from '../urls';
5
+
6
+ interface MenuResponse {
7
+ menu: MenuItemType[];
8
+ }
9
+
10
+ interface MenuHandlerParams {
11
+ depth?: number;
12
+ parent?: string;
13
+ }
14
+
15
+ const DEFAULT_DEPTH = 3;
16
+
17
+ const getMenuHandler =
18
+ ({ depth, parent }: MenuHandlerParams = { depth: DEFAULT_DEPTH }) =>
19
+ async () => {
20
+ const response = await appFetch<MenuResponse>(misc.menus(depth, parent));
21
+
22
+ return response?.menu;
23
+ };
24
+
25
+ /**
26
+ * Returns menu data.
27
+ *
28
+ * Default depth is 3
29
+ */
30
+ export const getMenu = async (params?: MenuHandlerParams) => {
31
+ return Cache.wrap(
32
+ CacheKey.Menu(params?.depth ?? DEFAULT_DEPTH, params?.parent),
33
+ getMenuHandler(params)
34
+ );
35
+ };