Merge branch 'shilangyu-feature/i18n-type-constraint'

This commit is contained in:
Dessalines 2021-03-01 16:25:34 -05:00
commit cc215fe99f
3 changed files with 59 additions and 13 deletions

View file

@ -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);
});

View file

@ -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);

View file

@ -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 };