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

@angular-extensions/elements

Package Overview
Dependencies
Maintainers
3
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 0.3.7 to 6.1.0

esm2015/lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive.js

6

angular-extensions-elements.d.ts

@@ -5,3 +5,5 @@ /**

export * from './public-api';
export { LazyElementDirective as ɵa } from './lib/lazy-elements/lazy-element/lazy-element.directive';
export { LazyElementsLoaderService as ɵb } from './lib/lazy-elements/lazy-elements-loader.service';
export { LazyElementDynamicDirective as ɵg } from './lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive';
export { LazyElementDirective as ɵd } from './lib/lazy-elements/lazy-element/lazy-element.directive';
export { ElementConfig as ɵe, LazyElementsLoaderService as ɵf } from './lib/lazy-elements/lazy-elements-loader.service';
export { LAZY_ELEMENT_CONFIGS as ɵa, LAZY_ELEMENT_ROOT_GUARD as ɵc, LAZY_ELEMENT_ROOT_OPTIONS as ɵb } from './lib/lazy-elements/lazy-elements.tokens';

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

{"__symbolic":"module","version":4,"metadata":{"LazyElementsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵa"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":7,"character":12}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":4,"character":1},"arguments":[{"selector":"[axLazyElement]"}]}],"members":{"url":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3},"arguments":["axLazyElement"]}]}],"loadingTemplateRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3},"arguments":["axLazyElementLoading"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":12,"character":17},{"__symbolic":"reference","name":"TemplateRef","module":"@angular/core","arguments":[{"__symbolic":"reference","name":"any"}]},{"__symbolic":"reference","name":"ɵb"}]}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"loadElement":[{"__symbolic":"method"}],"addElement":[{"__symbolic":"method"}],"hasElement":[{"__symbolic":"method"}],"stripUrlProtocol":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}}},"origins":{"LazyElementsModule":"./lib/lazy-elements/lazy-elements.module","ɵa":"./lib/lazy-elements/lazy-element/lazy-element.directive","ɵb":"./lib/lazy-elements/lazy-elements-loader.service"},"importAs":"@angular-extensions/elements"}
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":5,"character":40},"arguments":["LAZY_ELEMENT_CONFIGS"]},"ɵb":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":9,"character":45},"arguments":["LAZY_ELEMENT_ROOT_OPTIONS"]},"ɵc":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":13,"character":43},"arguments":["LAZY_ELEMENT_ROOT_GUARD"]},"LAZY_ELEMENTS_REGISTRY":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":17,"character":42},"arguments":["Lazu elements registry",{"__symbolic":"error","message":"Lambda not supported","line":21,"character":13,"module":"./lib/lazy-elements/lazy-elements.tokens"}]},"LazyElementsRegistry":{"__symbolic":"interface"},"createLazyElementRootGuard":{"__symbolic":"function"},"LazyElementsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":36,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵg"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":38,"character":12}],"exports":[{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵg"}],"providers":[]}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":92,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":93,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵa"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":95,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":96,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵc"}]}]],"parameters":[{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"Array","arguments":[{"__symbolic":"reference","name":"Array","arguments":[{"__symbolic":"reference","name":"ɵe"}]}]},{"__symbolic":"reference","name":"any"}]}]},"statics":{"forRoot":{"__symbolic":"function","parameters":["options"],"value":{"ngModule":{"__symbolic":"reference","name":"LazyElementsModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵa"},"useValue":{"__symbolic":"if","condition":{"__symbolic":"binop","operator":"&&","left":{"__symbolic":"reference","name":"options"},"right":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"elementConfigs"}},"thenExpression":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"elementConfigs"},"elseExpression":[]},"multi":true},{"provide":{"__symbolic":"reference","name":"ɵb"},"useValue":{"__symbolic":"if","condition":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"rootOptions"},"thenExpression":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"rootOptions"},"elseExpression":{}}},{"provide":{"__symbolic":"reference","module":"@angular/core","name":"ANALYZE_FOR_ENTRY_COMPONENTS","line":58,"character":19},"useValue":{"__symbolic":"reference","name":"options"},"multi":true},{"provide":{"__symbolic":"reference","name":"ɵc"},"useFactory":{"__symbolic":"reference","name":"createLazyElementRootGuard"},"deps":[[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":65,"character":44}},{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"SkipSelf","line":65,"character":60}}]]}]}},"forFeature":{"__symbolic":"function","parameters":["options"],"value":{"ngModule":{"__symbolic":"reference","name":"LazyElementsModule"},"providers":[{"provide":{"__symbolic":"reference","name":"ɵa"},"useValue":{"__symbolic":"if","condition":{"__symbolic":"binop","operator":"&&","left":{"__symbolic":"reference","name":"options"},"right":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"elementConfigs"}},"thenExpression":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"elementConfigs"},"elseExpression":[]},"multi":true},{"provide":{"__symbolic":"reference","module":"@angular/core","name":"ANALYZE_FOR_ENTRY_COMPONENTS","line":82,"character":19},"useValue":{"__symbolic":"binop","operator":"&&","left":{"__symbolic":"reference","name":"options"},"right":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"options"},"member":"elementConfigs"}},"multi":true}]}}}},"LazyElementModuleOptions":{"__symbolic":"interface"},"LazyElementModuleRootOptions":{"__symbolic":"interface"},"LazyElementRootOptions":{"__symbolic":"interface"},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":17,"character":1},"arguments":[{"selector":"[axLazyElement]"}]}],"members":{"url":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3},"arguments":["axLazyElement"]}]}],"loadingTemplateRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3},"arguments":["axLazyElementLoadingTemplate"]}]}],"errorTemplateRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3},"arguments":["axLazyElementErrorTemplate"]}]}],"isModule":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3},"arguments":["axLazyElementModule"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":27,"character":17},{"__symbolic":"reference","name":"TemplateRef","module":"@angular/core","arguments":[{"__symbolic":"reference","name":"any"}]},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":30,"character":17},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":31,"character":17}]}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵe":{"__symbolic":"interface"},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":20,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":27,"character":5},"arguments":[{"__symbolic":"reference","name":"LAZY_ELEMENTS_REGISTRY"}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":28,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":29,"character":5},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}]],"parameters":[{"__symbolic":"reference","name":"LazyElementsRegistry"},{"__symbolic":"reference","name":"LazyElementRootOptions"}]}],"addConfigs":[{"__symbolic":"method"}],"getElementConfig":[{"__symbolic":"method"}],"preload":[{"__symbolic":"method"}],"loadElement":[{"__symbolic":"method"}],"addElement":[{"__symbolic":"method"}],"hasElement":[{"__symbolic":"method"}],"stripUrlProtocol":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":17,"character":1},"arguments":[{"selector":"[axLazyElementDynamic]"}]}],"members":{"tag":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3},"arguments":["axLazyElementDynamic"]}]}],"url":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3},"arguments":["axLazyElementDynamicUrl"]}]}],"loadingTemplateRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3},"arguments":["axLazyElementDynamicLoadingTemplate"]}]}],"errorTemplateRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3},"arguments":["axLazyElementDynamicErrorTemplate"]}]}],"isModule":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3},"arguments":["axLazyElementDynamicModule"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":32,"character":17},{"__symbolic":"reference","name":"TemplateRef","module":"@angular/core","arguments":[{"__symbolic":"reference","name":"any"}]},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":35,"character":17},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":36,"character":17}]}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"ɵa":"./lib/lazy-elements/lazy-elements.tokens","ɵb":"./lib/lazy-elements/lazy-elements.tokens","ɵc":"./lib/lazy-elements/lazy-elements.tokens","LAZY_ELEMENTS_REGISTRY":"./lib/lazy-elements/lazy-elements.tokens","LazyElementsRegistry":"./lib/lazy-elements/lazy-elements.tokens","createLazyElementRootGuard":"./lib/lazy-elements/lazy-elements.module","LazyElementsModule":"./lib/lazy-elements/lazy-elements.module","LazyElementModuleOptions":"./lib/lazy-elements/lazy-elements.module","LazyElementModuleRootOptions":"./lib/lazy-elements/lazy-elements.module","LazyElementRootOptions":"./lib/lazy-elements/lazy-elements.module","ɵd":"./lib/lazy-elements/lazy-element/lazy-element.directive","ɵe":"./lib/lazy-elements/lazy-elements-loader.service","ɵf":"./lib/lazy-elements/lazy-elements-loader.service","ɵg":"./lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive"},"importAs":"@angular-extensions/elements"}
(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 = global || self, factory((global['angular-extensions'] = global['angular-extensions'] || {}, global['angular-extensions'].elements = {}), global.ng.core, global.ng.common));
}(this, function (exports, core, common) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/common'), require('@angular/core')) :
typeof define === 'function' && define.amd ? define('@angular-extensions/elements', ['exports', '@angular/common', '@angular/core'], factory) :
(factory((global['angular-extensions'] = global['angular-extensions'] || {}, global['angular-extensions'].elements = {}),global.ng.common,global.ng.core));
}(this, (function (exports,common,i0) { 'use strict';

@@ -12,10 +12,104 @@ /**

/** @type {?} */
var LAZY_ELEMENT_CONFIGS = new i0.InjectionToken('LAZY_ELEMENT_CONFIGS');
/** @type {?} */
var LAZY_ELEMENT_ROOT_OPTIONS = new i0.InjectionToken('LAZY_ELEMENT_ROOT_OPTIONS');
/** @type {?} */
var LAZY_ELEMENT_ROOT_GUARD = new i0.InjectionToken('LAZY_ELEMENT_ROOT_GUARD');
/** @type {?} */
var LAZY_ELEMENTS_REGISTRY = new i0.InjectionToken('Lazu elements registry', {
providedIn: 'root',
factory: ( /**
* @return {?}
*/function () { return new Map(); })
});
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
var LOG_PREFIX = '@angular-extensions/elements';
var LazyElementsLoaderService = /** @class */ (function () {
function LazyElementsLoaderService() {
this.registry = new Map();
function LazyElementsLoaderService(registry, options) {
this.registry = registry;
this.options = options;
this.configs = [];
if (!options) {
this.options = {};
}
}
/**
* @param {?} newConfigs
* @return {?}
*/
LazyElementsLoaderService.prototype.addConfigs = /**
* @param {?} newConfigs
* @return {?}
*/
function (newConfigs) {
var _this = this;
newConfigs.forEach(( /**
* @param {?} newConfig
* @return {?}
*/function (newConfig) {
/** @type {?} */
var existingConfig = _this.getElementConfig(newConfig.tag);
if (existingConfig) {
console.warn(LOG_PREFIX + " - ElementConfig for tag '" + newConfig.tag + "' was previously added, it will not be added multiple times, continue...");
}
else {
_this.configs.push(newConfig);
/** @type {?} */
var shouldPreload = newConfig.preload !== undefined
? newConfig.preload
: _this.options.preload;
if (shouldPreload) {
_this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);
}
}
}));
};
/**
* @param {?} tag
* @return {?}
*/
LazyElementsLoaderService.prototype.getElementConfig = /**
* @param {?} tag
* @return {?}
*/
function (tag) {
return this.configs.find(( /**
* @param {?} config
* @return {?}
*/function (config) { return config.tag === tag; }));
};
/**
* @param {?=} tags
* @return {?}
*/
LazyElementsLoaderService.prototype.preload = /**
* @param {?=} tags
* @return {?}
*/
function (tags) {
var _this = this;
/** @type {?} */
var configs = this.configs;
if (tags) {
configs = this.configs.filter(( /**
* @param {?} config
* @return {?}
*/function (config) { return tags.includes(config.tag); }));
}
configs.forEach(( /**
* @param {?} config
* @return {?}
*/function (config) {
return _this.loadElement(config.url, config.tag, config.isModule);
}));
};
/**
* @param {?} url
* @param {?} tag
* @param {?=} isModule
* @return {?}

@@ -26,22 +120,38 @@ */

* @param {?} tag
* @param {?=} isModule
* @return {?}
*/
function (url, tag) {
if (!url) {
throw new Error(LOG_PREFIX + " - url for <" + tag + "> not found");
}
if (!tag) {
throw new Error(LOG_PREFIX + " - tag for '" + url + "' not found, the *axLazyElement has to be used on HTML element");
}
if (!this.hasElement(url)) {
function (url, tag, isModule) {
/** @type {?} */
var notifier = this.addElement(url);
/** @type {?} */
var script = (/** @type {?} */ (document.createElement('script')));
script.src = url;
script.onload = notifier;
document.body.appendChild(script);
}
return this.registry.get(this.stripUrlProtocol(url));
};
var config = this.getElementConfig(tag);
if (!url) {
if (!config) {
throw new Error(LOG_PREFIX + " - url for <" + tag + "> not found");
}
url = config.url;
}
if (isModule === undefined) {
isModule =
config && config.isModule !== undefined
? config.isModule
: this.options.isModule;
}
if (!tag) {
throw new Error(LOG_PREFIX + " - tag for '" + url + "' not found, the *axLazyElement has to be used on HTML element");
}
if (!this.hasElement(url)) {
/** @type {?} */
var notifier = this.addElement(url);
/** @type {?} */
var script = ( /** @type {?} */(document.createElement('script')));
if (isModule) {
script.type = 'module';
}
script.src = url;
script.onload = notifier.resolve;
script.onerror = notifier.reject;
document.body.appendChild(script);
}
return this.registry.get(this.stripUrlProtocol(url));
};
/**

@@ -57,12 +167,12 @@ * @private

*/
function (url) {
/** @type {?} */
var notifier;
this.registry.set(this.stripUrlProtocol(url), new Promise((/**
* @param {?} resolve
* @return {?}
*/
function (resolve) { return (notifier = resolve); })));
return notifier;
};
function (url) {
/** @type {?} */
var notifier;
this.registry.set(this.stripUrlProtocol(url), new Promise(( /**
* @param {?} resolve
* @param {?} reject
* @return {?}
*/function (resolve, reject) { return (notifier = { resolve: resolve, reject: reject }); })));
return notifier;
};
/**

@@ -78,5 +188,5 @@ * @private

*/
function (url) {
return this.registry.has(this.stripUrlProtocol(url));
};
function (url) {
return this.registry.has(this.stripUrlProtocol(url));
};
/**

@@ -92,13 +202,17 @@ * @private

*/
function (url) {
return url.replace(/https?:\/\//, '');
};
function (url) {
return url.replace(/https?:\/\//, '');
};
LazyElementsLoaderService.decorators = [
{ type: core.Injectable, args: [{
{ type: i0.Injectable, args: [{
providedIn: 'root'
},] }
];
/** @nocollapse */
LazyElementsLoaderService.ctorParameters = function () { return []; };
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = core.ɵɵdefineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(); }, token: LazyElementsLoaderService, providedIn: "root" });
LazyElementsLoaderService.ctorParameters = function () {
return [
{ type: undefined, decorators: [{ type: i0.Inject, args: [LAZY_ELEMENTS_REGISTRY,] }] },
{ type: undefined, decorators: [{ type: i0.Optional }, { type: i0.Inject, args: [LAZY_ELEMENT_ROOT_OPTIONS,] }] }
];
};
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = i0.defineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(i0.inject(LAZY_ELEMENTS_REGISTRY), i0.inject(LAZY_ELEMENT_ROOT_OPTIONS, 8)); }, token: LazyElementsLoaderService, providedIn: "root" });
return LazyElementsLoaderService;

@@ -111,7 +225,11 @@ }());

