diff options
author | crupest <crupest@outlook.com> | 2020-11-11 23:43:19 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-11-11 23:43:19 +0800 |
commit | 6281ccaee525300c5aa303404584b8ce489ebeb2 (patch) | |
tree | 53a1fd24db0aad634ab929da5f58329643c69e8d | |
parent | 6ec7f243308fdcbde1eedd92045bc84601fe00f0 (diff) | |
download | timeline-6281ccaee525300c5aa303404584b8ce489ebeb2.tar.gz timeline-6281ccaee525300c5aa303404584b8ce489ebeb2.tar.bz2 timeline-6281ccaee525300c5aa303404584b8ce489ebeb2.zip |
feat: Add admin i18n.
-rw-r--r-- | FrontEnd/src/app/i18n.ts | 41 | ||||
-rw-r--r-- | FrontEnd/src/app/locales/en/admin.json | 1 | ||||
-rw-r--r-- | FrontEnd/src/app/locales/zh/admin.json | 1 |
3 files changed, 31 insertions, 12 deletions
diff --git a/FrontEnd/src/app/i18n.ts b/FrontEnd/src/app/i18n.ts index c39888ed..5b8e9d41 100644 --- a/FrontEnd/src/app/i18n.ts +++ b/FrontEnd/src/app/i18n.ts @@ -13,18 +13,30 @@ const backend: BackendModule = { callback(null, result); } - if (namespace !== "translation") { - error("Namespace must be 'translation'."); - } + const promise = (() => { + if (namespace === "translation") { + if (language === "en") { + return import("./locales/en/translation.json"); + } else if (language === "zh") { + return import("./locales/zh/translation.json"); + } else { + error(`Language ${language} is not supported.`); + } + } else if (namespace === "admin") { + if (language === "en") { + return import("./locales/en/admin.json"); + } else if (language === "zh") { + return import("./locales/zh/admin.json"); + } else { + error(`Language ${language} is not supported.`); + } + } else { + error(`Namespace ${namespace} is not supported.`); + } + })(); - if (language === "en") { - const res = (await import("./locales/en/translation.json")).default; - success(res); - } else if (language === "zh") { - const res = (await import("./locales/zh/translation.json")).default; - success(res); - } else { - error(`Language ${language} is not supported.`); + if (promise) { + success((await promise).default); } }, init() {}, // eslint-disable-line @typescript-eslint/no-empty-function @@ -61,7 +73,12 @@ export const i18nPromise = i18n if (module.hot) { module.hot.accept( - ["./locales/en/translation.json", "./locales/zh/translation.json"], + [ + "./locales/en/translation.json", + "./locales/zh/translation.json", + "./locales/en/admin.json", + "./locales/zh/admin.json", + ], () => { void i18n.reloadResources(); } diff --git a/FrontEnd/src/app/locales/en/admin.json b/FrontEnd/src/app/locales/en/admin.json new file mode 100644 index 00000000..69a88e3b --- /dev/null +++ b/FrontEnd/src/app/locales/en/admin.json @@ -0,0 +1 @@ +{}
diff --git a/FrontEnd/src/app/locales/zh/admin.json b/FrontEnd/src/app/locales/zh/admin.json new file mode 100644 index 00000000..69a88e3b --- /dev/null +++ b/FrontEnd/src/app/locales/zh/admin.json @@ -0,0 +1 @@ +{}
|