Skip to content

Commit

Permalink
Show all locales, <50% complete will be called devLocales
Browse files Browse the repository at this point in the history
Dev locales show on dev or based on env var PHANPY_SHOW_DEV_LOCALES
  • Loading branch information
cheeaun committed Aug 21, 2024
1 parent cea06f3 commit 25d73c4
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 25 deletions.
4 changes: 2 additions & 2 deletions lingui.config.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { LOCALES } from './src/locales';
import { ALL_LOCALES } from './src/locales';

const config = {
locales: LOCALES,
locales: ALL_LOCALES,
sourceLocale: 'en',
pseudoLocale: 'pseudo-LOCALE',
fallbackLocales: {
Expand Down
46 changes: 28 additions & 18 deletions src/components/lang-selector.jsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { useLingui } from '@lingui/react';
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 localeCode2Text from '../utils/localeCode2Text';

Expand All @@ -16,10 +16,6 @@ export default function LangSelector() {
// Sorted on render, so the order won't suddenly change based on current locale
const populatedLocales = useMemo(() => {
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
// Wait till there's too many languages and there are regional clashes
const regionlessCode = regionMaps[lang] || lang.replace(/-[a-z]+$/i, '');
Expand All @@ -45,9 +41,6 @@ export default function LangSelector() {
native,
};
}).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
const order = a._common.localeCompare(b._common, i18n.locale);
if (order !== 0) return order;
Expand All @@ -70,16 +63,6 @@ export default function LangSelector() {
}}
>
{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
const common = localeCode2Text({
code: regionlessCode,
Expand All @@ -97,6 +80,33 @@ export default function LangSelector() {
</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} &lrm;[{completion}%]
</option>
);
})}
</optgroup>
)}
</select>
</label>
);
Expand Down
14 changes: 11 additions & 3 deletions src/locales.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,15 @@ const locales = [
.filter(({ completion }) => completion >= PERCENTAGE_THRESHOLD)
.map(({ code }) => code),
];
if (import.meta.env.DEV) {
locales.push('pseudo-LOCALE');
}
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];
4 changes: 2 additions & 2 deletions src/utils/lang.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
} from '@lingui/detect-locale';
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 localeMatch from '../utils/locale-match';

Expand Down Expand Up @@ -62,7 +62,7 @@ export function initActivateLang() {
DEFAULT_LANG,
);
const matchedLang =
LOCALES.find((l) => l === lang) || localeMatch(lang, LOCALES);
ALL_LOCALES.find((l) => l === lang) || localeMatch(lang, ALL_LOCALES);
activateLang(matchedLang);

// const yes = confirm(t`Reload to apply language setting?`);
Expand Down

0 comments on commit 25d73c4

Please sign in to comment.