agent-ecosystem/landing/data/i18n.ts
infiniti 47cea58543
feat(i18n): add expanded app locale support
* feat(i18n): add CJK app locale support

* feat(i18n): add Spanish Hindi and Portuguese locales

* feat(i18n): add French Arabic and Bengali locales

* feat(i18n): add Urdu Indonesian and German locales

* feat(i18n): add landing locales for Bengali Urdu and Indonesian

* fix(i18n): address locale review feedback

---------

Co-authored-by: iliya <iliyazelenkog@gmail.com>
2026-05-24 22:10:47 +03:00

82 lines
2.8 KiB
TypeScript

export type LocaleCode =
| 'en'
| 'ru'
| 'zh'
| 'es'
| 'hi'
| 'ar'
| 'pt'
| 'fr'
| 'ja'
| 'ko'
| 'de'
| 'bn'
| 'ur'
| 'id';
export const supportedLocales = [
{ code: 'en', iso: 'en-US', name: 'English', flag: '\u{1F1FA}\u{1F1F8}', file: 'en.json' },
{ code: 'zh', iso: 'zh-CN', name: '中文', flag: '\u{1F1E8}\u{1F1F3}', file: 'zh.json' },
{ code: 'es', iso: 'es-ES', name: 'Español', flag: '\u{1F1EA}\u{1F1F8}', file: 'es.json' },
{ code: 'hi', iso: 'hi-IN', name: 'हिन्दी', flag: '\u{1F1EE}\u{1F1F3}', file: 'hi.json' },
{ code: 'bn', iso: 'bn-BD', name: 'বাংলা', flag: '\u{1F1E7}\u{1F1E9}', file: 'bn.json' },
{
code: 'ar',
iso: 'ar-SA',
name: 'العربية',
flag: '\u{1F1F8}\u{1F1E6}',
file: 'ar.json',
dir: 'rtl',
},
{ code: 'pt', iso: 'pt-BR', name: 'Português', flag: '\u{1F1E7}\u{1F1F7}', file: 'pt.json' },
{ code: 'fr', iso: 'fr-FR', name: 'Français', flag: '\u{1F1EB}\u{1F1F7}', file: 'fr.json' },
{ code: 'ja', iso: 'ja-JP', name: '日本語', flag: '\u{1F1EF}\u{1F1F5}', file: 'ja.json' },
{ code: 'ko', iso: 'ko-KR', name: '한국어', flag: '\u{1F1F0}\u{1F1F7}', file: 'ko.json' },
{
code: 'ur',
iso: 'ur-PK',
name: 'اردو',
flag: '\u{1F1F5}\u{1F1F0}',
file: 'ur.json',
dir: 'rtl',
},
{ code: 'id', iso: 'id-ID', name: 'Indonesia', flag: '\u{1F1EE}\u{1F1E9}', file: 'id.json' },
{ code: 'de', iso: 'de-DE', name: 'Deutsch', flag: '\u{1F1E9}\u{1F1EA}', file: 'de.json' },
{ code: 'ru', iso: 'ru-RU', name: 'Русский', flag: '\u{1F1F7}\u{1F1FA}', file: 'ru.json' },
] as const;
export const defaultLocale: LocaleCode = 'en';
export const pages = ['/', '/download'] as const;
/** Pages for sitemap */
export const sitemapPages = ['/', '/download'] as const;
export type SitemapPagePath = (typeof sitemapPages)[number];
export const getLocaleMeta = (localeCode: LocaleCode) =>
supportedLocales.find((locale) => locale.code === localeCode) ?? supportedLocales[0];
export const getLocalizedPagePath = (page: SitemapPagePath, localeCode: LocaleCode): string => {
if (localeCode === defaultLocale) return page;
return page === '/' ? `/${localeCode}` : `/${localeCode}${page}`;
};
/** Generates i18n routes for a given list of pages */
const buildI18nRoutes = (source: readonly string[]): string[] => {
const routes: string[] = [];
for (const page of source) {
routes.push(page);
for (const locale of supportedLocales) {
if (locale.code === defaultLocale) continue;
routes.push(page === '/' ? `/${locale.code}` : `/${locale.code}${page}`);
}
}
return routes;
};
/** All i18n routes (for prerender) */
export const generateI18nRoutes = (): string[] => buildI18nRoutes(pages);
/** i18n routes for sitemap only */
export const generateSitemapRoutes = (): string[] => buildI18nRoutes(sitemapPages);