UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

165 lines 22.2 kB
import { Directive, Host, Input, IterableDiffers, TemplateRef, ViewContainerRef, } from '@angular/core'; import { TranslateService } from './translate.service'; import * as i0 from "@angular/core"; import * as i1 from "./translate.service"; const TEMPLATE_INTERPOLATE = /(\{\{([^}]+)\}\}|\{([^}]+)\})/g; const placeholder = (val) => ({ type: 'placeholder', val: val.trim(), }); const text = (val) => ({ type: 'text', val }); export class TranslateView { constructor(templateRef, match = '') { this.templateRef = templateRef; this.match = match; } isText() { return !this.match; } } export class TranslateDirective { constructor(viewContainer, translate, differs) { this.viewContainer = viewContainer; this.translate = translate; this.differs = differs; this.dirty = false; this.views = {}; this.differ = null; this.viewIndexes = {}; this.inlineTracker = (index, item) => item.type === 'text' ? `${item.val}_${index}` : `${item.val}_${index}_${this.views[item.val] ? 'has_view' : 'no_view'}`; } set aclTranslate(key) { this.translateKey = key; this.dirty = true; } ngDoCheck() { if (this.dirty || this.locale !== this.translate.locale) { this.locale = this.translate.locale; this.inlines = this.separateContent(this.translate.getRaw(this.translateKey)); if (!this.differ) { try { this.differ = this.differs.find([]).create(this.inlineTracker); } catch { throw new Error(`Cannot find differ for translate directive inlines`); } } this.update(this.inlines); } } separateContent(content) { if (content.length === 0) { return []; } const matches = content.matchAll(TEMPLATE_INTERPOLATE); const result = []; let prevIndex = 0; for (const match of matches) { if (match.index > prevIndex) { result.push(text(content.slice(prevIndex, match.index))); } const placeholderContent = match[2] || match[3]; result.push(placeholder(placeholderContent)); prevIndex = match.index + match[0].length; } if (prevIndex < content.length) { result.push(text(content.slice(prevIndex, content.length))); } return result; } update(inlines) { if (!this.textView) { throw new Error('translate directive need aclTranslateText to render text'); } if (!this.differ) { return; } const changes = this.differ.diff(inlines); if (!changes) { return; } this.applyChanges(changes); this.dirty = false; } applyChanges(changes) { changes.forEachOperation((change, adjustedPreviousIndex, currentIndex) => { if (change.previousIndex === null) { const item = change.item; const index = currentIndex === null ? undefined : currentIndex; if (item.type === 'text') { this.viewContainer.createEmbeddedView(this.textView.templateRef, { $implicit: item.val }, index); } else { const view = this.views[item.val]; if (view) { this.viewContainer.createEmbeddedView(view.templateRef, null, index); } else { this.viewContainer.createEmbeddedView(this.textView.templateRef, { $implicit: item.val }, index); } this.viewIndexes[item.val] = this.viewIndexes[item.val] || [index]; } } else if (currentIndex === null) { this.viewContainer.remove(adjustedPreviousIndex === null ? undefined : adjustedPreviousIndex); } else if (adjustedPreviousIndex !== null) { const view = this.viewContainer.get(adjustedPreviousIndex); this.viewContainer.move(view, currentIndex); } }); } addView(view) { if (view.isText()) { this.textView = view; } else { this.views[view.match] = view; this.update(this.inlines); } } static { this.ɵfac = function TranslateDirective_Factory(t) { return new (t || TranslateDirective)(i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i1.TranslateService), i0.ɵɵdirectiveInject(i0.IterableDiffers)); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TranslateDirective, selectors: [["", "aclTranslate", ""]], inputs: { aclTranslate: "aclTranslate" }, standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TranslateDirective, [{ type: Directive, args: [{ selector: '[aclTranslate]', standalone: true }] }], () => [{ type: i0.ViewContainerRef }, { type: i1.TranslateService }, { type: i0.IterableDiffers }], { aclTranslate: [{ type: Input }] }); })(); export class TranslateMatchDirective { constructor(templateRef, aclTranslate) { this.templateRef = templateRef; this.aclTranslate = aclTranslate; } set aclTranslateMatch(val) { this.aclTranslate.addView(new TranslateView(this.templateRef, val)); } static { this.ɵfac = function TranslateMatchDirective_Factory(t) { return new (t || TranslateMatchDirective)(i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(TranslateDirective, 1)); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TranslateMatchDirective, selectors: [["", "aclTranslateMatch", ""]], inputs: { aclTranslateMatch: "aclTranslateMatch" }, standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TranslateMatchDirective, [{ type: Directive, args: [{ selector: '[aclTranslateMatch]', standalone: true }] }], () => [{ type: i0.TemplateRef }, { type: TranslateDirective, decorators: [{ type: Host }] }], { aclTranslateMatch: [{ type: Input }] }); })(); export class TranslateTextDirective { constructor(templateRef, aclTranslate) { this.aclTranslate = aclTranslate; this.aclTranslate.addView(new TranslateView(templateRef)); } static { this.ɵfac = function TranslateTextDirective_Factory(t) { return new (t || TranslateTextDirective)(i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(TranslateDirective, 1)); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TranslateTextDirective, selectors: [["", "aclTranslateText", ""]], standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TranslateTextDirective, [{ type: Directive, args: [{ selector: '[aclTranslateText]', standalone: true }] }], () => [{ type: i0.TemplateRef }, { type: TranslateDirective, decorators: [{ type: Host }] }], null); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translate.directive.js","sourceRoot":"","sources":["../../../../../libs/common/src/translate/translate.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  DoCheck,\n  Host,\n  Input,\n  IterableChanges,\n  IterableDiffer,\n  IterableDiffers,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { Dictionary } from 'ts-essentials';\n\nimport { TranslateService } from './translate.service';\n\ninterface Inline {\n  type: 'placeholder' | 'text';\n  val: string;\n}\n\nconst TEMPLATE_INTERPOLATE = /(\\{\\{([^}]+)\\}\\}|\\{([^}]+)\\})/g;\n\nconst placeholder = (val: string): Inline => ({\n  type: 'placeholder',\n  val: val.trim(),\n});\n\nconst text = (val: string): Inline => ({ type: 'text', val });\n\nexport class TranslateView {\n  constructor(\n    public readonly templateRef: TemplateRef<any>,\n    public readonly match = '',\n  ) {}\n\n  isText() {\n    return !this.match;\n  }\n}\n\n@Directive({ selector: '[aclTranslate]', standalone: true })\nexport class TranslateDirective implements DoCheck {\n  constructor(\n    private readonly viewContainer: ViewContainerRef,\n    private readonly translate: TranslateService,\n    private readonly differs: IterableDiffers,\n  ) {}\n\n  @Input() set aclTranslate(key: string) {\n    this.translateKey = key;\n    this.dirty = true;\n  }\n\n  translateKey: string | Dictionary<string>;\n\n  private locale: string;\n\n  private dirty = false;\n\n  private textView: TranslateView;\n\n  private views: Dictionary<TranslateView> = {};\n\n  private differ: IterableDiffer<Inline> | null = null;\n\n  private viewIndexes: Dictionary<number[]> = {};\n\n  private inlines: Inline[];\n\n  inlineTracker = (index: number, item: Inline) =>\n    item.type === 'text'\n      ? `${item.val}_${index}`\n      : `${item.val}_${index}_${this.views[item.val] ? 'has_view' : 'no_view'}`;\n\n  ngDoCheck(): void {\n    if (this.dirty || this.locale !== this.translate.locale) {\n      this.locale = this.translate.locale;\n      this.inlines = this.separateContent(\n        this.translate.getRaw(this.translateKey),\n      );\n\n      if (!this.differ) {\n        try {\n          this.differ = this.differs.find([]).create(this.inlineTracker);\n        } catch {\n          throw new Error(`Cannot find differ for translate directive inlines`);\n        }\n      }\n\n      this.update(this.inlines);\n    }\n  }\n\n  separateContent(content: string) {\n    if (content.length === 0) {\n      return [];\n    }\n\n    const matches = content.matchAll(TEMPLATE_INTERPOLATE);\n\n    const result: Inline[] = [];\n    let prevIndex = 0;\n\n    for (const match of matches) {\n      if (match.index > prevIndex) {\n        result.push(text(content.slice(prevIndex, match.index)));\n      }\n\n      const placeholderContent = match[2] || match[3];\n      result.push(placeholder(placeholderContent));\n\n      prevIndex = match.index + match[0].length;\n    }\n\n    if (prevIndex < content.length) {\n      result.push(text(content.slice(prevIndex, content.length)));\n    }\n\n    return result;\n  }\n\n  private update(inlines: Inline[]) {\n    if (!this.textView) {\n      throw new Error(\n        'translate directive need aclTranslateText to render text',\n      );\n    }\n\n    if (!this.differ) {\n      return;\n    }\n\n    const changes = this.differ.diff(inlines);\n\n    if (!changes) {\n      return;\n    }\n\n    this.applyChanges(changes);\n\n    this.dirty = false;\n  }\n\n  private applyChanges(changes: IterableChanges<Inline>) {\n    changes.forEachOperation((change, adjustedPreviousIndex, currentIndex) => {\n      if (change.previousIndex === null) {\n        const item = change.item;\n        const index = currentIndex === null ? undefined : currentIndex;\n        if (item.type === 'text') {\n          this.viewContainer.createEmbeddedView(\n            this.textView.templateRef,\n            { $implicit: item.val },\n            index,\n          );\n        } else {\n          const view = this.views[item.val];\n          if (view) {\n            this.viewContainer.createEmbeddedView(\n              view.templateRef,\n              null,\n              index,\n            );\n          } else {\n            this.viewContainer.createEmbeddedView(\n              this.textView.templateRef,\n              { $implicit: item.val },\n              index,\n            );\n          }\n\n          this.viewIndexes[item.val] = this.viewIndexes[item.val] || [index];\n        }\n      } else if (currentIndex === null) {\n        this.viewContainer.remove(\n          adjustedPreviousIndex === null ? undefined : adjustedPreviousIndex,\n        );\n      } else if (adjustedPreviousIndex !== null) {\n        const view = this.viewContainer.get(adjustedPreviousIndex)!;\n        this.viewContainer.move(view, currentIndex);\n      }\n    });\n  }\n\n  addView(view: TranslateView) {\n    if (view.isText()) {\n      this.textView = view;\n    } else {\n      this.views[view.match] = view;\n      this.update(this.inlines);\n    }\n  }\n}\n\n@Directive({ selector: '[aclTranslateMatch]', standalone: true })\nexport class TranslateMatchDirective {\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    @Host() private readonly aclTranslate: TranslateDirective,\n  ) {}\n\n  @Input() set aclTranslateMatch(val: string) {\n    this.aclTranslate.addView(new TranslateView(this.templateRef, val));\n  }\n}\n\n@Directive({ selector: '[aclTranslateText]', standalone: true })\nexport class TranslateTextDirective {\n  constructor(\n    templateRef: TemplateRef<any>,\n    @Host() private readonly aclTranslate: TranslateDirective,\n  ) {\n    this.aclTranslate.addView(new TranslateView(templateRef));\n  }\n}\n"]}