mirror of
https://github.com/cheeaun/phanpy.git
synced 2025-01-22 08:36:21 +01:00
Show all locales, <50% complete will be called devLocales
Dev locales show on dev or based on env var PHANPY_SHOW_DEV_LOCALES
This commit is contained in:
parent
cea06f32fc
commit
25d73c4b46
4 changed files with 43 additions and 25 deletions
|
@ -1,7 +1,7 @@
|
||||||
import { LOCALES } from './src/locales';
|
import { ALL_LOCALES } from './src/locales';
|
||||||
|
|
||||||
const config = {
|
const config = {
|
||||||
locales: LOCALES,
|
locales: ALL_LOCALES,
|
||||||
sourceLocale: 'en',
|
sourceLocale: 'en',
|
||||||
pseudoLocale: 'pseudo-LOCALE',
|
pseudoLocale: 'pseudo-LOCALE',
|
||||||
fallbackLocales: {
|
fallbackLocales: {
|
||||||
|
|
|
@ -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 { CATALOGS, DEFAULT_LANG, LOCALES } from '../locales';
|
import { CATALOGS, DEFAULT_LANG, DEV_LOCALES, LOCALES } from '../locales';
|
||||||
import { activateLang } from '../utils/lang';
|
import { activateLang } from '../utils/lang';
|
||||||
import localeCode2Text from '../utils/localeCode2Text';
|
import localeCode2Text from '../utils/localeCode2Text';
|
||||||
|
|
||||||
|
@ -16,10 +16,6 @@ export default function LangSelector() {
|
||||||
// Sorted on render, so the order won't suddenly change based on current locale
|
// Sorted on render, so the order won't suddenly change based on current locale
|
||||||
const populatedLocales = useMemo(() => {
|
const populatedLocales = useMemo(() => {
|
||||||
return LOCALES.map((lang) => {
|
return LOCALES.map((lang) => {
|
||||||
if (lang === 'pseudo-LOCALE') {
|
|
||||||
return { code: lang, native: 'Pseudolocalization (test)' };
|
|
||||||
}
|
|
||||||
|
|
||||||
// Don't need regions for now, it makes text too noisy
|
// Don't need regions for now, it makes text too noisy
|
||||||
// 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, '');
|
||||||
|
@ -45,9 +41,6 @@ export default function LangSelector() {
|
||||||
native,
|
native,
|
||||||
};
|
};
|
||||||
}).sort((a, b) => {
|
}).sort((a, b) => {
|
||||||
// If pseudo-LOCALE, always put it at the bottom
|
|
||||||
if (a.code === 'pseudo-LOCALE') return 1;
|
|
||||||
if (b.code === 'pseudo-LOCALE') return -1;
|
|
||||||
// Sort by common name
|
// Sort by common name
|
||||||
const order = a._common.localeCompare(b._common, i18n.locale);
|
const order = a._common.localeCompare(b._common, i18n.locale);
|
||||||
if (order !== 0) return order;
|
if (order !== 0) return order;
|
||||||
|
@ -70,16 +63,6 @@ export default function LangSelector() {
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{populatedLocales.map(({ code, regionlessCode, native }) => {
|
{populatedLocales.map(({ code, regionlessCode, native }) => {
|
||||||
if (code === 'pseudo-LOCALE') {
|
|
||||||
return (
|
|
||||||
<>
|
|
||||||
<hr />
|
|
||||||
<option value={code} key={code}>
|
|
||||||
{native}
|
|
||||||
</option>
|
|
||||||
</>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
// Common name changes based on current locale
|
// Common name changes based on current locale
|
||||||
const common = localeCode2Text({
|
const common = localeCode2Text({
|
||||||
code: regionlessCode,
|
code: regionlessCode,
|
||||||
|
@ -97,6 +80,33 @@ export default function LangSelector() {
|
||||||
</option>
|
</option>
|
||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
|
{(import.meta.env.DEV || import.meta.env.PHANPY_SHOW_DEV_LOCALES) && (
|
||||||
|
<optgroup label="🚧 Development (<50% translated)">
|
||||||
|
{DEV_LOCALES.map((code) => {
|
||||||
|
if (code === 'pseudo-LOCALE') {
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<hr />
|
||||||
|
<option value={code} key={code}>
|
||||||
|
Pseudolocalization (test)
|
||||||
|
</option>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
const nativeName = CATALOGS.find(
|
||||||
|
(c) => c.code === code,
|
||||||
|
)?.nativeName;
|
||||||
|
const completion = CATALOGS.find(
|
||||||
|
(c) => c.code === code,
|
||||||
|
)?.completion;
|
||||||
|
return (
|
||||||
|
<option value={code} key={code}>
|
||||||
|
{nativeName || code} ‎[{completion}%]
|
||||||
|
</option>
|
||||||
|
);
|
||||||
|
})}
|
||||||
|
</optgroup>
|
||||||
|
)}
|
||||||
</select>
|
</select>
|
||||||
</label>
|
</label>
|
||||||
);
|
);
|
||||||
|
|
|
@ -12,7 +12,15 @@ const locales = [
|
||||||
.filter(({ completion }) => completion >= PERCENTAGE_THRESHOLD)
|
.filter(({ completion }) => completion >= PERCENTAGE_THRESHOLD)
|
||||||
.map(({ code }) => code),
|
.map(({ code }) => code),
|
||||||
];
|
];
|
||||||
if (import.meta.env.DEV) {
|
|
||||||
locales.push('pseudo-LOCALE');
|
|
||||||
}
|
|
||||||
export const LOCALES = locales;
|
export const LOCALES = locales;
|
||||||
|
|
||||||
|
let devLocales = [];
|
||||||
|
if (import.meta.env.DEV || import.meta.env.PHANPY_SHOW_DEV_LOCALES) {
|
||||||
|
devLocales = catalogs
|
||||||
|
.filter(({ completion }) => completion < PERCENTAGE_THRESHOLD)
|
||||||
|
.map(({ code }) => code);
|
||||||
|
devLocales.push('pseudo-LOCALE');
|
||||||
|
}
|
||||||
|
export const DEV_LOCALES = devLocales;
|
||||||
|
|
||||||
|
export const ALL_LOCALES = [...locales, ...devLocales];
|
||||||
|
|
|
@ -7,7 +7,7 @@ import {
|
||||||
} from '@lingui/detect-locale';
|
} from '@lingui/detect-locale';
|
||||||
import Locale from 'intl-locale-textinfo-polyfill';
|
import Locale from 'intl-locale-textinfo-polyfill';
|
||||||
|
|
||||||
import { DEFAULT_LANG, LOCALES } from '../locales';
|
import { ALL_LOCALES, DEFAULT_LANG } from '../locales';
|
||||||
import { messages } from '../locales/en.po';
|
import { messages } from '../locales/en.po';
|
||||||
import localeMatch from '../utils/locale-match';
|
import localeMatch from '../utils/locale-match';
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ export function initActivateLang() {
|
||||||
DEFAULT_LANG,
|
DEFAULT_LANG,
|
||||||
);
|
);
|
||||||
const matchedLang =
|
const matchedLang =
|
||||||
LOCALES.find((l) => l === lang) || localeMatch(lang, LOCALES);
|
ALL_LOCALES.find((l) => l === lang) || localeMatch(lang, ALL_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