From 3d6a5044a65769013401fb021883304611842b55 Mon Sep 17 00:00:00 2001 From: Aral Roca Gomez Date: Fri, 4 Aug 2023 16:41:58 +0200 Subject: [PATCH] fix(client-components): fix use hook with suspense (#68) --- .../__snapshots__/templateAppDir.test.js.snap | 192 +++++++++++------- src/templateAppDir.ts | 24 ++- 2 files changed, 136 insertions(+), 80 deletions(-) diff --git a/__tests__/__snapshots__/templateAppDir.test.js.snap b/__tests__/__snapshots__/templateAppDir.test.js.snap index 9da0e6a..5eb2d18 100644 --- a/__tests__/__snapshots__/templateAppDir.test.js.snap +++ b/__tests__/__snapshots__/templateAppDir.test.js.snap @@ -1744,7 +1744,7 @@ import { useSearchParams as __useSearchParams, useParams as __useParams, } from \\"next/navigation\\"; -import { use as __use } from \\"react\\"; +import { use as __use, Suspense as __Suspense } from \\"react\\"; import __loadNamespaces from \\"next-translate/loadNamespaces\\"; // Some comment before @@ -1773,25 +1773,33 @@ export default function __Next_Translate_new__88d9831a00__(props) { pathname: \\"/about/us/\\", }; - const { __lang, __namespaces } = __use( - __loadNamespaces({ - ...config, - loadLocaleFrom: - __i18nConfig.loadLocaleFrom || - ((l, n) => - import(\`@next-translate-root/locales/\${l}/\${n}\`).then( - (m) => m.default - )), - }) + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__88d9831a00__ + {...props} + config={config} + promise={__loadNamespaces({ + ...config, + loadLocaleFrom: + __i18nConfig.loadLocaleFrom || + ((l, n) => + import(\`@next-translate-root/locales/\${l}/\${n}\`).then( + (m) => m.default + )), + })} + /> + ); +} +function __Next_Translate__child__88d9831a00__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config, }; - return ; } " @@ -1805,7 +1813,7 @@ import { useSearchParams as __useSearchParams, useParams as __useParams, } from \\"next/navigation\\"; -import { use as __use } from \\"react\\"; +import { use as __use, Suspense as __Suspense } from \\"react\\"; import __loadNamespaces from \\"next-translate/loadNamespaces\\"; // Some comment before @@ -1834,25 +1842,33 @@ export default function __Next_Translate_new__88d9831a00__(props) { pathname: \\"/\\", }; - const { __lang, __namespaces } = __use( - __loadNamespaces({ - ...config, - loadLocaleFrom: - __i18nConfig.loadLocaleFrom || - ((l, n) => - import(\`@next-translate-root/locales/\${l}/\${n}\`).then( - (m) => m.default - )), - }) + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__88d9831a00__ + {...props} + config={config} + promise={__loadNamespaces({ + ...config, + loadLocaleFrom: + __i18nConfig.loadLocaleFrom || + ((l, n) => + import(\`@next-translate-root/locales/\${l}/\${n}\`).then( + (m) => m.default + )), + })} + /> + ); +} +function __Next_Translate__child__88d9831a00__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config, }; - return ; } " @@ -1866,7 +1882,7 @@ import { useSearchParams as __useSearchParams, useParams as __useParams, } from \\"next/navigation\\"; -import { use as __use } from \\"react\\"; +import { use as __use, Suspense as __Suspense } from \\"react\\"; import __loadNamespaces from \\"next-translate/loadNamespaces\\"; // Some comment before @@ -1895,25 +1911,33 @@ export default function __Next_Translate_new__88d9831a00__(props) { pathname: \\"/\\", }; - const { __lang, __namespaces } = __use( - __loadNamespaces({ - ...config, - loadLocaleFrom: - __i18nConfig.loadLocaleFrom || - ((l, n) => - import(\`@next-translate-root/locales/\${l}/\${n}\`).then( - (m) => m.default - )), - }) + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__88d9831a00__ + {...props} + config={config} + promise={__loadNamespaces({ + ...config, + loadLocaleFrom: + __i18nConfig.loadLocaleFrom || + ((l, n) => + import(\`@next-translate-root/locales/\${l}/\${n}\`).then( + (m) => m.default + )), + })} + /> + ); +} +function __Next_Translate__child__88d9831a00__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config, }; - return ; } " @@ -1963,7 +1987,7 @@ import { useSearchParams as __useSearchParams, useParams as __useParams, } from \\"next/navigation\\"; -import { use as __use } from \\"react\\"; +import { use as __use, Suspense as __Suspense } from \\"react\\"; import __loadNamespaces from \\"next-translate/loadNamespaces\\"; import useTranslation from \\"next-translate/useTranslation\\"; export const dynamic = \\"force-static\\"; @@ -1987,25 +2011,33 @@ export default function __Next_Translate_new__88d9831a00__(props) { pathname: \\"/about/us/\\", }; - const { __lang, __namespaces } = __use( - __loadNamespaces({ - ...config, - loadLocaleFrom: - __i18nConfig.loadLocaleFrom || - ((l, n) => - import(\`@next-translate-root/locales/\${l}/\${n}\`).then( - (m) => m.default - )), - }) + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__88d9831a00__ + {...props} + config={config} + promise={__loadNamespaces({ + ...config, + loadLocaleFrom: + __i18nConfig.loadLocaleFrom || + ((l, n) => + import(\`@next-translate-root/locales/\${l}/\${n}\`).then( + (m) => m.default + )), + })} + /> + ); +} +function __Next_Translate__child__88d9831a00__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config, }; - return ; } " @@ -2019,7 +2051,7 @@ import { useSearchParams as __useSearchParams, useParams as __useParams, } from \\"next/navigation\\"; -import { use as __use } from \\"react\\"; +import { use as __use, Suspense as __Suspense } from \\"react\\"; import __loadNamespaces from \\"next-translate/loadNamespaces\\"; import useTranslation from \\"next-translate/useTranslation\\"; export const dynamic = \\"force-static\\"; @@ -2043,25 +2075,33 @@ export default function __Next_Translate_new__88d9831a00__(props) { pathname: \\"/\\", }; - const { __lang, __namespaces } = __use( - __loadNamespaces({ - ...config, - loadLocaleFrom: - __i18nConfig.loadLocaleFrom || - ((l, n) => - import(\`@next-translate-root/locales/\${l}/\${n}\`).then( - (m) => m.default - )), - }) + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__88d9831a00__ + {...props} + config={config} + promise={__loadNamespaces({ + ...config, + loadLocaleFrom: + __i18nConfig.loadLocaleFrom || + ((l, n) => + import(\`@next-translate-root/locales/\${l}/\${n}\`).then( + (m) => m.default + )), + })} + /> + ); +} +function __Next_Translate__child__88d9831a00__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config, }; - return ; } " @@ -2075,7 +2115,7 @@ import { useSearchParams as __useSearchParams, useParams as __useParams, } from \\"next/navigation\\"; -import { use as __use } from \\"react\\"; +import { use as __use, Suspense as __Suspense } from \\"react\\"; import __loadNamespaces from \\"next-translate/loadNamespaces\\"; import useTranslation from \\"next-translate/useTranslation\\"; export const dynamic = \\"force-static\\"; @@ -2099,25 +2139,33 @@ export default function __Next_Translate_new__88d9831a00__(props) { pathname: \\"/\\", }; - const { __lang, __namespaces } = __use( - __loadNamespaces({ - ...config, - loadLocaleFrom: - __i18nConfig.loadLocaleFrom || - ((l, n) => - import(\`@next-translate-root/locales/\${l}/\${n}\`).then( - (m) => m.default - )), - }) + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__88d9831a00__ + {...props} + config={config} + promise={__loadNamespaces({ + ...config, + loadLocaleFrom: + __i18nConfig.loadLocaleFrom || + ((l, n) => + import(\`@next-translate-root/locales/\${l}/\${n}\`).then( + (m) => m.default + )), + })} + /> + ); +} +function __Next_Translate__child__88d9831a00__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config, }; - return ; } " diff --git a/src/templateAppDir.ts b/src/templateAppDir.ts index 45e5917..8770342 100644 --- a/src/templateAppDir.ts +++ b/src/templateAppDir.ts @@ -151,7 +151,7 @@ function templateRCCPage({ import ${INTERNAL_CONFIG_KEY} from '@next-translate-root/i18n' import AppDirI18nProvider from 'next-translate/AppDirI18nProvider' import { useSearchParams as __useSearchParams, useParams as __useParams } from 'next/navigation' - import { use as __use } from 'react' + import { use as __use, Suspense as __Suspense } from 'react' import __loadNamespaces from 'next-translate/loadNamespaces' ${clientCode} @@ -178,14 +178,22 @@ function templateRCCPage({ pathname: '${pathname}', } - const { __lang, __namespaces } = __use(__loadNamespaces({ ...config, ${addLoadLocalesFrom( - existLocalesFolder - )} })); - - const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {} - globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config } + return ( + <__Suspense fallback={null}> + <__Next_Translate__child__${hash}__ + {...props} + config={config} + promise={__loadNamespaces({ ...config, ${addLoadLocalesFrom(existLocalesFolder)} })} + /> + + ) + } - return <${pageVariableName} {...props} /> + function __Next_Translate__child__${hash}__({ promise, config, ...props }) { + const { __lang, __namespaces } = __use(promise); + const oldNamespaces = globalThis.__NEXT_TRANSLATE__?.namespaces ?? {}; + globalThis.__NEXT_TRANSLATE__ = { lang: __lang, namespaces: { ...oldNamespaces, ...__namespaces }, config }; + return <${pageVariableName} {...props} />; } ` }