mirror of
https://github.com/LemmyNet/lemmy-ui.git
synced 2024-11-23 04:41:14 +00:00
Merge branch 'shilangyu-feature/i18n-type-constraint'
This commit is contained in:
commit
cc215fe99f
3 changed files with 59 additions and 13 deletions
|
@ -1,27 +1,68 @@
|
||||||
fs = require('fs');
|
const fs = require("fs");
|
||||||
|
|
||||||
let translationDir = 'lemmy-translations/translations/';
|
const translationDir = "lemmy-translations/translations/";
|
||||||
let outDir = 'src/shared/translations/';
|
const outDir = "src/shared/translations/";
|
||||||
fs.mkdirSync(outDir, { recursive: true });
|
fs.mkdirSync(outDir, { recursive: true });
|
||||||
fs.readdir(translationDir, (_err, files) => {
|
fs.readdir(translationDir, (_err, files) => {
|
||||||
files.forEach(filename => {
|
files.forEach(filename => {
|
||||||
const lang = filename.split('.')[0];
|
const lang = filename.split(".")[0];
|
||||||
try {
|
try {
|
||||||
const json = JSON.parse(
|
const json = JSON.parse(
|
||||||
fs.readFileSync(translationDir + filename, 'utf8')
|
fs.readFileSync(translationDir + filename, "utf8")
|
||||||
);
|
);
|
||||||
var data = `export const ${lang} = {\n translation: {`;
|
let data = `export const ${lang} = {\n translation: {`;
|
||||||
for (var key in json) {
|
for (const key in json) {
|
||||||
if (key in json) {
|
if (key in json) {
|
||||||
const value = json[key].replace(/"/g, '\\"');
|
const value = json[key].replace(/"/g, '\\"');
|
||||||
data = `${data}\n ${key}: "${value}",`;
|
data += `\n ${key}: "${value}",`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
data += '\n },\n};';
|
data += "\n },\n};";
|
||||||
const target = outDir + lang + '.ts';
|
const target = outDir + lang + ".ts";
|
||||||
fs.writeFileSync(target, data);
|
fs.writeFileSync(target, data);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
console.error(err);
|
console.error(err);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// generate types for i18n keys
|
||||||
|
const baseLanguage = "en";
|
||||||
|
|
||||||
|
fs.readFile(`${translationDir}${baseLanguage}.json`, "utf8", (_, fileStr) => {
|
||||||
|
const keys = Object.keys(JSON.parse(fileStr));
|
||||||
|
|
||||||
|
const data = `import { i18n } from "i18next";
|
||||||
|
|
||||||
|
declare module "i18next" {
|
||||||
|
export type I18nKeys =
|
||||||
|
${keys.map(key => ` | "${key}"`).join("\n")};
|
||||||
|
|
||||||
|
export interface TFunctionTyped {
|
||||||
|
// basic usage
|
||||||
|
<
|
||||||
|
TResult extends TFunctionResult = string,
|
||||||
|
TInterpolationMap extends Record<string, unknown> = StringMap
|
||||||
|
>(
|
||||||
|
key: I18nKeys | I18nKeys[],
|
||||||
|
options?: TOptions<TInterpolationMap> | string
|
||||||
|
): TResult;
|
||||||
|
// overloaded usage
|
||||||
|
<
|
||||||
|
TResult extends TFunctionResult = string,
|
||||||
|
TInterpolationMap extends Record<string, unknown> = StringMap
|
||||||
|
>(
|
||||||
|
key: I18nKeys | I18nKeys[],
|
||||||
|
defaultValue?: string,
|
||||||
|
options?: TOptions<TInterpolationMap> | string
|
||||||
|
): TResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface i18nTyped extends i18n {
|
||||||
|
t: TFunctionTyped;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
fs.writeFileSync(`${outDir}i18next.d.ts`, data);
|
||||||
|
});
|
||||||
|
|
|
@ -1,8 +1,11 @@
|
||||||
|
import { I18nKeys } from "i18next";
|
||||||
import { Component } from "inferno";
|
import { Component } from "inferno";
|
||||||
import { i18n } from "../i18next";
|
import { i18n } from "../i18next";
|
||||||
|
|
||||||
export class NoMatch extends Component<any, any> {
|
export class NoMatch extends Component<any, any> {
|
||||||
private errCode = new URLSearchParams(this.props.location.search).get("err");
|
private errCode = new URLSearchParams(this.props.location.search).get(
|
||||||
|
"err"
|
||||||
|
) as I18nKeys;
|
||||||
|
|
||||||
constructor(props: any, context: any) {
|
constructor(props: any, context: any) {
|
||||||
super(props, context);
|
super(props, context);
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import i18next from "i18next";
|
import i18next, { i18nTyped } from "i18next";
|
||||||
import { getLanguage } from "./utils";
|
import { getLanguage } from "./utils";
|
||||||
import { en } from "./translations/en";
|
import { en } from "./translations/en";
|
||||||
import { el } from "./translations/el";
|
import { el } from "./translations/el";
|
||||||
|
@ -84,4 +84,6 @@ i18next.init({
|
||||||
interpolation: { format },
|
interpolation: { format },
|
||||||
});
|
});
|
||||||
|
|
||||||
export { i18next as i18n, resources };
|
export const i18n = i18next as i18nTyped;
|
||||||
|
|
||||||
|
export { resources };
|
||||||
|
|
Loading…
Reference in a new issue