UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

263 lines 33.9 kB
import { __decorate, __metadata, __values } from "tslib"; import { Directive, EmbeddedViewRef, Input, OnChanges, ChangeDetectorRef, SimpleChange, SimpleChanges, TemplateRef, ViewContainerRef, NgModule, NgZone, Output, EventEmitter } from '@angular/core'; import { CommonModule } from '@angular/common'; /** * @hidden */ var IgxTemplateOutletDirective = /** @class */ (function () { function IgxTemplateOutletDirective(_viewContainerRef, _zone, cdr) { this._viewContainerRef = _viewContainerRef; this._zone = _zone; this.cdr = cdr; /** * The embedded views cache. Collection is key-value paired. * Key is the template id, value is the embedded view for the related template. */ this._embeddedViewsMap = new Map(); this.onViewCreated = new EventEmitter(); this.onViewMoved = new EventEmitter(); this.onCachedViewLoaded = new EventEmitter(); this.onBeforeViewDetach = new EventEmitter(); } IgxTemplateOutletDirective.prototype.ngOnChanges = function (changes) { var actionType = this._getActionType(changes); switch (actionType) { case TemplateOutletAction.CreateView: this._recreateView(); break; case TemplateOutletAction.MoveView: this._moveView(); break; case TemplateOutletAction.UseCachedView: this._useCachedView(); break; case TemplateOutletAction.UpdateViewContext: this._updateExistingContext(this.igxTemplateOutletContext); break; } }; IgxTemplateOutletDirective.prototype.cleanCache = function () { this._embeddedViewsMap.forEach(function (item) { if (!item.destroyed) { item.destroy(); } }); this._embeddedViewsMap.clear(); }; IgxTemplateOutletDirective.prototype.cleanView = function (tmplID) { var embView = this._embeddedViewsMap.get(tmplID); if (embView) { embView.destroy(); this._embeddedViewsMap.delete(tmplID); } }; IgxTemplateOutletDirective.prototype._recreateView = function () { var prevIndex = this._viewRef ? this._viewContainerRef.indexOf(this._viewRef) : -1; // detach old and create new if (prevIndex !== -1) { this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext }); this._viewContainerRef.detach(prevIndex); } if (this.igxTemplateOutlet) { this._viewRef = this._viewContainerRef.createEmbeddedView(this.igxTemplateOutlet, this.igxTemplateOutletContext); this.onViewCreated.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext }); var tmplId = this.igxTemplateOutletContext['templateID']; if (tmplId) { // if context contains a template id, check if we have a view for that template already stored in the cache // if not create a copy and add it to the cache in detached state. // Note: Views in detached state do not appear in the DOM, however they remain stored in memory. var res = this._embeddedViewsMap.get(this.igxTemplateOutletContext['templateID']); if (!res) { this._embeddedViewsMap.set(this.igxTemplateOutletContext['templateID'], this._viewRef); } } } }; IgxTemplateOutletDirective.prototype._moveView = function () { // using external view and inserting it in current view. var view = this.igxTemplateOutletContext['moveView']; var owner = this.igxTemplateOutletContext['owner']; if (view !== this._viewRef) { if (owner._viewContainerRef.indexOf(view) !== -1) { // detach in case view it is attached somewhere else at the moment. this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext }); owner._viewContainerRef.detach(owner._viewContainerRef.indexOf(view)); } if (this._viewRef && this._viewContainerRef.indexOf(this._viewRef) !== -1) { this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext }); this._viewContainerRef.detach(this._viewContainerRef.indexOf(this._viewRef)); } this._viewRef = view; this._viewContainerRef.insert(view, 0); this._updateExistingContext(this.igxTemplateOutletContext); this.onViewMoved.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext }); } }; IgxTemplateOutletDirective.prototype._useCachedView = function () { // use view for specific template cached in the current template outlet var tmplID = this.igxTemplateOutletContext['templateID']; var cachedView = tmplID ? this._embeddedViewsMap.get(tmplID) : null; // if view exists, but template has been changed and there is a view in the cache with the related template // then detach old view and insert the stored one with the matching template // after that update its context. if (this._viewContainerRef.length > 0) { this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext }); this._viewContainerRef.detach(this._viewContainerRef.indexOf(this._viewRef)); } this._viewRef = cachedView; var oldContext = this._cloneContext(cachedView.context); this._viewContainerRef.insert(this._viewRef, 0); this._updateExistingContext(this.igxTemplateOutletContext); this.onCachedViewLoaded.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext, oldContext: oldContext }); }; IgxTemplateOutletDirective.prototype._shouldRecreateView = function (changes) { var ctxChange = changes['igxTemplateOutletContext']; return !!changes['igxTemplateOutlet'] || (ctxChange && this._hasContextShapeChanged(ctxChange)); }; IgxTemplateOutletDirective.prototype._hasContextShapeChanged = function (ctxChange) { var e_1, _a; var prevCtxKeys = Object.keys(ctxChange.previousValue || {}); var currCtxKeys = Object.keys(ctxChange.currentValue || {}); if (prevCtxKeys.length === currCtxKeys.length) { try { for (var currCtxKeys_1 = __values(currCtxKeys), currCtxKeys_1_1 = currCtxKeys_1.next(); !currCtxKeys_1_1.done; currCtxKeys_1_1 = currCtxKeys_1.next()) { var propName = currCtxKeys_1_1.value; if (prevCtxKeys.indexOf(propName) === -1) { return true; } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (currCtxKeys_1_1 && !currCtxKeys_1_1.done && (_a = currCtxKeys_1.return)) _a.call(currCtxKeys_1); } finally { if (e_1) throw e_1.error; } } return false; } else { return true; } }; IgxTemplateOutletDirective.prototype._updateExistingContext = function (ctx) { var e_2, _a; try { for (var _b = __values(Object.keys(ctx)), _c = _b.next(); !_c.done; _c = _b.next()) { var propName = _c.value; this._viewRef.context[propName] = this.igxTemplateOutletContext[propName]; } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_2) throw e_2.error; } } }; IgxTemplateOutletDirective.prototype._cloneContext = function (ctx) { var e_3, _a; var clone = {}; try { for (var _b = __values(Object.keys(ctx)), _c = _b.next(); !_c.done; _c = _b.next()) { var propName = _c.value; clone[propName] = ctx[propName]; } } catch (e_3_1) { e_3 = { error: e_3_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_3) throw e_3.error; } } return clone; }; IgxTemplateOutletDirective.prototype._getActionType = function (changes) { var movedView = this.igxTemplateOutletContext['moveView']; var tmplID = this.igxTemplateOutletContext['templateID']; var cachedView = tmplID ? this._embeddedViewsMap.get(tmplID) : null; var shouldRecreate = this._shouldRecreateView(changes); if (movedView) { // view is moved from external source return TemplateOutletAction.MoveView; } else if (shouldRecreate && cachedView) { // should recreate (template or context change) and there is a matching template in cache return TemplateOutletAction.UseCachedView; } else if (!this._viewRef || shouldRecreate) { // no view or should recreate return TemplateOutletAction.CreateView; } else if (this.igxTemplateOutletContext) { // has context, update context return TemplateOutletAction.UpdateViewContext; } }; IgxTemplateOutletDirective.ctorParameters = function () { return [ { type: ViewContainerRef }, { type: NgZone }, { type: ChangeDetectorRef } ]; }; __decorate([ Input(), __metadata("design:type", Object) ], IgxTemplateOutletDirective.prototype, "igxTemplateOutletContext", void 0); __decorate([ Input(), __metadata("design:type", TemplateRef) ], IgxTemplateOutletDirective.prototype, "igxTemplateOutlet", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxTemplateOutletDirective.prototype, "onViewCreated", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxTemplateOutletDirective.prototype, "onViewMoved", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxTemplateOutletDirective.prototype, "onCachedViewLoaded", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxTemplateOutletDirective.prototype, "onBeforeViewDetach", void 0); IgxTemplateOutletDirective = __decorate([ Directive({ selector: '[igxTemplateOutlet]' }), __metadata("design:paramtypes", [ViewContainerRef, NgZone, ChangeDetectorRef]) ], IgxTemplateOutletDirective); return IgxTemplateOutletDirective; }()); export { IgxTemplateOutletDirective }; var TemplateOutletAction; (function (TemplateOutletAction) { TemplateOutletAction[TemplateOutletAction["CreateView"] = 0] = "CreateView"; TemplateOutletAction[TemplateOutletAction["MoveView"] = 1] = "MoveView"; TemplateOutletAction[TemplateOutletAction["UseCachedView"] = 2] = "UseCachedView"; TemplateOutletAction[TemplateOutletAction["UpdateViewContext"] = 3] = "UpdateViewContext"; })(TemplateOutletAction || (TemplateOutletAction = {})); /** * @hidden */ var IgxTemplateOutletModule = /** @class */ (function () { function IgxTemplateOutletModule() { } IgxTemplateOutletModule = __decorate([ NgModule({ declarations: [IgxTemplateOutletDirective], entryComponents: [], exports: [IgxTemplateOutletDirective], imports: [CommonModule] }) ], IgxTemplateOutletModule); return IgxTemplateOutletModule; }()); export { IgxTemplateOutletModule }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template_outlet.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/directives/template-outlet/template_outlet.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive, EmbeddedViewRef, Input, OnChanges, ChangeDetectorRef,\n    SimpleChange, SimpleChanges, TemplateRef, ViewContainerRef, NgModule, NgZone, Output, EventEmitter\n} from '@angular/core';\n\nimport { CommonModule } from '@angular/common';\nimport { IBaseEventArgs } from '../../core/utils';\n\n/**\n * @hidden\n */\n@Directive({ selector: '[igxTemplateOutlet]' })\nexport class IgxTemplateOutletDirective implements OnChanges {\n    private _viewRef !: EmbeddedViewRef<any>;\n\n    /**\n    * The embedded views cache. Collection is key-value paired.\n    * Key is the template id, value is the embedded view for the related template.\n    */\n    private _embeddedViewsMap: Map<string, EmbeddedViewRef<any>> = new Map();\n\n    @Input() public igxTemplateOutletContext !: Object;\n\n    @Input() public igxTemplateOutlet !: TemplateRef<any>;\n\n    @Output()\n    public onViewCreated = new EventEmitter<IViewChangeEventArgs>();\n\n    @Output()\n    public onViewMoved = new EventEmitter<IViewChangeEventArgs>();\n\n    @Output()\n    public onCachedViewLoaded = new EventEmitter<ICachedViewLoadedEventArgs>();\n\n    @Output()\n    public onBeforeViewDetach = new EventEmitter<IViewChangeEventArgs>();\n\n    constructor(public _viewContainerRef: ViewContainerRef, private _zone: NgZone, public cdr: ChangeDetectorRef) {\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        const actionType: TemplateOutletAction = this._getActionType(changes);\n        switch (actionType) {\n            case TemplateOutletAction.CreateView: this._recreateView(); break;\n            case TemplateOutletAction.MoveView: this._moveView(); break;\n            case TemplateOutletAction.UseCachedView: this._useCachedView(); break;\n            case TemplateOutletAction.UpdateViewContext: this._updateExistingContext(this.igxTemplateOutletContext); break;\n        }\n    }\n\n    public cleanCache() {\n        this._embeddedViewsMap.forEach((item) => {\n            if (!item.destroyed) {\n                item.destroy();\n            }\n        });\n        this._embeddedViewsMap.clear();\n    }\n\n    public cleanView(tmplID) {\n        const embView = this._embeddedViewsMap.get(tmplID);\n        if (embView) {\n            embView.destroy();\n            this._embeddedViewsMap.delete(tmplID);\n        }\n    }\n\n    private _recreateView() {\n        const prevIndex = this._viewRef ? this._viewContainerRef.indexOf(this._viewRef) : -1;\n        // detach old and create new\n        if (prevIndex !== -1) {\n            this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext });\n            this._viewContainerRef.detach(prevIndex);\n        }\n        if (this.igxTemplateOutlet) {\n            this._viewRef = this._viewContainerRef.createEmbeddedView(\n                this.igxTemplateOutlet, this.igxTemplateOutletContext);\n            this.onViewCreated.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext });\n            const tmplId = this.igxTemplateOutletContext['templateID'];\n            if (tmplId) {\n                // if context contains a template id, check if we have a view for that template already stored in the cache\n                // if not create a copy and add it to the cache in detached state.\n                // Note: Views in detached state do not appear in the DOM, however they remain stored in memory.\n                const res = this._embeddedViewsMap.get(this.igxTemplateOutletContext['templateID']);\n                if (!res) {\n                    this._embeddedViewsMap.set(this.igxTemplateOutletContext['templateID'], this._viewRef);\n                }\n            }\n        }\n    }\n\n    private _moveView() {\n        // using external view and inserting it in current view.\n        const view = this.igxTemplateOutletContext['moveView'];\n        const owner = this.igxTemplateOutletContext['owner'];\n        if (view !== this._viewRef) {\n            if (owner._viewContainerRef.indexOf(view) !== -1) {\n                // detach in case view it is attached somewhere else at the moment.\n                this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext });\n                owner._viewContainerRef.detach(owner._viewContainerRef.indexOf(view));\n            }\n            if (this._viewRef && this._viewContainerRef.indexOf(this._viewRef) !== -1) {\n                this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext });\n                this._viewContainerRef.detach(this._viewContainerRef.indexOf(this._viewRef));\n            }\n            this._viewRef = view;\n            this._viewContainerRef.insert(view, 0);\n            this._updateExistingContext(this.igxTemplateOutletContext);\n            this.onViewMoved.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext });\n        }\n    }\n    private _useCachedView() {\n        // use view for specific template cached in the current template outlet\n        const tmplID = this.igxTemplateOutletContext['templateID'];\n        const cachedView = tmplID ?\n            this._embeddedViewsMap.get(tmplID) :\n            null;\n        // if view exists, but template has been changed and there is a view in the cache with the related template\n        // then detach old view and insert the stored one with the matching template\n        // after that update its context.\n        if (this._viewContainerRef.length > 0) {\n            this.onBeforeViewDetach.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext });\n            this._viewContainerRef.detach(this._viewContainerRef.indexOf(this._viewRef));\n        }\n\n        this._viewRef = cachedView;\n        const oldContext = this._cloneContext(cachedView.context);\n        this._viewContainerRef.insert(this._viewRef, 0);\n        this._updateExistingContext(this.igxTemplateOutletContext);\n        this.onCachedViewLoaded.emit({ owner: this, view: this._viewRef, context: this.igxTemplateOutletContext, oldContext });\n    }\n\n    private _shouldRecreateView(changes: SimpleChanges): boolean {\n        const ctxChange = changes['igxTemplateOutletContext'];\n        return !!changes['igxTemplateOutlet'] || (ctxChange && this._hasContextShapeChanged(ctxChange));\n    }\n\n    private _hasContextShapeChanged(ctxChange: SimpleChange): boolean {\n        const prevCtxKeys = Object.keys(ctxChange.previousValue || {});\n        const currCtxKeys = Object.keys(ctxChange.currentValue || {});\n\n        if (prevCtxKeys.length === currCtxKeys.length) {\n            for (const propName of currCtxKeys) {\n                if (prevCtxKeys.indexOf(propName) === -1) {\n                    return true;\n                }\n            }\n            return false;\n        } else {\n            return true;\n        }\n    }\n\n    private _updateExistingContext(ctx: Object): void {\n        for (const propName of Object.keys(ctx)) {\n            (<any>this._viewRef.context)[propName] = (<any>this.igxTemplateOutletContext)[propName];\n        }\n    }\n\n    private _cloneContext(ctx: any): any {\n        const clone = {};\n        for (const propName of Object.keys(ctx)) {\n            clone[propName] = ctx[propName];\n        }\n        return clone;\n    }\n\n    private _getActionType(changes: SimpleChanges) {\n        const movedView = this.igxTemplateOutletContext['moveView'];\n        const tmplID = this.igxTemplateOutletContext['templateID'];\n        const cachedView = tmplID ?\n            this._embeddedViewsMap.get(tmplID) :\n            null;\n        const shouldRecreate = this._shouldRecreateView(changes);\n        if (movedView) {\n            // view is moved from external source\n            return TemplateOutletAction.MoveView;\n        } else if (shouldRecreate && cachedView) {\n            // should recreate (template or context change) and there is a matching template in cache\n            return TemplateOutletAction.UseCachedView;\n        } else if (!this._viewRef || shouldRecreate) {\n            // no view or should recreate\n            return TemplateOutletAction.CreateView;\n        } else if (this.igxTemplateOutletContext) {\n            // has context, update context\n            return TemplateOutletAction.UpdateViewContext;\n        }\n    }\n}\nenum TemplateOutletAction {\n    CreateView,\n    MoveView,\n    UseCachedView,\n    UpdateViewContext\n}\n\nexport interface IViewChangeEventArgs extends IBaseEventArgs {\n    owner: IgxTemplateOutletDirective;\n    view: EmbeddedViewRef<any>;\n    context: any;\n}\n\nexport interface ICachedViewLoadedEventArgs extends IViewChangeEventArgs {\n    oldContext: any;\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxTemplateOutletDirective],\n    entryComponents: [],\n    exports: [IgxTemplateOutletDirective],\n    imports: [CommonModule]\n})\n\nexport class IgxTemplateOutletModule {\n}\n"]}