@ngneat/transloco
Version:
The internationalization (i18n) library for Angular
310 lines • 25.4 kB
JavaScript
/**
* @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":"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","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"]}