From 5579f4b482c0b5350a1468432522f9e16f4bf4fd Mon Sep 17 00:00:00 2001 From: Dessalines Date: Sun, 19 Jan 2020 16:23:04 -0500 Subject: Automatically update translation report. Fixes #439 --- ui/package.json | 2 +- ui/translation_report.ts | 65 +++++++++++++++++++++++++++++++----------------- 2 files changed, 43 insertions(+), 24 deletions(-) (limited to 'ui') diff --git a/ui/package.json b/ui/package.json index a2767e4a..ea6343da 100644 --- a/ui/package.json +++ b/ui/package.json @@ -57,7 +57,7 @@ "engineStrict": true, "husky": { "hooks": { - "pre-commit": "cargo clippy --manifest-path ../server/Cargo.toml --all-targets --all-features -- -D warnings && lint-staged" + "pre-commit": "ts-node translation_report.ts && git add ../README.md && cargo clippy --manifest-path ../server/Cargo.toml --all-targets --all-features -- -D warnings && lint-staged" } }, "lint-staged": { diff --git a/ui/translation_report.ts b/ui/translation_report.ts index 1975cfa5..71a09559 100644 --- a/ui/translation_report.ts +++ b/ui/translation_report.ts @@ -8,31 +8,50 @@ import { sv } from './src/translations/sv'; import { ru } from './src/translations/ru'; import { nl } from './src/translations/nl'; import { it } from './src/translations/it'; +import fs from 'fs'; -let files = [ - { t: de, n: 'de' }, - { t: eo, n: 'eo' }, - { t: es, n: 'es' }, - { t: fr, n: 'fr' }, - { t: it, n: 'it' }, - { t: nl, n: 'nl' }, - { t: ru, n: 'ru' }, - { t: sv, n: 'sv' }, - { t: zh, n: 'zh' }, -]; -let masterKeys = Object.keys(en.translation); - -let report = 'lang | done | missing\n'; -report += '--- | --- | ---\n'; - -for (let file of files) { - let keys = Object.keys(file.t.translation); - let pct: number = (keys.length / masterKeys.length) * 100; - let missing = difference(masterKeys, keys); - report += `${file.n} | ${pct.toFixed(0)}% | ${missing} \n`; -} +let readmePath = '../README.md'; + +let open = ''; +let close = ''; + +let readmeTxt = fs.readFileSync(readmePath, { encoding: 'utf8' }); + +let before = readmeTxt.split(open)[0]; +let after = readmeTxt.split(close)[1]; + +let report = buildReport(); + +let alteredReadmeTxt = `${before}${open}\n\n${report}\n${close}${after}`; -console.log(report); +fs.writeFileSync(readmePath, alteredReadmeTxt); + +function buildReport(): string { + let files = [ + { t: de, n: 'de' }, + { t: eo, n: 'eo' }, + { t: es, n: 'es' }, + { t: fr, n: 'fr' }, + { t: it, n: 'it' }, + { t: nl, n: 'nl' }, + { t: ru, n: 'ru' }, + { t: sv, n: 'sv' }, + { t: zh, n: 'zh' }, + ]; + let masterKeys = Object.keys(en.translation); + + let report = 'lang | done | missing\n'; + report += '--- | --- | ---\n'; + + for (let file of files) { + let keys = Object.keys(file.t.translation); + let pct: number = (keys.length / masterKeys.length) * 100; + let missing = difference(masterKeys, keys); + report += `${file.n} | ${pct.toFixed(0)}% | ${missing} \n`; + } + + return report; +} function difference(a: Array, b: Array): Array { return a.filter(x => !b.includes(x)); -- cgit v1.2.3