@angular-extensions/elements
Advanced tools
Comparing version 12.5.0 to 12.6.0
@@ -544,2 +544,7 @@ (function (global, factory) { | ||
this.cdr = cdr; | ||
this.url = null; | ||
this.loadingTemplateRef = null; | ||
this.errorTemplateRef = null; | ||
this.isModule = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.importMap = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.viewRef = null; | ||
@@ -665,2 +670,8 @@ this.subscription = rxjs.Subscription.EMPTY; | ||
this.elementsLoaderService = elementsLoaderService; | ||
this.tag = null; | ||
this.url = null; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.loadingTemplateRef = null; | ||
this.errorTemplateRef = null; | ||
this.isModule = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.importMap = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.viewRef = null; | ||
@@ -683,4 +694,4 @@ this.subscription = rxjs.Subscription.EMPTY; | ||
} | ||
var elementConfig = this.elementsLoaderService.getElementConfig(this.tag) || | ||
{}; | ||
var tag = this.tag; | ||
var elementConfig = this.elementsLoaderService.getElementConfig(tag) || {}; | ||
var options = this.elementsLoaderService.options; | ||
@@ -695,5 +706,5 @@ var loadingComponent = elementConfig.loadingComponent || options.loadingComponent; | ||
} | ||
var loadElement$ = rxjs.from(this.elementsLoaderService.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)); | ||
var loadElement$ = rxjs.from(this.elementsLoaderService.loadElement(this.url, tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)); | ||
this.subscription = loadElement$ | ||
.pipe(operators.mergeMap(function () { return customElements.whenDefined(_this.tag); })) | ||
.pipe(operators.mergeMap(function () { return customElements.whenDefined(tag); })) | ||
.subscribe({ | ||
@@ -705,3 +716,3 @@ next: function () { | ||
if (name === 'ax-lazy-element') { | ||
name = _this.tag; | ||
name = tag; | ||
} | ||
@@ -779,2 +790,4 @@ return _this.document.createElement(name); | ||
"use strict"; | ||
function createLazyElementRootGuard(rootOptions) { | ||
@@ -781,0 +794,0 @@ if (ngDevMode && rootOptions) { |
@@ -18,2 +18,8 @@ import { Directive, Inject, Input, PLATFORM_ID, } from '@angular/core'; | ||
this.elementsLoaderService = elementsLoaderService; | ||
this.tag = null; | ||
this.url = null; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.loadingTemplateRef = null; | ||
this.errorTemplateRef = null; | ||
this.isModule = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.importMap = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.viewRef = null; | ||
@@ -35,4 +41,4 @@ this.subscription = Subscription.EMPTY; | ||
} | ||
const elementConfig = this.elementsLoaderService.getElementConfig(this.tag) || | ||
{}; | ||
const tag = this.tag; | ||
const elementConfig = this.elementsLoaderService.getElementConfig(tag) || {}; | ||
const options = this.elementsLoaderService.options; | ||
@@ -47,5 +53,5 @@ const loadingComponent = elementConfig.loadingComponent || options.loadingComponent; | ||
} | ||
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)); | ||
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)); | ||
this.subscription = loadElement$ | ||
.pipe(mergeMap(() => customElements.whenDefined(this.tag))) | ||
.pipe(mergeMap(() => customElements.whenDefined(tag))) | ||
.subscribe({ | ||
@@ -57,3 +63,3 @@ next: () => { | ||
if (name === 'ax-lazy-element') { | ||
name = this.tag; | ||
name = tag; | ||
} | ||
@@ -127,2 +133,2 @@ return this.document.createElement(name); | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-element-dynamic.directive.js","sourceRoot":"","sources":["../../../../../../projects/elements/src/lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentFactoryResolver,\n  Directive,\n  EmbeddedViewRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  PLATFORM_ID,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { from, Subscription } from 'rxjs';\nimport { mergeMap } from 'rxjs/operators';\n\nimport {\n  ElementConfig,\n  LazyElementsLoaderService,\n} from '../lazy-elements-loader.service';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\n@Directive({\n  selector: '[axLazyElementDynamic]',\n})\nexport class LazyElementDynamicDirective implements OnInit, OnDestroy {\n  @Input('axLazyElementDynamic') tag: string;\n  @Input('axLazyElementDynamicUrl') url: string; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementDynamicLoadingTemplate') // eslint-disable-line @angular-eslint/no-input-rename\n  loadingTemplateRef: TemplateRef<any>;\n  @Input('axLazyElementDynamicErrorTemplate') // eslint-disable-line @angular-eslint/no-input-rename\n  errorTemplateRef: TemplateRef<any>;\n  @Input('axLazyElementDynamicModule') isModule: boolean | undefined; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementDynamicImportMap') importMap: boolean | undefined; // eslint-disable-line @angular-eslint/no-input-rename\n\n  private viewRef: EmbeddedViewRef<any> = null;\n  private subscription = Subscription.EMPTY;\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformId: string,\n    @Inject(DOCUMENT) private document: Document,\n    private renderer: Renderer2,\n    private vcr: ViewContainerRef,\n    private cfr: ComponentFactoryResolver,\n    private cdr: ChangeDetectorRef,\n    private template: TemplateRef<any>,\n    private elementsLoaderService: LazyElementsLoaderService\n  ) {}\n\n  ngOnInit() {\n    // There's no sense to execute the below logic on the Node.js side since the JavaScript\n    // will not be loaded on the server-side (Angular will only append the script to body).\n    // The `loadElement` promise will never be resolved, since it gets resolved when the `load` event is emitted.\n    // `customElements` are also undefined on the Node.js side; thus, it will always render the error template.\n    if (isPlatformServer(this.platformId)) {\n      return;\n    }\n\n    if (ngDevMode) {\n      if (!this.tag || this.tag.length === 0 || !this.tag.includes('-')) {\n        throw new Error(\n          `${LOG_PREFIX} - Valid tag has to be specified when using *axLazyElementDynamic directive (use *axLazyElementDynamic=\"'some-tag'\"), got: \"${this.tag}\"`\n        );\n      }\n    }\n\n    const elementConfig =\n      this.elementsLoaderService.getElementConfig(this.tag) ||\n      ({} as ElementConfig);\n    const options = this.elementsLoaderService.options;\n    const loadingComponent =\n      elementConfig.loadingComponent || options.loadingComponent;\n\n    if (this.loadingTemplateRef) {\n      this.vcr.createEmbeddedView(this.loadingTemplateRef);\n    } else if (loadingComponent) {\n      const factory = this.cfr.resolveComponentFactory(loadingComponent);\n      this.vcr.createComponent(factory);\n    }\n\n    const loadElement$ = from(\n      this.elementsLoaderService.loadElement(\n        this.url,\n        this.tag,\n        this.isModule,\n        this.importMap,\n        elementConfig?.hooks\n      )\n    );\n\n    this.subscription = loadElement$\n      .pipe(mergeMap(() => customElements.whenDefined(this.tag)))\n      .subscribe({\n        next: () => {\n          this.vcr.clear();\n          const originalCreateElement = this.renderer.createElement;\n          this.renderer.createElement = (name: string, namespace: string) => {\n            if (name === 'ax-lazy-element') {\n              name = this.tag;\n            }\n            return this.document.createElement(name);\n          };\n          this.viewRef = this.vcr.createEmbeddedView(this.template);\n          this.renderer.createElement = originalCreateElement;\n          this.cdr.markForCheck();\n        },\n        error: (error) => {\n          const errorComponent =\n            elementConfig.errorComponent || options.errorComponent;\n          this.vcr.clear();\n          if (this.errorTemplateRef) {\n            this.vcr.createEmbeddedView(this.errorTemplateRef);\n            this.cdr.markForCheck();\n          } else if (errorComponent) {\n            const factory = this.cfr.resolveComponentFactory(errorComponent);\n            this.vcr.createComponent(factory);\n            this.cdr.markForCheck();\n          } else if (ngDevMode) {\n            console.error(\n              `${LOG_PREFIX} - Loading of element <${this.tag}> failed, please provide <ng-template #error>Loading failed...</ng-template> and reference it in *axLazyElementDynamic=\"errorTemplate: error\" to display customized error message in place of element\\n\\n`,\n              error\n            );\n          }\n        },\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  destroyEmbeddedView() {\n    if (this.viewRef && !this.viewRef.destroyed) {\n      this.viewRef.detach();\n      this.viewRef.destroy();\n      this.viewRef = null;\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-element-dynamic.directive.js","sourceRoot":"","sources":["../../../../../../projects/elements/src/lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentFactoryResolver,\n  Directive,\n  EmbeddedViewRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  PLATFORM_ID,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { from, Subscription } from 'rxjs';\nimport { mergeMap } from 'rxjs/operators';\n\nimport {\n  ElementConfig,\n  LazyElementsLoaderService,\n} from '../lazy-elements-loader.service';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\n@Directive({\n  selector: '[axLazyElementDynamic]',\n})\nexport class LazyElementDynamicDirective implements OnInit, OnDestroy {\n  @Input('axLazyElementDynamic') tag: string | null = null;\n  @Input('axLazyElementDynamicUrl') url: string | null = null; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementDynamicLoadingTemplate') // eslint-disable-line @angular-eslint/no-input-rename\n  loadingTemplateRef: TemplateRef<any> | null = null;\n  @Input('axLazyElementDynamicErrorTemplate') // eslint-disable-line @angular-eslint/no-input-rename\n  errorTemplateRef: TemplateRef<any> | null = null;\n  @Input('axLazyElementDynamicModule') isModule = false; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementDynamicImportMap') importMap = false; // eslint-disable-line @angular-eslint/no-input-rename\n\n  private viewRef: EmbeddedViewRef<any> | null = null;\n  private subscription = Subscription.EMPTY;\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformId: string,\n    @Inject(DOCUMENT) private document: Document,\n    private renderer: Renderer2,\n    private vcr: ViewContainerRef,\n    private cfr: ComponentFactoryResolver,\n    private cdr: ChangeDetectorRef,\n    private template: TemplateRef<any>,\n    private elementsLoaderService: LazyElementsLoaderService\n  ) {}\n\n  ngOnInit() {\n    // There's no sense to execute the below logic on the Node.js side since the JavaScript\n    // will not be loaded on the server-side (Angular will only append the script to body).\n    // The `loadElement` promise will never be resolved, since it gets resolved when the `load` event is emitted.\n    // `customElements` are also undefined on the Node.js side; thus, it will always render the error template.\n    if (isPlatformServer(this.platformId)) {\n      return;\n    }\n\n    if (ngDevMode) {\n      if (!this.tag || this.tag.length === 0 || !this.tag.includes('-')) {\n        throw new Error(\n          `${LOG_PREFIX} - Valid tag has to be specified when using *axLazyElementDynamic directive (use *axLazyElementDynamic=\"'some-tag'\"), got: \"${this.tag}\"`\n        );\n      }\n    }\n\n    const tag = this.tag!;\n\n    const elementConfig =\n      this.elementsLoaderService.getElementConfig(tag) || ({} as ElementConfig);\n    const options = this.elementsLoaderService.options;\n    const loadingComponent =\n      elementConfig.loadingComponent || options.loadingComponent;\n\n    if (this.loadingTemplateRef) {\n      this.vcr.createEmbeddedView(this.loadingTemplateRef);\n    } else if (loadingComponent) {\n      const factory = this.cfr.resolveComponentFactory(loadingComponent);\n      this.vcr.createComponent(factory);\n    }\n\n    const loadElement$ = from(\n      this.elementsLoaderService.loadElement(\n        this.url,\n        tag,\n        this.isModule,\n        this.importMap,\n        elementConfig?.hooks\n      )\n    );\n\n    this.subscription = loadElement$\n      .pipe(mergeMap(() => customElements.whenDefined(tag)))\n      .subscribe({\n        next: () => {\n          this.vcr.clear();\n          const originalCreateElement = this.renderer.createElement;\n          this.renderer.createElement = (name: string, namespace: string) => {\n            if (name === 'ax-lazy-element') {\n              name = tag;\n            }\n            return this.document.createElement(name);\n          };\n          this.viewRef = this.vcr.createEmbeddedView(this.template);\n          this.renderer.createElement = originalCreateElement;\n          this.cdr.markForCheck();\n        },\n        error: (error) => {\n          const errorComponent =\n            elementConfig.errorComponent || options.errorComponent;\n          this.vcr.clear();\n          if (this.errorTemplateRef) {\n            this.vcr.createEmbeddedView(this.errorTemplateRef);\n            this.cdr.markForCheck();\n          } else if (errorComponent) {\n            const factory = this.cfr.resolveComponentFactory(errorComponent);\n            this.vcr.createComponent(factory);\n            this.cdr.markForCheck();\n          } else if (ngDevMode) {\n            console.error(\n              `${LOG_PREFIX} - Loading of element <${this.tag}> failed, please provide <ng-template #error>Loading failed...</ng-template> and reference it in *axLazyElementDynamic=\"errorTemplate: error\" to display customized error message in place of element\\n\\n`,\n              error\n            );\n          }\n        },\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  destroyEmbeddedView() {\n    if (this.viewRef && !this.viewRef.destroyed) {\n      this.viewRef.detach();\n      this.viewRef.destroy();\n      this.viewRef = null;\n    }\n  }\n}\n"]} |
@@ -16,2 +16,7 @@ import { Directive, Inject, Input, PLATFORM_ID, } from '@angular/core'; | ||
this.cdr = cdr; | ||
this.url = null; | ||
this.loadingTemplateRef = null; | ||
this.errorTemplateRef = null; | ||
this.isModule = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.importMap = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.viewRef = null; | ||
@@ -121,2 +126,2 @@ this.subscription = Subscription.EMPTY; | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-element.directive.js","sourceRoot":"","sources":["../../../../../../projects/elements/src/lib/lazy-elements/lazy-element/lazy-element.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentFactoryResolver,\n  Directive,\n  EmbeddedViewRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  PLATFORM_ID,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport {\n  animationFrameScheduler,\n  BehaviorSubject,\n  EMPTY,\n  from,\n  Subscription,\n} from 'rxjs';\nimport { catchError, debounceTime, mergeMap, switchMap } from 'rxjs/operators';\n\nimport {\n  ElementConfig,\n  LazyElementsLoaderService,\n} from '../lazy-elements-loader.service';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\n@Directive({\n  selector: '[axLazyElement]',\n})\nexport class LazyElementDirective implements OnChanges, OnInit, OnDestroy {\n  @Input('axLazyElement') url: string;\n  @Input('axLazyElementLoadingTemplate') loadingTemplateRef: TemplateRef<any>; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementErrorTemplate') errorTemplateRef: TemplateRef<any>; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementModule') isModule: boolean | undefined; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementImportMap') importMap: boolean | undefined; // eslint-disable-line @angular-eslint/no-input-rename\n\n  private viewRef: EmbeddedViewRef<any> = null;\n  private subscription = Subscription.EMPTY;\n  private url$ = new BehaviorSubject<string | null>(null);\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformId: string,\n    private vcr: ViewContainerRef,\n    private template: TemplateRef<any>,\n    private elementsLoaderService: LazyElementsLoaderService,\n    private cfr: ComponentFactoryResolver,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.url) {\n      this.url$.next(this.url);\n    }\n  }\n\n  ngOnInit() {\n    // There's no sense to execute the below logic on the Node.js side since the JavaScript\n    // will not be loaded on the server-side (Angular will only append the script to body).\n    // The `loadElement` promise will never be resolved, since it gets resolved when the `load` event is emitted.\n    // `customElements` are also undefined on the Node.js side; thus, it will always render the error template.\n    if (isPlatformServer(this.platformId)) {\n      return;\n    }\n\n    this.setupUrlListener();\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  destroyEmbeddedView() {\n    if (this.viewRef && !this.viewRef.destroyed) {\n      this.viewRef.detach();\n      this.viewRef.destroy();\n      this.viewRef = null;\n    }\n  }\n\n  private setupUrlListener(): void {\n    const tpl = this.template as any;\n    const elementTag = tpl._declarationTContainer\n      ? tpl._declarationTContainer.tagName || tpl._declarationTContainer.value\n      : tpl._def.element.template.nodes[0].element.name;\n\n    const elementConfig =\n      this.elementsLoaderService.getElementConfig(elementTag) ||\n      ({} as ElementConfig);\n    const options = this.elementsLoaderService.options;\n    const loadingComponent =\n      elementConfig.loadingComponent || options.loadingComponent;\n\n    this.subscription = this.url$\n      .pipe(\n        // This is used to coalesce changes since the `url$` subject might emit multiple values initially, e.g.\n        // `null` (initial value) and the url itself (when the `url` binding is provided).\n        // The `animationFrameScheduler` is used to prevent the frame drop.\n        debounceTime(0, animationFrameScheduler),\n        switchMap((url) => {\n          if (this.loadingTemplateRef) {\n            this.vcr.createEmbeddedView(this.loadingTemplateRef);\n          } else if (loadingComponent) {\n            const factory = this.cfr.resolveComponentFactory(loadingComponent);\n            this.vcr.createComponent(factory);\n          }\n\n          return from(\n            this.elementsLoaderService.loadElement(\n              url,\n              elementTag,\n              this.isModule,\n              this.importMap,\n              elementConfig?.hooks\n            )\n          ).pipe(\n            catchError(() => {\n              this.vcr.clear();\n              const errorComponent =\n                elementConfig.errorComponent || options.errorComponent;\n              if (this.errorTemplateRef) {\n                this.vcr.createEmbeddedView(this.errorTemplateRef);\n                this.cdr.markForCheck();\n              } else if (errorComponent) {\n                const factory =\n                  this.cfr.resolveComponentFactory(errorComponent);\n                this.vcr.createComponent(factory);\n                this.cdr.markForCheck();\n              } else if (ngDevMode) {\n                console.error(\n                  `${LOG_PREFIX} - Loading of element <${elementTag}> failed, please provide <ng-template #error>Loading failed...</ng-template> and reference it in *axLazyElement=\"errorTemplate: error\" to display customized error message in place of element`\n                );\n              }\n              return EMPTY;\n            })\n          );\n        }),\n        mergeMap(() => customElements.whenDefined(elementTag))\n      )\n      .subscribe({\n        next: () => {\n          this.vcr.clear();\n          this.viewRef = this.vcr.createEmbeddedView(this.template);\n          this.cdr.markForCheck();\n        },\n      });\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-element.directive.js","sourceRoot":"","sources":["../../../../../../projects/elements/src/lib/lazy-elements/lazy-element/lazy-element.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentFactoryResolver,\n  Directive,\n  EmbeddedViewRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  PLATFORM_ID,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { isPlatformServer } from '@angular/common';\nimport {\n  animationFrameScheduler,\n  BehaviorSubject,\n  EMPTY,\n  from,\n  Subscription,\n} from 'rxjs';\nimport { catchError, debounceTime, mergeMap, switchMap } from 'rxjs/operators';\n\nimport {\n  ElementConfig,\n  LazyElementsLoaderService,\n} from '../lazy-elements-loader.service';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\n@Directive({\n  selector: '[axLazyElement]',\n})\nexport class LazyElementDirective implements OnChanges, OnInit, OnDestroy {\n  @Input('axLazyElement') url: string | null = null;\n  @Input('axLazyElementLoadingTemplate') // eslint-disable-line @angular-eslint/no-input-rename\n  loadingTemplateRef: TemplateRef<any> | null = null;\n  @Input('axLazyElementErrorTemplate') // eslint-disable-line @angular-eslint/no-input-rename\n  errorTemplateRef: TemplateRef<any> | null = null;\n  @Input('axLazyElementModule') isModule = false; // eslint-disable-line @angular-eslint/no-input-rename\n  @Input('axLazyElementImportMap') importMap = false; // eslint-disable-line @angular-eslint/no-input-rename\n\n  private viewRef: EmbeddedViewRef<any> | null = null;\n  private subscription = Subscription.EMPTY;\n  private url$ = new BehaviorSubject<string | null>(null);\n\n  constructor(\n    @Inject(PLATFORM_ID) private platformId: string,\n    private vcr: ViewContainerRef,\n    private template: TemplateRef<any>,\n    private elementsLoaderService: LazyElementsLoaderService,\n    private cfr: ComponentFactoryResolver,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.url) {\n      this.url$.next(this.url);\n    }\n  }\n\n  ngOnInit() {\n    // There's no sense to execute the below logic on the Node.js side since the JavaScript\n    // will not be loaded on the server-side (Angular will only append the script to body).\n    // The `loadElement` promise will never be resolved, since it gets resolved when the `load` event is emitted.\n    // `customElements` are also undefined on the Node.js side; thus, it will always render the error template.\n    if (isPlatformServer(this.platformId)) {\n      return;\n    }\n\n    this.setupUrlListener();\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  destroyEmbeddedView() {\n    if (this.viewRef && !this.viewRef.destroyed) {\n      this.viewRef.detach();\n      this.viewRef.destroy();\n      this.viewRef = null;\n    }\n  }\n\n  private setupUrlListener(): void {\n    const tpl = this.template as any;\n    const elementTag = tpl._declarationTContainer\n      ? tpl._declarationTContainer.tagName || tpl._declarationTContainer.value\n      : tpl._def.element.template.nodes[0].element.name;\n\n    const elementConfig =\n      this.elementsLoaderService.getElementConfig(elementTag) ||\n      ({} as ElementConfig);\n    const options = this.elementsLoaderService.options;\n    const loadingComponent =\n      elementConfig.loadingComponent || options.loadingComponent;\n\n    this.subscription = this.url$\n      .pipe(\n        // This is used to coalesce changes since the `url$` subject might emit multiple values initially, e.g.\n        // `null` (initial value) and the url itself (when the `url` binding is provided).\n        // The `animationFrameScheduler` is used to prevent the frame drop.\n        debounceTime(0, animationFrameScheduler),\n        switchMap((url) => {\n          if (this.loadingTemplateRef) {\n            this.vcr.createEmbeddedView(this.loadingTemplateRef);\n          } else if (loadingComponent) {\n            const factory = this.cfr.resolveComponentFactory(loadingComponent);\n            this.vcr.createComponent(factory);\n          }\n\n          return from(\n            this.elementsLoaderService.loadElement(\n              url,\n              elementTag,\n              this.isModule,\n              this.importMap,\n              elementConfig?.hooks\n            )\n          ).pipe(\n            catchError(() => {\n              this.vcr.clear();\n              const errorComponent =\n                elementConfig.errorComponent || options.errorComponent;\n              if (this.errorTemplateRef) {\n                this.vcr.createEmbeddedView(this.errorTemplateRef);\n                this.cdr.markForCheck();\n              } else if (errorComponent) {\n                const factory =\n                  this.cfr.resolveComponentFactory(errorComponent);\n                this.vcr.createComponent(factory);\n                this.cdr.markForCheck();\n              } else if (ngDevMode) {\n                console.error(\n                  `${LOG_PREFIX} - Loading of element <${elementTag}> failed, please provide <ng-template #error>Loading failed...</ng-template> and reference it in *axLazyElement=\"errorTemplate: error\" to display customized error message in place of element`\n                );\n              }\n              return EMPTY;\n            })\n          );\n        }),\n        mergeMap(() => customElements.whenDefined(elementTag))\n      )\n      .subscribe({\n        next: () => {\n          this.vcr.clear();\n          this.viewRef = this.vcr.createEmbeddedView(this.template);\n          this.cdr.markForCheck();\n        },\n      });\n  }\n}\n"]} |
@@ -165,2 +165,2 @@ import { __awaiter } from "tslib"; | ||
}] }]; } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements-loader.service.js","sourceRoot":"","sources":["../../../../../projects/elements/src/lib/lazy-elements/lazy-elements-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ErrorHandler,\n  Inject,\n  Injectable,\n  Optional,\n  Type,\n} from '@angular/core';\n\nimport { LazyElementRootOptions } from './lazy-elements.module';\nimport {\n  LAZY_ELEMENT_ROOT_OPTIONS,\n  LAZY_ELEMENTS_REGISTRY,\n  LazyElementsRegistry,\n} from './lazy-elements.tokens';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\nexport type Hook = (tag: string) => Promise<void> | void;\n\nexport interface HooksConfig {\n  beforeLoad?: Hook;\n  afterLoad?: Hook;\n}\n\nexport interface ElementConfig {\n  tag: string;\n  url: string;\n  isModule?: boolean;\n  importMap?: boolean;\n  loadingComponent?: Type<any>;\n  errorComponent?: Type<any>;\n  preload?: boolean;\n  hooks?: HooksConfig;\n  isAdded?: boolean;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LazyElementsLoaderService {\n  configs: ElementConfig[] = [];\n\n  constructor(\n    private errorHandler: ErrorHandler,\n    @Inject(LAZY_ELEMENTS_REGISTRY) private registry: LazyElementsRegistry,\n    @Optional()\n    @Inject(LAZY_ELEMENT_ROOT_OPTIONS)\n    public options: LazyElementRootOptions\n  ) {\n    if (!options) {\n      this.options = {};\n    }\n  }\n\n  addConfigs(newConfigs: ElementConfig[]) {\n    newConfigs.forEach((newConfig) => {\n      const existingConfig = this.getElementConfig(newConfig.tag);\n      if (existingConfig) {\n        ngDevMode &&\n          console.warn(\n            `${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`\n          );\n      } else {\n        newConfig.isAdded = true;\n        this.configs.push(newConfig);\n        const shouldPreload =\n          newConfig.preload !== undefined\n            ? newConfig.preload\n            : this.options.preload;\n        if (shouldPreload) {\n          this.loadElement(\n            newConfig.url,\n            newConfig.tag,\n            newConfig.isModule,\n            newConfig.importMap,\n            newConfig.hooks\n          );\n        }\n      }\n    });\n  }\n\n  getElementConfig(tag: string): ElementConfig {\n    return this.configs.find((config) => config.tag === tag);\n  }\n\n  preload(tags?: string[]) {\n    let configs = this.configs;\n    if (tags) {\n      configs = this.configs.filter((config) => tags.includes(config.tag));\n    }\n    configs.forEach((config) =>\n      this.loadElement(\n        config.url,\n        config.tag,\n        config.isModule,\n        config.importMap,\n        config.hooks\n      )\n    );\n  }\n\n  async loadElement(\n    url: string,\n    tag: string,\n    isModule?: boolean,\n    importMap?: boolean,\n    hooksConfig?: HooksConfig\n  ): Promise<void> {\n    const config = this.getElementConfig(tag);\n    isModule ??= config?.isModule ?? this.options.isModule;\n    importMap ??= config?.importMap ?? this.options.importMap;\n\n    if (ngDevMode && !tag) {\n      throw new Error(\n        `${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`\n      );\n    }\n\n    if (!url) {\n      if (ngDevMode && !config?.url && !importMap) {\n        throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);\n      } else if (importMap) {\n        url = tag;\n      } else {\n        url = config.url;\n      }\n    }\n\n    if (!this.hasElement(url)) {\n      const notifier = this.addElement(url);\n\n      const beforeLoadHook =\n        hooksConfig?.beforeLoad ??\n        config?.hooks?.beforeLoad ??\n        this.options?.hooks?.beforeLoad;\n      const afterLoadHook =\n        hooksConfig?.afterLoad ??\n        config?.hooks?.afterLoad ??\n        this.options?.hooks?.afterLoad;\n\n      if (importMap) {\n        url = await this.resolveImportMap(url);\n      }\n\n      const script = document.createElement('script') as HTMLScriptElement;\n      if (isModule) {\n        script.type = 'module';\n      }\n      script.src = url;\n      const onLoad = () => {\n        if (afterLoadHook) {\n          this.handleHook(afterLoadHook, tag)\n            .then(notifier.resolve)\n            .catch(notifier.reject);\n        } else {\n          notifier.resolve();\n        }\n\n        cleanup();\n      };\n      const onError = (error: ErrorEvent) => {\n        notifier.reject(error);\n        cleanup();\n        // Caretaker note: don't put it before the `reject` and `cleanup` since the user may have some\n        // custom error handler that will re-throw the error through `throw error`. Hence the code won't\n        // be executed, and the promise won't be rejected.\n        this.errorHandler.handleError(error);\n      };\n      // The `load` and `error` event listeners capture `this`. That's why they have to be removed manually.\n      // Otherwise, the `LazyElementsLoaderService` is not going to be GC'd.\n      function cleanup() {\n        script.removeEventListener('load', onLoad);\n        script.removeEventListener('error', onError);\n      }\n      script.addEventListener('load', onLoad);\n      script.addEventListener('error', onError);\n      if (beforeLoadHook) {\n        this.handleHook(beforeLoadHook, tag)\n          .then(() => document.body.appendChild(script))\n          .catch(notifier.reject);\n      } else {\n        document.body.appendChild(script);\n      }\n    }\n    return this.registry.get(this.stripUrlProtocol(url));\n  }\n\n  private addElement(url: string): Notifier {\n    let notifier: Notifier;\n    this.registry.set(\n      this.stripUrlProtocol(url),\n      new Promise<void>((resolve, reject) => (notifier = { resolve, reject }))\n    );\n    return notifier;\n  }\n\n  private hasElement(url: string): boolean {\n    return this.registry.has(this.stripUrlProtocol(url));\n  }\n\n  private stripUrlProtocol(url: string): string {\n    return url.replace(/https?:\\/\\//, '');\n  }\n\n  private handleHook(hook: Hook, tag: string): Promise<void> {\n    try {\n      return Promise.resolve(hook(tag));\n    } catch (err) {\n      return Promise.reject(err);\n    }\n  }\n\n  private async resolveImportMap(url: string) {\n    const System = (window as any).System;\n    if (System) {\n      await System.prepareImport();\n      url = System.resolve(url);\n    } else if (ngDevMode) {\n      throw new Error(\n        `${LOG_PREFIX} - importMap feature depends on SystemJS library to be globally loaded but none was found, thus '${url}' can't be resolved. You should either load SystemJS or remove the importMap flag.`\n      );\n    }\n    return url;\n  }\n}\n\ninterface Notifier {\n  resolve: () => void;\n  reject: (error: any) => void;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements-loader.service.js","sourceRoot":"","sources":["../../../../../projects/elements/src/lib/lazy-elements/lazy-elements-loader.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAEL,MAAM,EACN,UAAU,EACV,QAAQ,GAET,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,yBAAyB,EACzB,sBAAsB,GAEvB,MAAM,wBAAwB,CAAC;;AAEhC,MAAM,UAAU,GAAG,8BAA8B,CAAC;AAwBlD,MAAM,OAAO,yBAAyB;IAGpC,YACU,YAA0B,EACM,QAA8B,EAG/D,OAA+B;QAJ9B,iBAAY,GAAZ,YAAY,CAAc;QACM,aAAQ,GAAR,QAAQ,CAAsB;QAG/D,YAAO,GAAP,OAAO,CAAwB;QAPxC,YAAO,GAAoB,EAAE,CAAC;QAS5B,IAAI,CAAC,OAAO,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;SACnB;IACH,CAAC;IAED,UAAU,CAAC,UAA2B;QACpC,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC/B,MAAM,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YAC5D,IAAI,cAAc,EAAE;gBAClB,SAAS;oBACP,OAAO,CAAC,IAAI,CACV,GAAG,UAAU,6BAA6B,SAAS,CAAC,GAAG,0EAA0E,CAClI,CAAC;aACL;iBAAM;gBACL,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;gBACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBAC7B,MAAM,aAAa,GACjB,SAAS,CAAC,OAAO,KAAK,SAAS;oBAC7B,CAAC,CAAC,SAAS,CAAC,OAAO;oBACnB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;gBAC3B,IAAI,aAAa,EAAE;oBACjB,IAAI,CAAC,WAAW,CACd,SAAS,CAAC,GAAG,EACb,SAAS,CAAC,GAAG,EACb,SAAS,CAAC,QAAQ,EAClB,SAAS,CAAC,SAAS,EACnB,SAAS,CAAC,KAAK,CAChB,CAAC;iBACH;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,GAAW;QAC1B,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,CAAC,IAAe;QACrB,IAAI,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC3B,IAAI,IAAI,EAAE;YACR,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;SACtE;QACD,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CACzB,IAAI,CAAC,WAAW,CACd,MAAM,CAAC,GAAG,EACV,MAAM,CAAC,GAAG,EACV,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,KAAK,CACb,CACF,CAAC;IACJ,CAAC;IAEK,WAAW,CACf,GAAkB,EAClB,GAAW,EACX,QAAkB,EAClB,SAAmB,EACnB,WAAyB;;;YAEzB,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;YAC1C,QAAQ,aAAR,QAAQ,cAAR,QAAQ,IAAR,QAAQ,GAAK,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,mCAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAC;YACvD,SAAS,aAAT,SAAS,cAAT,SAAS,IAAT,SAAS,GAAK,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,mCAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAC;YAE1D,IAAI,SAAS,IAAI,CAAC,GAAG,EAAE;gBACrB,MAAM,IAAI,KAAK,CACb,GAAG,UAAU,eAAe,GAAG,gEAAgE,CAChG,CAAC;aACH;YAED,IAAI,CAAC,GAAG,EAAE;gBACR,IAAI,SAAS,IAAI,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,GAAG,CAAA,IAAI,CAAC,SAAS,EAAE;oBAC3C,MAAM,IAAI,KAAK,CAAC,GAAG,UAAU,eAAe,GAAG,aAAa,CAAC,CAAC;iBAC/D;qBAAM,IAAI,SAAS,EAAE;oBACpB,GAAG,GAAG,GAAG,CAAC;iBACX;qBAAM;oBACL,GAAG,GAAG,MAAO,CAAC,GAAG,CAAC;iBACnB;aACF;YAED,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;gBACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;gBAEtC,MAAM,cAAc,GAClB,MAAA,MAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,mCACvB,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,0CAAE,UAAU,mCACzB,MAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,KAAK,0CAAE,UAAU,CAAC;gBAClC,MAAM,aAAa,GACjB,MAAA,MAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,SAAS,mCACtB,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,0CAAE,SAAS,mCACxB,MAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,KAAK,0CAAE,SAAS,CAAC;gBAEjC,IAAI,SAAS,EAAE;oBACb,GAAG,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;iBACxC;gBAED,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAsB,CAAC;gBACrE,IAAI,QAAQ,EAAE;oBACZ,MAAM,CAAC,IAAI,GAAG,QAAQ,CAAC;iBACxB;gBACD,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC;gBACjB,MAAM,MAAM,GAAG,GAAG,EAAE;oBAClB,IAAI,aAAa,EAAE;wBACjB,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,GAAG,CAAC;6BAChC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;6BACtB,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;qBAC3B;yBAAM;wBACL,QAAQ,CAAC,OAAO,EAAE,CAAC;qBACpB;oBAED,OAAO,EAAE,CAAC;gBACZ,CAAC,CAAC;gBACF,MAAM,OAAO,GAAG,CAAC,KAAiB,EAAE,EAAE;oBACpC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBACvB,OAAO,EAAE,CAAC;oBACV,8FAA8F;oBAC9F,gGAAgG;oBAChG,kDAAkD;oBAClD,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACvC,CAAC,CAAC;gBACF,sGAAsG;gBACtG,sEAAsE;gBACtE,SAAS,OAAO;oBACd,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;oBAC3C,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBAC/C,CAAC;gBACD,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;gBACxC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBAC1C,IAAI,cAAc,EAAE;oBAClB,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,GAAG,CAAC;yBACjC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;yBAC7C,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;iBAC3B;qBAAM;oBACL,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;iBACnC;aACF;YACD,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;;KACtD;IAEO,UAAU,CAAC,GAAW;QAC5B,IAAI,QAAkB,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,GAAG,CACf,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAC1B,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC,QAAQ,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC,CACzE,CAAC;QACF,OAAO,QAAS,CAAC;IACnB,CAAC;IAEO,UAAU,CAAC,GAAW;QAC5B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;IACvD,CAAC;IAEO,gBAAgB,CAAC,GAAW;QAClC,OAAO,GAAG,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;IACxC,CAAC;IAEO,UAAU,CAAC,IAAU,EAAE,GAAW;QACxC,IAAI;YACF,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;SACnC;QAAC,OAAO,GAAG,EAAE;YACZ,OAAO,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SAC5B;IACH,CAAC;IAEa,gBAAgB,CAAC,GAAW;;YACxC,MAAM,MAAM,GAAI,MAAc,CAAC,MAAM,CAAC;YACtC,IAAI,MAAM,EAAE;gBACV,MAAM,MAAM,CAAC,aAAa,EAAE,CAAC;gBAC7B,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;aAC3B;iBAAM,IAAI,SAAS,EAAE;gBACpB,MAAM,IAAI,KAAK,CACb,GAAG,UAAU,oGAAoG,GAAG,oFAAoF,CACzM,CAAC;aACH;YACD,OAAO,GAAG,CAAC;QACb,CAAC;KAAA;;sHAzLU,yBAAyB,8CAK1B,sBAAsB,aAEtB,yBAAyB;0HAPxB,yBAAyB,cAFxB,MAAM;2FAEP,yBAAyB;kBAHrC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAMI,MAAM;2BAAC,sBAAsB;;0BAC7B,QAAQ;;0BACR,MAAM;2BAAC,yBAAyB","sourcesContent":["import {\n  ErrorHandler,\n  Inject,\n  Injectable,\n  Optional,\n  Type,\n} from '@angular/core';\n\nimport { LazyElementRootOptions } from './lazy-elements.module';\nimport {\n  LAZY_ELEMENT_ROOT_OPTIONS,\n  LAZY_ELEMENTS_REGISTRY,\n  LazyElementsRegistry,\n} from './lazy-elements.tokens';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\nexport type Hook = (tag: string) => Promise<void> | void;\n\nexport interface HooksConfig {\n  beforeLoad?: Hook;\n  afterLoad?: Hook;\n}\n\nexport interface ElementConfig {\n  tag: string;\n  url: string;\n  isModule?: boolean;\n  importMap?: boolean;\n  loadingComponent?: Type<any>;\n  errorComponent?: Type<any>;\n  preload?: boolean;\n  hooks?: HooksConfig;\n  isAdded?: boolean;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LazyElementsLoaderService {\n  configs: ElementConfig[] = [];\n\n  constructor(\n    private errorHandler: ErrorHandler,\n    @Inject(LAZY_ELEMENTS_REGISTRY) private registry: LazyElementsRegistry,\n    @Optional()\n    @Inject(LAZY_ELEMENT_ROOT_OPTIONS)\n    public options: LazyElementRootOptions\n  ) {\n    if (!options) {\n      this.options = {};\n    }\n  }\n\n  addConfigs(newConfigs: ElementConfig[]) {\n    newConfigs.forEach((newConfig) => {\n      const existingConfig = this.getElementConfig(newConfig.tag);\n      if (existingConfig) {\n        ngDevMode &&\n          console.warn(\n            `${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`\n          );\n      } else {\n        newConfig.isAdded = true;\n        this.configs.push(newConfig);\n        const shouldPreload =\n          newConfig.preload !== undefined\n            ? newConfig.preload\n            : this.options.preload;\n        if (shouldPreload) {\n          this.loadElement(\n            newConfig.url,\n            newConfig.tag,\n            newConfig.isModule,\n            newConfig.importMap,\n            newConfig.hooks\n          );\n        }\n      }\n    });\n  }\n\n  getElementConfig(tag: string): ElementConfig | undefined {\n    return this.configs.find((config) => config.tag === tag);\n  }\n\n  preload(tags?: string[]) {\n    let configs = this.configs;\n    if (tags) {\n      configs = this.configs.filter((config) => tags.includes(config.tag));\n    }\n    configs.forEach((config) =>\n      this.loadElement(\n        config.url,\n        config.tag,\n        config.isModule,\n        config.importMap,\n        config.hooks\n      )\n    );\n  }\n\n  async loadElement(\n    url: string | null,\n    tag: string,\n    isModule?: boolean,\n    importMap?: boolean,\n    hooksConfig?: HooksConfig\n  ): Promise<void> {\n    const config = this.getElementConfig(tag);\n    isModule ??= config?.isModule ?? this.options.isModule;\n    importMap ??= config?.importMap ?? this.options.importMap;\n\n    if (ngDevMode && !tag) {\n      throw new Error(\n        `${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`\n      );\n    }\n\n    if (!url) {\n      if (ngDevMode && !config?.url && !importMap) {\n        throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);\n      } else if (importMap) {\n        url = tag;\n      } else {\n        url = config!.url;\n      }\n    }\n\n    if (!this.hasElement(url)) {\n      const notifier = this.addElement(url);\n\n      const beforeLoadHook =\n        hooksConfig?.beforeLoad ??\n        config?.hooks?.beforeLoad ??\n        this.options?.hooks?.beforeLoad;\n      const afterLoadHook =\n        hooksConfig?.afterLoad ??\n        config?.hooks?.afterLoad ??\n        this.options?.hooks?.afterLoad;\n\n      if (importMap) {\n        url = await this.resolveImportMap(url);\n      }\n\n      const script = document.createElement('script') as HTMLScriptElement;\n      if (isModule) {\n        script.type = 'module';\n      }\n      script.src = url;\n      const onLoad = () => {\n        if (afterLoadHook) {\n          this.handleHook(afterLoadHook, tag)\n            .then(notifier.resolve)\n            .catch(notifier.reject);\n        } else {\n          notifier.resolve();\n        }\n\n        cleanup();\n      };\n      const onError = (error: ErrorEvent) => {\n        notifier.reject(error);\n        cleanup();\n        // Caretaker note: don't put it before the `reject` and `cleanup` since the user may have some\n        // custom error handler that will re-throw the error through `throw error`. Hence the code won't\n        // be executed, and the promise won't be rejected.\n        this.errorHandler.handleError(error);\n      };\n      // The `load` and `error` event listeners capture `this`. That's why they have to be removed manually.\n      // Otherwise, the `LazyElementsLoaderService` is not going to be GC'd.\n      function cleanup() {\n        script.removeEventListener('load', onLoad);\n        script.removeEventListener('error', onError);\n      }\n      script.addEventListener('load', onLoad);\n      script.addEventListener('error', onError);\n      if (beforeLoadHook) {\n        this.handleHook(beforeLoadHook, tag)\n          .then(() => document.body.appendChild(script))\n          .catch(notifier.reject);\n      } else {\n        document.body.appendChild(script);\n      }\n    }\n    return this.registry.get(this.stripUrlProtocol(url));\n  }\n\n  private addElement(url: string): Notifier {\n    let notifier: Notifier;\n    this.registry.set(\n      this.stripUrlProtocol(url),\n      new Promise<void>((resolve, reject) => (notifier = { resolve, reject }))\n    );\n    return notifier!;\n  }\n\n  private hasElement(url: string): boolean {\n    return this.registry.has(this.stripUrlProtocol(url));\n  }\n\n  private stripUrlProtocol(url: string): string {\n    return url.replace(/https?:\\/\\//, '');\n  }\n\n  private handleHook(hook: Hook, tag: string): Promise<void> {\n    try {\n      return Promise.resolve(hook(tag));\n    } catch (err) {\n      return Promise.reject(err);\n    }\n  }\n\n  private async resolveImportMap(url: string) {\n    const System = (window as any).System;\n    if (System) {\n      await System.prepareImport();\n      url = System.resolve(url);\n    } else if (ngDevMode) {\n      throw new Error(\n        `${LOG_PREFIX} - importMap feature depends on SystemJS library to be globally loaded but none was found, thus '${url}' can't be resolved. You should either load SystemJS or remove the importMap flag.`\n      );\n    }\n    return url;\n  }\n}\n\ninterface Notifier {\n  resolve: () => void;\n  reject: (error: any) => void;\n}\n"]} |
@@ -9,2 +9,2 @@ import { InjectionToken } from '@angular/core'; | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50cy50b2tlbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGVtZW50cy9zcmMvbGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy50b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUsvQyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGNBQWMsQ0FDcEQsc0JBQXNCLENBQ3ZCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FDcEMsSUFBSSxjQUFjLENBQXlCLDJCQUEyQixDQUFDLENBQUM7QUFFMUUsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxjQUFjLENBQ3ZELHlCQUF5QixDQUMxQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3RELHdCQUF3QixFQUN4QjtJQUNFLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLEdBQUcsRUFBeUI7Q0FDaEQsQ0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRWxlbWVudENvbmZpZyB9IGZyb20gJy4vbGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZSc7XG5pbXBvcnQgeyBMYXp5RWxlbWVudFJvb3RPcHRpb25zIH0gZnJvbSAnLi9sYXp5LWVsZW1lbnRzLm1vZHVsZSc7XG5cbmV4cG9ydCBjb25zdCBMQVpZX0VMRU1FTlRfQ09ORklHUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxFbGVtZW50Q29uZmlnW10+KFxuICAnTEFaWV9FTEVNRU5UX0NPTkZJR1MnXG4pO1xuXG5leHBvcnQgY29uc3QgTEFaWV9FTEVNRU5UX1JPT1RfT1BUSU9OUyA9XG4gIG5ldyBJbmplY3Rpb25Ub2tlbjxMYXp5RWxlbWVudFJvb3RPcHRpb25zPignTEFaWV9FTEVNRU5UX1JPT1RfT1BUSU9OUycpO1xuXG5leHBvcnQgY29uc3QgTEFaWV9FTEVNRU5UX1JPT1RfR1VBUkQgPSBuZXcgSW5qZWN0aW9uVG9rZW48dm9pZD4oXG4gICdMQVpZX0VMRU1FTlRfUk9PVF9HVUFSRCdcbik7XG5cbmV4cG9ydCBjb25zdCBMQVpZX0VMRU1FTlRTX1JFR0lTVFJZID0gbmV3IEluamVjdGlvblRva2VuPExhenlFbGVtZW50c1JlZ2lzdHJ5PihcbiAgJ0xBWllfRUxFTUVOVFNfUkVHSVNUUlknLFxuICB7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICAgIGZhY3Rvcnk6ICgpID0+IG5ldyBNYXA8c3RyaW5nLCBQcm9taXNlPHZvaWQ+PigpLFxuICB9XG4pO1xuXG5leHBvcnQgaW50ZXJmYWNlIExhenlFbGVtZW50c1JlZ2lzdHJ5IHtcbiAgZ2V0OiAodXJsOiBzdHJpbmcpID0+IFByb21pc2U8dm9pZD47XG4gIHNldDogKHVybDogc3RyaW5nLCBub3RpZmllcjogUHJvbWlzZTx2b2lkPikgPT4gdm9pZDtcbiAgaGFzOiAodXJsOiBzdHJpbmcpID0+IGJvb2xlYW47XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50cy50b2tlbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGVtZW50cy9zcmMvbGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy50b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUsvQyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGNBQWMsQ0FDcEQsc0JBQXNCLENBQ3ZCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FDcEMsSUFBSSxjQUFjLENBQXlCLDJCQUEyQixDQUFDLENBQUM7QUFFMUUsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxjQUFjLENBQ3ZELHlCQUF5QixDQUMxQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3RELHdCQUF3QixFQUN4QjtJQUNFLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLEdBQUcsRUFBeUI7Q0FDaEQsQ0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRWxlbWVudENvbmZpZyB9IGZyb20gJy4vbGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZSc7XG5pbXBvcnQgeyBMYXp5RWxlbWVudFJvb3RPcHRpb25zIH0gZnJvbSAnLi9sYXp5LWVsZW1lbnRzLm1vZHVsZSc7XG5cbmV4cG9ydCBjb25zdCBMQVpZX0VMRU1FTlRfQ09ORklHUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxFbGVtZW50Q29uZmlnW10+KFxuICAnTEFaWV9FTEVNRU5UX0NPTkZJR1MnXG4pO1xuXG5leHBvcnQgY29uc3QgTEFaWV9FTEVNRU5UX1JPT1RfT1BUSU9OUyA9XG4gIG5ldyBJbmplY3Rpb25Ub2tlbjxMYXp5RWxlbWVudFJvb3RPcHRpb25zPignTEFaWV9FTEVNRU5UX1JPT1RfT1BUSU9OUycpO1xuXG5leHBvcnQgY29uc3QgTEFaWV9FTEVNRU5UX1JPT1RfR1VBUkQgPSBuZXcgSW5qZWN0aW9uVG9rZW48dm9pZD4oXG4gICdMQVpZX0VMRU1FTlRfUk9PVF9HVUFSRCdcbik7XG5cbmV4cG9ydCBjb25zdCBMQVpZX0VMRU1FTlRTX1JFR0lTVFJZID0gbmV3IEluamVjdGlvblRva2VuPExhenlFbGVtZW50c1JlZ2lzdHJ5PihcbiAgJ0xBWllfRUxFTUVOVFNfUkVHSVNUUlknLFxuICB7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICAgIGZhY3Rvcnk6ICgpID0+IG5ldyBNYXA8c3RyaW5nLCBQcm9taXNlPHZvaWQ+PigpLFxuICB9XG4pO1xuXG5leHBvcnQgaW50ZXJmYWNlIExhenlFbGVtZW50c1JlZ2lzdHJ5IGV4dGVuZHMgTWFwPHN0cmluZywgUHJvbWlzZTx2b2lkPj4ge1xuICBnZXQ6ICh1cmw6IHN0cmluZykgPT4gUHJvbWlzZTx2b2lkPiB8IHVuZGVmaW5lZDtcbiAgc2V0OiAodXJsOiBzdHJpbmcsIG5vdGlmaWVyOiBQcm9taXNlPHZvaWQ+KSA9PiB0aGlzO1xuICBoYXM6ICh1cmw6IHN0cmluZykgPT4gYm9vbGVhbjtcbn1cbiJdfQ== |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctZGV2LW1vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGVtZW50cy9zcmMvbGliL2xhenktZWxlbWVudHMvbmctZGV2LW1vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGRlc2NyaXB0aW9uIFdpbGwgYmUgcHJvdmlkZWQgdGhyb3VnaCBUZXJzZXIgZ2xvYmFsIGRlZmluaXRpb25zIGJ5IEFuZ3VsYXIgQ0xJIGR1cmluZyB0aGVcbiAqIHByb2R1Y3Rpb24gYnVpbGQgKG5nIGJ1aWxkIC0tY29uZmlndXJhdGlvbiBwcm9kdWN0aW9uKS4gVGhpcyBpcyBob3cgQW5ndWxhciBkb2VzIHRyZWUtc2hha2luZyBpbnRlcm5hbGx5LlxuICpcbiAqIEBpbnRlcm5hbFxuICovXG5kZWNsYXJlIGNvbnN0IG5nRGV2TW9kZTogYm9vbGVhbjtcbiJdfQ== |
@@ -186,2 +186,7 @@ import * as i0 from '@angular/core'; | ||
this.cdr = cdr; | ||
this.url = null; | ||
this.loadingTemplateRef = null; | ||
this.errorTemplateRef = null; | ||
this.isModule = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.importMap = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.viewRef = null; | ||
@@ -303,2 +308,8 @@ this.subscription = Subscription.EMPTY; | ||
this.elementsLoaderService = elementsLoaderService; | ||
this.tag = null; | ||
this.url = null; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.loadingTemplateRef = null; | ||
this.errorTemplateRef = null; | ||
this.isModule = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.importMap = false; // eslint-disable-line @angular-eslint/no-input-rename | ||
this.viewRef = null; | ||
@@ -320,4 +331,4 @@ this.subscription = Subscription.EMPTY; | ||
} | ||
const elementConfig = this.elementsLoaderService.getElementConfig(this.tag) || | ||
{}; | ||
const tag = this.tag; | ||
const elementConfig = this.elementsLoaderService.getElementConfig(tag) || {}; | ||
const options = this.elementsLoaderService.options; | ||
@@ -332,5 +343,5 @@ const loadingComponent = elementConfig.loadingComponent || options.loadingComponent; | ||
} | ||
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)); | ||
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)); | ||
this.subscription = loadElement$ | ||
.pipe(mergeMap(() => customElements.whenDefined(this.tag))) | ||
.pipe(mergeMap(() => customElements.whenDefined(tag))) | ||
.subscribe({ | ||
@@ -342,3 +353,3 @@ next: () => { | ||
if (name === 'ax-lazy-element') { | ||
name = this.tag; | ||
name = tag; | ||
} | ||
@@ -413,2 +424,4 @@ return this.document.createElement(name); | ||
"use strict"; | ||
function createLazyElementRootGuard(rootOptions) { | ||
@@ -415,0 +428,0 @@ if (ngDevMode && rootOptions) { |
@@ -13,8 +13,8 @@ import { ChangeDetectorRef, ComponentFactoryResolver, OnDestroy, OnInit, Renderer2, TemplateRef, ViewContainerRef } from '@angular/core'; | ||
private elementsLoaderService; | ||
tag: string; | ||
url: string; | ||
loadingTemplateRef: TemplateRef<any>; | ||
errorTemplateRef: TemplateRef<any>; | ||
isModule: boolean | undefined; | ||
importMap: boolean | undefined; | ||
tag: string | null; | ||
url: string | null; | ||
loadingTemplateRef: TemplateRef<any> | null; | ||
errorTemplateRef: TemplateRef<any> | null; | ||
isModule: boolean; | ||
importMap: boolean; | ||
private viewRef; | ||
@@ -21,0 +21,0 @@ private subscription; |
@@ -11,7 +11,7 @@ import { ChangeDetectorRef, ComponentFactoryResolver, OnChanges, OnDestroy, OnInit, SimpleChanges, TemplateRef, ViewContainerRef } from '@angular/core'; | ||
private cdr; | ||
url: string; | ||
loadingTemplateRef: TemplateRef<any>; | ||
errorTemplateRef: TemplateRef<any>; | ||
isModule: boolean | undefined; | ||
importMap: boolean | undefined; | ||
url: string | null; | ||
loadingTemplateRef: TemplateRef<any> | null; | ||
errorTemplateRef: TemplateRef<any> | null; | ||
isModule: boolean; | ||
importMap: boolean; | ||
private viewRef; | ||
@@ -18,0 +18,0 @@ private subscription; |
@@ -28,5 +28,5 @@ import { ErrorHandler, Type } from '@angular/core'; | ||
addConfigs(newConfigs: ElementConfig[]): void; | ||
getElementConfig(tag: string): ElementConfig; | ||
getElementConfig(tag: string): ElementConfig | undefined; | ||
preload(tags?: string[]): void; | ||
loadElement(url: string, tag: string, isModule?: boolean, importMap?: boolean, hooksConfig?: HooksConfig): Promise<void>; | ||
loadElement(url: string | null, tag: string, isModule?: boolean, importMap?: boolean, hooksConfig?: HooksConfig): Promise<void>; | ||
private addElement; | ||
@@ -33,0 +33,0 @@ private hasElement; |
@@ -8,6 +8,6 @@ import { InjectionToken } from '@angular/core'; | ||
export declare const LAZY_ELEMENTS_REGISTRY: InjectionToken<LazyElementsRegistry>; | ||
export interface LazyElementsRegistry { | ||
get: (url: string) => Promise<void>; | ||
set: (url: string, notifier: Promise<void>) => void; | ||
export interface LazyElementsRegistry extends Map<string, Promise<void>> { | ||
get: (url: string) => Promise<void> | undefined; | ||
set: (url: string, notifier: Promise<void>) => this; | ||
has: (url: string) => boolean; | ||
} |
{ | ||
"name": "@angular-extensions/elements", | ||
"version": "12.5.0", | ||
"version": "12.6.0", | ||
"peerDependencies": { | ||
@@ -5,0 +5,0 @@ "@angular/common": ">=12", |
@@ -123,1 +123,15 @@ <p align="center"> | ||
<!-- ALL-CONTRIBUTORS-LIST:END --> | ||
## Sponsors | ||
> Are you currently working in an enterprise environment with many applications and found yourself thinking you could provide so much more value only if you had better overview to plan, track progress and just get things done? | ||
Try _[Omniboard](https://omniboard.dev), the best tool for lead software engineers and architects_ | ||
that helps them to get an overview to drive change by querying and tracking all their code bases! | ||
The free plan let's you get a full overview of all your projects with your first dashboard, tracking up to 3 different things! | ||
<a href="http://www.youtube.com/watch?feature=player_embedded&v=uDnNE9FuLwc" target="_blank"> | ||
<img src="https://app.omniboard.dev/assets/videos/omniboard-getting-started.png" | ||
alt="Omniboard.dev - getting started in less than 5 minutes" width="100%" /> | ||
</a> |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
302448
2300
137