From c93550681f3373062d490a3c3a1836c72e034adc Mon Sep 17 00:00:00 2001
From: Manuel Kocher <manuel.kocher@tugraz.at>
Date: Wed, 17 Aug 2022 11:08:50 +0200
Subject: [PATCH] Remove i18n from adapter, add translation overrides to all
 components that use i18n

---
 packages/common/src/adapter-lit-element.js    | 14 --------
 packages/common/src/translation.js            | 14 ++++++--
 .../data-table-view/src/data-table-view.js    |  8 ++++-
 packages/data-table-view/src/i18n.js          |  4 ++-
 packages/file-handling/src/clipboard.js       | 11 ++++--
 packages/file-handling/src/file-sink.js       |  7 +++-
 packages/file-handling/src/file-source.js     | 13 ++++---
 packages/file-handling/src/i18n.js            |  4 ++-
 .../src/nextcloud-file-picker.js              | 36 +++++++++++--------
 ...owledge-base-web-page-element-view-demo.js | 12 ++++++-
 .../src/i18n.js                               |  4 ++-
 .../knowledge-base-web-page-element-view.js   | 10 +++++-
 packages/matomo/src/dbp-matomo-demo.js        | 13 ++++++-
 packages/matomo/src/i18n.js                   |  4 ++-
 .../notification/src/dbp-notification-demo.js | 12 ++++++-
 packages/notification/src/i18n.js             |  4 ++-
 packages/notification/src/notification.js     |  7 +++-
 .../src/dbp-person-profile-demo.js            |  7 +++-
 packages/person-profile/src/i18n.js           |  4 ++-
 packages/person-profile/src/person-profile.js | 11 +++++-
 .../src/dbp-person-select-demo.js             | 12 ++++++-
 packages/person-select/src/i18n.js            |  4 ++-
 packages/person-select/src/person-select.js   |  9 +++--
 packages/provider/src/dbp-provider-demo.js    | 13 +++++--
 packages/provider/src/i18n.js                 |  4 ++-
 .../src/dbp-qr-code-scanner-demo.js           | 11 ++++--
 packages/qr-code-scanner/src/i18n.js          |  4 ++-
 .../qr-code-scanner/src/qr-code-scanner.js    |  9 +++--
 .../src/dbp-resource-select-demo.js           | 12 ++++++-
 packages/resource-select/src/i18n.js          |  4 ++-
 .../resource-select/src/resource-select.js    |  8 ++++-
 packages/theme-switcher/src/theme-switcher.js |  8 ++++-
 packages/tooltip/src/dbp-tooltip-demo.js      | 12 ++++++-
 packages/tooltip/src/i18n.js                  |  4 ++-
 packages/typescript-example/src/i18n.ts       |  4 ++-
 .../src/typescript-example.ts                 | 14 +++++++-
 36 files changed, 259 insertions(+), 72 deletions(-)

diff --git a/packages/common/src/adapter-lit-element.js b/packages/common/src/adapter-lit-element.js
index 5d46a75b..aebc8115 100644
--- a/packages/common/src/adapter-lit-element.js
+++ b/packages/common/src/adapter-lit-element.js
@@ -1,6 +1,5 @@
 import {LitElement} from 'lit';
 import {Logger} from './logger';