*/
/** @type {?} */
var LOG_PREFIX$1 = '@angular-extensions/elements';
var LazyElementDirective = /** @class */ (function () {
function LazyElementDirective(vcr, template, elementsLoaderService) {
function LazyElementDirective(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}

@@ -124,31 +242,74 @@ /**

*/
function () {
var _this = this;
/** @type {?} */
var elementTag = ((/** @type {?} */ (this.template)))._def.element.template.nodes[0].element.name;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
this.elementsLoaderService.loadElement(this.url, elementTag).then((/**
function () {
var _this = this;
/** @type {?} */
var tpl = ( /** @type {?} */(this.template));
/** @type {?} */
var elementTag = tpl._declarationTContainer
? tpl._declarationTContainer.tagName
: tpl._def.element.template.nodes[0].element.name;
/** @type {?} */
var elementConfig = this.elementsLoaderService.getElementConfig(elementTag) ||
(( /** @type {?} */({})));
/** @type {?} */
var options = this.elementsLoaderService.options;
/** @type {?} */
var loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
else if (loadingComponent) {
/** @type {?} */
var factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule)
.then(( /**
* @return {?}
*/
function () {
_this.vcr.clear();
_this.vcr.createEmbeddedView(_this.template);
}));
};
*/function () {
_this.vcr.clear();
_this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
}))
.catch(( /**
* @return {?}
*/function () {
_this.vcr.clear();
/** @type {?} */
var errorComponent = elementConfig.errorComponent || options.errorComponent;
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
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.decorators = [
{ type: core.Directive, args: [{
{ type: i0.Directive, args: [{
selector: '[axLazyElement]'
},] }
];
/** @nocollapse */
LazyElementDirective.ctorParameters = function () { return [
{ type: core.ViewContainerRef },
{ type: core.TemplateRef },
{ type: LazyElementsLoaderService }
]; };
LazyElementDirective.ctorParameters = function () {
return [
{ type: i0.ViewContainerRef },
{ type: i0.TemplateRef },
{ type: LazyElementsLoaderService },
{ type: i0.ComponentFactoryResolver },
{ type: i0.ChangeDetectorRef }
];
};
LazyElementDirective.propDecorators = {
url: [{ type: core.Input, args: ['axLazyElement',] }],
loadingTemplateRef: [{ type: core.Input, args: ['axLazyElementLoading',] }]
url: [{ type: i0.Input, args: ['axLazyElement',] }],
loadingTemplateRef: [{ type: i0.Input, args: ['axLazyElementLoadingTemplate',] }],
errorTemplateRef: [{ type: i0.Input, args: ['axLazyElementErrorTemplate',] }],
isModule: [{ type: i0.Input, args: ['axLazyElementModule',] }]
};

@@ -162,22 +323,224 @@ return LazyElementDirective;

*/
/** @type {?} */
var LOG_PREFIX$2 = '@angular-extensions/elements';
var LazyElementDynamicDirective = /** @class */ (function () {
function LazyElementDynamicDirective(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}
/**
* @return {?}
*/
LazyElementDynamicDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
if (!this.tag || this.tag.length === 0 || !this.tag.includes('-')) {
throw new Error(LOG_PREFIX$2 + " - Valid tag has to be specified when using *axLazyElementDynamic directive (use *axLazyElementDynamic=\"'some-tag'\"), got: \"" + this.tag + "\"");
}
/** @type {?} */
var elementConfig = this.elementsLoaderService.getElementConfig(this.tag) ||
(( /** @type {?} */({})));
/** @type {?} */
var options = this.elementsLoaderService.options;
/** @type {?} */
var loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
else if (loadingComponent) {
/** @type {?} */
var factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, this.tag, this.isModule)
.then(( /**
* @return {?}
*/function () {
if ((( /** @type {?} */(_this.template)))._declarationTContainer) {
// (this.template as any)._declarationTContainer.tagName = this.tag;
throw new Error('The *axLazyElementDynamic directive is currently does NOT support Angular Ivy, please use standard *axLazyElement directive instead!');
}
else {
(( /** @type {?} */(_this
.template)))._def.element.template.nodes[0].element.name = _this.tag;
}
_this.vcr.clear();
_this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
}))
.catch(( /**
* @param {?} error
* @return {?}
*/function (error) {
/** @type {?} */
var errorComponent = elementConfig.errorComponent || options.errorComponent;
_this.vcr.clear();
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
var factory = _this.cfr.resolveComponentFactory(errorComponent);
_this.vcr.createComponent(factory);
_this.cdr.markForCheck();
}
else {
console.error(LOG_PREFIX$2 + " - 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.decorators = [
{ type: i0.Directive, args: [{
selector: '[axLazyElementDynamic]'
},] }
];
LazyElementDynamicDirective.ctorParameters = function () {
return [
{ type: i0.ViewContainerRef },
{ type: i0.TemplateRef },
{ type: LazyElementsLoaderService },
{ type: i0.ComponentFactoryResolver },
{ type: i0.ChangeDetectorRef }
];
};
LazyElementDynamicDirective.propDecorators = {
tag: [{ type: i0.Input, args: ['axLazyElementDynamic',] }],
url: [{ type: i0.Input, args: ['axLazyElementDynamicUrl',] }],
loadingTemplateRef: [{ type: i0.Input, args: ['axLazyElementDynamicLoadingTemplate',] }],
errorTemplateRef: [{ type: i0.Input, args: ['axLazyElementDynamicErrorTemplate',] }],
isModule: [{ type: i0.Input, args: ['axLazyElementDynamicModule',] }]
};
return LazyElementDynamicDirective;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @param {?} options
* @return {?}
*/
function createLazyElementRootGuard(options) {
if (options) {
throw new TypeError("LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.");
}
return 'guarded';
}
var LazyElementsModule = /** @class */ (function () {
function LazyElementsModule() {
function LazyElementsModule(lazyElementsLoaderService, elementConfigsMultiProvider, guard) {
if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {
/** @type {?} */
var lastAddedConfigs = elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];
lazyElementsLoaderService.addConfigs(lastAddedConfigs);
}
}
/**
* @param {?} options
* @return {?}
*/
LazyElementsModule.forRoot = /**
* @param {?} options
* @return {?}
*/
function (options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_OPTIONS,
useValue: options.rootOptions ? options.rootOptions : {}
},
{
provide: i0.ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options,
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_GUARD,
useFactory: createLazyElementRootGuard,
deps: [[LAZY_ELEMENT_CONFIGS, new i0.Optional(), new i0.SkipSelf()]]
}
]
};
};
/**
* @param {?} options
* @return {?}
*/
LazyElementsModule.forFeature = /**
* @param {?} options
* @return {?}
*/
function (options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: i0.ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options && options.elementConfigs,
multi: true
}
]
};
};
LazyElementsModule.decorators = [
{ type: core.NgModule, args: [{
declarations: [LazyElementDirective],
{ type: i0.NgModule, args: [{
declarations: [LazyElementDirective, LazyElementDynamicDirective],
imports: [common.CommonModule],
exports: [LazyElementDirective]
exports: [LazyElementDirective, LazyElementDynamicDirective],
providers: []
},] }
];
LazyElementsModule.ctorParameters = function () {
return [
{ type: LazyElementsLoaderService },
{ type: Array, decorators: [{ type: i0.Optional }, { type: i0.Inject, args: [LAZY_ELEMENT_CONFIGS,] }] },
{ type: undefined, decorators: [{ type: i0.Optional }, { type: i0.Inject, args: [LAZY_ELEMENT_ROOT_GUARD,] }] }
];
};
return LazyElementsModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
exports.LAZY_ELEMENTS_REGISTRY = LAZY_ELEMENTS_REGISTRY;
exports.createLazyElementRootGuard = createLazyElementRootGuard;
exports.LazyElementsModule = LazyElementsModule;
exports.ɵa = LazyElementDirective;
exports.ɵb = LazyElementsLoaderService;
exports.ɵg = LazyElementDynamicDirective;
exports.ɵd = LazyElementDirective;
exports.ɵf = LazyElementsLoaderService;
exports.ɵa = LAZY_ELEMENT_CONFIGS;
exports.ɵc = LAZY_ELEMENT_ROOT_GUARD;
exports.ɵb = LAZY_ELEMENT_ROOT_OPTIONS;
Object.defineProperty(exports, '__esModule', { value: true });
}));
//# sourceMappingURL=angular-extensions-elements.umd.js.map
})));
//# sourceMappingURL=angular-extensions-elements.umd.js.map

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("@angular-extensions/elements",["exports","@angular/core","@angular/common"],t):t(((e=e||self)["angular-extensions"]=e["angular-extensions"]||{},e["angular-extensions"].elements={}),e.ng.core,e.ng.common)}(this,function(e,t,n){"use strict";var r=function(){function e(){this.registry=new Map}return e.prototype.loadElement=function(e,t){if(!e)throw new Error("@angular-extensions/elements - url for <"+t+"> not found");if(!t)throw new Error("@angular-extensions/elements - tag for '"+e+"' not found, the *axLazyElement has to be used on HTML element");if(!this.hasElement(e)){var n=this.addElement(e),r=document.createElement("script");r.src=e,r.onload=n,document.body.appendChild(r)}return this.registry.get(this.stripUrlProtocol(e))},e.prototype.addElement=function(e){var t;return this.registry.set(this.stripUrlProtocol(e),new Promise(function(e){return t=e})),t},e.prototype.hasElement=function(e){return this.registry.has(this.stripUrlProtocol(e))},e.prototype.stripUrlProtocol=function(e){return e.replace(/https?:\/\//,"")},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e},token:e,providedIn:"root"}),e}(),o=function(){function e(e,t,n){this.vcr=e,this.template=t,this.elementsLoaderService=n}return e.prototype.ngOnInit=function(){var e=this,t=this.template._def.element.template.nodes[0].element.name;this.loadingTemplateRef&&this.vcr.createEmbeddedView(this.loadingTemplateRef),this.elementsLoaderService.loadElement(this.url,t).then(function(){e.vcr.clear(),e.vcr.createEmbeddedView(e.template)})},e.decorators=[{type:t.Directive,args:[{selector:"[axLazyElement]"}]}],e.ctorParameters=function(){return[{type:t.ViewContainerRef},{type:t.TemplateRef},{type:r}]},e.propDecorators={url:[{type:t.Input,args:["axLazyElement"]}],loadingTemplateRef:[{type:t.Input,args:["axLazyElementLoading"]}]},e}(),a=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[o],imports:[n.CommonModule],exports:[o]}]}],e}();e.LazyElementsModule=a,e.ɵa=o,e.ɵb=r,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/common"),require("@angular/core")):"function"==typeof define&&define.amd?define("@angular-extensions/elements",["exports","@angular/common","@angular/core"],t):t((e["angular-extensions"]=e["angular-extensions"]||{},e["angular-extensions"].elements={}),e.ng.common,e.ng.core)}(this,function(e,t,r){"use strict";var n=new r.InjectionToken("LAZY_ELEMENT_CONFIGS"),o=new r.InjectionToken("LAZY_ELEMENT_ROOT_OPTIONS"),a=new r.InjectionToken("LAZY_ELEMENT_ROOT_GUARD"),i=new r.InjectionToken("Lazu elements registry",{providedIn:"root",factory:function(){return new Map}}),l="@angular-extensions/elements",s=(c.prototype.addConfigs=function(e){var t=this;e.forEach(function(e){t.getElementConfig(e.tag)?console.warn(l+" - ElementConfig for tag '"+e.tag+"' was previously added, it will not be added multiple times, continue..."):(t.configs.push(e),(e.preload!==undefined?e.preload:t.options.preload)&&t.loadElement(e.url,e.tag,e.isModule))})},c.prototype.getElementConfig=function(t){return this.configs.find(function(e){return e.tag===t})},c.prototype.preload=function(t){var r=this,e=this.configs;t&&(e=this.configs.filter(function(e){return t.includes(e.tag)})),e.forEach(function(e){return r.loadElement(e.url,e.tag,e.isModule)})},c.prototype.loadElement=function(e,t,r){var n=this.getElementConfig(t);if(!e){if(!n)throw new Error(l+" - url for <"+t+"> not found");e=n.url}if(r===undefined&&(r=n&&n.isModule!==undefined?n.isModule:this.options.isModule),!t)throw new Error(l+" - tag for '"+e+"' not found, the *axLazyElement has to be used on HTML element");if(!this.hasElement(e)){var o=this.addElement(e),a=document.createElement("script");r&&(a.type="module"),a.src=e,a.onload=o.resolve,a.onerror=o.reject,document.body.appendChild(a)}return this.registry.get(this.stripUrlProtocol(e))},c.prototype.addElement=function(e){var r;return this.registry.set(this.stripUrlProtocol(e),new Promise(function(e,t){return r={resolve:e,reject:t}})),r},c.prototype.hasElement=function(e){return this.registry.has(this.stripUrlProtocol(e))},c.prototype.stripUrlProtocol=function(e){return e.replace(/https?:\/\//,"")},c.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],c.ctorParameters=function(){return[{type:undefined,decorators:[{type:r.Inject,args:[i]}]},{type:undefined,decorators:[{type:r.Optional},{type:r.Inject,args:[o]}]}]},c.ngInjectableDef=r.defineInjectable({factory:function(){return new c(r.inject(i),r.inject(o,8))},token:c,providedIn:"root"}),c);function c(e,t){this.registry=e,this.options=t,this.configs=[],t||(this.options={})}var d=(p.prototype.ngOnInit=function(){var r=this,e=this.template,n=e._declarationTContainer?e._declarationTContainer.tagName:e._def.element.template.nodes[0].element.name,o=this.elementsLoaderService.getElementConfig(n)||{},a=this.elementsLoaderService.options,t=o.loadingComponent||a.loadingComponent;if(this.loadingTemplateRef)this.vcr.createEmbeddedView(this.loadingTemplateRef);else if(t){var i=this.cfr.resolveComponentFactory(t);this.vcr.createComponent(i)}this.elementsLoaderService.loadElement(this.url,n,this.isModule).then(function(){r.vcr.clear(),r.vcr.createEmbeddedView(r.template),r.cdr.markForCheck()})["catch"](function(){r.vcr.clear();var e=o.errorComponent||a.errorComponent;if(r.errorTemplateRef)r.vcr.createEmbeddedView(r.errorTemplateRef),r.cdr.markForCheck();else if(e){var t=r.cfr.resolveComponentFactory(e);r.vcr.createComponent(t),r.cdr.markForCheck()}else console.error("@angular-extensions/elements - Loading of element <"+n+'> 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')})},p.decorators=[{type:r.Directive,args:[{selector:"[axLazyElement]"}]}],p.ctorParameters=function(){return[{type:r.ViewContainerRef},{type:r.TemplateRef},{type:s},{type:r.ComponentFactoryResolver},{type:r.ChangeDetectorRef}]},p.propDecorators={url:[{type:r.Input,args:["axLazyElement"]}],loadingTemplateRef:[{type:r.Input,args:["axLazyElementLoadingTemplate"]}],errorTemplateRef:[{type:r.Input,args:["axLazyElementErrorTemplate"]}],isModule:[{type:r.Input,args:["axLazyElementModule"]}]},p);function p(e,t,r,n,o){this.vcr=e,this.template=t,this.elementsLoaderService=r,this.cfr=n,this.cdr=o}var m="@angular-extensions/elements",u=(f.prototype.ngOnInit=function(){var n=this;if(!this.tag||0===this.tag.length||!this.tag.includes("-"))throw new Error(m+' - Valid tag has to be specified when using *axLazyElementDynamic directive (use *axLazyElementDynamic="\'some-tag\'"), got: "'+this.tag+'"');var o=this.elementsLoaderService.getElementConfig(this.tag)||{},a=this.elementsLoaderService.options,e=o.loadingComponent||a.loadingComponent;if(this.loadingTemplateRef)this.vcr.createEmbeddedView(this.loadingTemplateRef);else if(e){var t=this.cfr.resolveComponentFactory(e);this.vcr.createComponent(t)}this.elementsLoaderService.loadElement(this.url,this.tag,this.isModule).then(function(){if(n.template._declarationTContainer)throw new Error("The *axLazyElementDynamic directive is currently does NOT support Angular Ivy, please use standard *axLazyElement directive instead!");n.template._def.element.template.nodes[0].element.name=n.tag,n.vcr.clear(),n.vcr.createEmbeddedView(n.template),n.cdr.markForCheck()})["catch"](function(e){var t=o.errorComponent||a.errorComponent;if(n.vcr.clear(),n.errorTemplateRef)n.vcr.createEmbeddedView(n.errorTemplateRef),n.cdr.markForCheck();else if(t){var r=n.cfr.resolveComponentFactory(t);n.vcr.createComponent(r),n.cdr.markForCheck()}else console.error(m+" - Loading of element <"+n.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',e)})},f.decorators=[{type:r.Directive,args:[{selector:"[axLazyElementDynamic]"}]}],f.ctorParameters=function(){return[{type:r.ViewContainerRef},{type:r.TemplateRef},{type:s},{type:r.ComponentFactoryResolver},{type:r.ChangeDetectorRef}]},f.propDecorators={tag:[{type:r.Input,args:["axLazyElementDynamic"]}],url:[{type:r.Input,args:["axLazyElementDynamicUrl"]}],loadingTemplateRef:[{type:r.Input,args:["axLazyElementDynamicLoadingTemplate"]}],errorTemplateRef:[{type:r.Input,args:["axLazyElementDynamicErrorTemplate"]}],isModule:[{type:r.Input,args:["axLazyElementDynamicModule"]}]},f);function f(e,t,r,n,o){this.vcr=e,this.template=t,this.elementsLoaderService=r,this.cfr=n,this.cdr=o}function g(e){if(e)throw new TypeError("LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.");return"guarded"}var y=(h.forRoot=function(e){return{ngModule:h,providers:[{provide:n,useValue:e&&e.elementConfigs?e.elementConfigs:[],multi:!0},{provide:o,useValue:e.rootOptions?e.rootOptions:{}},{provide:r.ANALYZE_FOR_ENTRY_COMPONENTS,useValue:e,multi:!0},{provide:a,useFactory:g,deps:[[n,new r.Optional,new r.SkipSelf]]}]}},h.forFeature=function(e){return{ngModule:h,providers:[{provide:n,useValue:e&&e.elementConfigs?e.elementConfigs:[],multi:!0},{provide:r.ANALYZE_FOR_ENTRY_COMPONENTS,useValue:e&&e.elementConfigs,multi:!0}]}},h.decorators=[{type:r.NgModule,args:[{declarations:[d,u],imports:[t.CommonModule],exports:[d,u],providers:[]}]}],h.ctorParameters=function(){return[{type:s},{type:Array,decorators:[{type:r.Optional},{type:r.Inject,args:[n]}]},{type:undefined,decorators:[{type:r.Optional},{type:r.Inject,args:[a]}]}]},h);function h(e,t,r){if(t&&t.length){var n=t[t.length-1];e.addConfigs(n)}}e.LAZY_ELEMENTS_REGISTRY=i,e.createLazyElementRootGuard=g,e.LazyElementsModule=y,e.ɵg=u,e.ɵd=d,e.ɵf=s,e.ɵa=n,e.ɵc=a,e.ɵb=o,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=angular-extensions-elements.umd.min.js.map

@@ -8,5 +8,7 @@ /**

*/
export { LazyElementsModule } from './public-api';
export { LazyElementDirective as ɵa } from './lib/lazy-elements/lazy-element/lazy-element.directive';
export { LazyElementsLoaderService as ɵb } from './lib/lazy-elements/lazy-elements-loader.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1leHRlbnNpb25zLWVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGFuZ3VsYXItZXh0ZW5zaW9ucy9lbGVtZW50cy8iLCJzb3VyY2VzIjpbImFuZ3VsYXItZXh0ZW5zaW9ucy1lbGVtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsbUNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSx5REFBeUQsQ0FBQztBQUNuRyxPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sa0RBQWtELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG5cbmV4cG9ydCB7TGF6eUVsZW1lbnREaXJlY3RpdmUgYXMgybVhfSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudC9sYXp5LWVsZW1lbnQuZGlyZWN0aXZlJztcbmV4cG9ydCB7TGF6eUVsZW1lbnRzTG9hZGVyU2VydmljZSBhcyDJtWJ9IGZyb20gJy4vbGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZSc7Il19
export { LAZY_ELEMENTS_REGISTRY, createLazyElementRootGuard, LazyElementsModule } from './public-api';
export { LazyElementDynamicDirective as ɵg } from './lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive';
export { LazyElementDirective as ɵd } from './lib/lazy-elements/lazy-element/lazy-element.directive';
export { LazyElementsLoaderService as ɵf } from './lib/lazy-elements/lazy-elements-loader.service';
export { LAZY_ELEMENT_CONFIGS as ɵa, LAZY_ELEMENT_ROOT_GUARD as ɵc, LAZY_ELEMENT_ROOT_OPTIONS as ɵb } from './lib/lazy-elements/lazy-elements.tokens';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1leHRlbnNpb25zLWVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGFuZ3VsYXItZXh0ZW5zaW9ucy9lbGVtZW50cy8iLCJzb3VyY2VzIjpbImFuZ3VsYXItZXh0ZW5zaW9ucy1lbGVtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsdUZBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5RUFBeUUsQ0FBQztBQUMxSCxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0seURBQXlELENBQUM7QUFDbkcsT0FBTyxFQUFxQix5QkFBeUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxrREFBa0QsQ0FBQztBQUNySCxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyx5QkFBeUIsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtMYXp5RWxlbWVudER5bmFtaWNEaXJlY3RpdmUgYXMgybVnfSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudC1keW5hbWljL2xhenktZWxlbWVudC1keW5hbWljLmRpcmVjdGl2ZSc7XG5leHBvcnQge0xhenlFbGVtZW50RGlyZWN0aXZlIGFzIMm1ZH0gZnJvbSAnLi9saWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZSc7XG5leHBvcnQge0VsZW1lbnRDb25maWcgYXMgybVlLExhenlFbGVtZW50c0xvYWRlclNlcnZpY2UgYXMgybVmfSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudHMtbG9hZGVyLnNlcnZpY2UnO1xuZXhwb3J0IHtMQVpZX0VMRU1FTlRfQ09ORklHUyBhcyDJtWEsTEFaWV9FTEVNRU5UX1JPT1RfR1VBUkQgYXMgybVjLExBWllfRUxFTUVOVF9ST09UX09QVElPTlMgYXMgybVifSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudHMudG9rZW5zJzsiXX0=

@@ -5,4 +5,6 @@ /**

*/
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
import { Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef } from '@angular/core';
import { LazyElementsLoaderService } from '../lazy-elements-loader.service';
/** @type {?} */
const LOG_PREFIX = '@angular-extensions/elements';
export class LazyElementDirective {

@@ -14,7 +16,11 @@ // tslint:disable-line:no-input-rename

* @param {?} elementsLoaderService
* @param {?} cfr
* @param {?} cdr
*/
constructor(vcr, template, elementsLoaderService) {
constructor(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}

@@ -26,7 +32,25 @@ /**

/** @type {?} */
const elementTag = ((/** @type {?} */ (this.template)))._def.element.template.nodes[0].element.name;
const tpl = (/** @type {?} */ (this.template));
/** @type {?} */
const elementTag = tpl._declarationTContainer
? tpl._declarationTContainer.tagName
: tpl._def.element.template.nodes[0].element.name;
/** @type {?} */
const elementConfig = this.elementsLoaderService.getElementConfig(elementTag) ||
((/** @type {?} */ ({})));
/** @type {?} */
const options = this.elementsLoaderService.options;
/** @type {?} */
const loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
this.elementsLoaderService.loadElement(this.url, elementTag).then((/**
else if (loadingComponent) {
/** @type {?} */
const factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule)
.then((/**
* @return {?}

@@ -37,2 +61,24 @@ */

this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
}))
.catch((/**
* @return {?}
*/
() => {
this.vcr.clear();
/** @type {?} */
const errorComponent = elementConfig.errorComponent || options.errorComponent;
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
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`);
}
}));

@@ -46,11 +92,14 @@ }

];
/** @nocollapse */
LazyElementDirective.ctorParameters = () => [
{ type: ViewContainerRef },
{ type: TemplateRef },
{ type: LazyElementsLoaderService }
{ type: LazyElementsLoaderService },
{ type: ComponentFactoryResolver },
{ type: ChangeDetectorRef }
];
LazyElementDirective.propDecorators = {
url: [{ type: Input, args: ['axLazyElement',] }],
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoading',] }]
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoadingTemplate',] }],
errorTemplateRef: [{ type: Input, args: ['axLazyElementErrorTemplate',] }],
isModule: [{ type: Input, args: ['axLazyElementModule',] }]
};

@@ -62,2 +111,6 @@ if (false) {

LazyElementDirective.prototype.loadingTemplateRef;
/** @type {?} */
LazyElementDirective.prototype.errorTemplateRef;
/** @type {?} */
LazyElementDirective.prototype.isModule;
/**

@@ -78,3 +131,13 @@ * @type {?}

LazyElementDirective.prototype.elementsLoaderService;
/**
* @type {?}
* @private
*/
LazyElementDirective.prototype.cfr;
/**
* @type {?}
* @private
*/
LazyElementDirective.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXhGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBSzVFLE1BQU0sT0FBTyxvQkFBb0I7Ozs7Ozs7SUFJL0IsWUFDVSxHQUFxQixFQUNyQixRQUEwQixFQUMxQixxQkFBZ0Q7UUFGaEQsUUFBRyxHQUFILEdBQUcsQ0FBa0I7UUFDckIsYUFBUSxHQUFSLFFBQVEsQ0FBa0I7UUFDMUIsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUEyQjtJQUN2RCxDQUFDOzs7O0lBRUosUUFBUTs7Y0FDQSxVQUFVLEdBQUcsQ0FBQyxtQkFBQSxJQUFJLENBQUMsUUFBUSxFQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUk7UUFFckYsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDM0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsQ0FBQztTQUN0RDtRQUVELElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQyxJQUFJOzs7UUFBQyxHQUFHLEVBQUU7WUFDckUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM3QyxDQUFDLEVBQUMsQ0FBQztJQUNMLENBQUM7OztZQXhCRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjthQUM1Qjs7OztZQU4rQyxnQkFBZ0I7WUFBN0IsV0FBVztZQUVyQyx5QkFBeUI7OztrQkFNL0IsS0FBSyxTQUFDLGVBQWU7aUNBQ3JCLEtBQUssU0FBQyxzQkFBc0I7Ozs7SUFEN0IsbUNBQW9DOztJQUNwQyxrREFBb0U7Ozs7O0lBR2xFLG1DQUE2Qjs7Ozs7SUFDN0Isd0NBQWtDOzs7OztJQUNsQyxxREFBd0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IExhenlFbGVtZW50c0xvYWRlclNlcnZpY2UgfSBmcm9tICcuLi9sYXp5LWVsZW1lbnRzLWxvYWRlci5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2F4TGF6eUVsZW1lbnRdJ1xufSlcbmV4cG9ydCBjbGFzcyBMYXp5RWxlbWVudERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgnYXhMYXp5RWxlbWVudCcpIHVybDogc3RyaW5nO1xuICBASW5wdXQoJ2F4TGF6eUVsZW1lbnRMb2FkaW5nJykgbG9hZGluZ1RlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+OyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgdmNyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIHByaXZhdGUgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4sXG4gICAgcHJpdmF0ZSBlbGVtZW50c0xvYWRlclNlcnZpY2U6IExhenlFbGVtZW50c0xvYWRlclNlcnZpY2VcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IGVsZW1lbnRUYWcgPSAodGhpcy50ZW1wbGF0ZSBhcyBhbnkpLl9kZWYuZWxlbWVudC50ZW1wbGF0ZS5ub2Rlc1swXS5lbGVtZW50Lm5hbWU7XG5cbiAgICBpZiAodGhpcy5sb2FkaW5nVGVtcGxhdGVSZWYpIHtcbiAgICAgIHRoaXMudmNyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLmxvYWRpbmdUZW1wbGF0ZVJlZik7XG4gICAgfVxuXG4gICAgdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2UubG9hZEVsZW1lbnQodGhpcy51cmwsIGVsZW1lbnRUYWcpLnRoZW4oKCkgPT4ge1xuICAgICAgdGhpcy52Y3IuY2xlYXIoKTtcbiAgICAgIHRoaXMudmNyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlKTtcbiAgICB9KTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxLQUFLLEVBRUwsV0FBVyxFQUNYLGdCQUFnQixFQUNoQix3QkFBd0IsRUFDeEIsaUJBQWlCLEVBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDTCx5QkFBeUIsRUFFMUIsTUFBTSxpQ0FBaUMsQ0FBQzs7TUFFbkMsVUFBVSxHQUFHLDhCQUE4QjtBQUtqRCxNQUFNOzs7Ozs7Ozs7SUFNSixZQUNVLEdBQXFCLEVBQ3JCLFFBQTBCLEVBQzFCLHFCQUFnRCxFQUNoRCxHQUE2QixFQUM3QixHQUFzQjtRQUp0QixRQUFHLEdBQUgsR0FBRyxDQUFrQjtRQUNyQixhQUFRLEdBQVIsUUFBUSxDQUFrQjtRQUMxQiwwQkFBcUIsR0FBckIscUJBQXFCLENBQTJCO1FBQ2hELFFBQUcsR0FBSCxHQUFHLENBQTBCO1FBQzdCLFFBQUcsR0FBSCxHQUFHLENBQW1CO0lBQzdCLENBQUM7Ozs7SUFFSixRQUFROztjQUNBLEdBQUcsR0FBRyxtQkFBQSxJQUFJLENBQUMsUUFBUSxFQUFPOztjQUMxQixVQUFVLEdBQUcsR0FBRyxDQUFDLHNCQUFzQjtZQUMzQyxDQUFDLENBQUMsR0FBRyxDQUFDLHNCQUFzQixDQUFDLE9BQU87WUFDcEMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUk7O2NBRTdDLGFBQWEsR0FDakIsSUFBSSxDQUFDLHFCQUFxQixDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQztZQUN2RCxDQUFDLG1CQUFBLEVBQUUsRUFBaUIsQ0FBQzs7Y0FDakIsT0FBTyxHQUFHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPOztjQUM1QyxnQkFBZ0IsR0FDcEIsYUFBYSxDQUFDLGdCQUFnQixJQUFJLE9BQU8sQ0FBQyxnQkFBZ0I7UUFFNUQsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDM0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsQ0FBQztTQUN0RDthQUFNLElBQUksZ0JBQWdCLEVBQUU7O2tCQUNyQixPQUFPLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxnQkFBZ0IsQ0FBQztZQUNsRSxJQUFJLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUNuQztRQUNELElBQUksQ0FBQyxxQkFBcUI7YUFDdkIsV0FBVyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUM7YUFDaEQsSUFBSTs7O1FBQUMsR0FBRyxFQUFFO1lBQ1QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUMzQyxJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQzFCLENBQUMsRUFBQzthQUNELEtBQUs7OztRQUFDLEdBQUcsRUFBRTtZQUNWLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUM7O2tCQUNYLGNBQWMsR0FDbEIsYUFBYSxDQUFDLGNBQWMsSUFBSSxPQUFPLENBQUMsY0FBYztZQUN4RCxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtnQkFDekIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztnQkFDbkQsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLEVBQUUsQ0FBQzthQUN6QjtpQkFBTSxJQUFJLGNBQWMsRUFBRTs7c0JBQ25CLE9BQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLGNBQWMsQ0FBQztnQkFDaEUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7YUFDekI7aUJBQU07Z0JBQ0wsT0FBTyxDQUFDLEtBQUssQ0FDWCxHQUFHLFVBQVUsMEJBQTBCLFVBQVUsZ01BQWdNLENBQ2xQLENBQUM7YUFDSDtRQUNILENBQUMsRUFBQyxDQUFDO0lBQ1AsQ0FBQzs7O1lBNURGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsaUJBQWlCO2FBQzVCOzs7WUFkQyxnQkFBZ0I7WUFEaEIsV0FBVztZQU9YLHlCQUF5QjtZQUx6Qix3QkFBd0I7WUFDeEIsaUJBQWlCOzs7a0JBY2hCLEtBQUssU0FBQyxlQUFlO2lDQUNyQixLQUFLLFNBQUMsOEJBQThCOytCQUNwQyxLQUFLLFNBQUMsNEJBQTRCO3VCQUNsQyxLQUFLLFNBQUMscUJBQXFCOzs7O0lBSDVCLG1DQUFvQzs7SUFDcEMsa0RBQTRFOztJQUM1RSxnREFBd0U7O0lBQ3hFLHdDQUE0RDs7Ozs7SUFHMUQsbUNBQTZCOzs7OztJQUM3Qix3Q0FBa0M7Ozs7O0lBQ2xDLHFEQUF3RDs7Ozs7SUFDeEQsbUNBQXFDOzs7OztJQUNyQyxtQ0FBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIERpcmVjdGl2ZSxcclxuICBJbnB1dCxcclxuICBPbkluaXQsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbiAgVmlld0NvbnRhaW5lclJlZixcclxuICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7XHJcbiAgTGF6eUVsZW1lbnRzTG9hZGVyU2VydmljZSxcclxuICBFbGVtZW50Q29uZmlnXHJcbn0gZnJvbSAnLi4vbGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZSc7XHJcblxyXG5jb25zdCBMT0dfUFJFRklYID0gJ0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbYXhMYXp5RWxlbWVudF0nXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMYXp5RWxlbWVudERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCdheExhenlFbGVtZW50JykgdXJsOiBzdHJpbmc7XHJcbiAgQElucHV0KCdheExhenlFbGVtZW50TG9hZGluZ1RlbXBsYXRlJykgbG9hZGluZ1RlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+OyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxyXG4gIEBJbnB1dCgnYXhMYXp5RWxlbWVudEVycm9yVGVtcGxhdGUnKSBlcnJvclRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+OyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxyXG4gIEBJbnB1dCgnYXhMYXp5RWxlbWVudE1vZHVsZScpIGlzTW9kdWxlOiBib29sZWFuIHwgdW5kZWZpbmVkOyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgdmNyOiBWaWV3Q29udGFpbmVyUmVmLFxyXG4gICAgcHJpdmF0ZSB0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PixcclxuICAgIHByaXZhdGUgZWxlbWVudHNMb2FkZXJTZXJ2aWNlOiBMYXp5RWxlbWVudHNMb2FkZXJTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBjZnI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICAgIHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZlxyXG4gICkge31cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICBjb25zdCB0cGwgPSB0aGlzLnRlbXBsYXRlIGFzIGFueTtcclxuICAgIGNvbnN0IGVsZW1lbnRUYWcgPSB0cGwuX2RlY2xhcmF0aW9uVENvbnRhaW5lclxyXG4gICAgICA/IHRwbC5fZGVjbGFyYXRpb25UQ29udGFpbmVyLnRhZ05hbWVcclxuICAgICAgOiB0cGwuX2RlZi5lbGVtZW50LnRlbXBsYXRlLm5vZGVzWzBdLmVsZW1lbnQubmFtZTtcclxuXHJcbiAgICBjb25zdCBlbGVtZW50Q29uZmlnID1cclxuICAgICAgdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2UuZ2V0RWxlbWVudENvbmZpZyhlbGVtZW50VGFnKSB8fFxyXG4gICAgICAoe30gYXMgRWxlbWVudENvbmZpZyk7XHJcbiAgICBjb25zdCBvcHRpb25zID0gdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2Uub3B0aW9ucztcclxuICAgIGNvbnN0IGxvYWRpbmdDb21wb25lbnQgPVxyXG4gICAgICBlbGVtZW50Q29uZmlnLmxvYWRpbmdDb21wb25lbnQgfHwgb3B0aW9ucy5sb2FkaW5nQ29tcG9uZW50O1xyXG5cclxuICAgIGlmICh0aGlzLmxvYWRpbmdUZW1wbGF0ZVJlZikge1xyXG4gICAgICB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy5sb2FkaW5nVGVtcGxhdGVSZWYpO1xyXG4gICAgfSBlbHNlIGlmIChsb2FkaW5nQ29tcG9uZW50KSB7XHJcbiAgICAgIGNvbnN0IGZhY3RvcnkgPSB0aGlzLmNmci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShsb2FkaW5nQ29tcG9uZW50KTtcclxuICAgICAgdGhpcy52Y3IuY3JlYXRlQ29tcG9uZW50KGZhY3RvcnkpO1xyXG4gICAgfVxyXG4gICAgdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2VcclxuICAgICAgLmxvYWRFbGVtZW50KHRoaXMudXJsLCBlbGVtZW50VGFnLCB0aGlzLmlzTW9kdWxlKVxyXG4gICAgICAudGhlbigoKSA9PiB7XHJcbiAgICAgICAgdGhpcy52Y3IuY2xlYXIoKTtcclxuICAgICAgICB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZSk7XHJcbiAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XHJcbiAgICAgIH0pXHJcbiAgICAgIC5jYXRjaCgoKSA9PiB7XHJcbiAgICAgICAgdGhpcy52Y3IuY2xlYXIoKTtcclxuICAgICAgICBjb25zdCBlcnJvckNvbXBvbmVudCA9XHJcbiAgICAgICAgICBlbGVtZW50Q29uZmlnLmVycm9yQ29tcG9uZW50IHx8IG9wdGlvbnMuZXJyb3JDb21wb25lbnQ7XHJcbiAgICAgICAgaWYgKHRoaXMuZXJyb3JUZW1wbGF0ZVJlZikge1xyXG4gICAgICAgICAgdGhpcy52Y3IuY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMuZXJyb3JUZW1wbGF0ZVJlZik7XHJcbiAgICAgICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcclxuICAgICAgICB9IGVsc2UgaWYgKGVycm9yQ29tcG9uZW50KSB7XHJcbiAgICAgICAgICBjb25zdCBmYWN0b3J5ID0gdGhpcy5jZnIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoZXJyb3JDb21wb25lbnQpO1xyXG4gICAgICAgICAgdGhpcy52Y3IuY3JlYXRlQ29tcG9uZW50KGZhY3RvcnkpO1xyXG4gICAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXHJcbiAgICAgICAgICAgIGAke0xPR19QUkVGSVh9IC0gTG9hZGluZyBvZiBlbGVtZW50IDwke2VsZW1lbnRUYWd9PiBmYWlsZWQsIHBsZWFzZSBwcm92aWRlIDxuZy10ZW1wbGF0ZSAjZXJyb3I+TG9hZGluZyBmYWlsZWQuLi48L25nLXRlbXBsYXRlPiBhbmQgcmVmZXJlbmNlIGl0IGluICpheExhenlFbGVtZW50PVwiZXJyb3JUZW1wbGF0ZTogZXJyb3JcIiB0byBkaXNwbGF5IGN1c3RvbWl6ZWQgZXJyb3IgbWVzc2FnZSBpbiBwbGFjZSBvZiBlbGVtZW50YFxyXG4gICAgICAgICAgKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gIH1cclxufVxyXG4iXX0=

@@ -5,19 +5,118 @@ /**

*/
import { Injectable } from '@angular/core';
import { Injectable, Optional, Inject } from '@angular/core';
import { LAZY_ELEMENT_ROOT_OPTIONS, LAZY_ELEMENTS_REGISTRY } from './lazy-elements.tokens';
import * as i0 from "@angular/core";
import * as i1 from "./lazy-elements.tokens";
/** @type {?} */
const LOG_PREFIX = '@angular-extensions/elements';
/**
* @record
*/
export function ElementConfig() { }
if (false) {
/** @type {?} */
ElementConfig.prototype.tag;
/** @type {?} */
ElementConfig.prototype.url;
/** @type {?|undefined} */
ElementConfig.prototype.isModule;
/** @type {?|undefined} */
ElementConfig.prototype.loadingComponent;
/** @type {?|undefined} */
ElementConfig.prototype.errorComponent;
/** @type {?|undefined} */
ElementConfig.prototype.preload;
}
export class LazyElementsLoaderService {
constructor() {
this.registry = new Map();
/**
* @param {?} registry
* @param {?} options
*/
constructor(registry, options) {
this.registry = registry;
this.options = options;
this.configs = [];
if (!options) {
this.options = {};
}
}
/**
* @param {?} newConfigs
* @return {?}
*/
addConfigs(newConfigs) {
newConfigs.forEach((/**
* @param {?} newConfig
* @return {?}
*/
newConfig => {
/** @type {?} */
const existingConfig = this.getElementConfig(newConfig.tag);
if (existingConfig) {
console.warn(`${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`);
}
else {
this.configs.push(newConfig);
/** @type {?} */
const shouldPreload = newConfig.preload !== undefined
? newConfig.preload
: this.options.preload;
if (shouldPreload) {
this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);
}
}
}));
}
/**
* @param {?} tag
* @return {?}
*/
getElementConfig(tag) {
return this.configs.find((/**
* @param {?} config
* @return {?}
*/
config => config.tag === tag));
}
/**
* @param {?=} tags
* @return {?}
*/
preload(tags) {
/** @type {?} */
let configs = this.configs;
if (tags) {
configs = this.configs.filter((/**
* @param {?} config
* @return {?}
*/
config => tags.includes(config.tag)));
}
configs.forEach((/**
* @param {?} config
* @return {?}
*/
config => this.loadElement(config.url, config.tag, config.isModule)));
}
/**
* @param {?} url
* @param {?} tag
* @param {?=} isModule
* @return {?}
*/
loadElement(url, tag) {
loadElement(url, tag, isModule) {
/** @type {?} */
const config = this.getElementConfig(tag);
if (!url) {
throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);
if (!config) {
throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);
}
url = config.url;
}
if (isModule === undefined) {
isModule =
config && config.isModule !== undefined
? config.isModule
: this.options.isModule;
}
if (!tag) {

@@ -31,4 +130,8 @@ throw new Error(`${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`);

const script = (/** @type {?} */ (document.createElement('script')));
if (isModule) {
script.type = 'module';
}
script.src = url;
script.onload = notifier;
script.onload = notifier.resolve;
script.onerror = notifier.reject;
document.body.appendChild(script);

@@ -48,5 +151,6 @@ }

* @param {?} resolve
* @param {?} reject
* @return {?}
*/
resolve => (notifier = resolve))));
(resolve, reject) => (notifier = { resolve, reject }))));
return notifier;

@@ -76,9 +180,28 @@ }

];
/** @nocollapse */
LazyElementsLoaderService.ctorParameters = () => [];
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(); }, token: LazyElementsLoaderService, providedIn: "root" });
LazyElementsLoaderService.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [LAZY_ELEMENTS_REGISTRY,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_OPTIONS,] }] }
];
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = i0.defineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(i0.inject(i1.LAZY_ELEMENTS_REGISTRY), i0.inject(i1.LAZY_ELEMENT_ROOT_OPTIONS, 8)); }, token: LazyElementsLoaderService, providedIn: "root" });
if (false) {
/** @type {?} */
LazyElementsLoaderService.prototype.configs;
/**
* @type {?}
* @private
*/
LazyElementsLoaderService.prototype.registry;
/** @type {?} */
LazyElementsLoaderService.prototype.options;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnRzLWxvYWRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7TUFFckMsVUFBVSxHQUFHLDhCQUE4QjtBQUtqRCxNQUFNLE9BQU8seUJBQXlCO0lBR3BDO1FBRkEsYUFBUSxHQUErQixJQUFJLEdBQUcsRUFBeUIsQ0FBQztJQUV6RCxDQUFDOzs7Ozs7SUFFaEIsV0FBVyxDQUFDLEdBQVcsRUFBRSxHQUFXO1FBQ2xDLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDUixNQUFNLElBQUksS0FBSyxDQUFDLEdBQUcsVUFBVSxlQUFlLEdBQUcsYUFBYSxDQUFDLENBQUM7U0FDL0Q7UUFFRCxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQ1IsTUFBTSxJQUFJLEtBQUssQ0FBQyxHQUFHLFVBQVUsZUFBZSxHQUFHLGdFQUFnRSxDQUFDLENBQUM7U0FDbEg7UUFFRCxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFBRTs7a0JBQ25CLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQzs7a0JBQy9CLE1BQU0sR0FBRyxtQkFBQSxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUFxQjtZQUNwRSxNQUFNLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztZQUNqQixNQUFNLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQztZQUN6QixRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUNuQztRQUVELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDdkQsQ0FBQzs7Ozs7O0lBRU8sVUFBVSxDQUFDLEdBQVc7O1lBQ3hCLFFBQVE7UUFDWixJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxPQUFPOzs7O1FBQU8sT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUMsRUFBQyxDQUFDLENBQUM7UUFDbEcsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQzs7Ozs7O0lBRU8sVUFBVSxDQUFDLEdBQVc7UUFDNUIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUN2RCxDQUFDOzs7Ozs7SUFFTyxnQkFBZ0IsQ0FBQyxHQUFXO1FBQ2xDLE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7O1lBeENGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7Ozs7OztJQUVDLDZDQUF3RSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuY29uc3QgTE9HX1BSRUZJWCA9ICdAYW5ndWxhci1leHRlbnNpb25zL2VsZW1lbnRzJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTGF6eUVsZW1lbnRzTG9hZGVyU2VydmljZSB7XG4gIHJlZ2lzdHJ5OiBNYXA8c3RyaW5nLCBQcm9taXNlPHZvaWQ+PiA9IG5ldyBNYXA8c3RyaW5nLCBQcm9taXNlPHZvaWQ+PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBsb2FkRWxlbWVudCh1cmw6IHN0cmluZywgdGFnOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAoIXVybCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGAke0xPR19QUkVGSVh9IC0gdXJsIGZvciA8JHt0YWd9PiBub3QgZm91bmRgKTtcbiAgICB9XG5cbiAgICBpZiAoIXRhZykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGAke0xPR19QUkVGSVh9IC0gdGFnIGZvciAnJHt1cmx9JyBub3QgZm91bmQsIHRoZSAqYXhMYXp5RWxlbWVudCBoYXMgdG8gYmUgdXNlZCBvbiBIVE1MIGVsZW1lbnRgKTtcbiAgICB9XG5cbiAgICBpZiAoIXRoaXMuaGFzRWxlbWVudCh1cmwpKSB7XG4gICAgICBjb25zdCBub3RpZmllciA9IHRoaXMuYWRkRWxlbWVudCh1cmwpO1xuICAgICAgY29uc3Qgc2NyaXB0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnc2NyaXB0JykgYXMgSFRNTFNjcmlwdEVsZW1lbnQ7XG4gICAgICBzY3JpcHQuc3JjID0gdXJsO1xuICAgICAgc2NyaXB0Lm9ubG9hZCA9IG5vdGlmaWVyO1xuICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChzY3JpcHQpO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLnJlZ2lzdHJ5LmdldCh0aGlzLnN0cmlwVXJsUHJvdG9jb2wodXJsKSk7XG4gIH1cblxuICBwcml2YXRlIGFkZEVsZW1lbnQodXJsOiBzdHJpbmcpOiAoKSA9PiB2b2lkIHtcbiAgICBsZXQgbm90aWZpZXI7XG4gICAgdGhpcy5yZWdpc3RyeS5zZXQodGhpcy5zdHJpcFVybFByb3RvY29sKHVybCksIG5ldyBQcm9taXNlPHZvaWQ+KHJlc29sdmUgPT4gKG5vdGlmaWVyID0gcmVzb2x2ZSkpKTtcbiAgICByZXR1cm4gbm90aWZpZXI7XG4gIH1cblxuICBwcml2YXRlIGhhc0VsZW1lbnQodXJsOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5yZWdpc3RyeS5oYXModGhpcy5zdHJpcFVybFByb3RvY29sKHVybCkpO1xuICB9XG5cbiAgcHJpdmF0ZSBzdHJpcFVybFByb3RvY29sKHVybDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdXJsLnJlcGxhY2UoL2h0dHBzPzpcXC9cXC8vLCAnJyk7XG4gIH1cbn1cbiJdfQ==
/**
* @record
*/
function Notifier() { }
if (false) {
/** @type {?} */
Notifier.prototype.resolve;
/** @type {?} */
Notifier.prototype.reject;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements-loader.service.js","sourceRoot":"ng://@angular-extensions/elements/","sources":["lib/lazy-elements/lazy-elements-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type, Optional, Inject } from '@angular/core';\r\n\r\nimport { LazyElementRootOptions } from './lazy-elements.module';\r\nimport {\r\n  LAZY_ELEMENT_ROOT_OPTIONS,\r\n  LAZY_ELEMENTS_REGISTRY,\r\n  LazyElementsRegistry\r\n} from './lazy-elements.tokens';\r\n\r\nconst LOG_PREFIX = '@angular-extensions/elements';\r\n\r\nexport interface ElementConfig {\r\n  tag: string;\r\n  url: string;\r\n  isModule?: boolean;\r\n  loadingComponent?: Type<any>;\r\n  errorComponent?: Type<any>;\r\n  preload?: boolean;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class LazyElementsLoaderService {\r\n  configs: ElementConfig[] = [];\r\n\r\n  constructor(\r\n    @Inject(LAZY_ELEMENTS_REGISTRY) private registry: LazyElementsRegistry,\r\n    @Optional()\r\n    @Inject(LAZY_ELEMENT_ROOT_OPTIONS)\r\n    public options: LazyElementRootOptions\r\n  ) {\r\n    if (!options) {\r\n      this.options = {};\r\n    }\r\n  }\r\n\r\n  addConfigs(newConfigs: ElementConfig[]) {\r\n    newConfigs.forEach(newConfig => {\r\n      const existingConfig = this.getElementConfig(newConfig.tag);\r\n      if (existingConfig) {\r\n        console.warn(\r\n          `${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`\r\n        );\r\n      } else {\r\n        this.configs.push(newConfig);\r\n        const shouldPreload =\r\n          newConfig.preload !== undefined\r\n            ? newConfig.preload\r\n            : this.options.preload;\r\n        if (shouldPreload) {\r\n          this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  getElementConfig(tag: string): ElementConfig {\r\n    return this.configs.find(config => config.tag === tag);\r\n  }\r\n\r\n  preload(tags?: string[]) {\r\n    let configs = this.configs;\r\n    if (tags) {\r\n      configs = this.configs.filter(config => tags.includes(config.tag));\r\n    }\r\n    configs.forEach(config =>\r\n      this.loadElement(config.url, config.tag, config.isModule)\r\n    );\r\n  }\r\n\r\n  loadElement(url: string, tag: string, isModule?: boolean): Promise<void> {\r\n    const config = this.getElementConfig(tag);\r\n\r\n    if (!url) {\r\n      if (!config) {\r\n        throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);\r\n      }\r\n      url = config.url;\r\n    }\r\n\r\n    if (isModule === undefined) {\r\n      isModule =\r\n        config && config.isModule !== undefined\r\n          ? config.isModule\r\n          : this.options.isModule;\r\n    }\r\n\r\n    if (!tag) {\r\n      throw new Error(\r\n        `${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`\r\n      );\r\n    }\r\n\r\n    if (!this.hasElement(url)) {\r\n      const notifier = this.addElement(url);\r\n      const script = document.createElement('script') as HTMLScriptElement;\r\n      if (isModule) {\r\n        script.type = 'module';\r\n      }\r\n      script.src = url;\r\n      script.onload = notifier.resolve;\r\n      script.onerror = notifier.reject;\r\n      document.body.appendChild(script);\r\n    }\r\n\r\n    return this.registry.get(this.stripUrlProtocol(url));\r\n  }\r\n\r\n  private addElement(url: string): Notifier {\r\n    let notifier: Notifier;\r\n    this.registry.set(\r\n      this.stripUrlProtocol(url),\r\n      new Promise<void>((resolve, reject) => (notifier = { resolve, reject }))\r\n    );\r\n    return notifier;\r\n  }\r\n\r\n  private hasElement(url: string): boolean {\r\n    return this.registry.has(this.stripUrlProtocol(url));\r\n  }\r\n\r\n  private stripUrlProtocol(url: string): string {\r\n    return url.replace(/https?:\\/\\//, '');\r\n  }\r\n}\r\n\r\ninterface Notifier {\r\n  resolve: () => void;\r\n  reject: (error: any) => void;\r\n}\r\n"]}

@@ -5,14 +5,129 @@ /**

*/
import { NgModule } from '@angular/core';
import { NgModule, Optional, Inject, ANALYZE_FOR_ENTRY_COMPONENTS, SkipSelf } from '@angular/core';
import { CommonModule } from '@angular/common';
import { LazyElementDirective } from './lazy-element/lazy-element.directive';
import { LazyElementDynamicDirective } from './lazy-element-dynamic/lazy-element-dynamic.directive';
import { LazyElementsLoaderService } from './lazy-elements-loader.service';
import { LAZY_ELEMENT_ROOT_OPTIONS, LAZY_ELEMENT_CONFIGS, LAZY_ELEMENT_ROOT_GUARD, LAZY_ELEMENTS_REGISTRY } from './lazy-elements.tokens';
export { LAZY_ELEMENTS_REGISTRY };
/**
* @param {?} options
* @return {?}
*/
export function createLazyElementRootGuard(options) {
if (options) {
throw new TypeError(`LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.`);
}
return 'guarded';
}
export class LazyElementsModule {
/**
* @param {?} lazyElementsLoaderService
* @param {?} elementConfigsMultiProvider
* @param {?} guard
*/
constructor(lazyElementsLoaderService, elementConfigsMultiProvider, guard) {
if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {
/** @type {?} */
const lastAddedConfigs = elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];
lazyElementsLoaderService.addConfigs(lastAddedConfigs);
}
}
/**
* @param {?} options
* @return {?}
*/
static forRoot(options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_OPTIONS,
useValue: options.rootOptions ? options.rootOptions : {}
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options,
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_GUARD,
useFactory: createLazyElementRootGuard,
deps: [[LAZY_ELEMENT_CONFIGS, new Optional(), new SkipSelf()]]
}
]
};
}
/**
* @param {?} options
* @return {?}
*/
static forFeature(options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options && options.elementConfigs,
multi: true
}
]
};
}
}
LazyElementsModule.decorators = [
{ type: NgModule, args: [{
declarations: [LazyElementDirective],
declarations: [LazyElementDirective, LazyElementDynamicDirective],
imports: [CommonModule],
exports: [LazyElementDirective]
exports: [LazyElementDirective, LazyElementDynamicDirective],
providers: []
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYW5ndWxhci1leHRlbnNpb25zL2VsZW1lbnRzLyIsInNvdXJjZXMiOlsibGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBTzdFLE1BQU0sT0FBTyxrQkFBa0I7OztZQUw5QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLENBQUMsb0JBQW9CLENBQUM7Z0JBQ3BDLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztnQkFDdkIsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7YUFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgTGF6eUVsZW1lbnREaXJlY3RpdmUgfSBmcm9tICcuL2xhenktZWxlbWVudC9sYXp5LWVsZW1lbnQuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTGF6eUVsZW1lbnREaXJlY3RpdmVdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW0xhenlFbGVtZW50RGlyZWN0aXZlXVxufSlcbmV4cG9ydCBjbGFzcyBMYXp5RWxlbWVudHNNb2R1bGUge31cbiJdfQ==
LazyElementsModule.ctorParameters = () => [
{ type: LazyElementsLoaderService },
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_CONFIGS,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_GUARD,] }] }
];
/**
* @record
*/
export function LazyElementModuleOptions() { }
if (false) {
/** @type {?|undefined} */
LazyElementModuleOptions.prototype.elementConfigs;
}
/**
* @record
*/
export function LazyElementModuleRootOptions() { }
if (false) {
/** @type {?|undefined} */
LazyElementModuleRootOptions.prototype.elementConfigs;
/** @type {?|undefined} */
LazyElementModuleRootOptions.prototype.rootOptions;
}
/**
* @record
*/
export function LazyElementRootOptions() { }
if (false) {
/** @type {?|undefined} */
LazyElementRootOptions.prototype.loadingComponent;
/** @type {?|undefined} */
LazyElementRootOptions.prototype.errorComponent;
/** @type {?|undefined} */
LazyElementRootOptions.prototype.isModule;
/** @type {?|undefined} */
LazyElementRootOptions.prototype.preload;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements.module.js","sourceRoot":"ng://@angular-extensions/elements/","sources":["lib/lazy-elements/lazy-elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  NgModule,\r\n  Optional,\r\n  Inject,\r\n  ModuleWithProviders,\r\n  ANALYZE_FOR_ENTRY_COMPONENTS,\r\n  Type,\r\n  SkipSelf\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\n\r\nimport { LazyElementDirective } from './lazy-element/lazy-element.directive';\r\nimport { LazyElementDynamicDirective } from './lazy-element-dynamic/lazy-element-dynamic.directive';\r\nimport {\r\n  ElementConfig,\r\n  LazyElementsLoaderService\r\n} from './lazy-elements-loader.service';\r\nimport {\r\n  LAZY_ELEMENT_ROOT_OPTIONS,\r\n  LAZY_ELEMENT_CONFIGS,\r\n  LAZY_ELEMENT_ROOT_GUARD,\r\n  LAZY_ELEMENTS_REGISTRY,\r\n  LazyElementsRegistry\r\n} from './lazy-elements.tokens';\r\n\r\nexport { LAZY_ELEMENTS_REGISTRY, LazyElementsRegistry };\r\n\r\nexport function createLazyElementRootGuard(options: LazyElementModuleOptions) {\r\n  if (options) {\r\n    throw new TypeError(\r\n      `LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.`\r\n    );\r\n  }\r\n  return 'guarded';\r\n}\r\n\r\n@NgModule({\r\n  declarations: [LazyElementDirective, LazyElementDynamicDirective],\r\n  imports: [CommonModule],\r\n  exports: [LazyElementDirective, LazyElementDynamicDirective],\r\n  providers: []\r\n})\r\nexport class LazyElementsModule {\r\n  static forRoot(options: LazyElementModuleRootOptions): ModuleWithProviders {\r\n    return {\r\n      ngModule: LazyElementsModule,\r\n      providers: [\r\n        {\r\n          provide: LAZY_ELEMENT_CONFIGS,\r\n          useValue:\r\n            options && options.elementConfigs ? options.elementConfigs : [],\r\n          multi: true\r\n        },\r\n        {\r\n          provide: LAZY_ELEMENT_ROOT_OPTIONS,\r\n          useValue: options.rootOptions ? options.rootOptions : {}\r\n        },\r\n        {\r\n          provide: ANALYZE_FOR_ENTRY_COMPONENTS,\r\n          useValue: options,\r\n          multi: true\r\n        },\r\n        {\r\n          provide: LAZY_ELEMENT_ROOT_GUARD,\r\n          useFactory: createLazyElementRootGuard,\r\n          deps: [[LAZY_ELEMENT_CONFIGS, new Optional(), new SkipSelf()]]\r\n        }\r\n      ]\r\n    };\r\n  }\r\n\r\n  static forFeature(options: LazyElementModuleOptions): ModuleWithProviders {\r\n    return {\r\n      ngModule: LazyElementsModule,\r\n      providers: [\r\n        {\r\n          provide: LAZY_ELEMENT_CONFIGS,\r\n          useValue:\r\n            options && options.elementConfigs ? options.elementConfigs : [],\r\n          multi: true\r\n        },\r\n        {\r\n          provide: ANALYZE_FOR_ENTRY_COMPONENTS,\r\n          useValue: options && options.elementConfigs,\r\n          multi: true\r\n        }\r\n      ]\r\n    };\r\n  }\r\n\r\n  constructor(\r\n    lazyElementsLoaderService: LazyElementsLoaderService,\r\n    @Optional()\r\n    @Inject(LAZY_ELEMENT_CONFIGS)\r\n    elementConfigsMultiProvider: ElementConfig[][],\r\n    @Optional()\r\n    @Inject(LAZY_ELEMENT_ROOT_GUARD)\r\n    guard: any\r\n  ) {\r\n    if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {\r\n      const lastAddedConfigs =\r\n        elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];\r\n      lazyElementsLoaderService.addConfigs(lastAddedConfigs);\r\n    }\r\n  }\r\n}\r\n\r\nexport interface LazyElementModuleOptions {\r\n  elementConfigs?: ElementConfig[];\r\n}\r\n\r\nexport interface LazyElementModuleRootOptions {\r\n  elementConfigs?: ElementConfig[];\r\n  rootOptions?: LazyElementRootOptions;\r\n}\r\n\r\nexport interface LazyElementRootOptions {\r\n  loadingComponent?: Type<any>;\r\n  errorComponent?: Type<any>;\r\n  isModule?: boolean;\r\n  preload?: boolean;\r\n}\r\n"]}

@@ -8,3 +8,3 @@ /**

*/
export { LazyElementsModule } from './lib/lazy-elements/lazy-elements.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxtQ0FBYywwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZWxlbWVudHNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudHMubW9kdWxlJztcbiJdfQ==
export { LAZY_ELEMENTS_REGISTRY, createLazyElementRootGuard, LazyElementsModule } from './lib/lazy-elements/lazy-elements.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSx1RkFBYywwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBlbGVtZW50c1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy5tb2R1bGUnO1xyXG4iXX0=

@@ -8,5 +8,7 @@ /**

*/
export { LazyElementsModule } from './public-api';
export { LazyElementDirective as ɵa } from './lib/lazy-elements/lazy-element/lazy-element.directive';
export { LazyElementsLoaderService as ɵb } from './lib/lazy-elements/lazy-elements-loader.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1leHRlbnNpb25zLWVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGFuZ3VsYXItZXh0ZW5zaW9ucy9lbGVtZW50cy8iLCJzb3VyY2VzIjpbImFuZ3VsYXItZXh0ZW5zaW9ucy1lbGVtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsbUNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSx5REFBeUQsQ0FBQztBQUNuRyxPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sa0RBQWtELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG5cbmV4cG9ydCB7TGF6eUVsZW1lbnREaXJlY3RpdmUgYXMgybVhfSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudC9sYXp5LWVsZW1lbnQuZGlyZWN0aXZlJztcbmV4cG9ydCB7TGF6eUVsZW1lbnRzTG9hZGVyU2VydmljZSBhcyDJtWJ9IGZyb20gJy4vbGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZSc7Il19
export { LAZY_ELEMENTS_REGISTRY, createLazyElementRootGuard, LazyElementsModule } from './public-api';
export { LazyElementDynamicDirective as ɵg } from './lib/lazy-elements/lazy-element-dynamic/lazy-element-dynamic.directive';
export { LazyElementDirective as ɵd } from './lib/lazy-elements/lazy-element/lazy-element.directive';
export { LazyElementsLoaderService as ɵf } from './lib/lazy-elements/lazy-elements-loader.service';
export { LAZY_ELEMENT_CONFIGS as ɵa, LAZY_ELEMENT_ROOT_GUARD as ɵc, LAZY_ELEMENT_ROOT_OPTIONS as ɵb } from './lib/lazy-elements/lazy-elements.tokens';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1leHRlbnNpb25zLWVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGFuZ3VsYXItZXh0ZW5zaW9ucy9lbGVtZW50cy8iLCJzb3VyY2VzIjpbImFuZ3VsYXItZXh0ZW5zaW9ucy1lbGVtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsdUZBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5RUFBeUUsQ0FBQztBQUMxSCxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0seURBQXlELENBQUM7QUFDbkcsT0FBTyxFQUFxQix5QkFBeUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxrREFBa0QsQ0FBQztBQUNySCxPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyx5QkFBeUIsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtMYXp5RWxlbWVudER5bmFtaWNEaXJlY3RpdmUgYXMgybVnfSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudC1keW5hbWljL2xhenktZWxlbWVudC1keW5hbWljLmRpcmVjdGl2ZSc7XG5leHBvcnQge0xhenlFbGVtZW50RGlyZWN0aXZlIGFzIMm1ZH0gZnJvbSAnLi9saWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZSc7XG5leHBvcnQge0VsZW1lbnRDb25maWcgYXMgybVlLExhenlFbGVtZW50c0xvYWRlclNlcnZpY2UgYXMgybVmfSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudHMtbG9hZGVyLnNlcnZpY2UnO1xuZXhwb3J0IHtMQVpZX0VMRU1FTlRfQ09ORklHUyBhcyDJtWEsTEFaWV9FTEVNRU5UX1JPT1RfR1VBUkQgYXMgybVjLExBWllfRUxFTUVOVF9ST09UX09QVElPTlMgYXMgybVifSBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudHMudG9rZW5zJzsiXX0=

@@ -5,9 +5,13 @@ /**

*/
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
import { Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef } from '@angular/core';
import { LazyElementsLoaderService } from '../lazy-elements-loader.service';
/** @type {?} */
var LOG_PREFIX = '@angular-extensions/elements';
var LazyElementDirective = /** @class */ (function () {
function LazyElementDirective(vcr, template, elementsLoaderService) {
function LazyElementDirective(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}

@@ -23,7 +27,25 @@ /**

/** @type {?} */
var elementTag = ((/** @type {?} */ (this.template)))._def.element.template.nodes[0].element.name;
var tpl = (/** @type {?} */ (this.template));
/** @type {?} */
var elementTag = tpl._declarationTContainer
? tpl._declarationTContainer.tagName
: tpl._def.element.template.nodes[0].element.name;
/** @type {?} */
var elementConfig = this.elementsLoaderService.getElementConfig(elementTag) ||
((/** @type {?} */ ({})));
/** @type {?} */
var options = this.elementsLoaderService.options;
/** @type {?} */
var loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
this.elementsLoaderService.loadElement(this.url, elementTag).then((/**
else if (loadingComponent) {
/** @type {?} */
var factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule)
.then((/**
* @return {?}

@@ -34,2 +56,24 @@ */

_this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
}))
.catch((/**
* @return {?}
*/
function () {
_this.vcr.clear();
/** @type {?} */
var errorComponent = elementConfig.errorComponent || options.errorComponent;
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
var 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");
}
}));

@@ -42,11 +86,14 @@ };

];
/** @nocollapse */
LazyElementDirective.ctorParameters = function () { return [
{ type: ViewContainerRef },
{ type: TemplateRef },
{ type: LazyElementsLoaderService }
{ type: LazyElementsLoaderService },
{ type: ComponentFactoryResolver },
{ type: ChangeDetectorRef }
]; };
LazyElementDirective.propDecorators = {
url: [{ type: Input, args: ['axLazyElement',] }],
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoading',] }]
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoadingTemplate',] }],
errorTemplateRef: [{ type: Input, args: ['axLazyElementErrorTemplate',] }],
isModule: [{ type: Input, args: ['axLazyElementModule',] }]
};

@@ -61,2 +108,6 @@ return LazyElementDirective;

LazyElementDirective.prototype.loadingTemplateRef;
/** @type {?} */
LazyElementDirective.prototype.errorTemplateRef;
/** @type {?} */
LazyElementDirective.prototype.isModule;
/**

@@ -77,3 +128,13 @@ * @type {?}

LazyElementDirective.prototype.elementsLoaderService;
/**
* @type {?}
* @private
*/
LazyElementDirective.prototype.cfr;
/**
* @type {?}
* @private
*/
LazyElementDirective.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXhGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRTVFO0lBT0UsOEJBQ1UsR0FBcUIsRUFDckIsUUFBMEIsRUFDMUIscUJBQWdEO1FBRmhELFFBQUcsR0FBSCxHQUFHLENBQWtCO1FBQ3JCLGFBQVEsR0FBUixRQUFRLENBQWtCO1FBQzFCLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBMkI7SUFDdkQsQ0FBQzs7OztJQUVKLHVDQUFROzs7SUFBUjtRQUFBLGlCQVdDOztZQVZPLFVBQVUsR0FBRyxDQUFDLG1CQUFBLElBQUksQ0FBQyxRQUFRLEVBQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSTtRQUVyRixJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUMzQixJQUFJLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1NBQ3REO1FBRUQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDLElBQUk7OztRQUFDO1lBQ2hFLEtBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDakIsS0FBSSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxLQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDN0MsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOztnQkF4QkYsU0FBUyxTQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7aUJBQzVCOzs7O2dCQU4rQyxnQkFBZ0I7Z0JBQTdCLFdBQVc7Z0JBRXJDLHlCQUF5Qjs7O3NCQU0vQixLQUFLLFNBQUMsZUFBZTtxQ0FDckIsS0FBSyxTQUFDLHNCQUFzQjs7SUFvQi9CLDJCQUFDO0NBQUEsQUF6QkQsSUF5QkM7U0F0Qlksb0JBQW9COzs7SUFDL0IsbUNBQW9DOztJQUNwQyxrREFBb0U7Ozs7O0lBR2xFLG1DQUE2Qjs7Ozs7SUFDN0Isd0NBQWtDOzs7OztJQUNsQyxxREFBd0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IExhenlFbGVtZW50c0xvYWRlclNlcnZpY2UgfSBmcm9tICcuLi9sYXp5LWVsZW1lbnRzLWxvYWRlci5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2F4TGF6eUVsZW1lbnRdJ1xufSlcbmV4cG9ydCBjbGFzcyBMYXp5RWxlbWVudERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgnYXhMYXp5RWxlbWVudCcpIHVybDogc3RyaW5nO1xuICBASW5wdXQoJ2F4TGF6eUVsZW1lbnRMb2FkaW5nJykgbG9hZGluZ1RlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+OyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgdmNyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIHByaXZhdGUgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4sXG4gICAgcHJpdmF0ZSBlbGVtZW50c0xvYWRlclNlcnZpY2U6IExhenlFbGVtZW50c0xvYWRlclNlcnZpY2VcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IGVsZW1lbnRUYWcgPSAodGhpcy50ZW1wbGF0ZSBhcyBhbnkpLl9kZWYuZWxlbWVudC50ZW1wbGF0ZS5ub2Rlc1swXS5lbGVtZW50Lm5hbWU7XG5cbiAgICBpZiAodGhpcy5sb2FkaW5nVGVtcGxhdGVSZWYpIHtcbiAgICAgIHRoaXMudmNyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLmxvYWRpbmdUZW1wbGF0ZVJlZik7XG4gICAgfVxuXG4gICAgdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2UubG9hZEVsZW1lbnQodGhpcy51cmwsIGVsZW1lbnRUYWcpLnRoZW4oKCkgPT4ge1xuICAgICAgdGhpcy52Y3IuY2xlYXIoKTtcbiAgICAgIHRoaXMudmNyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlKTtcbiAgICB9KTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxLQUFLLEVBRUwsV0FBVyxFQUNYLGdCQUFnQixFQUNoQix3QkFBd0IsRUFDeEIsaUJBQWlCLEVBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDTCx5QkFBeUIsRUFFMUIsTUFBTSxpQ0FBaUMsQ0FBQzs7SUFFbkMsVUFBVSxHQUFHLDhCQUE4QjtBQUVqRDtJQVNFLDhCQUNVLEdBQXFCLEVBQ3JCLFFBQTBCLEVBQzFCLHFCQUFnRCxFQUNoRCxHQUE2QixFQUM3QixHQUFzQjtRQUp0QixRQUFHLEdBQUgsR0FBRyxDQUFrQjtRQUNyQixhQUFRLEdBQVIsUUFBUSxDQUFrQjtRQUMxQiwwQkFBcUIsR0FBckIscUJBQXFCLENBQTJCO1FBQ2hELFFBQUcsR0FBSCxHQUFHLENBQTBCO1FBQzdCLFFBQUcsR0FBSCxHQUFHLENBQW1CO0lBQzdCLENBQUM7Ozs7SUFFSix1Q0FBUTs7O0lBQVI7UUFBQSxpQkEyQ0M7O1lBMUNPLEdBQUcsR0FBRyxtQkFBQSxJQUFJLENBQUMsUUFBUSxFQUFPOztZQUMxQixVQUFVLEdBQUcsR0FBRyxDQUFDLHNCQUFzQjtZQUMzQyxDQUFDLENBQUMsR0FBRyxDQUFDLHNCQUFzQixDQUFDLE9BQU87WUFDcEMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUk7O1lBRTdDLGFBQWEsR0FDakIsSUFBSSxDQUFDLHFCQUFxQixDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQztZQUN2RCxDQUFDLG1CQUFBLEVBQUUsRUFBaUIsQ0FBQzs7WUFDakIsT0FBTyxHQUFHLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPOztZQUM1QyxnQkFBZ0IsR0FDcEIsYUFBYSxDQUFDLGdCQUFnQixJQUFJLE9BQU8sQ0FBQyxnQkFBZ0I7UUFFNUQsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDM0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsQ0FBQztTQUN0RDthQUFNLElBQUksZ0JBQWdCLEVBQUU7O2dCQUNyQixPQUFPLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxnQkFBZ0IsQ0FBQztZQUNsRSxJQUFJLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUNuQztRQUNELElBQUksQ0FBQyxxQkFBcUI7YUFDdkIsV0FBVyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUM7YUFDaEQsSUFBSTs7O1FBQUM7WUFDSixLQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2pCLEtBQUksQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsS0FBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQzNDLEtBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUIsQ0FBQyxFQUFDO2FBQ0QsS0FBSzs7O1FBQUM7WUFDTCxLQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDOztnQkFDWCxjQUFjLEdBQ2xCLGFBQWEsQ0FBQyxjQUFjLElBQUksT0FBTyxDQUFDLGNBQWM7WUFDeEQsSUFBSSxLQUFJLENBQUMsZ0JBQWdCLEVBQUU7Z0JBQ3pCLEtBQUksQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsS0FBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7Z0JBQ25ELEtBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7YUFDekI7aUJBQU0sSUFBSSxjQUFjLEVBQUU7O29CQUNuQixPQUFPLEdBQUcsS0FBSSxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxjQUFjLENBQUM7Z0JBQ2hFLEtBQUksQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUNsQyxLQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQ3pCO2lCQUFNO2dCQUNMLE9BQU8sQ0FBQyxLQUFLLENBQ1IsVUFBVSwrQkFBMEIsVUFBVSxxTUFBZ00sQ0FDbFAsQ0FBQzthQUNIO1FBQ0gsQ0FBQyxFQUFDLENBQUM7SUFDUCxDQUFDOztnQkE1REYsU0FBUyxTQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7aUJBQzVCOzs7Z0JBZEMsZ0JBQWdCO2dCQURoQixXQUFXO2dCQU9YLHlCQUF5QjtnQkFMekIsd0JBQXdCO2dCQUN4QixpQkFBaUI7OztzQkFjaEIsS0FBSyxTQUFDLGVBQWU7cUNBQ3JCLEtBQUssU0FBQyw4QkFBOEI7bUNBQ3BDLEtBQUssU0FBQyw0QkFBNEI7MkJBQ2xDLEtBQUssU0FBQyxxQkFBcUI7O0lBc0Q5QiwyQkFBQztDQUFBLEFBN0RELElBNkRDO1NBMURZLG9CQUFvQjs7O0lBQy9CLG1DQUFvQzs7SUFDcEMsa0RBQTRFOztJQUM1RSxnREFBd0U7O0lBQ3hFLHdDQUE0RDs7Ozs7SUFHMUQsbUNBQTZCOzs7OztJQUM3Qix3Q0FBa0M7Ozs7O0lBQ2xDLHFEQUF3RDs7Ozs7SUFDeEQsbUNBQXFDOzs7OztJQUNyQyxtQ0FBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIERpcmVjdGl2ZSxcclxuICBJbnB1dCxcclxuICBPbkluaXQsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbiAgVmlld0NvbnRhaW5lclJlZixcclxuICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7XHJcbiAgTGF6eUVsZW1lbnRzTG9hZGVyU2VydmljZSxcclxuICBFbGVtZW50Q29uZmlnXHJcbn0gZnJvbSAnLi4vbGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZSc7XHJcblxyXG5jb25zdCBMT0dfUFJFRklYID0gJ0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbYXhMYXp5RWxlbWVudF0nXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMYXp5RWxlbWVudERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCdheExhenlFbGVtZW50JykgdXJsOiBzdHJpbmc7XHJcbiAgQElucHV0KCdheExhenlFbGVtZW50TG9hZGluZ1RlbXBsYXRlJykgbG9hZGluZ1RlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+OyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxyXG4gIEBJbnB1dCgnYXhMYXp5RWxlbWVudEVycm9yVGVtcGxhdGUnKSBlcnJvclRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+OyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxyXG4gIEBJbnB1dCgnYXhMYXp5RWxlbWVudE1vZHVsZScpIGlzTW9kdWxlOiBib29sZWFuIHwgdW5kZWZpbmVkOyAvLyB0c2xpbnQ6ZGlzYWJsZS1saW5lOm5vLWlucHV0LXJlbmFtZVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgdmNyOiBWaWV3Q29udGFpbmVyUmVmLFxyXG4gICAgcHJpdmF0ZSB0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PixcclxuICAgIHByaXZhdGUgZWxlbWVudHNMb2FkZXJTZXJ2aWNlOiBMYXp5RWxlbWVudHNMb2FkZXJTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBjZnI6IENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICAgIHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZlxyXG4gICkge31cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICBjb25zdCB0cGwgPSB0aGlzLnRlbXBsYXRlIGFzIGFueTtcclxuICAgIGNvbnN0IGVsZW1lbnRUYWcgPSB0cGwuX2RlY2xhcmF0aW9uVENvbnRhaW5lclxyXG4gICAgICA/IHRwbC5fZGVjbGFyYXRpb25UQ29udGFpbmVyLnRhZ05hbWVcclxuICAgICAgOiB0cGwuX2RlZi5lbGVtZW50LnRlbXBsYXRlLm5vZGVzWzBdLmVsZW1lbnQubmFtZTtcclxuXHJcbiAgICBjb25zdCBlbGVtZW50Q29uZmlnID1cclxuICAgICAgdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2UuZ2V0RWxlbWVudENvbmZpZyhlbGVtZW50VGFnKSB8fFxyXG4gICAgICAoe30gYXMgRWxlbWVudENvbmZpZyk7XHJcbiAgICBjb25zdCBvcHRpb25zID0gdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2Uub3B0aW9ucztcclxuICAgIGNvbnN0IGxvYWRpbmdDb21wb25lbnQgPVxyXG4gICAgICBlbGVtZW50Q29uZmlnLmxvYWRpbmdDb21wb25lbnQgfHwgb3B0aW9ucy5sb2FkaW5nQ29tcG9uZW50O1xyXG5cclxuICAgIGlmICh0aGlzLmxvYWRpbmdUZW1wbGF0ZVJlZikge1xyXG4gICAgICB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy5sb2FkaW5nVGVtcGxhdGVSZWYpO1xyXG4gICAgfSBlbHNlIGlmIChsb2FkaW5nQ29tcG9uZW50KSB7XHJcbiAgICAgIGNvbnN0IGZhY3RvcnkgPSB0aGlzLmNmci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShsb2FkaW5nQ29tcG9uZW50KTtcclxuICAgICAgdGhpcy52Y3IuY3JlYXRlQ29tcG9uZW50KGZhY3RvcnkpO1xyXG4gICAgfVxyXG4gICAgdGhpcy5lbGVtZW50c0xvYWRlclNlcnZpY2VcclxuICAgICAgLmxvYWRFbGVtZW50KHRoaXMudXJsLCBlbGVtZW50VGFnLCB0aGlzLmlzTW9kdWxlKVxyXG4gICAgICAudGhlbigoKSA9PiB7XHJcbiAgICAgICAgdGhpcy52Y3IuY2xlYXIoKTtcclxuICAgICAgICB0aGlzLnZjci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZSk7XHJcbiAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XHJcbiAgICAgIH0pXHJcbiAgICAgIC5jYXRjaCgoKSA9PiB7XHJcbiAgICAgICAgdGhpcy52Y3IuY2xlYXIoKTtcclxuICAgICAgICBjb25zdCBlcnJvckNvbXBvbmVudCA9XHJcbiAgICAgICAgICBlbGVtZW50Q29uZmlnLmVycm9yQ29tcG9uZW50IHx8IG9wdGlvbnMuZXJyb3JDb21wb25lbnQ7XHJcbiAgICAgICAgaWYgKHRoaXMuZXJyb3JUZW1wbGF0ZVJlZikge1xyXG4gICAgICAgICAgdGhpcy52Y3IuY3JlYXRlRW1iZWRkZWRWaWV3KHRoaXMuZXJyb3JUZW1wbGF0ZVJlZik7XHJcbiAgICAgICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcclxuICAgICAgICB9IGVsc2UgaWYgKGVycm9yQ29tcG9uZW50KSB7XHJcbiAgICAgICAgICBjb25zdCBmYWN0b3J5ID0gdGhpcy5jZnIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoZXJyb3JDb21wb25lbnQpO1xyXG4gICAgICAgICAgdGhpcy52Y3IuY3JlYXRlQ29tcG9uZW50KGZhY3RvcnkpO1xyXG4gICAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXHJcbiAgICAgICAgICAgIGAke0xPR19QUkVGSVh9IC0gTG9hZGluZyBvZiBlbGVtZW50IDwke2VsZW1lbnRUYWd9PiBmYWlsZWQsIHBsZWFzZSBwcm92aWRlIDxuZy10ZW1wbGF0ZSAjZXJyb3I+TG9hZGluZyBmYWlsZWQuLi48L25nLXRlbXBsYXRlPiBhbmQgcmVmZXJlbmNlIGl0IGluICpheExhenlFbGVtZW50PVwiZXJyb3JUZW1wbGF0ZTogZXJyb3JcIiB0byBkaXNwbGF5IGN1c3RvbWl6ZWQgZXJyb3IgbWVzc2FnZSBpbiBwbGFjZSBvZiBlbGVtZW50YFxyXG4gICAgICAgICAgKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gIH1cclxufVxyXG4iXX0=

@@ -5,13 +5,113 @@ /**

*/
import { Injectable } from '@angular/core';
import { Injectable, Optional, Inject } from '@angular/core';
import { LAZY_ELEMENT_ROOT_OPTIONS, LAZY_ELEMENTS_REGISTRY } from './lazy-elements.tokens';
import * as i0 from "@angular/core";
import * as i1 from "./lazy-elements.tokens";
/** @type {?} */
var LOG_PREFIX = '@angular-extensions/elements';
/**
* @record
*/
export function ElementConfig() { }
if (false) {
/** @type {?} */
ElementConfig.prototype.tag;
/** @type {?} */
ElementConfig.prototype.url;
/** @type {?|undefined} */
ElementConfig.prototype.isModule;
/** @type {?|undefined} */
ElementConfig.prototype.loadingComponent;
/** @type {?|undefined} */
ElementConfig.prototype.errorComponent;
/** @type {?|undefined} */
ElementConfig.prototype.preload;
}
var LazyElementsLoaderService = /** @class */ (function () {
function LazyElementsLoaderService() {
this.registry = new Map();
function LazyElementsLoaderService(registry, options) {
this.registry = registry;
this.options = options;
this.configs = [];
if (!options) {
this.options = {};
}
}
/**
* @param {?} newConfigs
* @return {?}
*/
LazyElementsLoaderService.prototype.addConfigs = /**
* @param {?} newConfigs
* @return {?}
*/
function (newConfigs) {
var _this = this;
newConfigs.forEach((/**
* @param {?} newConfig
* @return {?}
*/
function (newConfig) {
/** @type {?} */
var existingConfig = _this.getElementConfig(newConfig.tag);
if (existingConfig) {
console.warn(LOG_PREFIX + " - ElementConfig for tag '" + newConfig.tag + "' was previously added, it will not be added multiple times, continue...");
}
else {
_this.configs.push(newConfig);
/** @type {?} */
var shouldPreload = newConfig.preload !== undefined
? newConfig.preload
: _this.options.preload;
if (shouldPreload) {
_this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);
}
}
}));
};
/**
* @param {?} tag
* @return {?}
*/
LazyElementsLoaderService.prototype.getElementConfig = /**
* @param {?} tag
* @return {?}
*/
function (tag) {
return this.configs.find((/**
* @param {?} config
* @return {?}
*/
function (config) { return config.tag === tag; }));
};
/**
* @param {?=} tags
* @return {?}
*/
LazyElementsLoaderService.prototype.preload = /**
* @param {?=} tags
* @return {?}
*/
function (tags) {
var _this = this;
/** @type {?} */
var configs = this.configs;
if (tags) {
configs = this.configs.filter((/**
* @param {?} config
* @return {?}
*/
function (config) { return tags.includes(config.tag); }));
}
configs.forEach((/**
* @param {?} config
* @return {?}
*/
function (config) {
return _this.loadElement(config.url, config.tag, config.isModule);
}));
};
/**
* @param {?} url
* @param {?} tag
* @param {?=} isModule
* @return {?}

@@ -22,8 +122,20 @@ */

* @param {?} tag
* @param {?=} isModule
* @return {?}
*/
function (url, tag) {
function (url, tag, isModule) {
/** @type {?} */
var config = this.getElementConfig(tag);
if (!url) {
throw new Error(LOG_PREFIX + " - url for <" + tag + "> not found");
if (!config) {
throw new Error(LOG_PREFIX + " - url for <" + tag + "> not found");
}
url = config.url;
}
if (isModule === undefined) {
isModule =
config && config.isModule !== undefined
? config.isModule
: this.options.isModule;
}
if (!tag) {

@@ -37,4 +149,8 @@ throw new Error(LOG_PREFIX + " - tag for '" + url + "' not found, the *axLazyElement has to be used on HTML element");

var script = (/** @type {?} */ (document.createElement('script')));
if (isModule) {
script.type = 'module';
}
script.src = url;
script.onload = notifier;
script.onload = notifier.resolve;
script.onerror = notifier.reject;
document.body.appendChild(script);

@@ -59,5 +175,6 @@ }

* @param {?} resolve
* @param {?} reject
* @return {?}
*/
function (resolve) { return (notifier = resolve); })));
function (resolve, reject) { return (notifier = { resolve: resolve, reject: reject }); })));
return notifier;

@@ -96,5 +213,7 @@ };

];
/** @nocollapse */
LazyElementsLoaderService.ctorParameters = function () { return []; };
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(); }, token: LazyElementsLoaderService, providedIn: "root" });
LazyElementsLoaderService.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [LAZY_ELEMENTS_REGISTRY,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_OPTIONS,] }] }
]; };
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = i0.defineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(i0.inject(i1.LAZY_ELEMENTS_REGISTRY), i0.inject(i1.LAZY_ELEMENT_ROOT_OPTIONS, 8)); }, token: LazyElementsLoaderService, providedIn: "root" });
return LazyElementsLoaderService;

@@ -105,4 +224,21 @@ }());

/** @type {?} */
LazyElementsLoaderService.prototype.configs;
/**
* @type {?}
* @private
*/
LazyElementsLoaderService.prototype.registry;
/** @type {?} */
LazyElementsLoaderService.prototype.options;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50cy1sb2FkZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvbGF6eS1lbGVtZW50cy9sYXp5LWVsZW1lbnRzLWxvYWRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7SUFFckMsVUFBVSxHQUFHLDhCQUE4QjtBQUVqRDtJQU1FO1FBRkEsYUFBUSxHQUErQixJQUFJLEdBQUcsRUFBeUIsQ0FBQztJQUV6RCxDQUFDOzs7Ozs7SUFFaEIsK0NBQVc7Ozs7O0lBQVgsVUFBWSxHQUFXLEVBQUUsR0FBVztRQUNsQyxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQ1IsTUFBTSxJQUFJLEtBQUssQ0FBSSxVQUFVLG9CQUFlLEdBQUcsZ0JBQWEsQ0FBQyxDQUFDO1NBQy9EO1FBRUQsSUFBSSxDQUFDLEdBQUcsRUFBRTtZQUNSLE1BQU0sSUFBSSxLQUFLLENBQUksVUFBVSxvQkFBZSxHQUFHLG1FQUFnRSxDQUFDLENBQUM7U0FDbEg7UUFFRCxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFBRTs7Z0JBQ25CLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQzs7Z0JBQy9CLE1BQU0sR0FBRyxtQkFBQSxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUFxQjtZQUNwRSxNQUFNLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztZQUNqQixNQUFNLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQztZQUN6QixRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUNuQztRQUVELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDdkQsQ0FBQzs7Ozs7O0lBRU8sOENBQVU7Ozs7O0lBQWxCLFVBQW1CLEdBQVc7O1lBQ3hCLFFBQVE7UUFDWixJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxPQUFPOzs7O1FBQU8sVUFBQSxPQUFPLElBQUksT0FBQSxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUMsRUFBcEIsQ0FBb0IsRUFBQyxDQUFDLENBQUM7UUFDbEcsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQzs7Ozs7O0lBRU8sOENBQVU7Ozs7O0lBQWxCLFVBQW1CLEdBQVc7UUFDNUIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUN2RCxDQUFDOzs7Ozs7SUFFTyxvREFBZ0I7Ozs7O0lBQXhCLFVBQXlCLEdBQVc7UUFDbEMsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN4QyxDQUFDOztnQkF4Q0YsVUFBVSxTQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7Ozs7b0NBTkQ7Q0E2Q0MsQUF6Q0QsSUF5Q0M7U0F0Q1kseUJBQXlCOzs7SUFDcEMsNkNBQXdFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5jb25zdCBMT0dfUFJFRklYID0gJ0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBMYXp5RWxlbWVudHNMb2FkZXJTZXJ2aWNlIHtcbiAgcmVnaXN0cnk6IE1hcDxzdHJpbmcsIFByb21pc2U8dm9pZD4+ID0gbmV3IE1hcDxzdHJpbmcsIFByb21pc2U8dm9pZD4+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIGxvYWRFbGVtZW50KHVybDogc3RyaW5nLCB0YWc6IHN0cmluZyk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICghdXJsKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYCR7TE9HX1BSRUZJWH0gLSB1cmwgZm9yIDwke3RhZ30+IG5vdCBmb3VuZGApO1xuICAgIH1cblxuICAgIGlmICghdGFnKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYCR7TE9HX1BSRUZJWH0gLSB0YWcgZm9yICcke3VybH0nIG5vdCBmb3VuZCwgdGhlICpheExhenlFbGVtZW50IGhhcyB0byBiZSB1c2VkIG9uIEhUTUwgZWxlbWVudGApO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5oYXNFbGVtZW50KHVybCkpIHtcbiAgICAgIGNvbnN0IG5vdGlmaWVyID0gdGhpcy5hZGRFbGVtZW50KHVybCk7XG4gICAgICBjb25zdCBzY3JpcHQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzY3JpcHQnKSBhcyBIVE1MU2NyaXB0RWxlbWVudDtcbiAgICAgIHNjcmlwdC5zcmMgPSB1cmw7XG4gICAgICBzY3JpcHQub25sb2FkID0gbm90aWZpZXI7XG4gICAgICBkb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKHNjcmlwdCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMucmVnaXN0cnkuZ2V0KHRoaXMuc3RyaXBVcmxQcm90b2NvbCh1cmwpKTtcbiAgfVxuXG4gIHByaXZhdGUgYWRkRWxlbWVudCh1cmw6IHN0cmluZyk6ICgpID0+IHZvaWQge1xuICAgIGxldCBub3RpZmllcjtcbiAgICB0aGlzLnJlZ2lzdHJ5LnNldCh0aGlzLnN0cmlwVXJsUHJvdG9jb2wodXJsKSwgbmV3IFByb21pc2U8dm9pZD4ocmVzb2x2ZSA9PiAobm90aWZpZXIgPSByZXNvbHZlKSkpO1xuICAgIHJldHVybiBub3RpZmllcjtcbiAgfVxuXG4gIHByaXZhdGUgaGFzRWxlbWVudCh1cmw6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLnJlZ2lzdHJ5Lmhhcyh0aGlzLnN0cmlwVXJsUHJvdG9jb2wodXJsKSk7XG4gIH1cblxuICBwcml2YXRlIHN0cmlwVXJsUHJvdG9jb2wodXJsOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiB1cmwucmVwbGFjZSgvaHR0cHM/OlxcL1xcLy8sICcnKTtcbiAgfVxufVxuIl19
/**
* @record
*/
function Notifier() { }
if (false) {
/** @type {?} */
Notifier.prototype.resolve;
/** @type {?} */
Notifier.prototype.reject;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements-loader.service.js","sourceRoot":"ng://@angular-extensions/elements/","sources":["lib/lazy-elements/lazy-elements-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type, Optional, Inject } from '@angular/core';\r\n\r\nimport { LazyElementRootOptions } from './lazy-elements.module';\r\nimport {\r\n  LAZY_ELEMENT_ROOT_OPTIONS,\r\n  LAZY_ELEMENTS_REGISTRY,\r\n  LazyElementsRegistry\r\n} from './lazy-elements.tokens';\r\n\r\nconst LOG_PREFIX = '@angular-extensions/elements';\r\n\r\nexport interface ElementConfig {\r\n  tag: string;\r\n  url: string;\r\n  isModule?: boolean;\r\n  loadingComponent?: Type<any>;\r\n  errorComponent?: Type<any>;\r\n  preload?: boolean;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class LazyElementsLoaderService {\r\n  configs: ElementConfig[] = [];\r\n\r\n  constructor(\r\n    @Inject(LAZY_ELEMENTS_REGISTRY) private registry: LazyElementsRegistry,\r\n    @Optional()\r\n    @Inject(LAZY_ELEMENT_ROOT_OPTIONS)\r\n    public options: LazyElementRootOptions\r\n  ) {\r\n    if (!options) {\r\n      this.options = {};\r\n    }\r\n  }\r\n\r\n  addConfigs(newConfigs: ElementConfig[]) {\r\n    newConfigs.forEach(newConfig => {\r\n      const existingConfig = this.getElementConfig(newConfig.tag);\r\n      if (existingConfig) {\r\n        console.warn(\r\n          `${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`\r\n        );\r\n      } else {\r\n        this.configs.push(newConfig);\r\n        const shouldPreload =\r\n          newConfig.preload !== undefined\r\n            ? newConfig.preload\r\n            : this.options.preload;\r\n        if (shouldPreload) {\r\n          this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  getElementConfig(tag: string): ElementConfig {\r\n    return this.configs.find(config => config.tag === tag);\r\n  }\r\n\r\n  preload(tags?: string[]) {\r\n    let configs = this.configs;\r\n    if (tags) {\r\n      configs = this.configs.filter(config => tags.includes(config.tag));\r\n    }\r\n    configs.forEach(config =>\r\n      this.loadElement(config.url, config.tag, config.isModule)\r\n    );\r\n  }\r\n\r\n  loadElement(url: string, tag: string, isModule?: boolean): Promise<void> {\r\n    const config = this.getElementConfig(tag);\r\n\r\n    if (!url) {\r\n      if (!config) {\r\n        throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);\r\n      }\r\n      url = config.url;\r\n    }\r\n\r\n    if (isModule === undefined) {\r\n      isModule =\r\n        config && config.isModule !== undefined\r\n          ? config.isModule\r\n          : this.options.isModule;\r\n    }\r\n\r\n    if (!tag) {\r\n      throw new Error(\r\n        `${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`\r\n      );\r\n    }\r\n\r\n    if (!this.hasElement(url)) {\r\n      const notifier = this.addElement(url);\r\n      const script = document.createElement('script') as HTMLScriptElement;\r\n      if (isModule) {\r\n        script.type = 'module';\r\n      }\r\n      script.src = url;\r\n      script.onload = notifier.resolve;\r\n      script.onerror = notifier.reject;\r\n      document.body.appendChild(script);\r\n    }\r\n\r\n    return this.registry.get(this.stripUrlProtocol(url));\r\n  }\r\n\r\n  private addElement(url: string): Notifier {\r\n    let notifier: Notifier;\r\n    this.registry.set(\r\n      this.stripUrlProtocol(url),\r\n      new Promise<void>((resolve, reject) => (notifier = { resolve, reject }))\r\n    );\r\n    return notifier;\r\n  }\r\n\r\n  private hasElement(url: string): boolean {\r\n    return this.registry.has(this.stripUrlProtocol(url));\r\n  }\r\n\r\n  private stripUrlProtocol(url: string): string {\r\n    return url.replace(/https?:\\/\\//, '');\r\n  }\r\n}\r\n\r\ninterface Notifier {\r\n  resolve: () => void;\r\n  reject: (error: any) => void;\r\n}\r\n"]}

@@ -5,18 +5,134 @@ /**

*/
import { NgModule } from '@angular/core';
import { NgModule, Optional, Inject, ANALYZE_FOR_ENTRY_COMPONENTS, SkipSelf } from '@angular/core';
import { CommonModule } from '@angular/common';
import { LazyElementDirective } from './lazy-element/lazy-element.directive';
import { LazyElementDynamicDirective } from './lazy-element-dynamic/lazy-element-dynamic.directive';
import { LazyElementsLoaderService } from './lazy-elements-loader.service';
import { LAZY_ELEMENT_ROOT_OPTIONS, LAZY_ELEMENT_CONFIGS, LAZY_ELEMENT_ROOT_GUARD, LAZY_ELEMENTS_REGISTRY } from './lazy-elements.tokens';
export { LAZY_ELEMENTS_REGISTRY };
/**
* @param {?} options
* @return {?}
*/
export function createLazyElementRootGuard(options) {
if (options) {
throw new TypeError("LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.");
}
return 'guarded';
}
var LazyElementsModule = /** @class */ (function () {
function LazyElementsModule() {
function LazyElementsModule(lazyElementsLoaderService, elementConfigsMultiProvider, guard) {
if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {
/** @type {?} */
var lastAddedConfigs = elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];
lazyElementsLoaderService.addConfigs(lastAddedConfigs);
}
}
/**
* @param {?} options
* @return {?}
*/
LazyElementsModule.forRoot = /**
* @param {?} options
* @return {?}
*/
function (options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_OPTIONS,
useValue: options.rootOptions ? options.rootOptions : {}
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options,
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_GUARD,
useFactory: createLazyElementRootGuard,
deps: [[LAZY_ELEMENT_CONFIGS, new Optional(), new SkipSelf()]]
}
]
};
};
/**
* @param {?} options
* @return {?}
*/
LazyElementsModule.forFeature = /**
* @param {?} options
* @return {?}
*/
function (options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options && options.elementConfigs,
multi: true
}
]
};
};
LazyElementsModule.decorators = [
{ type: NgModule, args: [{
declarations: [LazyElementDirective],
declarations: [LazyElementDirective, LazyElementDynamicDirective],
imports: [CommonModule],
exports: [LazyElementDirective]
exports: [LazyElementDirective, LazyElementDynamicDirective],
providers: []
},] }
];
LazyElementsModule.ctorParameters = function () { return [
{ type: LazyElementsLoaderService },
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_CONFIGS,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_GUARD,] }] }
]; };
return LazyElementsModule;
}());
export { LazyElementsModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1lbGVtZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYW5ndWxhci1leHRlbnNpb25zL2VsZW1lbnRzLyIsInNvdXJjZXMiOlsibGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTdFO0lBQUE7SUFLaUMsQ0FBQzs7Z0JBTGpDLFFBQVEsU0FBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztpQkFDaEM7O0lBQ2dDLHlCQUFDO0NBQUEsQUFMbEMsSUFLa0M7U0FBckIsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IExhenlFbGVtZW50RGlyZWN0aXZlIH0gZnJvbSAnLi9sYXp5LWVsZW1lbnQvbGF6eS1lbGVtZW50LmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0xhenlFbGVtZW50RGlyZWN0aXZlXSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtMYXp5RWxlbWVudERpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgTGF6eUVsZW1lbnRzTW9kdWxlIHt9XG4iXX0=
/**
* @record
*/
export function LazyElementModuleOptions() { }
if (false) {
/** @type {?|undefined} */
LazyElementModuleOptions.prototype.elementConfigs;
}
/**
* @record
*/
export function LazyElementModuleRootOptions() { }
if (false) {
/** @type {?|undefined} */
LazyElementModuleRootOptions.prototype.elementConfigs;
/** @type {?|undefined} */
LazyElementModuleRootOptions.prototype.rootOptions;
}
/**
* @record
*/
export function LazyElementRootOptions() { }
if (false) {
/** @type {?|undefined} */
LazyElementRootOptions.prototype.loadingComponent;
/** @type {?|undefined} */
LazyElementRootOptions.prototype.errorComponent;
/** @type {?|undefined} */
LazyElementRootOptions.prototype.isModule;
/** @type {?|undefined} */
LazyElementRootOptions.prototype.preload;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-elements.module.js","sourceRoot":"ng://@angular-extensions/elements/","sources":["lib/lazy-elements/lazy-elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  NgModule,\r\n  Optional,\r\n  Inject,\r\n  ModuleWithProviders,\r\n  ANALYZE_FOR_ENTRY_COMPONENTS,\r\n  Type,\r\n  SkipSelf\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\n\r\nimport { LazyElementDirective } from './lazy-element/lazy-element.directive';\r\nimport { LazyElementDynamicDirective } from './lazy-element-dynamic/lazy-element-dynamic.directive';\r\nimport {\r\n  ElementConfig,\r\n  LazyElementsLoaderService\r\n} from './lazy-elements-loader.service';\r\nimport {\r\n  LAZY_ELEMENT_ROOT_OPTIONS,\r\n  LAZY_ELEMENT_CONFIGS,\r\n  LAZY_ELEMENT_ROOT_GUARD,\r\n  LAZY_ELEMENTS_REGISTRY,\r\n  LazyElementsRegistry\r\n} from './lazy-elements.tokens';\r\n\r\nexport { LAZY_ELEMENTS_REGISTRY, LazyElementsRegistry };\r\n\r\nexport function createLazyElementRootGuard(options: LazyElementModuleOptions) {\r\n  if (options) {\r\n    throw new TypeError(\r\n      `LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.`\r\n    );\r\n  }\r\n  return 'guarded';\r\n}\r\n\r\n@NgModule({\r\n  declarations: [LazyElementDirective, LazyElementDynamicDirective],\r\n  imports: [CommonModule],\r\n  exports: [LazyElementDirective, LazyElementDynamicDirective],\r\n  providers: []\r\n})\r\nexport class LazyElementsModule {\r\n  static forRoot(options: LazyElementModuleRootOptions): ModuleWithProviders {\r\n    return {\r\n      ngModule: LazyElementsModule,\r\n      providers: [\r\n        {\r\n          provide: LAZY_ELEMENT_CONFIGS,\r\n          useValue:\r\n            options && options.elementConfigs ? options.elementConfigs : [],\r\n          multi: true\r\n        },\r\n        {\r\n          provide: LAZY_ELEMENT_ROOT_OPTIONS,\r\n          useValue: options.rootOptions ? options.rootOptions : {}\r\n        },\r\n        {\r\n          provide: ANALYZE_FOR_ENTRY_COMPONENTS,\r\n          useValue: options,\r\n          multi: true\r\n        },\r\n        {\r\n          provide: LAZY_ELEMENT_ROOT_GUARD,\r\n          useFactory: createLazyElementRootGuard,\r\n          deps: [[LAZY_ELEMENT_CONFIGS, new Optional(), new SkipSelf()]]\r\n        }\r\n      ]\r\n    };\r\n  }\r\n\r\n  static forFeature(options: LazyElementModuleOptions): ModuleWithProviders {\r\n    return {\r\n      ngModule: LazyElementsModule,\r\n      providers: [\r\n        {\r\n          provide: LAZY_ELEMENT_CONFIGS,\r\n          useValue:\r\n            options && options.elementConfigs ? options.elementConfigs : [],\r\n          multi: true\r\n        },\r\n        {\r\n          provide: ANALYZE_FOR_ENTRY_COMPONENTS,\r\n          useValue: options && options.elementConfigs,\r\n          multi: true\r\n        }\r\n      ]\r\n    };\r\n  }\r\n\r\n  constructor(\r\n    lazyElementsLoaderService: LazyElementsLoaderService,\r\n    @Optional()\r\n    @Inject(LAZY_ELEMENT_CONFIGS)\r\n    elementConfigsMultiProvider: ElementConfig[][],\r\n    @Optional()\r\n    @Inject(LAZY_ELEMENT_ROOT_GUARD)\r\n    guard: any\r\n  ) {\r\n    if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {\r\n      const lastAddedConfigs =\r\n        elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];\r\n      lazyElementsLoaderService.addConfigs(lastAddedConfigs);\r\n    }\r\n  }\r\n}\r\n\r\nexport interface LazyElementModuleOptions {\r\n  elementConfigs?: ElementConfig[];\r\n}\r\n\r\nexport interface LazyElementModuleRootOptions {\r\n  elementConfigs?: ElementConfig[];\r\n  rootOptions?: LazyElementRootOptions;\r\n}\r\n\r\nexport interface LazyElementRootOptions {\r\n  loadingComponent?: Type<any>;\r\n  errorComponent?: Type<any>;\r\n  isModule?: boolean;\r\n  preload?: boolean;\r\n}\r\n"]}

@@ -8,3 +8,3 @@ /**

*/
export { LazyElementsModule } from './lib/lazy-elements/lazy-elements.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxtQ0FBYywwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZWxlbWVudHNcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9sYXp5LWVsZW1lbnRzL2xhenktZWxlbWVudHMubW9kdWxlJztcbiJdfQ==
export { LAZY_ELEMENTS_REGISTRY, createLazyElementRootGuard, LazyElementsModule } from './lib/lazy-elements/lazy-elements.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bhbmd1bGFyLWV4dGVuc2lvbnMvZWxlbWVudHMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSx1RkFBYywwQ0FBMEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBlbGVtZW50c1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhenktZWxlbWVudHMvbGF6eS1lbGVtZW50cy5tb2R1bGUnO1xyXG4iXX0=

@@ -1,3 +0,3 @@

import { Injectable, ɵɵdefineInjectable, Directive, ViewContainerRef, TemplateRef, Input, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { InjectionToken, Injectable, Optional, Inject, Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef, NgModule, ANALYZE_FOR_ENTRY_COMPONENTS, SkipSelf, defineInjectable, inject } from '@angular/core';

@@ -9,16 +9,114 @@ /**

/** @type {?} */
const LAZY_ELEMENT_CONFIGS = new InjectionToken('LAZY_ELEMENT_CONFIGS');
/** @type {?} */
const LAZY_ELEMENT_ROOT_OPTIONS = new InjectionToken('LAZY_ELEMENT_ROOT_OPTIONS');
/** @type {?} */
const LAZY_ELEMENT_ROOT_GUARD = new InjectionToken('LAZY_ELEMENT_ROOT_GUARD');
/** @type {?} */
const LAZY_ELEMENTS_REGISTRY = new InjectionToken('Lazu elements registry', {
providedIn: 'root',
factory: (/**
* @return {?}
*/
() => new Map())
});
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
const LOG_PREFIX = '@angular-extensions/elements';
class LazyElementsLoaderService {
constructor() {
this.registry = new Map();
/**
* @param {?} registry
* @param {?} options
*/
constructor(registry, options) {
this.registry = registry;
this.options = options;
this.configs = [];
if (!options) {
this.options = {};
}
}
/**
* @param {?} newConfigs
* @return {?}
*/
addConfigs(newConfigs) {
newConfigs.forEach((/**
* @param {?} newConfig
* @return {?}
*/
newConfig => {
/** @type {?} */
const existingConfig = this.getElementConfig(newConfig.tag);
if (existingConfig) {
console.warn(`${LOG_PREFIX} - ElementConfig for tag '${newConfig.tag}' was previously added, it will not be added multiple times, continue...`);
}
else {
this.configs.push(newConfig);
/** @type {?} */
const shouldPreload = newConfig.preload !== undefined
? newConfig.preload
: this.options.preload;
if (shouldPreload) {
this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);
}
}
}));
}
/**
* @param {?} tag
* @return {?}
*/
getElementConfig(tag) {
return this.configs.find((/**
* @param {?} config
* @return {?}
*/
config => config.tag === tag));
}
/**
* @param {?=} tags
* @return {?}
*/
preload(tags) {
/** @type {?} */
let configs = this.configs;
if (tags) {
configs = this.configs.filter((/**
* @param {?} config
* @return {?}
*/
config => tags.includes(config.tag)));
}
configs.forEach((/**
* @param {?} config
* @return {?}
*/
config => this.loadElement(config.url, config.tag, config.isModule)));
}
/**
* @param {?} url
* @param {?} tag
* @param {?=} isModule
* @return {?}
*/
loadElement(url, tag) {
loadElement(url, tag, isModule) {
/** @type {?} */
const config = this.getElementConfig(tag);
if (!url) {
throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);
if (!config) {
throw new Error(`${LOG_PREFIX} - url for <${tag}> not found`);
}
url = config.url;
}
if (isModule === undefined) {
isModule =
config && config.isModule !== undefined
? config.isModule
: this.options.isModule;
}
if (!tag) {

@@ -32,4 +130,8 @@ throw new Error(`${LOG_PREFIX} - tag for '${url}' not found, the *axLazyElement has to be used on HTML element`);

const script = (/** @type {?} */ (document.createElement('script')));
if (isModule) {
script.type = 'module';
}
script.src = url;
script.onload = notifier;
script.onload = notifier.resolve;
script.onerror = notifier.reject;
document.body.appendChild(script);

@@ -49,5 +151,6 @@ }

* @param {?} resolve
* @param {?} reject
* @return {?}
*/
resolve => (notifier = resolve))));
(resolve, reject) => (notifier = { resolve, reject }))));
return notifier;

@@ -77,5 +180,7 @@ }

];
/** @nocollapse */
LazyElementsLoaderService.ctorParameters = () => [];
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = ɵɵdefineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(); }, token: LazyElementsLoaderService, providedIn: "root" });
LazyElementsLoaderService.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [LAZY_ELEMENTS_REGISTRY,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_OPTIONS,] }] }
];
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = defineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(inject(LAZY_ELEMENTS_REGISTRY), inject(LAZY_ELEMENT_ROOT_OPTIONS, 8)); }, token: LazyElementsLoaderService, providedIn: "root" });

@@ -86,2 +191,4 @@ /**

*/
/** @type {?} */
const LOG_PREFIX$1 = '@angular-extensions/elements';
class LazyElementDirective {

@@ -93,7 +200,11 @@ // tslint:disable-line:no-input-rename

* @param {?} elementsLoaderService
* @param {?} cfr
* @param {?} cdr
*/
constructor(vcr, template, elementsLoaderService) {
constructor(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}

@@ -105,7 +216,25 @@ /**

/** @type {?} */
const elementTag = ((/** @type {?} */ (this.template)))._def.element.template.nodes[0].element.name;
const tpl = (/** @type {?} */ (this.template));
/** @type {?} */
const elementTag = tpl._declarationTContainer
? tpl._declarationTContainer.tagName
: tpl._def.element.template.nodes[0].element.name;
/** @type {?} */
const elementConfig = this.elementsLoaderService.getElementConfig(elementTag) ||
((/** @type {?} */ ({})));
/** @type {?} */
const options = this.elementsLoaderService.options;
/** @type {?} */
const loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
this.elementsLoaderService.loadElement(this.url, elementTag).then((/**
else if (loadingComponent) {
/** @type {?} */
const factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule)
.then((/**
* @return {?}

@@ -116,2 +245,24 @@ */

this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
}))
.catch((/**
* @return {?}
*/
() => {
this.vcr.clear();
/** @type {?} */
const errorComponent = elementConfig.errorComponent || options.errorComponent;
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
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`);
}
}));

@@ -125,11 +276,14 @@ }

];
/** @nocollapse */
LazyElementDirective.ctorParameters = () => [
{ type: ViewContainerRef },
{ type: TemplateRef },
{ type: LazyElementsLoaderService }
{ type: LazyElementsLoaderService },
{ type: ComponentFactoryResolver },
{ type: ChangeDetectorRef }
];
LazyElementDirective.propDecorators = {
url: [{ type: Input, args: ['axLazyElement',] }],
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoading',] }]
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoadingTemplate',] }],
errorTemplateRef: [{ type: Input, args: ['axLazyElementErrorTemplate',] }],
isModule: [{ type: Input, args: ['axLazyElementModule',] }]
};

@@ -141,13 +295,209 @@

*/
/** @type {?} */
const LOG_PREFIX$2 = '@angular-extensions/elements';
class LazyElementDynamicDirective {
// tslint:disable-line:no-input-rename
/**
* @param {?} vcr
* @param {?} template
* @param {?} elementsLoaderService
* @param {?} cfr
* @param {?} cdr
*/
constructor(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}
/**
* @return {?}
*/
ngOnInit() {
if (!this.tag || this.tag.length === 0 || !this.tag.includes('-')) {
throw new Error(`${LOG_PREFIX$2} - Valid tag has to be specified when using *axLazyElementDynamic directive (use *axLazyElementDynamic="'some-tag'"), got: "${this.tag}"`);
}
/** @type {?} */
const elementConfig = this.elementsLoaderService.getElementConfig(this.tag) ||
((/** @type {?} */ ({})));
/** @type {?} */
const options = this.elementsLoaderService.options;
/** @type {?} */
const loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
else if (loadingComponent) {
/** @type {?} */
const factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, this.tag, this.isModule)
.then((/**
* @return {?}
*/
() => {
if (((/** @type {?} */ (this.template)))._declarationTContainer) {
// (this.template as any)._declarationTContainer.tagName = this.tag;
throw new Error('The *axLazyElementDynamic directive is currently does NOT support Angular Ivy, please use standard *axLazyElement directive instead!');
}
else {
((/** @type {?} */ (this
.template)))._def.element.template.nodes[0].element.name = this.tag;
}
this.vcr.clear();
this.vcr.createEmbeddedView(this.template);
this.cdr.markForCheck();
}))
.catch((/**
* @param {?} error
* @return {?}
*/
error => {
/** @type {?} */
const errorComponent = elementConfig.errorComponent || options.errorComponent;
this.vcr.clear();
if (this.errorTemplateRef) {
this.vcr.createEmbeddedView(this.errorTemplateRef);
this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
const factory = this.cfr.resolveComponentFactory(errorComponent);
this.vcr.createComponent(factory);
this.cdr.markForCheck();
}
else {
console.error(`${LOG_PREFIX$2} - 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.decorators = [
{ type: Directive, args: [{
selector: '[axLazyElementDynamic]'
},] }
];
LazyElementDynamicDirective.ctorParameters = () => [
{ type: ViewContainerRef },
{ type: TemplateRef },
{ type: LazyElementsLoaderService },
{ type: ComponentFactoryResolver },
{ type: ChangeDetectorRef }
];
LazyElementDynamicDirective.propDecorators = {
tag: [{ type: Input, args: ['axLazyElementDynamic',] }],
url: [{ type: Input, args: ['axLazyElementDynamicUrl',] }],
loadingTemplateRef: [{ type: Input, args: ['axLazyElementDynamicLoadingTemplate',] }],
errorTemplateRef: [{ type: Input, args: ['axLazyElementDynamicErrorTemplate',] }],
isModule: [{ type: Input, args: ['axLazyElementDynamicModule',] }]
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @param {?} options
* @return {?}
*/
function createLazyElementRootGuard(options) {
if (options) {
throw new TypeError(`LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.`);
}
return 'guarded';
}
class LazyElementsModule {
/**
* @param {?} lazyElementsLoaderService
* @param {?} elementConfigsMultiProvider
* @param {?} guard
*/
constructor(lazyElementsLoaderService, elementConfigsMultiProvider, guard) {
if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {
/** @type {?} */
const lastAddedConfigs = elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];
lazyElementsLoaderService.addConfigs(lastAddedConfigs);
}
}
/**
* @param {?} options
* @return {?}
*/
static forRoot(options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_OPTIONS,
useValue: options.rootOptions ? options.rootOptions : {}
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options,
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_GUARD,
useFactory: createLazyElementRootGuard,
deps: [[LAZY_ELEMENT_CONFIGS, new Optional(), new SkipSelf()]]
}
]
};
}
/**
* @param {?} options
* @return {?}
*/
static forFeature(options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options && options.elementConfigs,
multi: true
}
]
};
}
}
LazyElementsModule.decorators = [
{ type: NgModule, args: [{
declarations: [LazyElementDirective],
declarations: [LazyElementDirective, LazyElementDynamicDirective],
imports: [CommonModule],
exports: [LazyElementDirective]
exports: [LazyElementDirective, LazyElementDynamicDirective],
providers: []
},] }
];
LazyElementsModule.ctorParameters = () => [
{ type: LazyElementsLoaderService },
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_CONFIGS,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_GUARD,] }] }
];
export { LazyElementsModule, LazyElementDirective as ɵa, LazyElementsLoaderService as ɵb };
//# sourceMappingURL=angular-extensions-elements.js.map
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { LAZY_ELEMENTS_REGISTRY, createLazyElementRootGuard, LazyElementsModule, LazyElementDynamicDirective as ɵg, LazyElementDirective as ɵd, LazyElementsLoaderService as ɵf, LAZY_ELEMENT_CONFIGS as ɵa, LAZY_ELEMENT_ROOT_GUARD as ɵc, LAZY_ELEMENT_ROOT_OPTIONS as ɵb };
//# sourceMappingURL=angular-extensions-elements.js.map

@@ -1,3 +0,3 @@

import { Injectable, ɵɵdefineInjectable, Directive, ViewContainerRef, TemplateRef, Input, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { InjectionToken, Injectable, Optional, Inject, Directive, Input, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef, NgModule, ANALYZE_FOR_ENTRY_COMPONENTS, SkipSelf, defineInjectable, inject } from '@angular/core';

@@ -9,10 +9,109 @@ /**

/** @type {?} */
var LAZY_ELEMENT_CONFIGS = new InjectionToken('LAZY_ELEMENT_CONFIGS');
/** @type {?} */
var LAZY_ELEMENT_ROOT_OPTIONS = new InjectionToken('LAZY_ELEMENT_ROOT_OPTIONS');
/** @type {?} */
var LAZY_ELEMENT_ROOT_GUARD = new InjectionToken('LAZY_ELEMENT_ROOT_GUARD');
/** @type {?} */
var LAZY_ELEMENTS_REGISTRY = new InjectionToken('Lazu elements registry', {
providedIn: 'root',
factory: (/**
* @return {?}
*/
function () { return new Map(); })
});
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
var LOG_PREFIX = '@angular-extensions/elements';
var LazyElementsLoaderService = /** @class */ (function () {
function LazyElementsLoaderService() {
this.registry = new Map();
function LazyElementsLoaderService(registry, options) {
this.registry = registry;
this.options = options;
this.configs = [];
if (!options) {
this.options = {};
}
}
/**
* @param {?} newConfigs
* @return {?}
*/
LazyElementsLoaderService.prototype.addConfigs = /**
* @param {?} newConfigs
* @return {?}
*/
function (newConfigs) {
var _this = this;
newConfigs.forEach((/**
* @param {?} newConfig
* @return {?}
*/
function (newConfig) {
/** @type {?} */
var existingConfig = _this.getElementConfig(newConfig.tag);
if (existingConfig) {
console.warn(LOG_PREFIX + " - ElementConfig for tag '" + newConfig.tag + "' was previously added, it will not be added multiple times, continue...");
}
else {
_this.configs.push(newConfig);
/** @type {?} */
var shouldPreload = newConfig.preload !== undefined
? newConfig.preload
: _this.options.preload;
if (shouldPreload) {
_this.loadElement(newConfig.url, newConfig.tag, newConfig.isModule);
}
}
}));
};
/**
* @param {?} tag
* @return {?}
*/
LazyElementsLoaderService.prototype.getElementConfig = /**
* @param {?} tag
* @return {?}
*/
function (tag) {
return this.configs.find((/**
* @param {?} config
* @return {?}
*/
function (config) { return config.tag === tag; }));
};
/**
* @param {?=} tags
* @return {?}
*/
LazyElementsLoaderService.prototype.preload = /**
* @param {?=} tags
* @return {?}
*/
function (tags) {
var _this = this;
/** @type {?} */
var configs = this.configs;
if (tags) {
configs = this.configs.filter((/**
* @param {?} config
* @return {?}
*/
function (config) { return tags.includes(config.tag); }));
}
configs.forEach((/**
* @param {?} config
* @return {?}
*/
function (config) {
return _this.loadElement(config.url, config.tag, config.isModule);
}));
};
/**
* @param {?} url
* @param {?} tag
* @param {?=} isModule
* @return {?}

@@ -23,8 +122,20 @@ */

* @param {?} tag
* @param {?=} isModule
* @return {?}
*/
function (url, tag) {
function (url, tag, isModule) {
/** @type {?} */
var config = this.getElementConfig(tag);
if (!url) {
throw new Error(LOG_PREFIX + " - url for <" + tag + "> not found");
if (!config) {
throw new Error(LOG_PREFIX + " - url for <" + tag + "> not found");
}
url = config.url;
}
if (isModule === undefined) {
isModule =
config && config.isModule !== undefined
? config.isModule
: this.options.isModule;
}
if (!tag) {

@@ -38,4 +149,8 @@ throw new Error(LOG_PREFIX + " - tag for '" + url + "' not found, the *axLazyElement has to be used on HTML element");

var script = (/** @type {?} */ (document.createElement('script')));
if (isModule) {
script.type = 'module';
}
script.src = url;
script.onload = notifier;
script.onload = notifier.resolve;
script.onerror = notifier.reject;
document.body.appendChild(script);

@@ -60,5 +175,6 @@ }

* @param {?} resolve
* @param {?} reject
* @return {?}
*/
function (resolve) { return (notifier = resolve); })));
function (resolve, reject) { return (notifier = { resolve: resolve, reject: reject }); })));
return notifier;

@@ -97,5 +213,7 @@ };

];
/** @nocollapse */
LazyElementsLoaderService.ctorParameters = function () { return []; };
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = ɵɵdefineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(); }, token: LazyElementsLoaderService, providedIn: "root" });
LazyElementsLoaderService.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [LAZY_ELEMENTS_REGISTRY,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_OPTIONS,] }] }
]; };
/** @nocollapse */ LazyElementsLoaderService.ngInjectableDef = defineInjectable({ factory: function LazyElementsLoaderService_Factory() { return new LazyElementsLoaderService(inject(LAZY_ELEMENTS_REGISTRY), inject(LAZY_ELEMENT_ROOT_OPTIONS, 8)); }, token: LazyElementsLoaderService, providedIn: "root" });
return LazyElementsLoaderService;

@@ -108,7 +226,11 @@ }());

*/
/** @type {?} */
var LOG_PREFIX$1 = '@angular-extensions/elements';
var LazyElementDirective = /** @class */ (function () {
function LazyElementDirective(vcr, template, elementsLoaderService) {
function LazyElementDirective(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}

@@ -124,7 +246,25 @@ /**

/** @type {?} */
var elementTag = ((/** @type {?} */ (this.template)))._def.element.template.nodes[0].element.name;
var tpl = (/** @type {?} */ (this.template));
/** @type {?} */
var elementTag = tpl._declarationTContainer
? tpl._declarationTContainer.tagName
: tpl._def.element.template.nodes[0].element.name;
/** @type {?} */
var elementConfig = this.elementsLoaderService.getElementConfig(elementTag) ||
((/** @type {?} */ ({})));
/** @type {?} */
var options = this.elementsLoaderService.options;
/** @type {?} */
var loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
this.elementsLoaderService.loadElement(this.url, elementTag).then((/**
else if (loadingComponent) {
/** @type {?} */
var factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, elementTag, this.isModule)
.then((/**
* @return {?}

@@ -135,2 +275,24 @@ */

_this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
}))
.catch((/**
* @return {?}
*/
function () {
_this.vcr.clear();
/** @type {?} */
var errorComponent = elementConfig.errorComponent || options.errorComponent;
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
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");
}
}));

@@ -143,11 +305,14 @@ };

];
/** @nocollapse */
LazyElementDirective.ctorParameters = function () { return [
{ type: ViewContainerRef },
{ type: TemplateRef },
{ type: LazyElementsLoaderService }
{ type: LazyElementsLoaderService },
{ type: ComponentFactoryResolver },
{ type: ChangeDetectorRef }
]; };
LazyElementDirective.propDecorators = {
url: [{ type: Input, args: ['axLazyElement',] }],
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoading',] }]
loadingTemplateRef: [{ type: Input, args: ['axLazyElementLoadingTemplate',] }],
errorTemplateRef: [{ type: Input, args: ['axLazyElementErrorTemplate',] }],
isModule: [{ type: Input, args: ['axLazyElementModule',] }]
};

@@ -161,16 +326,210 @@ return LazyElementDirective;

*/
/** @type {?} */
var LOG_PREFIX$2 = '@angular-extensions/elements';
var LazyElementDynamicDirective = /** @class */ (function () {
function LazyElementDynamicDirective(vcr, template, elementsLoaderService, cfr, cdr) {
this.vcr = vcr;
this.template = template;
this.elementsLoaderService = elementsLoaderService;
this.cfr = cfr;
this.cdr = cdr;
}
/**
* @return {?}
*/
LazyElementDynamicDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
if (!this.tag || this.tag.length === 0 || !this.tag.includes('-')) {
throw new Error(LOG_PREFIX$2 + " - Valid tag has to be specified when using *axLazyElementDynamic directive (use *axLazyElementDynamic=\"'some-tag'\"), got: \"" + this.tag + "\"");
}
/** @type {?} */
var elementConfig = this.elementsLoaderService.getElementConfig(this.tag) ||
((/** @type {?} */ ({})));
/** @type {?} */
var options = this.elementsLoaderService.options;
/** @type {?} */
var loadingComponent = elementConfig.loadingComponent || options.loadingComponent;
if (this.loadingTemplateRef) {
this.vcr.createEmbeddedView(this.loadingTemplateRef);
}
else if (loadingComponent) {
/** @type {?} */
var factory = this.cfr.resolveComponentFactory(loadingComponent);
this.vcr.createComponent(factory);
}
this.elementsLoaderService
.loadElement(this.url, this.tag, this.isModule)
.then((/**
* @return {?}
*/
function () {
if (((/** @type {?} */ (_this.template)))._declarationTContainer) {
// (this.template as any)._declarationTContainer.tagName = this.tag;
throw new Error('The *axLazyElementDynamic directive is currently does NOT support Angular Ivy, please use standard *axLazyElement directive instead!');
}
else {
((/** @type {?} */ (_this
.template)))._def.element.template.nodes[0].element.name = _this.tag;
}
_this.vcr.clear();
_this.vcr.createEmbeddedView(_this.template);
_this.cdr.markForCheck();
}))
.catch((/**
* @param {?} error
* @return {?}
*/
function (error) {
/** @type {?} */
var errorComponent = elementConfig.errorComponent || options.errorComponent;
_this.vcr.clear();
if (_this.errorTemplateRef) {
_this.vcr.createEmbeddedView(_this.errorTemplateRef);
_this.cdr.markForCheck();
}
else if (errorComponent) {
/** @type {?} */
var factory = _this.cfr.resolveComponentFactory(errorComponent);
_this.vcr.createComponent(factory);
_this.cdr.markForCheck();
}
else {
console.error(LOG_PREFIX$2 + " - 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.decorators = [
{ type: Directive, args: [{
selector: '[axLazyElementDynamic]'
},] }
];
LazyElementDynamicDirective.ctorParameters = function () { return [
{ type: ViewContainerRef },
{ type: TemplateRef },
{ type: LazyElementsLoaderService },
{ type: ComponentFactoryResolver },
{ type: ChangeDetectorRef }
]; };
LazyElementDynamicDirective.propDecorators = {
tag: [{ type: Input, args: ['axLazyElementDynamic',] }],
url: [{ type: Input, args: ['axLazyElementDynamicUrl',] }],
loadingTemplateRef: [{ type: Input, args: ['axLazyElementDynamicLoadingTemplate',] }],
errorTemplateRef: [{ type: Input, args: ['axLazyElementDynamicErrorTemplate',] }],
isModule: [{ type: Input, args: ['axLazyElementDynamicModule',] }]
};
return LazyElementDynamicDirective;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @param {?} options
* @return {?}
*/
function createLazyElementRootGuard(options) {
if (options) {
throw new TypeError("LazyElementsModule.forRoot() called twice. Feature modules should use LazyElementsModule.forFeature() instead.");
}
return 'guarded';
}
var LazyElementsModule = /** @class */ (function () {
function LazyElementsModule() {
function LazyElementsModule(lazyElementsLoaderService, elementConfigsMultiProvider, guard) {
if (elementConfigsMultiProvider && elementConfigsMultiProvider.length) {
/** @type {?} */
var lastAddedConfigs = elementConfigsMultiProvider[elementConfigsMultiProvider.length - 1];
lazyElementsLoaderService.addConfigs(lastAddedConfigs);
}
}
/**
* @param {?} options
* @return {?}
*/
LazyElementsModule.forRoot = /**
* @param {?} options
* @return {?}
*/
function (options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_OPTIONS,
useValue: options.rootOptions ? options.rootOptions : {}
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options,
multi: true
},
{
provide: LAZY_ELEMENT_ROOT_GUARD,
useFactory: createLazyElementRootGuard,
deps: [[LAZY_ELEMENT_CONFIGS, new Optional(), new SkipSelf()]]
}
]
};
};
/**
* @param {?} options
* @return {?}
*/
LazyElementsModule.forFeature = /**
* @param {?} options
* @return {?}
*/
function (options) {
return {
ngModule: LazyElementsModule,
providers: [
{
provide: LAZY_ELEMENT_CONFIGS,
useValue: options && options.elementConfigs ? options.elementConfigs : [],
multi: true
},
{
provide: ANALYZE_FOR_ENTRY_COMPONENTS,
useValue: options && options.elementConfigs,
multi: true
}
]
};
};
LazyElementsModule.decorators = [
{ type: NgModule, args: [{
declarations: [LazyElementDirective],
declarations: [LazyElementDirective, LazyElementDynamicDirective],
imports: [CommonModule],
exports: [LazyElementDirective]
exports: [LazyElementDirective, LazyElementDynamicDirective],
providers: []
},] }
];
LazyElementsModule.ctorParameters = function () { return [
{ type: LazyElementsLoaderService },
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_CONFIGS,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LAZY_ELEMENT_ROOT_GUARD,] }] }
]; };
return LazyElementsModule;
}());
export { LazyElementsModule, LazyElementDirective as ɵa, LazyElementsLoaderService as ɵb };
//# sourceMappingURL=angular-extensions-elements.js.map
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { LAZY_ELEMENTS_REGISTRY, createLazyElementRootGuard, LazyElementsModule, LazyElementDynamicDirective as ɵg, LazyElementDirective as ɵd, LazyElementsLoaderService as ɵf, LAZY_ELEMENT_CONFIGS as ɵa, LAZY_ELEMENT_ROOT_GUARD as ɵc, LAZY_ELEMENT_ROOT_OPTIONS as ɵb };
//# sourceMappingURL=angular-extensions-elements.js.map

@@ -1,2 +0,2 @@

import { OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
import { OnInit, TemplateRef, ViewContainerRef, ComponentFactoryResolver, ChangeDetectorRef } from '@angular/core';
import { LazyElementsLoaderService } from '../lazy-elements-loader.service';

@@ -7,6 +7,10 @@ export declare class LazyElementDirective implements OnInit {

private elementsLoaderService;
private cfr;
private cdr;
url: string;
loadingTemplateRef: TemplateRef<any>;
constructor(vcr: ViewContainerRef, template: TemplateRef<any>, elementsLoaderService: LazyElementsLoaderService);
errorTemplateRef: TemplateRef<any>;
isModule: boolean | undefined;
constructor(vcr: ViewContainerRef, template: TemplateRef<any>, elementsLoaderService: LazyElementsLoaderService, cfr: ComponentFactoryResolver, cdr: ChangeDetectorRef);
ngOnInit(): void;
}

@@ -0,8 +1,24 @@

import { Type } from '@angular/core';
import { LazyElementRootOptions } from './lazy-elements.module';
import { LazyElementsRegistry } from './lazy-elements.tokens';
export interface ElementConfig {
tag: string;
url: string;
isModule?: boolean;
loadingComponent?: Type<any>;
errorComponent?: Type<any>;
preload?: boolean;
}
export declare class LazyElementsLoaderService {
registry: Map<string, Promise<void>>;
constructor();
loadElement(url: string, tag: string): Promise<void>;
private addElement;
private hasElement;
private stripUrlProtocol;
private registry;
options: LazyElementRootOptions;
configs: ElementConfig[];
constructor(registry: LazyElementsRegistry, options: LazyElementRootOptions);
addConfigs(newConfigs: ElementConfig[]): void;
getElementConfig(tag: string): ElementConfig;
preload(tags?: string[]): void;
loadElement(url: string, tag: string, isModule?: boolean): Promise<void>;
private addElement(url);
private hasElement(url);
private stripUrlProtocol(url);
}

@@ -0,2 +1,23 @@

import { ModuleWithProviders, Type } from '@angular/core';
import { ElementConfig, LazyElementsLoaderService } from './lazy-elements-loader.service';
import { LAZY_ELEMENTS_REGISTRY, LazyElementsRegistry } from './lazy-elements.tokens';
export { LAZY_ELEMENTS_REGISTRY, LazyElementsRegistry };
export declare function createLazyElementRootGuard(options: LazyElementModuleOptions): string;
export declare class LazyElementsModule {
static forRoot(options: LazyElementModuleRootOptions): ModuleWithProviders;
static forFeature(options: LazyElementModuleOptions): ModuleWithProviders;
constructor(lazyElementsLoaderService: LazyElementsLoaderService, elementConfigsMultiProvider: ElementConfig[][], guard: any);
}
export interface LazyElementModuleOptions {
elementConfigs?: ElementConfig[];
}
export interface LazyElementModuleRootOptions {
elementConfigs?: ElementConfig[];
rootOptions?: LazyElementRootOptions;
}
export interface LazyElementRootOptions {
loadingComponent?: Type<any>;
errorComponent?: Type<any>;
isModule?: boolean;
preload?: boolean;
}
{
"name": "@angular-extensions/elements",
"version": "0.3.7",
"version": "6.1.0",
"peerDependencies": {
"@angular/common": ">6.0.0",
"@angular/core": ">6.0.0"
"@angular/common": "^8.0.0",
"@angular/core": "^8.0.0"
},

@@ -11,2 +11,22 @@ "publishConfig": {

},
"keywords": [
"angular",
"elements",
"web componentst",
"custom elements",
"lazy loading",
"microfrontends",
"components",
"web component"
],
"author": "Tomas Trajan <@tomastrajan>",
"license": "MIT",
"homepage": "https://github.com/angular-extensions/elements#readme",
"repository": {
"type": "git",
"url": "git+https://github.com/angular-extensions/elements.git"
},
"bugs": {
"url": "https://github.com/angular-extensions/elements/issues"
},
"main": "bundles/angular-extensions-elements.umd.js",

@@ -13,0 +33,0 @@ "module": "fesm5/angular-extensions-elements.js",

export * from './lib/lazy-elements/lazy-elements.module';

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

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