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.0.0 to 12.1.0

124

bundles/angular-extensions-elements.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('@angular-extensions/elements', ['exports', '@angular/core', '@angular/common'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global['angular-extensions'] = global['angular-extensions'] || {}, global['angular-extensions'].elements = {}), global.ng.core, global.ng.common));
}(this, (function (exports, i0, common) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('rxjs'), require('rxjs/operators')) :
typeof define === 'function' && define.amd ? define('@angular-extensions/elements', ['exports', '@angular/core', '@angular/common', 'rxjs', 'rxjs/operators'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global['angular-extensions'] = global['angular-extensions'] || {}, global['angular-extensions'].elements = {}), global.ng.core, global.ng.common, global.rxjs, global.rxjs.operators));
}(this, (function (exports, i0, common, rxjs, operators) { 'use strict';

@@ -522,2 +522,3 @@ function _interopNamespace(e) {

this.viewRef = null;
this.subscription = rxjs.Subscription.EMPTY;
}

@@ -541,27 +542,32 @@ LazyElementDirective.prototype.ngOnInit = function () {

}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)
.then(function () { return customElements.whenDefined(elementTag); })
.then(function () {
_this.vcr.clear();
_this.viewRef = _this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
})
.catch(function (err) {
_this.vcr.clear();
var errorComponent = elementConfig.errorComponent || options.errorComponent;
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
var loadElement$ = rxjs.from(this.elementsLoaderService.loadElement(this.url, elementTag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks));
this.subscription = loadElement$
.pipe(operators.mergeMap(function () { return customElements.whenDefined(elementTag); }))
.subscribe({
next: function () {
_this.vcr.clear();
_this.viewRef = _this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
}
else if (errorComponent) {
var factory = _this.cfr.resolveComponentFactory(errorComponent);
_this.vcr.createComponent(factory);
_this.cdr.markForCheck();
}
else {
console.error(LOG_PREFIX$1 + " - 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");
}
},
error: function () {
_this.vcr.clear();
var errorComponent = elementConfig.errorComponent || options.errorComponent;
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
var factory = _this.cfr.resolveComponentFactory(errorComponent);
_this.vcr.createComponent(factory);
_this.cdr.markForCheck();
}
else {
console.error(LOG_PREFIX$1 + " - 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");
}
},
});
};
LazyElementDirective.prototype.ngOnDestroy = function () {
this.subscription.unsubscribe();
};
LazyElementDirective.prototype.destroyEmbeddedView = function () {

@@ -612,2 +618,3 @@ if (this.viewRef && !this.viewRef.destroyed) {

this.viewRef = null;
this.subscription = rxjs.Subscription.EMPTY;
}

@@ -630,35 +637,40 @@ LazyElementDynamicDirective.prototype.ngOnInit = function () {

}
this.elementsLoaderService
.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)
.then(function () { return customElements.whenDefined(_this.tag); })
.then(function () {
_this.vcr.clear();
var originalCreateElement = _this.renderer.createElement;
_this.renderer.createElement = function (name, namespace) {
if (name === 'ax-lazy-element') {
name = _this.tag;
var loadElement$ = rxjs.from(this.elementsLoaderService.loadElement(this.url, this.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); }))
.subscribe({
next: function () {
_this.vcr.clear();
var originalCreateElement = _this.renderer.createElement;
_this.renderer.createElement = function (name, namespace) {
if (name === 'ax-lazy-element') {
name = _this.tag;
}
return _this.document.createElement(name);
};
_this.viewRef = _this.vcr.createEmbeddedView(_this.template);
_this.renderer.createElement = originalCreateElement;
_this.cdr.markForCheck();
},
error: function (error) {
var errorComponent = elementConfig.errorComponent || options.errorComponent;
_this.vcr.clear();
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
return _this.document.createElement(name);
};
_this.viewRef = _this.vcr.createEmbeddedView(_this.template);
_this.renderer.createElement = originalCreateElement;
_this.cdr.markForCheck();
})
.catch(function (error) {
var errorComponent = elementConfig.errorComponent || options.errorComponent;
_this.vcr.clear();
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
var factory = _this.cfr.resolveComponentFactory(errorComponent);
_this.vcr.createComponent(factory);
_this.cdr.markForCheck();
}
else {
console.error(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", error);
}
else if (errorComponent) {
var factory = _this.cfr.resolveComponentFactory(errorComponent);
_this.vcr.createComponent(factory);
_this.cdr.markForCheck();
}
else {
console.error(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", error);
}
},
});
};
LazyElementDynamicDirective.prototype.ngOnDestroy = function () {
this.subscription.unsubscribe();
};
LazyElementDynamicDirective.prototype.destroyEmbeddedView = function () {

@@ -665,0 +677,0 @@ if (this.viewRef && !this.viewRef.destroyed) {

import { Directive, Inject, Input, } from '@angular/core';
import { DOCUMENT } from '@angular/common';
import { from, Subscription } from 'rxjs';
import { mergeMap } from 'rxjs/operators';
import * as i0 from "@angular/core";

@@ -17,2 +19,3 @@ import * as i1 from "../lazy-elements-loader.service";

this.viewRef = null;
this.subscription = Subscription.EMPTY;
}

@@ -34,35 +37,40 @@ ngOnInit() {

}
this.elementsLoaderService
.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)
.then(() => customElements.whenDefined(this.tag))
.then(() => {
this.vcr.clear();
const originalCreateElement = this.renderer.createElement;
this.renderer.createElement = (name, namespace) => {
if (name === 'ax-lazy-element') {
name = this.tag;
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks));
this.subscription = loadElement$
.pipe(mergeMap(() => customElements.whenDefined(this.tag)))
.subscribe({
next: () => {
this.vcr.clear();
const originalCreateElement = this.renderer.createElement;
this.renderer.createElement = (name, namespace) => {
if (name === 'ax-lazy-element') {
name = this.tag;
}
return this.document.createElement(name);
};
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.renderer.createElement = originalCreateElement;
this.cdr.markForCheck();
},
error: (error) => {
const errorComponent = elementConfig.errorComponent || options.errorComponent;
this.vcr.clear();
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
return this.document.createElement(name);
};
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.renderer.createElement = originalCreateElement;
this.cdr.markForCheck();
})
.catch((error) => {
const errorComponent = elementConfig.errorComponent || options.errorComponent;
this.vcr.clear();
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${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`, error);
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${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`, error);
}
},
});
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
destroyEmbeddedView() {

@@ -105,2 +113,2 @@ if (this.viewRef && !this.viewRef.destroyed) {

}] } });
//# 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  OnInit,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\nimport {\n  ElementConfig,\n  LazyElementsLoaderService,\n} from '../lazy-elements-loader.service';\n\nconst LOG_PREFIX = '@angular-extensions/elements';\n\n/** @dynamic */\n@Directive({\n  selector: '[axLazyElementDynamic]',\n})\nexport class LazyElementDynamicDirective implements OnInit {\n  @Input('axLazyElementDynamic') tag: string;\n  @Input('axLazyElementDynamicUrl') url: string; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementDynamicLoadingTemplate')\n  loadingTemplateRef: TemplateRef<any>; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementDynamicErrorTemplate')\n  errorTemplateRef: TemplateRef<any>; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementDynamicModule') isModule: boolean | undefined; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementDynamicImportMap') importMap: boolean | undefined; // tslint:disable-line:no-input-rename\n\n  private viewRef: EmbeddedViewRef<any> = null;\n\n  constructor(\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    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    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    this.elementsLoaderService\n      .loadElement(\n        this.url,\n        this.tag,\n        this.isModule,\n        this.importMap,\n        elementConfig?.hooks\n      )\n      .then(() => customElements.whenDefined(this.tag))\n      .then(() => {\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      .catch((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 {\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  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  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { DOCUMENT } 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/** @dynamic */\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(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    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    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 {\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"]}
import { Directive, Input, } from '@angular/core';
import { from, Subscription } from 'rxjs';
import { mergeMap } from 'rxjs/operators';
import * as i0 from "@angular/core";

