@angular-extensions/elements
Advanced tools
Comparing version 12.0.0 to 12.1.0
(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":"AAAA,OAAO,EAGL,SAAS,EAET,KAAK,GAIN,MAAM,eAAe,CAAC;;;AAOvB,MAAM,UAAU,GAAG,8BAA8B,CAAC;AAKlD,MAAM,OAAO,oBAAoB;IAS/B,YACU,GAAqB,EACrB,QAA0B,EAC1B,qBAAgD,EAChD,GAA6B,EAC7B,GAAsB;QAJtB,QAAG,GAAH,GAAG,CAAkB;QACrB,aAAQ,GAAR,QAAQ,CAAkB;QAC1B,0BAAqB,GAArB,qBAAqB,CAA2B;QAChD,QAAG,GAAH,GAAG,CAA0B;QAC7B,QAAG,GAAH,GAAG,CAAmB;QAPxB,YAAO,GAAyB,IAAI,CAAC;IAQ1C,CAAC;IAEJ,QAAQ;QACN,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,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;SACtD;aAAM,IAAI,gBAAgB,EAAE;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,CAAC;YACnE,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,qBAAqB;aACvB,WAAW,CACV,IAAI,CAAC,GAAG,EACR,UAAU,EACV,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,SAAS,EACd,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,KAAK,CACrB;aACA,IAAI,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;aAClD,IAAI,CAAC,GAAG,EAAE;YACT,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;YACjB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC1D,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;YACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;YACjB,MAAM,cAAc,GAClB,aAAa,CAAC,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC;YACzD,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACzB,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACnD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;iBAAM,IAAI,cAAc,EAAE;gBACzB,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,cAAc,CAAC,CAAC;gBACjE,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;gBAClC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;aACzB;iBAAM;gBACL,OAAO,CAAC,KAAK,CACX,GAAG,UAAU,0BAA0B,UAAU,gMAAgM,CAClP,CAAC;aACH;QACH,CAAC,CAAC,CAAC;IACP,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;;iHA3EU,oBAAoB;qGAApB,oBAAoB;2FAApB,oBAAoB;kBAHhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,iBAAiB;iBAC5B;gPAEyB,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  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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
270372
2085
0