mirror of
https://github.com/NovaOSS/nova-betterchat.git
synced 2024-11-25 15:23:59 +01:00
Add language names (#198)
This commit is contained in:
parent
8f0ed233e9
commit
b4f3789060
|
@ -8,5 +8,6 @@
|
||||||
"trailingComma": "es5",
|
"trailingComma": "es5",
|
||||||
"bracketSpacing": true,
|
"bracketSpacing": true,
|
||||||
"jsxBracketSameLine": false,
|
"jsxBracketSameLine": false,
|
||||||
"arrowParens": "always"
|
"arrowParens": "always",
|
||||||
|
"quoteProps": "consistent"
|
||||||
}
|
}
|
||||||
|
|
1
public/locales/zh
Symbolic link
1
public/locales/zh
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
zh-CN
|
|
@ -2,7 +2,7 @@ import React, { useState } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
|
||||||
import DownChevronArrow from '@icon/DownChevronArrow';
|
import DownChevronArrow from '@icon/DownChevronArrow';
|
||||||
import { i18nLanguages } from '@src/i18n';
|
import { languageCodeToName, selectableLanguages } from '@constants/language';
|
||||||
|
|
||||||
const LanguageSelector = () => {
|
const LanguageSelector = () => {
|
||||||
const { i18n } = useTranslation();
|
const { i18n } = useTranslation();
|
||||||
|
@ -11,24 +11,25 @@ const LanguageSelector = () => {
|
||||||
return (
|
return (
|
||||||
<div className='prose dark:prose-invert relative'>
|
<div className='prose dark:prose-invert relative'>
|
||||||
<button
|
<button
|
||||||
className='btn btn-neutral btn-small flex w-32 flex justify-between'
|
className='btn btn-neutral btn-small w-36 flex justify-between'
|
||||||
type='button'
|
type='button'
|
||||||
onClick={() => setDropDown((prev) => !prev)}
|
onClick={() => setDropDown((prev) => !prev)}
|
||||||
>
|
>
|
||||||
{i18n.language}
|
{languageCodeToName[i18n.language as keyof typeof languageCodeToName] ??
|
||||||
|
i18n.language}
|
||||||
<DownChevronArrow />
|
<DownChevronArrow />
|
||||||
</button>
|
</button>
|
||||||
<div
|
<div
|
||||||
id='dropdown'
|
id='dropdown'
|
||||||
className={`${
|
className={`${
|
||||||
dropDown ? '' : 'hidden'
|
dropDown ? '' : 'hidden'
|
||||||
} absolute top-100 bottom-100 z-10 bg-white rounded-lg shadow-xl border-b border-black/10 dark:border-gray-900/50 text-gray-800 dark:text-gray-100 group dark:bg-gray-800 opacity-90 w-32`}
|
} absolute top-100 bottom-100 z-10 bg-white rounded-lg shadow-xl border-b border-black/10 dark:border-gray-900/50 text-gray-800 dark:text-gray-100 group dark:bg-gray-800 opacity-90 w-36`}
|
||||||
>
|
>
|
||||||
<ul
|
<ul
|
||||||
className='text-sm text-gray-700 dark:text-gray-200 p-0 m-0'
|
className='text-sm text-gray-700 dark:text-gray-200 p-0 m-0 max-h-72 overflow-auto'
|
||||||
aria-labelledby='dropdownDefaultButton'
|
aria-labelledby='dropdownDefaultButton'
|
||||||
>
|
>
|
||||||
{i18nLanguages.map((lang) => (
|
{selectableLanguages.map((lang) => (
|
||||||
<li
|
<li
|
||||||
className='px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white cursor-pointer'
|
className='px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white cursor-pointer'
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
|
@ -37,7 +38,7 @@ const LanguageSelector = () => {
|
||||||
}}
|
}}
|
||||||
key={lang}
|
key={lang}
|
||||||
>
|
>
|
||||||
{lang}
|
{languageCodeToName[lang]}
|
||||||
</li>
|
</li>
|
||||||
))}
|
))}
|
||||||
</ul>
|
</ul>
|
||||||
|
|
67
src/constants/language.ts
Normal file
67
src/constants/language.ts
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
// languages that have translation files in `public/locales`
|
||||||
|
export const i18nLanguages = [
|
||||||
|
// 'ar',
|
||||||
|
'da',
|
||||||
|
'en',
|
||||||
|
'en-GB',
|
||||||
|
'en-US',
|
||||||
|
'es',
|
||||||
|
'fr',
|
||||||
|
'fr-FR',
|
||||||
|
'it',
|
||||||
|
'ja',
|
||||||
|
'ms',
|
||||||
|
'nb',
|
||||||
|
'sv',
|
||||||
|
// 'ug',
|
||||||
|
'yue',
|
||||||
|
'zh',
|
||||||
|
'zh-CN',
|
||||||
|
'zh-HK',
|
||||||
|
'zh-TW',
|
||||||
|
] as const;
|
||||||
|
|
||||||
|
// languages that are selectable on the web page
|
||||||
|
export const selectableLanguages = [
|
||||||
|
// 'ar',
|
||||||
|
'da',
|
||||||
|
// 'en',
|
||||||
|
'en-GB',
|
||||||
|
'en-US',
|
||||||
|
'es',
|
||||||
|
// 'fr',
|
||||||
|
'fr-FR',
|
||||||
|
'it',
|
||||||
|
'ja',
|
||||||
|
'ms',
|
||||||
|
'nb',
|
||||||
|
'sv',
|
||||||
|
// 'ug',
|
||||||
|
'yue',
|
||||||
|
// 'zh',
|
||||||
|
'zh-CN',
|
||||||
|
// 'zh-HK',
|
||||||
|
'zh-TW',
|
||||||
|
] as const;
|
||||||
|
|
||||||
|
export const languageCodeToName = {
|
||||||
|
// 'ar': 'العربية',
|
||||||
|
'da': 'Dansk',
|
||||||
|
'en': 'English',
|
||||||
|
'en-GB': 'English (UK)',
|
||||||
|
'en-US': 'English (US)',
|
||||||
|
'es': 'Español',
|
||||||
|
'fr': 'Français',
|
||||||
|
'fr-FR': 'Français', // Français (France). no need to include "France" at this time, as there is currently only one variant
|
||||||
|
'it': 'Italiano',
|
||||||
|
'ja': '日本語',
|
||||||
|
'ms': 'Bahasa Melayu',
|
||||||
|
'nb': 'Norsk bokmål',
|
||||||
|
'sv': 'Svenska',
|
||||||
|
// 'ug': 'ئۇيغۇرچە',
|
||||||
|
'yue': '廣東話',
|
||||||
|
'zh': '中文',
|
||||||
|
'zh-CN': '中文(简体)',
|
||||||
|
'zh-HK': '廣東話', // 中文(香港). currently there is no support for `zh-HK`, so `zh-HK` will be regarded as `yue`
|
||||||
|
'zh-TW': '中文(台灣)',
|
||||||
|
};
|
21
src/i18n.ts
21
src/i18n.ts
|
@ -4,27 +4,6 @@ import { initReactI18next } from 'react-i18next';
|
||||||
import Backend from 'i18next-http-backend';
|
import Backend from 'i18next-http-backend';
|
||||||
import LanguageDetector from 'i18next-browser-languagedetector';
|
import LanguageDetector from 'i18next-browser-languagedetector';
|
||||||
|
|
||||||
export const i18nLanguages = [
|
|
||||||
// 'ar',
|
|
||||||
'da',
|
|
||||||
'en',
|
|
||||||
'en-GB',
|
|
||||||
'en-US',
|
|
||||||
'es',
|
|
||||||
'fr',
|
|
||||||
'fr-FR',
|
|
||||||
'it',
|
|
||||||
'ja',
|
|
||||||
'ms',
|
|
||||||
'nb',
|
|
||||||
'sv',
|
|
||||||
// 'ug',
|
|
||||||
'yue',
|
|
||||||
'zh-CN',
|
|
||||||
'zh-HK',
|
|
||||||
'zh-TW',
|
|
||||||
];
|
|
||||||
|
|
||||||
i18n
|
i18n
|
||||||
.use(Backend)
|
.use(Backend)
|
||||||
.use(LanguageDetector)
|
.use(LanguageDetector)
|
||||||
|
|
Loading…
Reference in a new issue