@@ -13,2 +15,3 @@ import * as i1 from "../lazy-elements-loader.service";

this.viewRef = null;
this.subscription = Subscription.EMPTY;
}

@@ -31,27 +34,32 @@ ngOnInit() {

}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)
.then(() => customElements.whenDefined(elementTag))
.then(() => {
this.vcr.clear();
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
})
.catch((err) => {
this.vcr.clear();
const errorComponent = elementConfig.errorComponent || options.errorComponent;
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, elementTag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks));
this.subscription = loadElement$
.pipe(mergeMap(() => customElements.whenDefined(elementTag)))
.subscribe({
next: () => {
this.vcr.clear();
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${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`);
}
},
error: () => {
this.vcr.clear();
const errorComponent = elementConfig.errorComponent || options.errorComponent;
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${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`);
}
},
});
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
destroyEmbeddedView() {

@@ -88,2 +96,2 @@ if (this.viewRef && !this.viewRef.destroyed) {

}] } });
//# 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  Input,\n  OnInit,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\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 OnInit {\n  @Input('axLazyElement') url: string;\n  @Input('axLazyElementLoadingTemplate') loadingTemplateRef: TemplateRef<any>; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementErrorTemplate') errorTemplateRef: TemplateRef<any>; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementModule') isModule: boolean | undefined; // tslint:disable-line:no-input-rename\n  @Input('axLazyElementImportMap') importMap: boolean | undefined; // tslint:disable-line:no-input-rename\n\n  private viewRef: EmbeddedViewRef<any> = null;\n\n  constructor(\n    private vcr: ViewContainerRef,\n    private template: TemplateRef<any>,\n    private elementsLoaderService: LazyElementsLoaderService,\n    private cfr: ComponentFactoryResolver,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit() {\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    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    this.elementsLoaderService\n      .loadElement(\n        this.url,\n        elementTag,\n        this.isModule,\n        this.importMap,\n        elementConfig?.hooks\n      )\n      .then(() => customElements.whenDefined(elementTag))\n      .then(() => {\n        this.vcr.clear();\n        this.viewRef = this.vcr.createEmbeddedView(this.template);\n        this.cdr.markForCheck();\n      })\n      .catch((err) => {\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 = this.cfr.resolveComponentFactory(errorComponent);\n          this.vcr.createComponent(factory);\n          this.cdr.markForCheck();\n        } else {\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      });\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.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  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\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: '[axLazyElement]',\n})\nexport class LazyElementDirective implements 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\n  constructor(\n    private vcr: ViewContainerRef,\n    private template: TemplateRef<any>,\n    private elementsLoaderService: LazyElementsLoaderService,\n    private cfr: ComponentFactoryResolver,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit() {\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    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        elementTag,\n        this.isModule,\n        this.importMap,\n        elementConfig?.hooks\n      )\n    );\n\n    this.subscription = loadElement$\n      .pipe(mergeMap(() => customElements.whenDefined(elementTag)))\n      .subscribe({\n        next: () => {\n          this.vcr.clear();\n          this.viewRef = this.vcr.createEmbeddedView(this.template);\n          this.cdr.markForCheck();\n        },\n        error: () => {\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 = this.cfr.resolveComponentFactory(errorComponent);\n            this.vcr.createComponent(factory);\n            this.cdr.markForCheck();\n          } else {\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        },\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"]}
import * as i0 from '@angular/core';
import { InjectionToken, Injectable, Inject, Optional, Directive, Input, SkipSelf, NgModule } from '@angular/core';
import { DOCUMENT, CommonModule } from '@angular/common';
import { Subscription, from } from 'rxjs';
import { mergeMap } from 'rxjs/operators';
import { __awaiter } from 'tslib';