-import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 
 export class AdapterLitElement extends LitElement {
     constructor() {
@@ -15,10 +14,6 @@ export class AdapterLitElement extends LitElement {
         this.subscribe = '';
         this.unsubscribe = '';
 
-        // dir and i18next instance of translation overrides
-        this._i18n = createInstance();
-        this.langDir = '';
-
         this.callbackStore = [];
 
         // Previously we used direct properties like this["lang"] (instead of this.propertyStore["lang"]) for storing the
@@ -84,11 +79,6 @@ export class AdapterLitElement extends LitElement {
 
         this.connected = true;
 
-        // use translation overrides if path is given
-        if(this.langDir != '') {
-          setOverridesByGlobalCache(this._i18n, this);
-        }
-
         const that = this;
 
         this.addEventListener(
@@ -276,10 +266,6 @@ export class AdapterLitElement extends LitElement {
                             value
                     );
 
-                    if(this.langDir) {
-                      setOverridesByGlobalCache(this._i18n, this);
-                    }
-
                     // If value is an object set it directly as property
                     if (typeof value === 'object' && value !== null) {
                         // Logger.debug("value is object", value);
diff --git a/packages/common/src/translation.js b/packages/common/src/translation.js
index bb4ea411..58eb373e 100644
--- a/packages/common/src/translation.js
+++ b/packages/common/src/translation.js
@@ -2,7 +2,7 @@ import {html} from 'lit';
 import {unsafeHTML} from 'lit/directives/unsafe-html.js';
 import DBPLitElement from '../dbp-lit-element';
 import * as commonStyles from '../styles.js';
-import {getOverrideNamespace, setOverridesByGlobalCache} from './i18n.js';
+import {getOverrideNamespace, setOverridesByGlobalCache, createInstance} from './i18n.js';
 
 export class Translation extends DBPLitElement {
     constructor() {
@@ -11,6 +11,11 @@ export class Translation extends DBPLitElement {
         this.lang = '';
         this.interpolation = '';
         this.unsafe = false;
+
+        // dir and i18next instance of translation overrides
+        this._i18n = createInstance();
+        this.langDir = '';
+
     }
 
     static get properties() {
@@ -37,6 +42,11 @@ export class Translation extends DBPLitElement {
       // get overrides everytime
       setOverridesByGlobalCache(this._i18n, this);
 
+      // use translation overrides if path is given
+      //if(this.langDir != '') {
+      //  setOverridesByGlobalCache(this._i18n, this);
+      //}
+
       // supercall after default i18n init to override translations only
       // if a override with this tagname is given
       super.connectedCallback();
@@ -84,7 +94,7 @@ export class Translation extends DBPLitElement {
         } else if (this._i18n.hasResourceBundle(this.lang, overrideNamespace)){
           keyComment = unsafeHTML("<!-- key '" + this.key + "' not found! -->");
           translation = "";
-          console.error("Key '" + this.key + "' not found! " + this._i18n.t(this.key));
+          console.error("Key '" + this.key + "' not found!");
         } else {
           keyComment = unsafeHTML("<!-- key '" + this.key + "' and namespace '" + overrideNamespace + "' not found! -->");
           translation = "";
diff --git a/packages/data-table-view/src/data-table-view.js b/packages/data-table-view/src/data-table-view.js
index 576934ea..aff9e74e 100644
--- a/packages/data-table-view/src/data-table-view.js
+++ b/packages/data-table-view/src/data-table-view.js
@@ -7,7 +7,7 @@ import bttn from 'datatables.net-buttons-dt';
 import bttn2 from 'datatables.net-buttons';
 import bttnHtml5 from 'datatables.net-buttons/js/buttons.html5.js';
 import bttnPrint from 'datatables.net-buttons/js/buttons.print.js';
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html, unsafeCSS} from 'lit';
 import de from '../assets/datatables/i18n/German';
 import en from '../assets/datatables/i18n/English';
@@ -30,6 +30,7 @@ export class DataTableView extends AdapterLitElement {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         // datatable properties
         this.table = null;
         this.responsive = null;
@@ -246,6 +247,11 @@ export class DataTableView extends AdapterLitElement {
         this.updateComplete.then(this.set_datatable(this.data, languageChange)).catch((e) => {
             console.log(e);
         });
+
+        if(this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
+
         super.update(changedProperties);
     }
 
diff --git a/packages/data-table-view/src/i18n.js b/packages/data-table-view/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/data-table-view/src/i18n.js
+++ b/packages/data-table-view/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/file-handling/src/clipboard.js b/packages/file-handling/src/clipboard.js
index fedc4d8e..a607d0dc 100644
--- a/packages/file-handling/src/clipboard.js
+++ b/packages/file-handling/src/clipboard.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import * as commonUtils from '@dbp-toolkit/common/utils';
@@ -21,6 +21,8 @@ export class Clipboard extends ScopedElementsMixin(AdapterLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
+
         this.allowedMimeTypes = '';
         this.clipboardFiles = {files: ''};
         this.clipboardSelectBtnDisabled = true;
@@ -109,6 +111,11 @@ export class Clipboard extends ScopedElementsMixin(AdapterLitElement) {
                     break;
             }
         });
+
+        if(this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
+
         super.update(changedProperties);
     }
 
@@ -865,7 +872,7 @@ export class Clipboard extends ScopedElementsMixin(AdapterLitElement) {
             ${commonStyles.getTabulatorStyles()}
             ${fileHandlingStyles.getFileHandlingCss()}
 
-            
+
             a {
                 border-bottom: var(--dbp-border);
                 padding: 0;
diff --git a/packages/file-handling/src/file-sink.js b/packages/file-handling/src/file-sink.js
index f30ef90c..6b0b75af 100644
--- a/packages/file-handling/src/file-sink.js
+++ b/packages/file-handling/src/file-sink.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import * as commonUtils from '@dbp-toolkit/common/utils';
@@ -22,6 +22,7 @@ export class FileSink extends ScopedElementsMixin(DbpFileHandlingLitElement) {
         this.context = '';
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.nextcloudAuthUrl = '';
         this.nextcloudWebDavUrl = '';
         this.nextcloudName = 'Nextcloud';
@@ -101,6 +102,10 @@ export class FileSink extends ScopedElementsMixin(DbpFileHandlingLitElement) {
             }
 
         });
+
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     async downloadCompressedFiles() {
diff --git a/packages/file-handling/src/file-source.js b/packages/file-handling/src/file-source.js
index da8abdd4..73839baf 100644
--- a/packages/file-handling/src/file-source.js
+++ b/packages/file-handling/src/file-source.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import * as commonUtils from '@dbp-toolkit/common/utils';
@@ -38,6 +38,7 @@ export class FileSource extends ScopedElementsMixin(DbpFileHandlingLitElement) {
         super();
         this.context = '';
         this._i18n = createInstance();
+        this.langDir = '';
         this.lang = this._i18n.language;
         this.nextcloudAuthUrl = '';
         this.nextcloudName = 'Nextcloud';
@@ -174,6 +175,10 @@ export class FileSource extends ScopedElementsMixin(DbpFileHandlingLitElement) {
             }
 
         });
+
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     disconnectedCallback() {
@@ -595,8 +600,8 @@ export class FileSource extends ScopedElementsMixin(DbpFileHandlingLitElement) {
             ${commonStyles.getModalDialogCSS()}
             ${fileHandlingStyles.getFileHandlingCss()}
 
-           
-            
+
+
             p {
                 margin-top: 0;
             }
@@ -686,7 +691,7 @@ export class FileSource extends ScopedElementsMixin(DbpFileHandlingLitElement) {
                 .paddles {
                     display: inherit;
                 }
-                
+
                 .paddles.hidden {
                     display: none
                 }
diff --git a/packages/file-handling/src/i18n.js b/packages/file-handling/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/file-handling/src/i18n.js
+++ b/packages/file-handling/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/file-handling/src/nextcloud-file-picker.js b/packages/file-handling/src/nextcloud-file-picker.js
index 2521f62a..6ee29370 100644
--- a/packages/file-handling/src/nextcloud-file-picker.js
+++ b/packages/file-handling/src/nextcloud-file-picker.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import DBPLitElement from '@dbp-toolkit/common/dbp-lit-element';
@@ -22,6 +22,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
 
         this.auth = {};
         this.authUrl = '';
@@ -323,6 +324,11 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
 
             window.addEventListener('resize', this.boundRefreshOnWindowSizeChange);
         });
+
+        // set translation overrides if requested
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     tableBuiltFunction() {
@@ -494,7 +500,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
             for (let key of Object.keys(localStorage)) {
                 if (
                     key.includes('nextcloud-webdav-username-') ||
-                    key.includes('nextcloud-webdav-password-') || 
+                    key.includes('nextcloud-webdav-password-') ||
                     key.includes('nextcloud-webdav-url-')
                 ) {
                     localStorage.removeItem(key);
@@ -839,7 +845,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                     ]);
 
                     if (this._('.tabulator-placeholder-contents')) {
-                        this._('.tabulator-placeholder-contents').innerText = 
+                        this._('.tabulator-placeholder-contents').innerText =
                             i18n.t('nextcloud-file-picker.no-favorites', {
                                 name: this.nextcloudName,
                             });
@@ -977,7 +983,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                 '</d:literal>' +
                 '               </d:gte>' +
 
-                
+
                 '               <d:or>' +
                 this.getMimeTypes() +
                 '               </d:or>' +
@@ -996,7 +1002,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                 '           </d:limit>' +
                 '       </d:basicsearch>' +
                 '   </d:searchrequest>',
-                
+
             })
             .then((contents) => {
                 parseXML(contents.data).then((davResp) => {
@@ -1010,7 +1016,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                     this.tabulatorTable.setSort([{column: 'lastmod', dir: 'desc'}]);
 
                     if (this._('.tabulator-placeholder-contents')) {
-                        this._('.tabulator-placeholder-contents').innerText = 
+                        this._('.tabulator-placeholder-contents').innerText =
                             i18n.t('nextcloud-file-picker.no-recent-files', {
                                 name: this.nextcloudName,
                             });
@@ -1061,21 +1067,21 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
 
     getMimeTypes() {
         let mimePart = '';
-        
+
         if (this.allowedMimeTypes && this.allowedMimeTypes !== 0 && this.allowedMimeTypes !== '*/*') {
             const mimeTypes = this.allowedMimeTypes.split(',');
-                
+
             mimeTypes.forEach((str) => {
-                mimePart += 
+                mimePart +=
                     '               <d:like>' +
                     '                  <d:prop>' +
                     '                      <d:getcontenttype/>' +
-                    '                  </d:prop>' + 
-                    '                  <d:literal>' + str + '</d:literal>' + 
+                    '                  </d:prop>' +
+                    '                  <d:literal>' + str + '</d:literal>' +
                     '               </d:like>';
             });
         } else {
-                mimePart = 
+                mimePart =
                     '               <d:like>' +
                     '                   <d:prop>' +
                     '                       <d:getcontenttype/>' +
@@ -1239,7 +1245,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                     this.tabulatorTable.setSort([{column: 'lastmod', dir: 'desc'}]);
 
                     if (this._('.tabulator-placeholder-contents')) {
-                        this._('.tabulator-placeholder-contents').innerText = 
+                        this._('.tabulator-placeholder-contents').innerText =
                             i18n.t('nextcloud-file-picker.no-recent-files', {
                                 name: this.nextcloudName,
                             });
@@ -3004,7 +3010,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                 left: 0px;
                 top: 1px;
             }
-            
+
             .table-wrapper {
                 max-width: 100%;
                 width: 100%;
@@ -3349,7 +3355,7 @@ export class NextcloudFilePicker extends ScopedElementsMixin(DBPLitElement) {
                                 <li
                                         class="${classMap({hidden: !this.storeSession})}"
                                         title="${i18n.t('nextcloud-file-picker.log-out')}">
-                                    <a 
+                                    <a
                                         class=""
                                         @click="${() => {
                                             this.logOut();
diff --git a/packages/knowledge-base-web-page-element-view/src/dbp-knowledge-base-web-page-element-view-demo.js b/packages/knowledge-base-web-page-element-view/src/dbp-knowledge-base-web-page-element-view-demo.js
index 84ad091a..b65aaf9a 100644
--- a/packages/knowledge-base-web-page-element-view/src/dbp-knowledge-base-web-page-element-view-demo.js
+++ b/packages/knowledge-base-web-page-element-view/src/dbp-knowledge-base-web-page-element-view-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {AuthKeycloak, LoginButton} from '@dbp-toolkit/auth';
@@ -12,6 +12,7 @@ export class KnowledgeBaseWebPageElementViewDemo extends ScopedElementsMixin(DBP
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.entryPointUrl = '';
         this.noAuth = false;
     }
@@ -33,6 +34,15 @@ export class KnowledgeBaseWebPageElementViewDemo extends ScopedElementsMixin(DBP
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // set translation overrides if requested
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         changedProperties.forEach((oldValue, propName) => {
             if (propName === 'lang') {
diff --git a/packages/knowledge-base-web-page-element-view/src/i18n.js b/packages/knowledge-base-web-page-element-view/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/knowledge-base-web-page-element-view/src/i18n.js
+++ b/packages/knowledge-base-web-page-element-view/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js b/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js
index 598075f5..9bf0ddd5 100644
--- a/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js
+++ b/packages/knowledge-base-web-page-element-view/src/knowledge-base-web-page-element-view.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {MiniSpinner} from '@dbp-toolkit/common';
@@ -14,6 +14,7 @@ export class KnowledgeBaseWebPageElementView extends ScopedElementsMixin(Adapter
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.value = '';
         this.html = '';
         this.entryPointUrl = '';
@@ -129,6 +130,13 @@ export class KnowledgeBaseWebPageElementView extends ScopedElementsMixin(Adapter
             .catch();
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
     update(changedProperties) {
         changedProperties.forEach((oldValue, propName) => {
             if (propName === 'lang') {
diff --git a/packages/matomo/src/dbp-matomo-demo.js b/packages/matomo/src/dbp-matomo-demo.js
index 18748614..0af5ce76 100644
--- a/packages/matomo/src/dbp-matomo-demo.js
+++ b/packages/matomo/src/dbp-matomo-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {AuthKeycloak, LoginButton} from '@dbp-toolkit/auth';
@@ -12,6 +12,8 @@ export class MatomoDemo extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
+
         this.entryPointUrl = '';
         this.matomoUrl = '';
         this.matomoSiteId = -1;
@@ -37,6 +39,15 @@ export class MatomoDemo extends ScopedElementsMixin(DBPLitElement) {
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // use translation overrides if path is given
+      if(this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         changedProperties.forEach((oldValue, propName) => {
             if (propName === 'lang') {
diff --git a/packages/matomo/src/i18n.js b/packages/matomo/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/matomo/src/i18n.js
+++ b/packages/matomo/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/notification/src/dbp-notification-demo.js b/packages/notification/src/dbp-notification-demo.js
index 7470f538..f0bfa34b 100644
--- a/packages/notification/src/dbp-notification-demo.js
+++ b/packages/notification/src/dbp-notification-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {send as notify} from '@dbp-toolkit/common/notification';
 import {css, html, LitElement} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
@@ -11,6 +11,7 @@ export class NotificationDemo extends ScopedElementsMixin(LitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
     }
 
     static get scopedElements() {
@@ -25,6 +26,15 @@ export class NotificationDemo extends ScopedElementsMixin(LitElement) {
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // use translation overrides if path is given
+      if(this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         changedProperties.forEach((oldValue, propName) => {
             if (propName === 'lang') {
diff --git a/packages/notification/src/i18n.js b/packages/notification/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/notification/src/i18n.js
+++ b/packages/notification/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/notification/src/notification.js b/packages/notification/src/notification.js
index f1079be4..78e81ab9 100644
--- a/packages/notification/src/notification.js
+++ b/packages/notification/src/notification.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {createUUID} from './utils';
 import {css, html} from 'lit';
 import DBPLitElement from '@dbp-toolkit/common/dbp-lit-element';
@@ -11,6 +11,7 @@ export class Notification extends DBPLitElement {
     constructor() {
         super();
         this._i18n = createInstance();
+        this.langDir = '';
         this.lang = this._i18n.language;
     }
 
@@ -64,6 +65,10 @@ export class Notification extends DBPLitElement {
             // mark the event as handled
             e.preventDefault();
         });
+
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     removeMessageId(messageElementId) {
diff --git a/packages/person-profile/src/dbp-person-profile-demo.js b/packages/person-profile/src/dbp-person-profile-demo.js
index 08e5a30b..f6c07f3d 100644
--- a/packages/person-profile/src/dbp-person-profile-demo.js
+++ b/packages/person-profile/src/dbp-person-profile-demo.js
@@ -1,5 +1,5 @@
 import {AuthKeycloak, LoginButton} from '@dbp-toolkit/auth';
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import DBPLitElement from '@dbp-toolkit/common/dbp-lit-element';
@@ -14,6 +14,7 @@ export class PersonProfileDemo extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.entryPointUrl = '';
         this.person = '';
         this.selectedPerson = '';
@@ -74,6 +75,10 @@ export class PersonProfileDemo extends ScopedElementsMixin(DBPLitElement) {
                 that.selectedPerson = $(this).data('object').identifier;
             };
         });
+
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     static get styles() {
diff --git a/packages/person-profile/src/i18n.js b/packages/person-profile/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/person-profile/src/i18n.js
+++ b/packages/person-profile/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/person-profile/src/person-profile.js b/packages/person-profile/src/person-profile.js
index 125c1a4d..f073d4f5 100644
--- a/packages/person-profile/src/person-profile.js
+++ b/packages/person-profile/src/person-profile.js
@@ -1,6 +1,6 @@
 import JSONLD from '@dbp-toolkit/common/jsonld';
 import {css, html} from 'lit';
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import DBPLitElement from '@dbp-toolkit/common/dbp-lit-element';
 import * as commonStyles from '@dbp-toolkit/common/styles';
 
@@ -9,6 +9,7 @@ export class PersonProfile extends DBPLitElement {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.entryPointUrl = '';
         this.jsonld = null;
         this.value = '';
@@ -27,6 +28,14 @@ export class PersonProfile extends DBPLitElement {
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         changedProperties.forEach((oldValue, propName) => {
             switch (propName) {
diff --git a/packages/person-select/src/dbp-person-select-demo.js b/packages/person-select/src/dbp-person-select-demo.js
index 18ab05f5..363f40dc 100644
--- a/packages/person-select/src/dbp-person-select-demo.js
+++ b/packages/person-select/src/dbp-person-select-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {PersonSelect} from './person-select.js';
@@ -11,6 +11,7 @@ export class PersonSelectDemo extends ScopedElementsMixin(DBPLitElement) {
     constructor() {
         super();
         this._i18n = createInstance();
+        this.langDir = '';
         this.lang = this._i18n.language;
         this.entryPointUrl = '';
         this.noAuth = false;
@@ -49,6 +50,15 @@ export class PersonSelectDemo extends ScopedElementsMixin(DBPLitElement) {
         ];
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // set translation overrides if requested
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         if (changedProperties.has('lang')) {
             this._i18n.changeLanguage(this.lang);
diff --git a/packages/person-select/src/i18n.js b/packages/person-select/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/person-select/src/i18n.js
+++ b/packages/person-select/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/person-select/src/person-select.js b/packages/person-select/src/person-select.js
index f56fc9b6..cd0bed53 100644
--- a/packages/person-select/src/person-select.js
+++ b/packages/person-select/src/person-select.js
@@ -6,7 +6,7 @@ import select2LangEn from './i18n/en/select2';
 import JSONLD from '@dbp-toolkit/common/jsonld';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {Icon} from '@dbp-toolkit/common';
 import * as commonUtils from '@dbp-toolkit/common/utils';
 import * as commonStyles from '@dbp-toolkit/common/styles';
@@ -30,6 +30,7 @@ export class PersonSelect extends ScopedElementsMixin(AdapterLitElement) {
         this.auth = {};
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.entryPointUrl = '';
         this.jsonld = null;
         this.$select = null;
@@ -93,6 +94,10 @@ export class PersonSelect extends ScopedElementsMixin(AdapterLitElement) {
             // try an init when user-interface is loaded
             this.initJSONLD();
         });
+
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     disconnectedCallback() {
@@ -395,7 +400,7 @@ export class PersonSelect extends ScopedElementsMixin(AdapterLitElement) {
                 .select2-bug .loading-results {
                     display: none !important;
                 }
-                
+
                 .select2-results__option.loading-results,
                 {
                     background-image: url("")
diff --git a/packages/provider/src/dbp-provider-demo.js b/packages/provider/src/dbp-provider-demo.js
index becd642c..f2d0d982 100644
--- a/packages/provider/src/dbp-provider-demo.js
+++ b/packages/provider/src/dbp-provider-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {AuthKeycloak, LoginButton} from '@dbp-toolkit/auth';
@@ -14,6 +14,7 @@ class ProviderDemo extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
     }
 
     static get scopedElements() {
@@ -34,6 +35,14 @@ class ProviderDemo extends ScopedElementsMixin(DBPLitElement) {
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     attributeChangedCallback(name, oldValue, newValue) {
         console.debug(
             'ProviderDemo (' +
@@ -146,7 +155,7 @@ class ProviderDemo extends ScopedElementsMixin(DBPLitElement) {
                         </div>
                     </dbp-provider>
                 </dbp-provider>
-                
+
                 <h2> DBP Provider Adapter</h2>
                 <p> The dbp-provider is for third party webcomponents, which we want to configure with a provider.</p>
                 <pre>&lt;dbp-provider  id="demoadapter"  dbp-style-red="color:red;" dbp-style-green="color:green;" >&lt;/dbp-provider&gt;</pre>
diff --git a/packages/provider/src/i18n.js b/packages/provider/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/provider/src/i18n.js
+++ b/packages/provider/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/qr-code-scanner/src/dbp-qr-code-scanner-demo.js b/packages/qr-code-scanner/src/dbp-qr-code-scanner-demo.js
index 248b91e2..df27f246 100644
--- a/packages/qr-code-scanner/src/dbp-qr-code-scanner-demo.js
+++ b/packages/qr-code-scanner/src/dbp-qr-code-scanner-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html, LitElement} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import * as commonUtils from '@dbp-toolkit/common/utils';
@@ -10,6 +10,7 @@ export class QrCodeScannerDemo extends ScopedElementsMixin(LitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
     }
 
     static get scopedElements() {
@@ -24,6 +25,12 @@ export class QrCodeScannerDemo extends ScopedElementsMixin(LitElement) {
         };
     }
 
+    connectedCallback() {
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         if (changedProperties.has('lang')) {
             this._i18n.changeLanguage(this.lang);
@@ -37,7 +44,7 @@ export class QrCodeScannerDemo extends ScopedElementsMixin(LitElement) {
             ${commonStyles.getThemeCSS()}
             ${commonStyles.getGeneralCSS()}
             ${commonStyles.getButtonCSS()}
-            
+
             h1 {
                 margin-bottom: 20px;
             }
diff --git a/packages/qr-code-scanner/src/i18n.js b/packages/qr-code-scanner/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/qr-code-scanner/src/i18n.js
+++ b/packages/qr-code-scanner/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/qr-code-scanner/src/qr-code-scanner.js b/packages/qr-code-scanner/src/qr-code-scanner.js
index e1ffcd07..bf50eb9a 100644
--- a/packages/qr-code-scanner/src/qr-code-scanner.js
+++ b/packages/qr-code-scanner/src/qr-code-scanner.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 import {css, html, unsafeCSS} from 'lit';
 import DBPLitElement from '@dbp-toolkit/common/dbp-lit-element';
 import * as commonStyles from '@dbp-toolkit/common/styles';
@@ -122,6 +122,7 @@ export class QrCodeScanner extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
 
         this._askPermission = false;
         this._loading = false;
@@ -175,6 +176,10 @@ export class QrCodeScanner extends ScopedElementsMixin(DBPLitElement) {
         if (!this.stopScan) {
             await this.startScanning();
         }
+
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     async disconnectedCallback() {
@@ -446,7 +451,7 @@ export class QrCodeScanner extends ScopedElementsMixin(DBPLitElement) {
             ${commonStyles.getGeneralCSS()}
             ${commonStyles.getSelect2CSS()}
             ${commonStyles.getButtonCSS()}
-            
+
             #loadingMessage {
                 text-align: center;
                 padding: 40px;
diff --git a/packages/resource-select/src/dbp-resource-select-demo.js b/packages/resource-select/src/dbp-resource-select-demo.js
index 7fad3a5d..4c550238 100644
--- a/packages/resource-select/src/dbp-resource-select-demo.js
+++ b/packages/resource-select/src/dbp-resource-select-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {ResourceSelect} from './resource-select.js';
@@ -12,6 +12,7 @@ export class ResourceSelectDemo extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.entryPointUrl = '';
         this.noAuth = false;
     }
@@ -33,6 +34,15 @@ export class ResourceSelectDemo extends ScopedElementsMixin(DBPLitElement) {
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // set translation overrides if requested
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         if (changedProperties.has('lang')) {
             this._i18n.changeLanguage(this.lang);
diff --git a/packages/resource-select/src/i18n.js b/packages/resource-select/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/resource-select/src/i18n.js
+++ b/packages/resource-select/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/resource-select/src/resource-select.js b/packages/resource-select/src/resource-select.js
index ec19718c..151e3408 100644
--- a/packages/resource-select/src/resource-select.js
+++ b/packages/resource-select/src/resource-select.js
@@ -1,7 +1,7 @@
 import $ from 'jquery';
 import select2 from 'select2';
 import select2CSSPath from 'select2/dist/css/select2.min.css';
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import * as commonUtils from '@dbp-toolkit/common/utils';
 import * as commonStyles from '@dbp-toolkit/common/styles';
@@ -21,6 +21,7 @@ export class ResourceSelect extends AdapterLitElement {
 
         this.auth = {};
         this.lang = this._i18n.language;
+        this.langDir = '';
         this.entryPointUrl = null;
         this.resourcePath = null;
         this.value = null;
@@ -57,6 +58,11 @@ export class ResourceSelect extends AdapterLitElement {
         super.connectedCallback();
         document.addEventListener('click', this._onDocumentClicked);
         this._updateAll();
+
+        // set translation overrides if requested
+        if (this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     disconnectedCallback() {
diff --git a/packages/theme-switcher/src/theme-switcher.js b/packages/theme-switcher/src/theme-switcher.js
index 4d7374e9..2370f803 100644
--- a/packages/theme-switcher/src/theme-switcher.js
+++ b/packages/theme-switcher/src/theme-switcher.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {html, css} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import {AdapterLitElement, Icon} from '@dbp-toolkit/common';
@@ -10,6 +10,8 @@ export class ThemeSwitcher extends ScopedElementsMixin(AdapterLitElement) {
         super();
 
         this._i18n = createInstance();
+        this.langDir = '';
+
         this.lang = this._i18n.language;
         this.themes = [];
         this.boundCloseAdditionalMenuHandler = this.hideModeMenu.bind(this);
@@ -57,6 +59,10 @@ export class ThemeSwitcher extends ScopedElementsMixin(AdapterLitElement) {
             this.loadTheme('light-theme');
             this.detectInitialMode();
         });
+
+        if(this.langDir != '') {
+          setOverridesByGlobalCache(this._i18n, this);
+        }
     }
 
     detectInitialMode() {
diff --git a/packages/tooltip/src/dbp-tooltip-demo.js b/packages/tooltip/src/dbp-tooltip-demo.js
index 59d4025c..c6f86e70 100644
--- a/packages/tooltip/src/dbp-tooltip-demo.js
+++ b/packages/tooltip/src/dbp-tooltip-demo.js
@@ -1,4 +1,4 @@
-import {createInstance} from './i18n.js';
+import {createInstance, setOverridesByGlobalCache} from './i18n.js';
 import {css, html} from 'lit';
 import {ScopedElementsMixin} from '@open-wc/scoped-elements';
 import * as commonUtils from '@dbp-toolkit/common/utils';
@@ -13,6 +13,7 @@ export class TooltipDemo extends ScopedElementsMixin(DBPLitElement) {
         super();
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
     }
 
     static get scopedElements() {
@@ -30,6 +31,15 @@ export class TooltipDemo extends ScopedElementsMixin(DBPLitElement) {
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // set translation overrides if requested
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         changedProperties.forEach((oldValue, propName) => {
             if (propName === 'lang') {
diff --git a/packages/tooltip/src/i18n.js b/packages/tooltip/src/i18n.js
index 0c6fedc8..930f3538 100644
--- a/packages/tooltip/src/i18n.js
+++ b/packages/tooltip/src/i18n.js
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/typescript-example/src/i18n.ts b/packages/typescript-example/src/i18n.ts
index 0c6fedc8..930f3538 100644
--- a/packages/typescript-example/src/i18n.ts
+++ b/packages/typescript-example/src/i18n.ts
@@ -1,4 +1,4 @@
-import {createInstance as _createInstance} from '@dbp-toolkit/common/i18next.js';
+import {createInstance as _createInstance, setOverridesByGlobalCache} from '@dbp-toolkit/common/i18next.js';
 
 import de from './i18n/de/translation.json';
 import en from './i18n/en/translation.json';
@@ -6,3 +6,5 @@ import en from './i18n/en/translation.json';
 export function createInstance() {
     return _createInstance({en: en, de: de}, 'de', 'en');
 }
+
+export {setOverridesByGlobalCache};
diff --git a/packages/typescript-example/src/typescript-example.ts b/packages/typescript-example/src/typescript-example.ts
index 3df50f67..a80bb0de 100644
--- a/packages/typescript-example/src/typescript-example.ts
+++ b/packages/typescript-example/src/typescript-example.ts
@@ -1,22 +1,34 @@
 import {html, LitElement} from 'lit';
-import {createInstance} from './i18n';
+import {createInstance, setOverridesByGlobalCache} from './i18n';
 
 export class TypeScriptExample extends LitElement {
     private _i18n;
+    private langDir;
 
     constructor() {
         super();
 
         this._i18n = createInstance();
         this.lang = this._i18n.language;
+        this.langDir = '';
     }
 
     static get properties() {
         return {
             lang: {type: String},
+            langDir: {type: String},
         };
     }
 
+    connectedCallback() {
+      super.connectedCallback();
+
+      // set translation overrides if requested
+      if (this.langDir != '') {
+        setOverridesByGlobalCache(this._i18n, this);
+      }
+    }
+
     update(changedProperties) {
         if (changedProperties.has('lang')) {
             this._i18n.changeLanguage(this.lang);
-- 
GitLab