aboutsummaryrefslogtreecommitdiff
path: root/Timeline/ClientApp/src/i18n.ts
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-05-30 16:23:25 +0800
committercrupest <crupest@outlook.com>2020-05-30 16:23:25 +0800
commit68ca8b0976efe90c0c40bcae69f0825671b98bad (patch)
tree9333baf56fd4e20e1e98edcc6afbbde9d82dcd3f /Timeline/ClientApp/src/i18n.ts
parent7e393559d2883a37b1be0c82cccc06bc97c3d102 (diff)
downloadtimeline-68ca8b0976efe90c0c40bcae69f0825671b98bad.tar.gz
timeline-68ca8b0976efe90c0c40bcae69f0825671b98bad.tar.bz2
timeline-68ca8b0976efe90c0c40bcae69f0825671b98bad.zip
Merge front end to this repo. But I need to wait for aspnet core support for custom port and package manager for dev server.
Diffstat (limited to 'Timeline/ClientApp/src/i18n.ts')
-rw-r--r--Timeline/ClientApp/src/i18n.ts80
1 files changed, 80 insertions, 0 deletions
diff --git a/Timeline/ClientApp/src/i18n.ts b/Timeline/ClientApp/src/i18n.ts
new file mode 100644
index 00000000..9f3a0801
--- /dev/null
+++ b/Timeline/ClientApp/src/i18n.ts
@@ -0,0 +1,80 @@
+import i18n, { BackendModule, ResourceKey } from 'i18next';
+import LanguageDetector from 'i18next-browser-languagedetector';
+import { initReactI18next } from 'react-i18next';
+
+const backend: BackendModule = {
+ type: 'backend',
+ async read(language, namespace, callback) {
+ function error(message: string): void {
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
+ callback(new Error(message), false as any);
+ }
+
+ function success(result: ResourceKey): void {
+ callback(null, result);
+ }
+
+ if (namespace !== 'translation') {
+ error("Namespace must be 'translation'.");
+ }
+
+ if (language === 'en') {
+ const res = (
+ await import(
+ /* webpackChunkName: "locales-en" */ './locales/en/translation'
+ )
+ ).default;
+ success(res);
+ } else if (language === 'zh') {
+ const res = (
+ await import(
+ /* webpackChunkName: "locales-zh" */ './locales/zh/translation'
+ )
+ ).default;
+ success(res);
+ } else {
+ error(`Language ${language} is not supported.`);
+ }
+ },
+ init() {}, // eslint-disable-line @typescript-eslint/no-empty-function
+ create() {} // eslint-disable-line @typescript-eslint/no-empty-function
+};
+
+export const i18nPromise = i18n
+ .use(LanguageDetector)
+ .use(backend)
+ .use(initReactI18next) // bind react-i18next to the instance
+ .init({
+ fallbackLng: 'en',
+ lowerCaseLng: true,
+
+ debug: process.env.NODE_ENV === 'development',
+
+ interpolation: {
+ escapeValue: false // not needed for react!!
+ }
+
+ // react i18next special options (optional)
+ // override if needed - omit if ok with defaults
+ /*
+ react: {
+ bindI18n: 'languageChanged',
+ bindI18nStore: '',
+ transEmptyNodeValue: '',
+ transSupportBasicHtmlNodes: true,
+ transKeepBasicHtmlNodesFor: ['br', 'strong', 'i'],
+ useSuspense: true,
+ }
+ */
+ });
+
+if (module.hot) {
+ module.hot.accept(
+ ['./locales/en/translation', './locales/zh/translation'],
+ () => {
+ i18n.reloadResources();
+ }
+ );
+}
+
+export default i18n;