@akinon/next 1.13.0 → 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.
- package/.editorconfig +7 -0
- package/.eslintrc.js +40 -40
- package/.prettierrc +13 -13
- package/CHANGELOG.md +19 -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/assets/styles/index.scss +28 -28
- 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 -0
- package/components/button.tsx +46 -0
- package/components/client-root.tsx +19 -19
- package/components/icon.tsx +18 -18
- package/components/image.tsx +133 -133
- package/components/index.ts +17 -1
- package/components/input.tsx +110 -0
- package/components/lazy-component.tsx +33 -33
- package/components/loader-spinner.tsx +23 -23
- package/components/mobile-app-toggler.tsx +26 -26
- package/components/oauth-login.tsx +24 -24
- package/components/plugin-module.tsx +11 -8
- package/components/price.tsx +55 -0
- 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 +7 -0
- package/components/trans.tsx +39 -39
- package/data/client/account.ts +208 -208
- package/data/client/address.ts +107 -107
- package/data/client/api.ts +85 -84
- package/data/client/b2b.ts +106 -106
- package/data/client/basket.ts +82 -82
- package/data/client/checkout.ts +516 -479
- 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 -88
- package/data/server/category.ts +132 -128
- 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 -62
- 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 -210
- 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 +12 -16
- 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/currency.ts +100 -100
- package/middlewares/default.ts +256 -256
- package/middlewares/index.ts +29 -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 +2 -1
- package/redux/hooks.ts +7 -7
- package/redux/middlewares/checkout.ts +265 -260
- package/redux/middlewares/index.ts +50 -50
- package/redux/reducers/checkout.ts +184 -171
- package/redux/reducers/config.ts +28 -28
- package/redux/reducers/header.ts +59 -59
- package/redux/reducers/index.ts +14 -14
- 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/b2b.ts +117 -117
- package/types/commerce/basket.ts +43 -43
- package/types/commerce/category.ts +114 -114
- package/types/commerce/checkout.ts +143 -136
- 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 -237
- 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/generate-commerce-search-params.ts +22 -22
- package/utils/get-currency.ts +29 -29
- 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/hooks/use-media-query.ts
CHANGED
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { useEffect, useState } from 'react';
|
|
4
|
-
|
|
5
|
-
export function useMediaQuery(query: string): boolean {
|
|
6
|
-
const getMatches = (query: string): boolean => {
|
|
7
|
-
if (typeof window !== 'undefined') {
|
|
8
|
-
return window.matchMedia(query).matches;
|
|
9
|
-
}
|
|
10
|
-
return false;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
const [matches, setMatches] = useState<boolean>(getMatches(query));
|
|
14
|
-
|
|
15
|
-
const handleChange = () => {
|
|
16
|
-
setMatches(getMatches(query));
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
useEffect(() => {
|
|
20
|
-
const matchMedia = window.matchMedia(query);
|
|
21
|
-
|
|
22
|
-
handleChange();
|
|
23
|
-
|
|
24
|
-
if (matchMedia.addEventListener) {
|
|
25
|
-
matchMedia.addEventListener('change', handleChange);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
return () => {
|
|
29
|
-
if (matchMedia.removeEventListener) {
|
|
30
|
-
matchMedia.removeEventListener('change', handleChange);
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
}, []);
|
|
34
|
-
|
|
35
|
-
return matches;
|
|
36
|
-
}
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { useEffect, useState } from 'react';
|
|
4
|
+
|
|
5
|
+
export function useMediaQuery(query: string): boolean {
|
|
6
|
+
const getMatches = (query: string): boolean => {
|
|
7
|
+
if (typeof window !== 'undefined') {
|
|
8
|
+
return window.matchMedia(query).matches;
|
|
9
|
+
}
|
|
10
|
+
return false;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const [matches, setMatches] = useState<boolean>(getMatches(query));
|
|
14
|
+
|
|
15
|
+
const handleChange = () => {
|
|
16
|
+
setMatches(getMatches(query));
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
const matchMedia = window.matchMedia(query);
|
|
21
|
+
|
|
22
|
+
handleChange();
|
|
23
|
+
|
|
24
|
+
if (matchMedia.addEventListener) {
|
|
25
|
+
matchMedia.addEventListener('change', handleChange);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
return () => {
|
|
29
|
+
if (matchMedia.removeEventListener) {
|
|
30
|
+
matchMedia.removeEventListener('change', handleChange);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
}, []);
|
|
34
|
+
|
|
35
|
+
return matches;
|
|
36
|
+
}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import { usePathname } from 'next/navigation';
|
|
2
|
-
import { useEffect, useState } from 'react';
|
|
3
|
-
import { useAppSelector } from '../redux/hooks';
|
|
4
|
-
|
|
5
|
-
export function useMobileIframeHandler({ sessionId }: { sessionId: string }) {
|
|
6
|
-
const pathname = usePathname();
|
|
7
|
-
const { isMobileApp } = useAppSelector((state) => state.root);
|
|
8
|
-
const [preventPageRender, setPreventPageRender] = useState(false);
|
|
9
|
-
|
|
10
|
-
useEffect(() => {
|
|
11
|
-
if (
|
|
12
|
-
pathname.includes('/orders/completed') &&
|
|
13
|
-
(isMobileApp || /iPad|iPhone|iPod|Android/i.test(navigator.userAgent)) &&
|
|
14
|
-
window.frameElement // Check if the page is inside an iframe
|
|
15
|
-
) {
|
|
16
|
-
setPreventPageRender(true);
|
|
17
|
-
}
|
|
18
|
-
}, [pathname]);
|
|
19
|
-
|
|
20
|
-
return {
|
|
21
|
-
preventPageRender
|
|
22
|
-
};
|
|
23
|
-
}
|
|
1
|
+
import { usePathname } from 'next/navigation';
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
3
|
+
import { useAppSelector } from '../redux/hooks';
|
|
4
|
+
|
|
5
|
+
export function useMobileIframeHandler({ sessionId }: { sessionId: string }) {
|
|
6
|
+
const pathname = usePathname();
|
|
7
|
+
const { isMobileApp } = useAppSelector((state) => state.root);
|
|
8
|
+
const [preventPageRender, setPreventPageRender] = useState(false);
|
|
9
|
+
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
if (
|
|
12
|
+
pathname.includes('/orders/completed') &&
|
|
13
|
+
(isMobileApp || /iPad|iPhone|iPod|Android/i.test(navigator.userAgent)) &&
|
|
14
|
+
window.frameElement // Check if the page is inside an iframe
|
|
15
|
+
) {
|
|
16
|
+
setPreventPageRender(true);
|
|
17
|
+
}
|
|
18
|
+
}, [pathname]);
|
|
19
|
+
|
|
20
|
+
return {
|
|
21
|
+
preventPageRender
|
|
22
|
+
};
|
|
23
|
+
}
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { useEffect, RefObject } from 'react';
|
|
4
|
-
|
|
5
|
-
type Event = MouseEvent | TouchEvent;
|
|
6
|
-
|
|
7
|
-
export function useOnClickOutside<T extends HTMLElement = HTMLElement>(
|
|
8
|
-
ref: RefObject<T>,
|
|
9
|
-
callback: (event: Event) => void,
|
|
10
|
-
mouseEvent: 'mousedown' | 'mouseup' | 'click' = 'click'
|
|
11
|
-
): void {
|
|
12
|
-
useEffect(() => {
|
|
13
|
-
const onClickHandler = (event: Event) => {
|
|
14
|
-
const el = ref?.current;
|
|
15
|
-
|
|
16
|
-
if (!el || el.contains((event?.target as Node) || null)) {
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
callback(event);
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
document.addEventListener(mouseEvent, onClickHandler);
|
|
24
|
-
return () => {
|
|
25
|
-
document.removeEventListener(mouseEvent, onClickHandler);
|
|
26
|
-
};
|
|
27
|
-
}, [callback, mouseEvent, ref]);
|
|
28
|
-
}
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { useEffect, RefObject } from 'react';
|
|
4
|
+
|
|
5
|
+
type Event = MouseEvent | TouchEvent;
|
|
6
|
+
|
|
7
|
+
export function useOnClickOutside<T extends HTMLElement = HTMLElement>(
|
|
8
|
+
ref: RefObject<T>,
|
|
9
|
+
callback: (event: Event) => void,
|
|
10
|
+
mouseEvent: 'mousedown' | 'mouseup' | 'click' = 'click'
|
|
11
|
+
): void {
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
const onClickHandler = (event: Event) => {
|
|
14
|
+
const el = ref?.current;
|
|
15
|
+
|
|
16
|
+
if (!el || el.contains((event?.target as Node) || null)) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
callback(event);
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
document.addEventListener(mouseEvent, onClickHandler);
|
|
24
|
+
return () => {
|
|
25
|
+
document.removeEventListener(mouseEvent, onClickHandler);
|
|
26
|
+
};
|
|
27
|
+
}, [callback, mouseEvent, ref]);
|
|
28
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import plugins from '
|
|
2
|
-
import
|
|
3
|
-
import { useAppSelector } from '
|
|
4
|
-
import { RootState } from '
|
|
1
|
+
import plugins from 'plugins';
|
|
2
|
+
import Settings from 'settings';
|
|
3
|
+
import { useAppSelector } from '../redux/hooks';
|
|
4
|
+
import { RootState } from 'redux/store';
|
|
5
5
|
|
|
6
6
|
export const usePaymentOptions = () => {
|
|
7
7
|
const { paymentOptions } = useAppSelector(
|
|
@@ -16,32 +16,28 @@ export const usePaymentOptions = () => {
|
|
|
16
16
|
|
|
17
17
|
const paymentTypeToPluginMap = {
|
|
18
18
|
pay_on_delivery: 'pz-pay-on-delivery',
|
|
19
|
-
bkm_express: 'pz-bkm'
|
|
19
|
+
bkm_express: 'pz-bkm',
|
|
20
|
+
masterpass: 'pz-masterpass'
|
|
20
21
|
};
|
|
21
22
|
|
|
22
23
|
const isInitialTypeIncluded = (type: string) => initialTypes.has(type);
|
|
23
24
|
|
|
24
|
-
const isPluginMapIncluded = (type: string) =>
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
}
|
|
29
|
-
return false;
|
|
30
|
-
};
|
|
25
|
+
const isPluginMapIncluded = (type: string) =>
|
|
26
|
+
paymentTypeToPluginMap[type]
|
|
27
|
+
? plugins.includes(paymentTypeToPluginMap[type])
|
|
28
|
+
: false;
|
|
31
29
|
|
|
32
30
|
const isExtraTypeIncluded = (type: string) => {
|
|
33
|
-
const extraPaymentTypes =
|
|
34
|
-
|
|
31
|
+
const extraPaymentTypes = Settings?.checkout?.extraPaymentTypes || [];
|
|
35
32
|
return (
|
|
36
33
|
extraPaymentTypes.includes(type) &&
|
|
37
34
|
!initialTypes.has(type) &&
|
|
38
|
-
!paymentTypeToPluginMap
|
|
35
|
+
!paymentTypeToPluginMap[type]
|
|
39
36
|
);
|
|
40
37
|
};
|
|
41
38
|
|
|
42
39
|
const filteredPaymentOptions = paymentOptions.filter((option) => {
|
|
43
40
|
const { payment_type } = option;
|
|
44
|
-
|
|
45
41
|
return (
|
|
46
42
|
isInitialTypeIncluded(payment_type) ||
|
|
47
43
|
isPluginMapIncluded(payment_type) ||
|
package/hooks/use-router.ts
CHANGED
|
@@ -1,45 +1,45 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { useRouter as _useRouter } from 'next/navigation';
|
|
4
|
-
import { urlLocaleMatcherRegex } from '../utils';
|
|
5
|
-
import { useLocalization } from './use-localization';
|
|
6
|
-
import { LocaleUrlStrategy } from '../localization';
|
|
7
|
-
|
|
8
|
-
export const useRouter = () => {
|
|
9
|
-
const { locale, locales, localeUrlStrategy, defaultLocaleValue } =
|
|
10
|
-
useLocalization();
|
|
11
|
-
const defaultLocale = locales.find((l) => l.value === defaultLocaleValue);
|
|
12
|
-
const router = _useRouter();
|
|
13
|
-
|
|
14
|
-
const pushOrReplace = (
|
|
15
|
-
fn: (href: string, options?) => void,
|
|
16
|
-
href: string,
|
|
17
|
-
options?
|
|
18
|
-
) => {
|
|
19
|
-
if (href.startsWith('http')) {
|
|
20
|
-
return fn(href, options);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const url = new URL(href, window.location.origin);
|
|
24
|
-
const pathnameWithoutLocale = url.pathname.replace(
|
|
25
|
-
urlLocaleMatcherRegex,
|
|
26
|
-
''
|
|
27
|
-
);
|
|
28
|
-
|
|
29
|
-
url.pathname = `${
|
|
30
|
-
locale === defaultLocale?.value &&
|
|
31
|
-
localeUrlStrategy === LocaleUrlStrategy.HideDefaultLocale
|
|
32
|
-
? ''
|
|
33
|
-
: `/${locale}`
|
|
34
|
-
}${pathnameWithoutLocale}`;
|
|
35
|
-
|
|
36
|
-
return fn(url.href, options);
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
return {
|
|
40
|
-
...router,
|
|
41
|
-
push: (href: string, options?) => pushOrReplace(router.push, href, options),
|
|
42
|
-
replace: (href: string, options?) =>
|
|
43
|
-
pushOrReplace(router.replace, href, options)
|
|
44
|
-
} as typeof router;
|
|
45
|
-
};
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { useRouter as _useRouter } from 'next/navigation';
|
|
4
|
+
import { urlLocaleMatcherRegex } from '../utils';
|
|
5
|
+
import { useLocalization } from './use-localization';
|
|
6
|
+
import { LocaleUrlStrategy } from '../localization';
|
|
7
|
+
|
|
8
|
+
export const useRouter = () => {
|
|
9
|
+
const { locale, locales, localeUrlStrategy, defaultLocaleValue } =
|
|
10
|
+
useLocalization();
|
|
11
|
+
const defaultLocale = locales.find((l) => l.value === defaultLocaleValue);
|
|
12
|
+
const router = _useRouter();
|
|
13
|
+
|
|
14
|
+
const pushOrReplace = (
|
|
15
|
+
fn: (href: string, options?) => void,
|
|
16
|
+
href: string,
|
|
17
|
+
options?
|
|
18
|
+
) => {
|
|
19
|
+
if (href.startsWith('http')) {
|
|
20
|
+
return fn(href, options);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const url = new URL(href, window.location.origin);
|
|
24
|
+
const pathnameWithoutLocale = url.pathname.replace(
|
|
25
|
+
urlLocaleMatcherRegex,
|
|
26
|
+
''
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
url.pathname = `${
|
|
30
|
+
locale === defaultLocale?.value &&
|
|
31
|
+
localeUrlStrategy === LocaleUrlStrategy.HideDefaultLocale
|
|
32
|
+
? ''
|
|
33
|
+
: `/${locale}`
|
|
34
|
+
}${pathnameWithoutLocale}`;
|
|
35
|
+
|
|
36
|
+
return fn(url.href, options);
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
return {
|
|
40
|
+
...router,
|
|
41
|
+
push: (href: string, options?) => pushOrReplace(router.push, href, options),
|
|
42
|
+
replace: (href: string, options?) =>
|
|
43
|
+
pushOrReplace(router.replace, href, options)
|
|
44
|
+
} as typeof router;
|
|
45
|
+
};
|
package/hooks/use-translation.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { LocalizationContext } from '../localization/provider';
|
|
2
|
-
import { useContext } from 'react';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* @deprecated Use useLocalization instead.
|
|
6
|
-
*/
|
|
7
|
-
export const useTranslation = (namespace?: string) => {
|
|
8
|
-
const { translate, locale } = useContext(LocalizationContext);
|
|
9
|
-
|
|
10
|
-
return {
|
|
11
|
-
t: (path: string) => translate(namespace ? `${namespace}.${path}` : path),
|
|
12
|
-
locale
|
|
13
|
-
};
|
|
14
|
-
};
|
|
1
|
+
import { LocalizationContext } from '../localization/provider';
|
|
2
|
+
import { useContext } from 'react';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @deprecated Use useLocalization instead.
|
|
6
|
+
*/
|
|
7
|
+
export const useTranslation = (namespace?: string) => {
|
|
8
|
+
const { translate, locale } = useContext(LocalizationContext);
|
|
9
|
+
|
|
10
|
+
return {
|
|
11
|
+
t: (path: string) => translate(namespace ? `${namespace}.${path}` : path),
|
|
12
|
+
locale
|
|
13
|
+
};
|
|
14
|
+
};
|