@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,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
+ }
@@ -17,7 +17,9 @@ export const usePaymentOptions = () => {
17
17
  const paymentTypeToPluginMap = {
18
18
  pay_on_delivery: 'pz-pay-on-delivery',
19
19
  bkm_express: 'pz-bkm',
20
- masterpass: 'pz-masterpass'
20
+ credit_payment: 'pz-credit-payment',
21
+ masterpass: 'pz-masterpass',
22
+ gpay: 'pz-gpay',
21
23
  };
22
24
 
23
25
  const isInitialTypeIncluded = (type: string) => initialTypes.has(type);
@@ -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
+ };
@@ -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
+ };