@@ -166,2 +168,3 @@

this.viewRef = null;
this.subscription = Subscription.EMPTY;
}

@@ -184,27 +187,32 @@ ngOnInit() {

}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)
.then(() => customElements.whenDefined(elementTag))
.then(() => {
this.vcr.clear();
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
})
.catch((err) => {
this.vcr.clear();
const errorComponent = elementConfig.errorComponent || options.errorComponent;
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, elementTag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks));
this.subscription = loadElement$
.pipe(mergeMap(() => customElements.whenDefined(elementTag)))
.subscribe({
next: () => {
this.vcr.clear();
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${LOG_PREFIX$1} - 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`);
}
},
error: () => {
this.vcr.clear();
const errorComponent = elementConfig.errorComponent || options.errorComponent;
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${LOG_PREFIX$1} - 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`);
}
},
});
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
destroyEmbeddedView() {

@@ -254,2 +262,3 @@ if (this.viewRef && !this.viewRef.destroyed) {

this.viewRef = null;
this.subscription = Subscription.EMPTY;
}

@@ -271,35 +280,40 @@ ngOnInit() {

}
this.elementsLoaderService
.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks)
.then(() => customElements.whenDefined(this.tag))
.then(() => {
this.vcr.clear();
const originalCreateElement = this.renderer.createElement;
this.renderer.createElement = (name, namespace) => {
if (name === 'ax-lazy-element') {
name = this.tag;
const loadElement$ = from(this.elementsLoaderService.loadElement(this.url, this.tag, this.isModule, this.importMap, elementConfig === null || elementConfig === void 0 ? void 0 : elementConfig.hooks));
this.subscription = loadElement$
.pipe(mergeMap(() => customElements.whenDefined(this.tag)))
.subscribe({
next: () => {
this.vcr.clear();
const originalCreateElement = this.renderer.createElement;
this.renderer.createElement = (name, namespace) => {
if (name === 'ax-lazy-element') {
name = this.tag;
}
return this.document.createElement(name);
};
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.renderer.createElement = originalCreateElement;
this.cdr.markForCheck();
},
error: (error) => {
const errorComponent = elementConfig.errorComponent || options.errorComponent;
this.vcr.clear();
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
return this.document.createElement(name);
};
this.viewRef = this.vcr.createEmbeddedView(this.template);
this.renderer.createElement = originalCreateElement;
this.cdr.markForCheck();
})
.catch((error) => {
const errorComponent = elementConfig.errorComponent || options.errorComponent;
this.vcr.clear();
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${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`, error);
}
else if (errorComponent) {
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${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`, error);
}
},
});
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
destroyEmbeddedView() {

@@ -306,0 +320,0 @@ if (this.viewRef && !this.viewRef.destroyed) {

@@ -1,6 +0,6 @@

import { ChangeDetectorRef, ComponentFactoryResolver, OnInit, Renderer2, TemplateRef, ViewContainerRef } from '@angular/core';
import { ChangeDetectorRef, ComponentFactoryResolver, OnDestroy, OnInit, Renderer2, TemplateRef, ViewContainerRef } from '@angular/core';
import { LazyElementsLoaderService } from '../lazy-elements-loader.service';
import * as i0 from "@angular/core";
/** @dynamic */
export declare class LazyElementDynamicDirective implements OnInit {
export declare class LazyElementDynamicDirective implements OnInit, OnDestroy {
private document;

@@ -20,4 +20,6 @@ private renderer;

private viewRef;
private subscription;
constructor(document: Document, renderer: Renderer2, vcr: ViewContainerRef, cfr: ComponentFactoryResolver, cdr: ChangeDetectorRef, template: TemplateRef<any>, elementsLoaderService: LazyElementsLoaderService);
ngOnInit(): void;
ngOnDestroy(): void;
destroyEmbeddedView(): void;

@@ -24,0 +26,0 @@ static ɵfac: i0.ɵɵFactoryDeclaration<LazyElementDynamicDirective, never>;

@@ -1,5 +0,5 @@

import { ChangeDetectorRef, ComponentFactoryResolver, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
import { ChangeDetectorRef, ComponentFactoryResolver, OnDestroy, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
import { LazyElementsLoaderService } from '../lazy-elements-loader.service';
import * as i0 from "@angular/core";
export declare class LazyElementDirective implements OnInit {
export declare class LazyElementDirective implements OnInit, OnDestroy {
private vcr;

@@ -16,4 +16,6 @@ private template;

private viewRef;
private subscription;
constructor(vcr: ViewContainerRef, template: TemplateRef<any>, elementsLoaderService: LazyElementsLoaderService, cfr: ComponentFactoryResolver, cdr: ChangeDetectorRef);
ngOnInit(): void;
ngOnDestroy(): void;
destroyEmbeddedView(): void;

@@ -20,0 +22,0 @@ static ɵfac: i0.ɵɵFactoryDeclaration<LazyElementDirective, never>;

{
"name": "@angular-extensions/elements",
"version": "12.0.0",
"version": "12.1.0",
"peerDependencies": {

@@ -5,0 +5,0 @@ "@angular/common": ">=12",

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