UNPKG

@ngneat/transloco

Version:

The internationalization (i18n) library for Angular

310 lines 25.4 kB
/** * @fileoverview added by tsickle * Generated from: lib/transloco.directive.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectorRef, Directive, ElementRef, Inject, Input, Optional, TemplateRef, ViewContainerRef } from '@angular/core'; import { forkJoin } from 'rxjs'; import { switchMap } from 'rxjs/operators'; import { TemplateHandler } from './template-handler'; import { TRANSLOCO_LANG } from './transloco-lang'; import { TRANSLOCO_LOADING_TEMPLATE } from './transloco-loading-template'; import { TRANSLOCO_SCOPE } from './transloco-scope'; import { TranslocoService } from './transloco.service'; import { listenOrNotOperator, resolveInlineLoader, shouldListenToLangChanges } from './shared'; import { LangResolver } from './lang-resolver'; import { ScopeResolver } from './scope-resolver'; export class TranslocoDirective { /** * @param {?} translocoService * @param {?} tpl * @param {?} providerScope * @param {?} providerLang * @param {?} providedLoadingTpl * @param {?} vcr * @param {?} cdr * @param {?} host */ constructor(translocoService, tpl, providerScope, providerLang, providedLoadingTpl, vcr, cdr, host) { this.translocoService = translocoService; this.tpl = tpl; this.providerScope = providerScope; this.providerLang = providerLang; this.providedLoadingTpl = providedLoadingTpl; this.vcr = vcr; this.cdr = cdr; this.host = host; this.translationMemo = {}; this.params = {}; this.loaderTplHandler = null; // Whether we already rendered the view once this.initialized = false; this.langResolver = new LangResolver(); this.scopeResolver = new ScopeResolver(this.translocoService); } /** * @return {?} */ ngOnInit() { /** @type {?} */ const listenToLangChange = shouldListenToLangChanges(this.translocoService, this.providerLang || this.inlineLang); this.subscription = this.translocoService.langChanges$ .pipe(switchMap((/** * @param {?} activeLang * @return {?} */ activeLang => { /** @type {?} */ const lang = this.langResolver.resolve({ inline: this.inlineLang, provider: this.providerLang, active: activeLang }); return Array.isArray(this.providerScope) ? forkJoin(((/** @type {?} */ (this.providerScope))).map((/** * @param {?} providerScope * @return {?} */ providerScope => this.resolveScope(lang, providerScope)))) : this.resolveScope(lang, this.providerScope); })), listenOrNotOperator(listenToLangChange)) .subscribe((/** * @return {?} */ () => { this.currentLang = this.langResolver.resolveLangBasedOnScope(this.path); this.tpl === null ? this.simpleStrategy() : this.structuralStrategy(this.currentLang, this.inlineRead); this.cdr.markForCheck(); this.initialized = true; })); /** @type {?} */ const loadingTpl = this.getLoadingTpl(); if (!this.initialized && loadingTpl) { this.loaderTplHandler = new TemplateHandler(loadingTpl, this.vcr); this.loaderTplHandler.attachView(); } } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { // We need to support dynamic keys/params, so if this is not the first change CD cycle // we need to run the function again in order to update the value /** @type {?} */ const notInit = Object.keys(changes).some((/** * @param {?} v * @return {?} */ v => changes[v].firstChange === false)); notInit && this.simpleStrategy(); } /** * @private * @return {?} */ simpleStrategy() { this.detachLoader(); this.host.nativeElement.innerText = this.translocoService.translate(this.key, this.params, this.currentLang); } /** * @private * @param {?} lang * @param {?} read * @return {?} */ structuralStrategy(lang, read) { this.translationMemo = {}; if (this.view) { // when the lang changes we need to change the reference so Angular will update the view this.view.context['$implicit'] = this.getTranslateFn(lang, read); this.view.context['currentLang'] = this.currentLang; } else { this.detachLoader(); this.view = this.vcr.createEmbeddedView(this.tpl, { $implicit: this.getTranslateFn(lang, read), currentLang: this.currentLang }); } } /** * @protected * @param {?} lang * @param {?} read * @return {?} */ getTranslateFn(lang, read) { return (/** * @param {?} key * @param {?} params * @return {?} */ (key, params) => { /** @type {?} */ const withRead = read ? `${read}.${key}` : key; /** @type {?} */ const withParams = params ? `${withRead}${JSON.stringify(params)}` : withRead; if (this.translationMemo.hasOwnProperty(withParams)) { return this.translationMemo[withParams].value; } this.translationMemo[withParams] = { params, value: this.translocoService.translate(withRead, params, lang) }; return this.translationMemo[withParams].value; }); } /** * @private * @return {?} */ getLoadingTpl() { return this.inlineTpl || this.providedLoadingTpl; } /** * @return {?} */ ngOnDestroy() { this.subscription && this.subscription.unsubscribe(); } /** * @private * @return {?} */ detachLoader() { this.loaderTplHandler && this.loaderTplHandler.detachView(); } /** * @private * @param {?} lang * @param {?} providerScope * @return {?} */ resolveScope(lang, providerScope) { /** @type {?} */ let resolvedScope = this.scopeResolver.resolve({ inline: this.inlineScope, provider: providerScope }); this.path = this.langResolver.resolveLangPath(lang, resolvedScope); /** @type {?} */ const inlineLoader = resolveInlineLoader(providerScope, resolvedScope); return this.translocoService._loadDependencies(this.path, inlineLoader); } } TranslocoDirective.decorators = [ { type: Directive, args: [{ selector: '[transloco]' },] } ]; /** @nocollapse */ TranslocoDirective.ctorParameters = () => [ { type: TranslocoService }, { type: TemplateRef, decorators: [{ type: Optional }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [TRANSLOCO_SCOPE,] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [TRANSLOCO_LANG,] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [TRANSLOCO_LOADING_TEMPLATE,] }] }, { type: ViewContainerRef }, { type: ChangeDetectorRef }, { type: ElementRef } ]; TranslocoDirective.propDecorators = { key: [{ type: Input, args: ['transloco',] }], params: [{ type: Input, args: ['translocoParams',] }], inlineScope: [{ type: Input, args: ['translocoScope',] }], inlineRead: [{ type: Input, args: ['translocoRead',] }], inlineLang: [{ type: Input, args: ['translocoLang',] }], inlineTpl: [{ type: Input, args: ['translocoLoadingTpl',] }] }; if (false) { /** @type {?} */ TranslocoDirective.prototype.subscription; /** @type {?} */ TranslocoDirective.prototype.view; /** * @type {?} * @private */ TranslocoDirective.prototype.translationMemo; /** @type {?} */ TranslocoDirective.prototype.key; /** @type {?} */ TranslocoDirective.prototype.params; /** @type {?} */ TranslocoDirective.prototype.inlineScope; /** @type {?} */ TranslocoDirective.prototype.inlineRead; /** @type {?} */ TranslocoDirective.prototype.inlineLang; /** @type {?} */ TranslocoDirective.prototype.inlineTpl; /** * @type {?} * @private */ TranslocoDirective.prototype.currentLang; /** * @type {?} * @private */ TranslocoDirective.prototype.loaderTplHandler; /** * @type {?} * @private */ TranslocoDirective.prototype.initialized; /** * @type {?} * @private */ TranslocoDirective.prototype.path; /** * @type {?} * @private */ TranslocoDirective.prototype.langResolver; /** * @type {?} * @private */ TranslocoDirective.prototype.scopeResolver; /** * @type {?} * @private */ TranslocoDirective.prototype.translocoService; /** * @type {?} * @private */ TranslocoDirective.prototype.tpl; /** * @type {?} * @private */ TranslocoDirective.prototype.providerScope; /** * @type {?} * @private */ TranslocoDirective.prototype.providerLang; /** * @type {?} * @private */ TranslocoDirective.prototype.providedLoadingTpl; /** * @type {?} * @private */ TranslocoDirective.prototype.vcr; /** * @type {?} * @private */ TranslocoDirective.prototype.cdr; /** * @type {?} * @private */ TranslocoDirective.prototype.host; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transloco.directive.js","sourceRoot":"ng://@ngneat/transloco/","sources":["lib/transloco.directive.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,UAAU,EAEV,MAAM,EACN,KAAK,EAIL,QAAQ,EACR,WAAW,EAEX,gBAAgB,EACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAA4B,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAQ,MAAM,oBAAoB,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,yBAAyB,EAAE,MAAM,UAAU,CAAC;AAC/F,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAKjD,MAAM,OAAO,kBAAkB;;;;;;;;;;;IAoB7B,YACU,gBAAkC,EACtB,GAA4F,EACnE,aAAyC,EAC1C,YAA2B,EACf,kBAAsC,EACtF,GAAqB,EACrB,GAAsB,EACtB,IAAgB;QAPhB,qBAAgB,GAAhB,gBAAgB,CAAkB;QACtB,QAAG,GAAH,GAAG,CAAyF;QACnE,kBAAa,GAAb,aAAa,CAA4B;QAC1C,iBAAY,GAAZ,YAAY,CAAe;QACf,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtF,QAAG,GAAH,GAAG,CAAkB;QACrB,QAAG,GAAH,GAAG,CAAmB;QACtB,SAAI,GAAJ,IAAI,CAAY;QAzBlB,oBAAe,GAAuD,EAAE,CAAC;QAGvD,WAAM,GAAY,EAAE,CAAC;QAOvC,qBAAgB,GAAoB,IAAI,CAAC;;QAEzC,gBAAW,GAAG,KAAK,CAAC;QAEpB,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,kBAAa,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAW9D,CAAC;;;;IAEJ,QAAQ;;cACA,kBAAkB,GAAG,yBAAyB,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,UAAU,CAAC;QAEjH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY;aACnD,IAAI,CACH,SAAS;;;;QAAC,UAAU,CAAC,EAAE;;kBACf,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;gBACrC,MAAM,EAAE,IAAI,CAAC,UAAU;gBACvB,QAAQ,EAAE,IAAI,CAAC,YAAY;gBAC3B,MAAM,EAAE,UAAU;aACnB,CAAC;YAEF,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC;gBACtC,CAAC,CAAC,QAAQ,CACN,CAAC,mBAAkB,IAAI,CAAC,aAAa,EAAA,CAAC,CAAC,GAAG;;;;gBAAC,aAAa,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,aAAa,CAAC,EAAC,CACpG;gBACH,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAClD,CAAC,EAAC,EACF,mBAAmB,CAAC,kBAAkB,CAAC,CACxC;aACA,SAAS;;;QAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxE,IAAI,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACvG,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAC1B,CAAC,EAAC,CAAC;;cAEC,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE;QACvC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,UAAU,EAAE;YACnC,IAAI,CAAC,gBAAgB,GAAG,IAAI,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;YAClE,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;SACpC;IACH,CAAC;;;;;IAED,WAAW,CAAC,OAAO;;;;cAGX,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI;;;;QAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,KAAK,KAAK,EAAC;QAChF,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;IACnC,CAAC;;;;;IAEO,cAAc;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAC/G,CAAC;;;;;;;IAEO,kBAAkB,CAAC,IAAY,EAAE,IAAwB;QAC/D,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAE1B,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,wFAAwF;YACxF,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACjE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC;SACrD;aAAM;YACL,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,GAAG,EAAE;gBAChD,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC;gBAC1C,WAAW,EAAE,IAAI,CAAC,WAAW;aAC9B,CAAC,CAAC;SACJ;IACH,CAAC;;;;;;;IAES,cAAc,CAAC,IAAY,EAAE,IAAwB;QAC7D;;;;;QAAO,CAAC,GAAW,EAAE,MAAe,EAAE,EAAE;;kBAChC,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG;;kBACxC,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ;YAC7E,IAAI,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE;gBACnD,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC;aAC/C;YACD,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,GAAG;gBACjC,MAAM;gBACN,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC;aAC/D,CAAC;YAEF,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC;QAChD,CAAC,EAAC;IACJ,CAAC;;;;;IAEO,aAAa;QACnB,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,CAAC;IACnD,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IACvD,CAAC;;;;;IAEO,YAAY;QAClB,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;IAC9D,CAAC;;;;;;;IAEO,YAAY,CAAC,IAAY,EAAE,aAA6B;;YAC1D,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,aAAa,EAAE,CAAC;QACrG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;;cAC7D,YAAY,GAAG,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC;QACtE,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;IAC1E,CAAC;;;YAjIF,SAAS,SAAC;gBACT,QAAQ,EAAE,aAAa;aACxB;;;;YARQ,gBAAgB;YAVvB,WAAW,uBAyCR,QAAQ;4CACR,QAAQ,YAAI,MAAM,SAAC,eAAe;4CAClC,QAAQ,YAAI,MAAM,SAAC,cAAc;4CACjC,QAAQ,YAAI,MAAM,SAAC,0BAA0B;YA1ChD,gBAAgB;YAZhB,iBAAiB;YAEjB,UAAU;;;kBAgCT,KAAK,SAAC,WAAW;qBACjB,KAAK,SAAC,iBAAiB;0BACvB,KAAK,SAAC,gBAAgB;yBACtB,KAAK,SAAC,eAAe;yBACrB,KAAK,SAAC,eAAe;wBACrB,KAAK,SAAC,qBAAqB;;;;IAT5B,0CAAkC;;IAClC,kCAA2B;;;;;IAC3B,6CAAiF;;IAEjF,iCAAgC;;IAChC,oCAA+C;;IAC/C,yCAAyD;;IACzD,wCAAuD;;IACvD,wCAAuD;;IACvD,uCAAsE;;;;;IAEtE,yCAA4B;;;;;IAC5B,8CAAiD;;;;;IAEjD,yCAA4B;;;;;IAC5B,kCAAqB;;;;;IACrB,0CAA0C;;;;;IAC1C,2CAAiE;;;;;IAG/D,8CAA0C;;;;;IAC1C,iCAAgH;;;;;IAChH,2CAAsF;;;;;IACtF,0CAAuE;;;;;IACvE,gDAA8F;;;;;IAC9F,iCAA6B;;;;;IAC7B,iCAA8B;;;;;IAC9B,kCAAwB","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EmbeddedViewRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  TemplateRef,\n  Type,\n  ViewContainerRef\n} from '@angular/core';\nimport { forkJoin, Observable, Subscription } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { TemplateHandler, View } from './template-handler';\nimport { TRANSLOCO_LANG } from './transloco-lang';\nimport { TRANSLOCO_LOADING_TEMPLATE } from './transloco-loading-template';\nimport { TRANSLOCO_SCOPE } from './transloco-scope';\nimport { TranslocoService } from './transloco.service';\nimport { HashMap, MaybeArray, Translation, TranslocoScope } from './types';\nimport { listenOrNotOperator, resolveInlineLoader, shouldListenToLangChanges } from './shared';\nimport { LangResolver } from './lang-resolver';\nimport { ScopeResolver } from './scope-resolver';\n\n@Directive({\n  selector: '[transloco]'\n})\nexport class TranslocoDirective implements OnInit, OnDestroy, OnChanges {\n  subscription: Subscription | null;\n  view: EmbeddedViewRef<any>;\n  private translationMemo: { [key: string]: { value: any; params: HashMap } } = {};\n\n  @Input('transloco') key: string;\n  @Input('translocoParams') params: HashMap = {};\n  @Input('translocoScope') inlineScope: string | undefined;\n  @Input('translocoRead') inlineRead: string | undefined;\n  @Input('translocoLang') inlineLang: string | undefined;\n  @Input('translocoLoadingTpl') inlineTpl: TemplateRef<any> | undefined;\n\n  private currentLang: string;\n  private loaderTplHandler: TemplateHandler = null;\n  // Whether we already rendered the view once\n  private initialized = false;\n  private path: string;\n  private langResolver = new LangResolver();\n  private scopeResolver = new ScopeResolver(this.translocoService);\n\n  constructor(\n    private translocoService: TranslocoService,\n    @Optional() private tpl: TemplateRef<{ $implicit: (key: string, params?: HashMap) => any; currentLang: string }>,\n    @Optional() @Inject(TRANSLOCO_SCOPE) private providerScope: MaybeArray<TranslocoScope>,\n    @Optional() @Inject(TRANSLOCO_LANG) private providerLang: string | null,\n    @Optional() @Inject(TRANSLOCO_LOADING_TEMPLATE) private providedLoadingTpl: Type<any> | string,\n    private vcr: ViewContainerRef,\n    private cdr: ChangeDetectorRef,\n    private host: ElementRef\n  ) {}\n\n  ngOnInit() {\n    const listenToLangChange = shouldListenToLangChanges(this.translocoService, this.providerLang || this.inlineLang);\n\n    this.subscription = this.translocoService.langChanges$\n      .pipe(\n        switchMap(activeLang => {\n          const lang = this.langResolver.resolve({\n            inline: this.inlineLang,\n            provider: this.providerLang,\n            active: activeLang\n          });\n\n          return Array.isArray(this.providerScope)\n            ? forkJoin(\n                (<TranslocoScope[]>this.providerScope).map(providerScope => this.resolveScope(lang, providerScope))\n              )\n            : this.resolveScope(lang, this.providerScope);\n        }),\n        listenOrNotOperator(listenToLangChange)\n      )\n      .subscribe(() => {\n        this.currentLang = this.langResolver.resolveLangBasedOnScope(this.path);\n        this.tpl === null ? this.simpleStrategy() : this.structuralStrategy(this.currentLang, this.inlineRead);\n        this.cdr.markForCheck();\n        this.initialized = true;\n      });\n\n    const loadingTpl = this.getLoadingTpl();\n    if (!this.initialized && loadingTpl) {\n      this.loaderTplHandler = new TemplateHandler(loadingTpl, this.vcr);\n      this.loaderTplHandler.attachView();\n    }\n  }\n\n  ngOnChanges(changes) {\n    // We need to support dynamic keys/params, so if this is not the first change CD cycle\n    // we need to run the function again in order to update the value\n    const notInit = Object.keys(changes).some(v => changes[v].firstChange === false);\n    notInit && this.simpleStrategy();\n  }\n\n  private simpleStrategy() {\n    this.detachLoader();\n    this.host.nativeElement.innerText = this.translocoService.translate(this.key, this.params, this.currentLang);\n  }\n\n  private structuralStrategy(lang: string, read: string | undefined) {\n    this.translationMemo = {};\n\n    if (this.view) {\n      // when the lang changes we need to change the reference so Angular will update the view\n      this.view.context['$implicit'] = this.getTranslateFn(lang, read);\n      this.view.context['currentLang'] = this.currentLang;\n    } else {\n      this.detachLoader();\n      this.view = this.vcr.createEmbeddedView(this.tpl, {\n        $implicit: this.getTranslateFn(lang, read),\n        currentLang: this.currentLang\n      });\n    }\n  }\n\n  protected getTranslateFn(lang: string, read: string | undefined): (key: string, params?: HashMap) => any {\n    return (key: string, params: HashMap) => {\n      const withRead = read ? `${read}.${key}` : key;\n      const withParams = params ? `${withRead}${JSON.stringify(params)}` : withRead;\n      if (this.translationMemo.hasOwnProperty(withParams)) {\n        return this.translationMemo[withParams].value;\n      }\n      this.translationMemo[withParams] = {\n        params,\n        value: this.translocoService.translate(withRead, params, lang)\n      };\n\n      return this.translationMemo[withParams].value;\n    };\n  }\n\n  private getLoadingTpl(): View {\n    return this.inlineTpl || this.providedLoadingTpl;\n  }\n\n  ngOnDestroy() {\n    this.subscription && this.subscription.unsubscribe();\n  }\n\n  private detachLoader() {\n    this.loaderTplHandler && this.loaderTplHandler.detachView();\n  }\n\n  private resolveScope(lang: string, providerScope: TranslocoScope): Observable<Translation | Translation[]> {\n    let resolvedScope = this.scopeResolver.resolve({ inline: this.inlineScope, provider: providerScope });\n    this.path = this.langResolver.resolveLangPath(lang, resolvedScope);\n    const inlineLoader = resolveInlineLoader(providerScope, resolvedScope);\n    return this.translocoService._loadDependencies(this.path, inlineLoader);\n  }\n}\n"]}