mirror of
https://github.com/cheeaun/phanpy.git
synced 2025-01-22 16:46:28 +01:00
Handle kab issue temporarily
This commit is contained in:
parent
2db909d7af
commit
3902db5c0b
4 changed files with 165 additions and 79 deletions
|
@ -15,6 +15,10 @@ const enPo = PO.parse(enContent);
|
||||||
const total = enPo.items.length;
|
const total = enPo.items.length;
|
||||||
console.log('Total strings:', total);
|
console.log('Total strings:', total);
|
||||||
|
|
||||||
|
const codeMaps = {
|
||||||
|
'kab-KAB': 'kab',
|
||||||
|
};
|
||||||
|
|
||||||
files.forEach((file) => {
|
files.forEach((file) => {
|
||||||
if (file.endsWith('.po')) {
|
if (file.endsWith('.po')) {
|
||||||
const code = file.replace(/\.po$/, '');
|
const code = file.replace(/\.po$/, '');
|
||||||
|
@ -30,31 +34,57 @@ files.forEach((file) => {
|
||||||
po.percentage = percentage;
|
po.percentage = percentage;
|
||||||
if (percentage > 0) {
|
if (percentage > 0) {
|
||||||
// Ignore empty catalogs
|
// Ignore empty catalogs
|
||||||
catalogs[code] = percentage;
|
catalogs[codeMaps[code] || code] = percentage;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const regionMaps = {
|
||||||
|
'zh-CN': 'zh-Hans',
|
||||||
|
'zh-TW': 'zh-Hant',
|
||||||
|
};
|
||||||
|
|
||||||
|
function IDN(inputCode, outputCode) {
|
||||||
|
let result;
|
||||||
|
const regionlessInputCode =
|
||||||
|
regionMaps[inputCode] || inputCode.replace(/-[a-z]+$/i, '');
|
||||||
|
const regionlessOutputCode =
|
||||||
|
regionMaps[outputCode] || outputCode.replace(/-[a-z]+$/i, '');
|
||||||
|
const inputCodes =
|
||||||
|
regionlessInputCode !== inputCode
|
||||||
|
? [inputCode, regionlessInputCode]
|
||||||
|
: [inputCode];
|
||||||
|
const outputCodes =
|
||||||
|
regionlessOutputCode !== outputCode
|
||||||
|
? [regionlessOutputCode, outputCode]
|
||||||
|
: [outputCode];
|
||||||
|
|
||||||
|
for (const inputCode of inputCodes) {
|
||||||
|
for (const outputCode of outputCodes) {
|
||||||
|
try {
|
||||||
|
result = new Intl.DisplayNames([inputCode], {
|
||||||
|
type: 'language',
|
||||||
|
}).of(outputCode);
|
||||||
|
break;
|
||||||
|
} catch (e) {}
|
||||||
|
}
|
||||||
|
if (result) break;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
// Sort by percentage
|
// Sort by percentage
|
||||||
const sortedCatalogs = Object.entries(catalogs)
|
const sortedCatalogs = Object.entries(catalogs)
|
||||||
.sort((a, b) => b[1] - a[1])
|
.sort((a, b) => b[1] - a[1])
|
||||||
.map(([code, percentage]) => {
|
.map(([code, completion]) => {
|
||||||
const name = new Intl.DisplayNames(['en'], { type: 'language' }).of(code);
|
const nativeName = IDN(code, code);
|
||||||
return { code, name, percentage };
|
const name = IDN('en', code);
|
||||||
|
// let names = {};
|
||||||
|
return { code, nativeName, name, completion };
|
||||||
});
|
});
|
||||||
|
|
||||||
console.table(sortedCatalogs);
|
console.table(sortedCatalogs);
|
||||||
|
|
||||||
const path = 'src/data/catalogs.json';
|
const path = 'src/data/catalogs.json';
|
||||||
fs.writeFileSync(
|
fs.writeFileSync(path, JSON.stringify(sortedCatalogs, null, 2));
|
||||||
path,
|
|
||||||
JSON.stringify(
|
|
||||||
Object.entries(catalogs).map(([code, percentage]) => ({
|
|
||||||
code,
|
|
||||||
completion: percentage,
|
|
||||||
})),
|
|
||||||
null,
|
|
||||||
2,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
console.log('File written:', path);
|
console.log('File written:', path);
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import { useLingui } from '@lingui/react';
|
import { useLingui } from '@lingui/react';
|
||||||
import { useMemo } from 'preact/hooks';
|
import { useMemo } from 'preact/hooks';
|
||||||
|
|
||||||
import { DEFAULT_LANG, LOCALES } from '../locales';
|
import { CATALOGS, DEFAULT_LANG, LOCALES } from '../locales';
|
||||||
import { activateLang } from '../utils/lang';
|
import { activateLang } from '../utils/lang';
|
||||||
import localeCode2Text from '../utils/localeCode2Text';
|
import localeCode2Text from '../utils/localeCode2Text';
|
||||||
|
|
||||||
|
@ -24,7 +24,11 @@ export default function LangSelector() {
|
||||||
// Wait till there's too many languages and there are regional clashes
|
// Wait till there's too many languages and there are regional clashes
|
||||||
const regionlessCode = regionMaps[lang] || lang.replace(/-[a-z]+$/i, '');
|
const regionlessCode = regionMaps[lang] || lang.replace(/-[a-z]+$/i, '');
|
||||||
|
|
||||||
const native = localeCode2Text({ code: regionlessCode, locale: lang });
|
const native = localeCode2Text({
|
||||||
|
code: regionlessCode,
|
||||||
|
locale: lang,
|
||||||
|
fallback: CATALOGS[lang]?.nativeName || lang,
|
||||||
|
});
|
||||||
|
|
||||||
// Not used when rendering because it'll change based on current locale
|
// Not used when rendering because it'll change based on current locale
|
||||||
// Only used for sorting on render
|
// Only used for sorting on render
|
||||||
|
|
|
@ -1,90 +1,134 @@
|
||||||
[
|
[
|
||||||
{
|
|
||||||
"code": "ar-SA",
|
|
||||||
"completion": 22
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"code": "ca-ES",
|
"code": "ca-ES",
|
||||||
|
"nativeName": "català",
|
||||||
|
"name": "Catalan",
|
||||||
"completion": 100
|
"completion": 100
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"code": "cs-CZ",
|
|
||||||
"completion": 72
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "de-DE",
|
|
||||||
"completion": 99
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "eo-UY",
|
|
||||||
"completion": 15
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"code": "es-ES",
|
"code": "es-ES",
|
||||||
|
"nativeName": "español",
|
||||||
|
"name": "Spanish",
|
||||||
"completion": 100
|
"completion": 100
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"code": "eu-ES",
|
"code": "eu-ES",
|
||||||
|
"nativeName": "euskara",
|
||||||
|
"name": "Basque",
|
||||||
"completion": 100
|
"completion": 100
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"code": "fa-IR",
|
|
||||||
"completion": 62
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"code": "fi-FI",
|
"code": "fi-FI",
|
||||||
|
"nativeName": "suomi",
|
||||||
|
"name": "Finnish",
|
||||||
"completion": 100
|
"completion": 100
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"code": "fr-FR",
|
|
||||||
"completion": 95
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"code": "gl-ES",
|
"code": "gl-ES",
|
||||||
|
"nativeName": "galego",
|
||||||
|
"name": "Galician",
|
||||||
"completion": 100
|
"completion": 100
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"code": "he-IL",
|
|
||||||
"completion": 11
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "it-IT",
|
|
||||||
"completion": 13
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "ja-JP",
|
|
||||||
"completion": 32
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "kab-KAB",
|
|
||||||
"completion": 54
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "ko-KR",
|
|
||||||
"completion": 76
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "lt-LT",
|
|
||||||
"completion": 25
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "nl-NL",
|
|
||||||
"completion": 49
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "ru-RU",
|
|
||||||
"completion": 24
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"code": "th-TH",
|
|
||||||
"completion": 3
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"code": "zh-CN",
|
"code": "zh-CN",
|
||||||
|
"nativeName": "简体中文",
|
||||||
|
"name": "Simplified Chinese",
|
||||||
"completion": 100
|
"completion": 100
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"code": "de-DE",
|
||||||
|
"nativeName": "Deutsch",
|
||||||
|
"name": "German",
|
||||||
|
"completion": 99
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "fr-FR",
|
||||||
|
"nativeName": "français",
|
||||||
|
"name": "French",
|
||||||
|
"completion": 95
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "ko-KR",
|
||||||
|
"nativeName": "한국어",
|
||||||
|
"name": "Korean",
|
||||||
|
"completion": 76
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "cs-CZ",
|
||||||
|
"nativeName": "čeština",
|
||||||
|
"name": "Czech",
|
||||||
|
"completion": 72
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "fa-IR",
|
||||||
|
"nativeName": "فارسی",
|
||||||
|
"name": "Persian",
|
||||||
|
"completion": 62
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "kab",
|
||||||
|
"nativeName": "Taqbaylit",
|
||||||
|
"name": "Kabyle",
|
||||||
|
"completion": 54
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "nl-NL",
|
||||||
|
"nativeName": "Nederlands",
|
||||||
|
"name": "Dutch",
|
||||||
|
"completion": 49
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "ja-JP",
|
||||||
|
"nativeName": "日本語",
|
||||||
|
"name": "Japanese",
|
||||||
|
"completion": 32
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "lt-LT",
|
||||||
|
"nativeName": "lietuvių",
|
||||||
|
"name": "Lithuanian",
|
||||||
|
"completion": 25
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "ru-RU",
|
||||||
|
"nativeName": "русский",
|
||||||
|
"name": "Russian",
|
||||||
|
"completion": 24
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "ar-SA",
|
||||||
|
"nativeName": "العربية",
|
||||||
|
"name": "Arabic",
|
||||||
|
"completion": 22
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "eo-UY",
|
||||||
|
"nativeName": "Esperanto",
|
||||||
|
"name": "Esperanto",
|
||||||
|
"completion": 15
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "it-IT",
|
||||||
|
"nativeName": "italiano",
|
||||||
|
"name": "Italian",
|
||||||
|
"completion": 13
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "he-IL",
|
||||||
|
"nativeName": "עברית",
|
||||||
|
"name": "Hebrew",
|
||||||
|
"completion": 11
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"code": "th-TH",
|
||||||
|
"nativeName": "ไทย",
|
||||||
|
"name": "Thai",
|
||||||
|
"completion": 3
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"code": "zh-TW",
|
"code": "zh-TW",
|
||||||
|
"nativeName": "繁體中文",
|
||||||
|
"name": "Traditional Chinese",
|
||||||
"completion": 3
|
"completion": 3
|
||||||
}
|
}
|
||||||
]
|
]
|
|
@ -13,6 +13,10 @@ import localeMatch from '../utils/locale-match';
|
||||||
|
|
||||||
const { PHANPY_DEFAULT_LANG } = import.meta.env;
|
const { PHANPY_DEFAULT_LANG } = import.meta.env;
|
||||||
|
|
||||||
|
const langFileMaps = {
|
||||||
|
kab: 'kab-KAB',
|
||||||
|
};
|
||||||
|
|
||||||
i18n.load(DEFAULT_LANG, messages);
|
i18n.load(DEFAULT_LANG, messages);
|
||||||
i18n.on('change', () => {
|
i18n.on('change', () => {
|
||||||
const lang = i18n.locale;
|
const lang = i18n.locale;
|
||||||
|
@ -35,10 +39,13 @@ export async function activateLang(lang) {
|
||||||
console.log('💬 ACTIVATE LANG', DEFAULT_LANG, lang);
|
console.log('💬 ACTIVATE LANG', DEFAULT_LANG, lang);
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
const { messages } = await import(`../locales/${lang}.po`);
|
const { messages } = await import(
|
||||||
|
`../locales/${langFileMaps[lang] || lang}.po`
|
||||||
|
);
|
||||||
i18n.loadAndActivate({ locale: lang, messages });
|
i18n.loadAndActivate({ locale: lang, messages });
|
||||||
console.log('💬 ACTIVATE LANG', lang, messages);
|
console.log('💬 ACTIVATE LANG', lang, messages);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
console.error(e);
|
||||||
// Fallback to default language
|
// Fallback to default language
|
||||||
i18n.activate(DEFAULT_LANG);
|
i18n.activate(DEFAULT_LANG);
|
||||||
console.log('💬 ACTIVATE LANG', DEFAULT_LANG, lang);
|
console.log('💬 ACTIVATE LANG', DEFAULT_LANG, lang);
|
||||||
|
@ -54,7 +61,8 @@ export function initActivateLang() {
|
||||||
PHANPY_DEFAULT_LANG,
|
PHANPY_DEFAULT_LANG,
|
||||||
DEFAULT_LANG,
|
DEFAULT_LANG,
|
||||||
);
|
);
|
||||||
const matchedLang = localeMatch(lang, LOCALES);
|
const matchedLang =
|
||||||
|
LOCALES.find((l) => l === lang) || localeMatch(lang, LOCALES);
|
||||||
activateLang(matchedLang);
|
activateLang(matchedLang);
|
||||||
|
|
||||||
// const yes = confirm(t`Reload to apply language setting?`);
|
// const yes = confirm(t`Reload to apply language setting?`);
|
||||||
|
|
Loading…
Reference in a new issue