## library * i18next * react-i18next ## hooks * useTranslation * useGetLanguage * useI18N * useRenderI18nObject ## impl * App Boot - app/layout.tsx load i18n and init context - use `` - read locale with `getLocaleOnServer` (in node.js) - locale from cookie, or browser request header - only used in client app init and 2 server code(plugin desc, datasets) - use `` - init i18n context - `setLocaleOnClient` - `changeLanguage` (defined in i18n/i18next-config, also init i18n resources (side effects)) * is `i18next.changeLanguage` * all languages text is merge & load in FrontEnd as .js (see i18n/i18next-config) * i18n context - `locale` - current locale code (ex `eu-US`, `zh-Hans`) - `i18n` - useless - `setLocaleOnClient` - used by App Boot and user change language ### load i18n resources - client: i18n/i18next-config.ts * ns = camalCase(filename) * ex: `app/components/datasets/create/embedding-process/index.tsx` * `t('datasetSettings.form.retrievalSetting.title')` - server: i18n/server.ts * ns = filename * ex: `app/(commonLayout)/datasets/(datasetDetailLayout)/[datasetId]/settings/page.tsx` * `translate(locale, 'dataset-settings')` ## TODO * [ ] ts docs for useGetLanguage * [ ] ts docs for useI18N * [ ] client docs for i18n * [ ] server docs for i18n