@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.
- package/.editorconfig +7 -7
- package/.eslintrc.js +40 -40
- package/.gitattributes +15 -0
- package/.prettierrc +13 -13
- package/CHANGELOG.md +14 -0
- package/api/auth.ts +231 -231
- package/api/cache.ts +44 -44
- package/api/client.ts +174 -174
- package/api/logout.ts +42 -42
- package/bin/pz-check-dependencies.js +98 -98
- package/bin/pz-install-plugins.js +33 -33
- package/bin/pz-install-theme.js +58 -58
- package/bin/pz-postbuild.js +1 -1
- package/bin/pz-postdev.js +1 -1
- package/bin/pz-postinstall.js +6 -6
- package/bin/pz-poststart.js +1 -1
- package/bin/pz-prebuild.js +4 -4
- package/bin/pz-predev.js +4 -4
- package/bin/pz-prestart.js +1 -1
- package/bin/run-script.js +44 -44
- package/components/accordion.tsx +52 -52
- package/components/button.tsx +46 -46
- package/components/client-root.tsx +19 -19
- package/components/icon.tsx +18 -18
- package/components/image.tsx +133 -133
- package/components/index.ts +1 -0
- package/components/input.tsx +110 -110
- package/components/lazy-component.tsx +33 -33
- package/components/loader-spinner.tsx +23 -23
- package/components/mobile-app-toggler.tsx +26 -26
- package/components/modal.tsx +66 -0
- package/components/oauth-login.tsx +24 -24
- package/components/plugin-module.tsx +5 -0
- package/components/price.tsx +55 -55
- package/components/pz-providers.tsx +24 -24
- package/components/pz-root.tsx +21 -21
- package/components/radio.tsx +18 -18
- package/components/react-portal.tsx +45 -45
- package/components/redirect-three-d/content/index.tsx +74 -74
- package/components/redirect-three-d/index.tsx +17 -17
- package/components/selected-payment-option-view.tsx +1 -1
- package/components/trans.tsx +39 -39
- package/data/client/account.ts +208 -208
- package/data/client/api.ts +85 -85
- package/data/client/basket.ts +82 -82
- package/data/client/misc.ts +101 -101
- package/data/client/product.ts +89 -89
- package/data/client/user.ts +99 -99
- package/data/client/wishlist.ts +118 -118
- package/data/server/category.ts +132 -132
- package/data/server/flatpage.ts +21 -21
- package/data/server/form.ts +22 -22
- package/data/server/index.ts +10 -10
- package/data/server/landingpage.ts +24 -24
- package/data/server/list.ts +67 -67
- package/data/server/menu.ts +35 -35
- package/data/server/product.ts +86 -86
- package/data/server/seo.ts +48 -48
- package/data/server/special-page.ts +47 -47
- package/data/server/widget.ts +27 -27
- package/data/urls.ts +221 -221
- package/hocs/client/index.ts +1 -1
- package/hocs/client/with-segment-defaults.tsx +25 -25
- package/hocs/server/index.ts +1 -1
- package/hocs/server/with-segment-defaults.tsx +85 -85
- package/hooks/index.ts +10 -10
- package/hooks/use-captcha.tsx +76 -76
- package/hooks/use-common-product-attributes.ts +36 -36
- package/hooks/use-debounce.ts +20 -20
- package/hooks/use-localization.ts +78 -78
- package/hooks/use-media-query.ts +36 -36
- package/hooks/use-mobile-iframe-handler.ts +23 -23
- package/hooks/use-on-click-outside.tsx +28 -28
- package/hooks/use-payment-options.ts +3 -1
- package/hooks/use-router.ts +45 -45
- package/hooks/use-translation.ts +14 -14
- package/lib/cache.ts +215 -215
- package/localization/index.ts +5 -5
- package/localization/provider.tsx +58 -58
- package/middlewares/complete-gpay.ts +159 -0
- package/middlewares/currency.ts +100 -100
- package/middlewares/default.ts +259 -256
- package/middlewares/index.ts +31 -29
- package/middlewares/locale.ts +68 -68
- package/middlewares/oauth-login.ts +79 -79
- package/middlewares/pretty-url.ts +104 -104
- package/middlewares/redirection-payment.ts +160 -160
- package/middlewares/three-d-redirection.ts +159 -159
- package/middlewares/url-redirection.ts +65 -65
- package/package.json +2 -2
- package/plugins.js +1 -0
- package/redux/hooks.ts +7 -7
- package/redux/middlewares/index.ts +50 -50
- package/redux/reducers/checkout.ts +184 -184
- package/redux/reducers/config.ts +28 -28
- package/redux/reducers/header.ts +59 -59
- package/redux/reducers/root.ts +61 -61
- package/sentry/index.ts +27 -27
- package/tailwind/rtl.js +137 -137
- package/types/commerce/account.ts +64 -64
- package/types/commerce/address.ts +94 -94
- package/types/commerce/basket.ts +43 -43
- package/types/commerce/category.ts +114 -114
- package/types/commerce/checkout.ts +143 -143
- package/types/commerce/flatpage.ts +7 -7
- package/types/commerce/form.ts +66 -66
- package/types/commerce/index.ts +12 -12
- package/types/commerce/landingpage.ts +7 -7
- package/types/commerce/misc.ts +127 -127
- package/types/commerce/order.ts +119 -119
- package/types/commerce/product.ts +109 -109
- package/types/commerce/widget.ts +28 -28
- package/types/gtm.ts +16 -16
- package/types/index.ts +274 -274
- package/types/metadata.ts +7 -7
- package/types/next-auth.d.ts +24 -24
- package/utils/app-fetch.ts +69 -69
- package/utils/deep-merge.js +24 -24
- package/utils/image-loader.ts +31 -31
- package/utils/index.ts +150 -150
- package/utils/localization.ts +29 -29
- package/utils/log.ts +138 -138
- package/utils/menu-generator.ts +27 -27
- package/utils/mobile-3d-iframe.ts +77 -77
- package/utils/server-translation.ts +57 -57
- package/utils/server-variables.ts +9 -9
- package/with-pz-config.js +94 -94
package/data/server/category.ts
CHANGED
|
@@ -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
|
+
};
|
package/data/server/flatpage.ts
CHANGED
|
@@ -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
|
+
};
|
package/data/server/form.ts
CHANGED
|
@@ -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
|
+
};
|
package/data/server/index.ts
CHANGED
|
@@ -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
|
+
};
|
package/data/server/list.ts
CHANGED
|
@@ -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
|
+
};
|
package/data/server/menu.ts
CHANGED
|
@@ -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
|
+
};
|