feat: migrate nextjs to rr7

This commit is contained in:
David Nguyen
2025-01-02 15:33:37 +11:00
committed by Mythie
parent 9183f668d3
commit 75d7336763
1021 changed files with 60930 additions and 40839 deletions

View File

@ -1,17 +1,22 @@
import type { ReadonlyRequestCookies } from 'next/dist/server/web/spec-extension/adapters/request-cookies';
import type { I18n, MessageDescriptor } from '@lingui/core';
import { i18n } from '@lingui/core';
import { IS_APP_WEB, IS_APP_WEB_I18N_ENABLED } from '../constants/app';
import type { I18nLocaleData, SupportedLanguageCodes } from '../constants/i18n';
import { APP_I18N_OPTIONS } from '../constants/i18n';
import { env } from './env';
export async function dynamicActivate(i18nInstance: I18n, locale: string) {
const extension = process.env.NODE_ENV === 'development' ? 'po' : 'js';
export async function getTranslations(locale: string) {
const extension = env('NODE_ENV') === 'development' ? 'po' : 'mjs';
const { messages } = await import(`../translations/${locale}/web.${extension}`);
i18nInstance.loadAndActivate({ locale, messages });
return messages;
}
export async function dynamicActivate(locale: string) {
const messages = await getTranslations(locale);
i18n.loadAndActivate({ locale, messages });
}
const parseLanguageFromLocale = (locale: string): SupportedLanguageCodes | null => {
@ -28,25 +33,6 @@ const parseLanguageFromLocale = (locale: string): SupportedLanguageCodes | null
return foundSupportedLanguage;
};
/**
* Extract the language if supported from the cookies header.
*
* Returns `null` if not supported or not found.
*/
export const extractLocaleDataFromCookies = (
cookies: ReadonlyRequestCookies,
): SupportedLanguageCodes | null => {
const preferredLocale = cookies.get('language')?.value || '';
const language = parseLanguageFromLocale(preferredLocale || '');
if (!language) {
return null;
}
return language;
};
/**
* Extracts the language from the `accept-language` header.
*/
@ -65,35 +51,24 @@ export const extractLocaleDataFromHeaders = (
type ExtractLocaleDataOptions = {
headers: Headers;
cookies: ReadonlyRequestCookies;
};
/**
* Extract the supported language from the cookies, then header if not found.
* Extract the supported language from the header.
*
* Will return the default fallback language if not found.
*/
export const extractLocaleData = ({
headers,
cookies,
}: ExtractLocaleDataOptions): I18nLocaleData => {
let lang: SupportedLanguageCodes | null = extractLocaleDataFromCookies(cookies);
export const extractLocaleData = ({ headers }: ExtractLocaleDataOptions): I18nLocaleData => {
const headerLocales = (headers.get('accept-language') ?? '').split(',');
const langHeader = extractLocaleDataFromHeaders(headers);
if (!lang && langHeader?.lang) {
lang = langHeader.lang;
}
// Override web app to be English.
if (!IS_APP_WEB_I18N_ENABLED && IS_APP_WEB) {
lang = 'en';
}
const unknownLanguages = headerLocales
.map((locale) => parseLanguageFromLocale(locale))
.filter((value): value is SupportedLanguageCodes => value !== null);
// Filter out locales that are not valid.
const locales = (langHeader?.locales ?? []).filter((locale) => {
const languages = (unknownLanguages ?? []).filter((language) => {
try {
new Intl.Locale(locale);
new Intl.Locale(language);
return true;
} catch {
return false;
@ -101,8 +76,8 @@ export const extractLocaleData = ({
});
return {
lang: lang || APP_I18N_OPTIONS.sourceLang,
locales,
lang: languages[0] || APP_I18N_OPTIONS.sourceLang,
locales: headerLocales,
};
};