UNPKG

@ngx-translate/core

Version:

134 lines 18.1 kB
import { Injectable, Pipe } from '@angular/core'; import { isObservable } from 'rxjs'; import { equals, isDefined } from './util'; import * as i0 from "@angular/core"; import * as i1 from "./translate.service"; class TranslatePipe { translate; _ref; value = ''; lastKey = null; lastParams = []; onTranslationChange; onLangChange; onDefaultLangChange; constructor(translate, _ref) { this.translate = translate; this._ref = _ref; } updateValue(key, interpolateParams, translations) { let onTranslation = (res) => { this.value = res !== undefined ? res : key; this.lastKey = key; this._ref.markForCheck(); }; if (translations) { let res = this.translate.getParsedResult(translations, key, interpolateParams); if (isObservable(res.subscribe)) { res.subscribe(onTranslation); } else { onTranslation(res); } } this.translate.get(key, interpolateParams).subscribe(onTranslation); } transform(query, ...args) { if (!query || !query.length) { return query; } // if we ask another time for the same key, return the last value if (equals(query, this.lastKey) && equals(args, this.lastParams)) { return this.value; } let interpolateParams = undefined; if (isDefined(args[0]) && args.length) { if (typeof args[0] === 'string' && args[0].length) { // we accept objects written in the template such as {n:1}, {'n':1}, {n:'v'} // which is why we might need to change it to real JSON objects such as {"n":1} or {"n":"v"} let validArgs = args[0] .replace(/(\')?([a-zA-Z0-9_]+)(\')?(\s)?:/g, '"$2":') .replace(/:(\s)?(\')(.*?)(\')/g, ':"$3"'); try { interpolateParams = JSON.parse(validArgs); } catch (e) { throw new SyntaxError(`Wrong parameter in TranslatePipe. Expected a valid Object, received: ${args[0]}`); } } else if (typeof args[0] === 'object' && !Array.isArray(args[0])) { interpolateParams = args[0]; } } // store the query, in case it changes this.lastKey = query; // store the params, in case they change this.lastParams = args; // set the value this.updateValue(query, interpolateParams); // if there is a subscription to onLangChange, clean it this._dispose(); // subscribe to onTranslationChange event, in case the translations change if (!this.onTranslationChange) { this.onTranslationChange = this.translate.onTranslationChange.subscribe((event) => { if (this.lastKey && event.lang === this.translate.currentLang) { this.lastKey = null; this.updateValue(query, interpolateParams, event.translations); } }); } // subscribe to onLangChange event, in case the language changes if (!this.onLangChange) { this.onLangChange = this.translate.onLangChange.subscribe((event) => { if (this.lastKey) { this.lastKey = null; // we want to make sure it doesn't return the same value until it's been updated this.updateValue(query, interpolateParams, event.translations); } }); } // subscribe to onDefaultLangChange event, in case the default language changes if (!this.onDefaultLangChange) { this.onDefaultLangChange = this.translate.onDefaultLangChange.subscribe(() => { if (this.lastKey) { this.lastKey = null; // we want to make sure it doesn't return the same value until it's been updated this.updateValue(query, interpolateParams); } }); } return this.value; } /** * Clean any existing subscription to change events */ _dispose() { if (typeof this.onTranslationChange !== 'undefined') { this.onTranslationChange.unsubscribe(); this.onTranslationChange = undefined; } if (typeof this.onLangChange !== 'undefined') { this.onLangChange.unsubscribe(); this.onLangChange = undefined; } if (typeof this.onDefaultLangChange !== 'undefined') { this.onDefaultLangChange.unsubscribe(); this.onDefaultLangChange = undefined; } } ngOnDestroy() { this._dispose(); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TranslatePipe, deps: [{ token: i1.TranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Pipe }); static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: TranslatePipe, name: "translate", pure: false }); static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TranslatePipe }); } export { TranslatePipe }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TranslatePipe, decorators: [{ type: Injectable }, { type: Pipe, args: [{ name: 'translate', pure: false // required to update the value when the promise is resolved }] }], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i0.ChangeDetectorRef }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translate.pipe.js","sourceRoot":"","sources":["../../../lib/translate.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, EventEmitter, Injectable, OnDestroy, Pipe, PipeTransform} from '@angular/core';\r\nimport {isObservable} from 'rxjs';\r\nimport {DefaultLangChangeEvent, LangChangeEvent, TranslateService, TranslationChangeEvent} from './translate.service';\r\nimport {equals, isDefined} from './util';\r\nimport { Subscription } from 'rxjs';\r\n\r\n@Injectable()\r\n@Pipe({\r\n  name: 'translate',\r\n  pure: false // required to update the value when the promise is resolved\r\n})\r\nexport class TranslatePipe implements PipeTransform, OnDestroy {\r\n  value: string = '';\r\n  lastKey: string | null = null;\r\n  lastParams: any[] = [];\r\n  onTranslationChange: Subscription | undefined;\r\n  onLangChange: Subscription | undefined;\r\n  onDefaultLangChange: Subscription | undefined;\r\n\r\n  constructor(private translate: TranslateService, private _ref: ChangeDetectorRef) {\r\n  }\r\n\r\n  updateValue(key: string, interpolateParams?: Object, translations?: any): void {\r\n    let onTranslation = (res: string) => {\r\n      this.value = res !== undefined ? res : key;\r\n      this.lastKey = key;\r\n      this._ref.markForCheck();\r\n    };\r\n    if (translations) {\r\n      let res = this.translate.getParsedResult(translations, key, interpolateParams);\r\n      if (isObservable(res.subscribe)) {\r\n        res.subscribe(onTranslation);\r\n      } else {\r\n        onTranslation(res);\r\n      }\r\n    }\r\n    this.translate.get(key, interpolateParams).subscribe(onTranslation);\r\n  }\r\n\r\n  transform(query: string, ...args: any[]): any {\r\n    if (!query || !query.length) {\r\n      return query;\r\n    }\r\n\r\n    // if we ask another time for the same key, return the last value\r\n    if (equals(query, this.lastKey) && equals(args, this.lastParams)) {\r\n      return this.value;\r\n    }\r\n\r\n    let interpolateParams: Object | undefined = undefined;\r\n    if (isDefined(args[0]) && args.length) {\r\n      if (typeof args[0] === 'string' && args[0].length) {\r\n        // we accept objects written in the template such as {n:1}, {'n':1}, {n:'v'}\r\n        // which is why we might need to change it to real JSON objects such as {\"n\":1} or {\"n\":\"v\"}\r\n        let validArgs: string = args[0]\r\n          .replace(/(\\')?([a-zA-Z0-9_]+)(\\')?(\\s)?:/g, '\"$2\":')\r\n          .replace(/:(\\s)?(\\')(.*?)(\\')/g, ':\"$3\"');\r\n        try {\r\n          interpolateParams = JSON.parse(validArgs);\r\n        } catch (e) {\r\n          throw new SyntaxError(`Wrong parameter in TranslatePipe. Expected a valid Object, received: ${args[0]}`);\r\n        }\r\n      } else if (typeof args[0] === 'object' && !Array.isArray(args[0])) {\r\n        interpolateParams = args[0];\r\n      }\r\n    }\r\n\r\n    // store the query, in case it changes\r\n    this.lastKey = query;\r\n\r\n    // store the params, in case they change\r\n    this.lastParams = args;\r\n\r\n    // set the value\r\n    this.updateValue(query, interpolateParams);\r\n\r\n    // if there is a subscription to onLangChange, clean it\r\n    this._dispose();\r\n\r\n    // subscribe to onTranslationChange event, in case the translations change\r\n    if (!this.onTranslationChange) {\r\n      this.onTranslationChange = this.translate.onTranslationChange.subscribe((event: TranslationChangeEvent) => {\r\n        if (this.lastKey && event.lang === this.translate.currentLang) {\r\n          this.lastKey = null;\r\n          this.updateValue(query, interpolateParams, event.translations);\r\n        }\r\n      });\r\n    }\r\n\r\n    // subscribe to onLangChange event, in case the language changes\r\n    if (!this.onLangChange) {\r\n      this.onLangChange = this.translate.onLangChange.subscribe((event: LangChangeEvent) => {\r\n        if (this.lastKey) {\r\n          this.lastKey = null; // we want to make sure it doesn't return the same value until it's been updated\r\n          this.updateValue(query, interpolateParams, event.translations);\r\n        }\r\n      });\r\n    }\r\n\r\n    // subscribe to onDefaultLangChange event, in case the default language changes\r\n    if (!this.onDefaultLangChange) {\r\n      this.onDefaultLangChange = this.translate.onDefaultLangChange.subscribe(() => {\r\n        if (this.lastKey) {\r\n          this.lastKey = null; // we want to make sure it doesn't return the same value until it's been updated\r\n          this.updateValue(query, interpolateParams);\r\n        }\r\n      });\r\n    }\r\n\r\n    return this.value;\r\n  }\r\n\r\n  /**\r\n   * Clean any existing subscription to change events\r\n   */\r\n  private _dispose(): void {\r\n    if (typeof this.onTranslationChange !== 'undefined') {\r\n      this.onTranslationChange.unsubscribe();\r\n      this.onTranslationChange = undefined;\r\n    }\r\n    if (typeof this.onLangChange !== 'undefined') {\r\n      this.onLangChange.unsubscribe();\r\n      this.onLangChange = undefined;\r\n    }\r\n    if (typeof this.onDefaultLangChange !== 'undefined') {\r\n      this.onDefaultLangChange.unsubscribe();\r\n      this.onDefaultLangChange = undefined;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._dispose();\r\n  }\r\n}\r\n"]}