Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@angular-extensions/elements

Package Overview
Dependencies
Maintainers
4
Versions
67
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@angular-extensions/elements - npm Package Compare versions

Comparing version 12.5.0 to 12.6.0

23

bundles/angular-extensions-elements.umd.js

@@ -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":"AAAA,OAAO,EAGL,SAAS,EAET,MAAM,EACN,KAAK,EAIL,WAAW,GAIZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,uBAAuB,EACvB,eAAe,EACf,KAAK,EACL,IAAI,EACJ,YAAY,GACb,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;AAO/E,MAAM,UAAU,GAAG,8BAA8B,CAAC;AAKlD,MAAM,OAAO,oBAAoB;IAW/B,YAC+B,UAAkB,EACvC,GAAqB,EACrB,QAA0B,EAC1B,qBAAgD,EAChD,GAA6B,EAC7B,GAAsB;QALD,eAAU,GAAV,UAAU,CAAQ;QACvC,QAAG,GAAH,GAAG,CAAkB;QACrB,aAAQ,GAAR,QAAQ,CAAkB;QAC1B,0BAAqB,GAArB,qBAAqB,CAA2B;QAChD,QAAG,GAAH,GAAG,CAA0B;QAC7B,QAAG,GAAH,GAAG,CAAmB;QAVxB,YAAO,GAAyB,IAAI,CAAC;QACrC,iBAAY,GAAG,YAAY,CAAC,KAAK,CAAC;QAClC,SAAI,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;IASrD,CAAC;IAEJ,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC1B;IACH,CAAC;IAED,QAAQ;QACN,uFAAuF;QACvF,uFAAuF;QACvF,6GAA6G;QAC7G,2GAA2G;QAC3G,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACrC,OAAO;SACR;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;IAED,mBAAmB;QACjB,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAC3C,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YACtB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;IACH,CAAC;IAEO,gBAAgB;QACtB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAe,CAAC;QACjC,MAAM,UAAU,GAAG,GAAG,CAAC,sBAAsB;YAC3C,CAAC,CAAC,GAAG,CAAC,sBAAsB,CAAC,OAAO,IAAI,GAAG,CAAC,sBAAsB,CAAC,KAAK;YACxE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;QAEpD,MAAM,aAAa,GACjB,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,UAAU,CAAC;YACtD,EAAoB,CAAC;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC;QACnD,MAAM,gBAAgB,GACpB,aAAa,CAAC,gBAAgB,IAAI,OAAO,CAAC,gBAAgB,CAAC;QAE7D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,IAAI;aAC1B,IAAI;QACH,uGAAuG;QACvG,kFAAkF;QAClF,mEAAmE;QACnE,YAAY,CAAC,CAAC,EAAE,uBAAuB,CAAC,EACxC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAChB,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;aACtD;iBAAM,IAAI,gBAAgB,EAAE;gBAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,CAAC;gBACnE,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;aACnC;YAED,OAAO,IAAI,CACT,IAAI,CAAC,qBAAqB,CAAC,WAAW,CACpC,GAAG,EACH,UAAU,EACV,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,SAAS,EACd,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,KAAK,CACrB,CACF,CAAC,IAAI,CACJ,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;gBACjB,MAAM,cAAc,GAClB,aAAa,CAAC,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC;gBACzD,IAAI,IAAI,CAAC,gBAAgB,EAAE;oBACzB,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;oBACnD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;iBACzB;qBAAM,IAAI,cAAc,EAAE;oBACzB,MAAM,OAAO,GACX,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,cAAc,CAAC,CAAC;oBACnD,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;oBAClC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;iBACzB;qBAAM,IAAI,SAAS,EAAE;oBACpB,OAAO,CAAC,KAAK,CACX,GAAG,UAAU,0BAA0B,UAAU,gMAAgM,CAClP,CAAC;iBACH;gBACD,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,EACF,QAAQ,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CACvD;aACA,SAAS,CAAC;YACT,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;gBACjB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC1D,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC,CAAC;IACP,CAAC;;iHApHU,oBAAoB,kBAYrB,WAAW;qGAZV,oBAAoB;2FAApB,oBAAoB;kBAHhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,iBAAiB;iBAC5B;;0BAaI,MAAM;2BAAC,WAAW;oNAXG,GAAG;sBAA1B,KAAK;uBAAC,eAAe;gBACiB,kBAAkB;sBAAxD,KAAK;uBAAC,8BAA8B;gBACA,gBAAgB;sBAApD,KAAK;uBAAC,4BAA4B;gBACL,QAAQ;sBAArC,KAAK;uBAAC,qBAAqB;gBACK,SAAS;sBAAzC,KAAK;uBAAC,wBAAwB","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":"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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 | 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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc