From 188ac58a22bef7935840314eaf149ac6cc9d3f05 Mon Sep 17 00:00:00 2001 From: Bert Verhelst Date: Sun, 31 Oct 2021 20:15:03 +0100 Subject: [PATCH] fix: default untranslated keys to English if available --- extra/extract-translations.js | 4 +- extra/update-language-files/.gitignore | 3 - extra/update-language-files/index.js | 86 ---------------- extra/update-language-files/package.json | 12 --- package-lock.json | 73 ++++++++++++- package.json | 2 - src/components/NotificationDialog.vue | 18 ++-- src/components/notifications/index.js | 126 ++++++++++++++++++----- src/languages/README.md | 2 +- 9 files changed, 185 insertions(+), 141 deletions(-) delete mode 100644 extra/update-language-files/.gitignore delete mode 100644 extra/update-language-files/index.js delete mode 100644 extra/update-language-files/package.json diff --git a/extra/extract-translations.js b/extra/extract-translations.js index 6101edc..edcefbe 100644 --- a/extra/extract-translations.js +++ b/extra/extract-translations.js @@ -61,7 +61,7 @@ async function extractTranslations() { for (let extractedTranslation of englishExtracted) { for (let langDict of Object.values(languageList)) { if (!Object.keys(langDict).includes(extractedTranslation)) { - langDict[extractedTranslation] = extractedTranslation; + langDict[extractedTranslation] = en[extractedTranslation] || extractedTranslation; } } } @@ -78,6 +78,7 @@ async function extractTranslations() { } } + // Write the translation string json back to files for (let langName of Object.keys(languageList)) { const translationsString = JSON5.stringify(languageList[langName], { quote: "\"", @@ -87,6 +88,7 @@ async function extractTranslations() { await fs.writeFile(`./src/languages/${_.kebabCase(langName)}.js`, `export default ${translationsString};\n`); } + // Output warnings if there are any if (warnings.length) { console.log("Extraction successful with warnings: \n\t" + warnings.join("\n\t")); } else { diff --git a/extra/update-language-files/.gitignore b/extra/update-language-files/.gitignore deleted file mode 100644 index 410c913..0000000 --- a/extra/update-language-files/.gitignore +++ /dev/null @@ -1,3 +0,0 @@ -package-lock.json -test.js -languages/ diff --git a/extra/update-language-files/index.js b/extra/update-language-files/index.js deleted file mode 100644 index 7ba30cc..0000000 --- a/extra/update-language-files/index.js +++ /dev/null @@ -1,86 +0,0 @@ -// Need to use ES6 to read language files - -import fs from "fs"; -import path from "path"; -import util from "util"; - -// https://stackoverflow.com/questions/13786160/copy-folder-recursively-in-node-js -/** - * Look ma, it's cp -R. - * @param {string} src The path to the thing to copy. - * @param {string} dest The path to the new copy. - */ -const copyRecursiveSync = function (src, dest) { - let exists = fs.existsSync(src); - let stats = exists && fs.statSync(src); - let isDirectory = exists && stats.isDirectory(); - - if (isDirectory) { - fs.mkdirSync(dest); - fs.readdirSync(src).forEach(function (childItemName) { - copyRecursiveSync(path.join(src, childItemName), - path.join(dest, childItemName)); - }); - } else { - fs.copyFileSync(src, dest); - } -}; - -console.log("Arguments:", process.argv); -const baseLangCode = process.argv[2] || "en"; -console.log("Base Lang: " + baseLangCode); -if (fs.existsSync("./languages")) { - fs.rmdirSync("./languages", { recursive: true }); -} -copyRecursiveSync("../../src/languages", "./languages"); - -const en = (await import("./languages/en.js")).default; -const baseLang = (await import(`./languages/${baseLangCode}.js`)).default; -const files = fs.readdirSync("./languages"); -console.log("Files:", files); - -for (const file of files) { - if (!file.endsWith(".js")) { - console.log("Skipping " + file); - continue; - } - - console.log("Processing " + file); - const lang = await import("./languages/" + file); - - let obj; - - if (lang.default) { - obj = lang.default; - } else { - console.log("Empty file"); - obj = { - languageName: "" - }; - } - - // En first - for (const key in en) { - if (! obj[key]) { - obj[key] = en[key]; - } - } - - if (baseLang !== en) { - // Base second - for (const key in baseLang) { - if (! obj[key]) { - obj[key] = key; - } - } - } - - const code = "export default " + util.inspect(obj, { - depth: null, - }); - - fs.writeFileSync(`../../src/languages/${file}`, code); -} - -fs.rmdirSync("./languages", { recursive: true }); -console.log("Done. Fixing formatting by ESLint..."); diff --git a/extra/update-language-files/package.json b/extra/update-language-files/package.json deleted file mode 100644 index c729517..0000000 --- a/extra/update-language-files/package.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "name": "update-language-files", - "type": "module", - "version": "1.0.0", - "description": "", - "main": "index.js", - "scripts": { - "test": "echo \"Error: no test specified\" && exit 1" - }, - "author": "", - "license": "ISC" -} diff --git a/package-lock.json b/package-lock.json index 11feb34..7ddbcc1 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "uptime-kuma", - "version": "1.9.2", + "version": "1.10.0", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "uptime-kuma", - "version": "1.9.2", + "version": "1.10.0", "license": "MIT", "dependencies": { "@fortawesome/fontawesome-svg-core": "~1.2.36", @@ -76,8 +76,11 @@ "dns2": "~2.0.1", "eslint": "~7.32.0", "eslint-plugin-vue": "~7.18.0", + "find-in-files": "^0.5.0", "jest": "~27.2.4", "jest-puppeteer": "~6.0.0", + "json5": "^2.2.0", + "lodash": "^4.17.21", "puppeteer": "~10.4.0", "sass": "~1.42.1", "stylelint": "~13.13.1", @@ -6238,6 +6241,15 @@ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" }, + "node_modules/find": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/find/-/find-0.1.7.tgz", + "integrity": "sha1-yGyHrxqxjyIrvjjeyGy8dg0Wpvs=", + "dev": true, + "dependencies": { + "traverse-chain": "~0.1.0" + } + }, "node_modules/find-file-up": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/find-file-up/-/find-file-up-0.1.3.tgz", @@ -6251,6 +6263,16 @@ "node": ">=0.10.0" } }, + "node_modules/find-in-files": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/find-in-files/-/find-in-files-0.5.0.tgz", + "integrity": "sha512-VraTc6HdtdSHmAp0yJpAy20yPttGKzyBWc7b7FPnnsX9TOgmKx0g9xajizpF/iuu4IvNK4TP0SpyBT9zAlwG+g==", + "dev": true, + "dependencies": { + "find": "^0.1.5", + "q": "^1.0.1" + } + }, "node_modules/find-pkg": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/find-pkg/-/find-pkg-0.1.2.tgz", @@ -11591,6 +11613,16 @@ } } }, + "node_modules/q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", + "dev": true, + "engines": { + "node": ">=0.6.0", + "teleport": ">=0.2.0" + } + }, "node_modules/qrcode": { "version": "1.4.4", "resolved": "https://registry.npmjs.org/qrcode/-/qrcode-1.4.4.tgz", @@ -13745,6 +13777,12 @@ "node": ">=8" } }, + "node_modules/traverse-chain": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/traverse-chain/-/traverse-chain-0.1.0.tgz", + "integrity": "sha1-YdvC1Ttp/2CRoSoWj9fUMxB+QPE=", + "dev": true + }, "node_modules/tree-kill": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", @@ -19500,6 +19538,15 @@ } } }, + "find": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/find/-/find-0.1.7.tgz", + "integrity": "sha1-yGyHrxqxjyIrvjjeyGy8dg0Wpvs=", + "dev": true, + "requires": { + "traverse-chain": "~0.1.0" + } + }, "find-file-up": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/find-file-up/-/find-file-up-0.1.3.tgz", @@ -19510,6 +19557,16 @@ "resolve-dir": "^0.1.0" } }, + "find-in-files": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/find-in-files/-/find-in-files-0.5.0.tgz", + "integrity": "sha512-VraTc6HdtdSHmAp0yJpAy20yPttGKzyBWc7b7FPnnsX9TOgmKx0g9xajizpF/iuu4IvNK4TP0SpyBT9zAlwG+g==", + "dev": true, + "requires": { + "find": "^0.1.5", + "q": "^1.0.1" + } + }, "find-pkg": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/find-pkg/-/find-pkg-0.1.2.tgz", @@ -23526,6 +23583,12 @@ } } }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", + "dev": true + }, "qrcode": { "version": "1.4.4", "resolved": "https://registry.npmjs.org/qrcode/-/qrcode-1.4.4.tgz", @@ -25200,6 +25263,12 @@ "punycode": "^2.1.1" } }, + "traverse-chain": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/traverse-chain/-/traverse-chain-0.1.0.tgz", + "integrity": "sha1-YdvC1Ttp/2CRoSoWj9fUMxB+QPE=", + "dev": true + }, "tree-kill": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", diff --git a/package.json b/package.json index 691d411..5920c10 100644 --- a/package.json +++ b/package.json @@ -48,8 +48,6 @@ "test-install-script-ubuntu1604": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/ubuntu1604.dockerfile .", "test-nodejs16": "docker build --progress plain -f test/ubuntu-nodejs16.dockerfile .", "simple-dns-server": "node extra/simple-dns-server.js", - "update-language-files-with-base-lang": "cd extra/update-language-files && node index.js %npm_config_base_lang% && eslint ../../src/languages/**.js --fix", - "update-language-files": "cd extra/update-language-files && node index.js && eslint ../../src/languages/**.js --fix", "extract-translations": "node extra/extract-translations.js" }, "dependencies": { diff --git a/src/components/NotificationDialog.vue b/src/components/NotificationDialog.vue index 362d9d3..241557d 100644 --- a/src/components/NotificationDialog.vue +++ b/src/components/NotificationDialog.vue @@ -13,7 +13,7 @@
@@ -69,10 +69,9 @@