Socket
Socket
Sign inDemoInstall

ngx-ntk-smart-module

Package Overview
Dependencies
5
Maintainers
1
Versions
12
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.0.3 to 1.1.2

esm2015/lib/modal/ntk-smart-modal-stack.service.js

4

bundles/ngx-ntk-smart-module.umd.min.js

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

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-ntk-smart-module",["exports","@angular/core","@angular/common"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["ngx-ntk-smart-module"]={},t.ng.core,t.ng.common)}(this,(function(t,e,i){"use strict";
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-ntk-smart-module",["exports","@angular/core","@angular/common"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["ngx-ntk-smart-module"]={},t.ng.core,t.ng.common)}(this,(function(t,e,n){"use strict";
/*! *****************************************************************************

@@ -15,3 +15,3 @@ Copyright (c) Microsoft Corporation.

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */Object.create;function o(t,e){var i="function"==typeof Symbol&&t[Symbol.iterator];if(!i)return t;var o,n,s=i.call(t),r=[];try{for(;(void 0===e||e-- >0)&&!(o=s.next()).done;)r.push(o.value)}catch(t){n={error:t}}finally{try{o&&!o.done&&(i=s.return)&&i.call(s)}finally{if(n)throw n.error}}return r}function n(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(o(arguments[e]));return t}Object.create;var s=function(){function t(){this.modalStack=[]}return t.prototype.addModal=function(t,e){if(e){var i=this.modalStack.findIndex((function(e){return e.id===t.id}));i>-1?this.modalStack[i].modal=t.modal:this.modalStack.push(t)}else this.modalStack.push(t)},t.prototype.getModal=function(t){if(!this.modalStack||0===this.modalStack.length)return null;var e=this.modalStack.filter((function(e){return e.id===t}))[0];return e?e.modal:null},t.prototype.get=function(t){return this.getModal(t)},t.prototype.open=function(t,e){void 0===e&&(e=!1);var i=this.modalStack.find((function(e){return e.id===t}));if(!i)throw new Error("Modal not found");i.modal.open(e)},t.prototype.close=function(t){var e=this.modalStack.find((function(e){return e.id===t}));if(!e)throw new Error("Modal not found");e.modal.close()},t.prototype.toggle=function(t,e){void 0===e&&(e=!1);var i=this.modalStack.find((function(e){return e.id===t}));if(!i)throw new Error("Modal not found");i.modal.toggle(e)},t.prototype.getModalStack=function(){return this.modalStack},t.prototype.getOpenedModals=function(){var t=[];return this.modalStack.forEach((function(e){e.modal.visible&&t.push(e)})),t},t.prototype.getHigherIndex=function(){var t=[1041];return this.getModalStack().forEach((function(e){t.push(e.modal.layerPosition)})),Math.max.apply(Math,n(t))+1},t.prototype.getModalStackCount=function(){return this.modalStack.length},t.prototype.removeModal=function(t){var e=this.modalStack.findIndex((function(e){return e.id===t}));e>-1&&this.modalStack.splice(e,1)},t.prototype.setModalData=function(t,e,i){return!!this.modalStack.find((function(t){return t.id===e}))&&(this.getModal(e).setData(t,i),!0)},t.prototype.getModalData=function(t){return this.getModal(t).getData()},t.prototype.resetModalData=function(t){if(this.modalStack.find((function(e){return e.id===t}))){var e=this.getModal(t).getData();return this.getModal(t).removeData(),e}return!1},t.prototype.closeLatestModal=function(){var t=this;clearTimeout(this.debouncer),this.debouncer=setTimeout((function(){var e;return t.getOpenedModals().forEach((function(t){t.modal.layerPosition>(e?e.modal.layerPosition:0)&&(e=t)})),!!e&&e.modal.close()}),100)},t}();s.decorators=[{type:e.Injectable}];var r=function(){function t(t,i,o){var n=this;this.privateRenderer=t,this.privateChangeDetectorRef=i,this.privateNtkSmartModalService=o,this.closable=!0,this.escapable=!0,this.dismissable=!0,this.identifier="",this.customClass="nsm-dialog-animation-fade",this.visible=!1,this.backdrop=!0,this.force=!0,this.hideDelay=500,this.autostart=!1,this.visibleChange=new e.EventEmitter,this.onClose=new e.EventEmitter,this.onCloseFinished=new e.EventEmitter,this.onDismiss=new e.EventEmitter,this.onDismissFinished=new e.EventEmitter,this.onAnyCloseEvent=new e.EventEmitter,this.onAnyCloseEventFinished=new e.EventEmitter,this.onOpen=new e.EventEmitter,this.onEscape=new e.EventEmitter,this.onDataAdded=new e.EventEmitter,this.onDataRemoved=new e.EventEmitter,this.layerPosition=1041,this.overlayVisible=!1,this.openedClass=!1,this.escapeKeyboardEvent=function(t){27===t.keyCode&&(n.onEscape.emit(n),n.privateNtkSmartModalService.closeLatestModal())}}return t.prototype.ngOnInit=function(){if(!this.identifier||!this.identifier.length)throw new Error("identifier field isn’t set. Please set one before calling <ntk-smart-modal> in a template.");this.layerPosition+=this.privateNtkSmartModalService.getModalStackCount(),this.privateNtkSmartModalService.addModal({id:this.identifier,modal:this},this.force),this.autostart&&this.privateNtkSmartModalService.open(this.identifier)},t.prototype.ngOnDestroy=function(){this.privateNtkSmartModalService.removeModal(this.identifier),window.removeEventListener("keyup",this.escapeKeyboardEvent),this.privateNtkSmartModalService.getModalStack.length||this.privateRenderer.removeClass(document.body,"dialog-open")},t.prototype.open=function(t){var e=this;t&&(this.layerPosition=this.privateNtkSmartModalService.getHigherIndex()),this.privateRenderer.addClass(document.body,"dialog-open"),this.overlayVisible=!0,this.visible=!0,setTimeout((function(){e.openedClass=!0,e.target&&e.targetPlacement(),e.privateChangeDetectorRef.markForCheck()})),this.onOpen.emit(this),this.escapable&&window.addEventListener("keyup",this.escapeKeyboardEvent)},t.prototype.close=function(){var t=this;this.openedClass=!1,this.onClose.emit(this),this.onAnyCloseEvent.emit(this),this.privateNtkSmartModalService.getOpenedModals().length<2&&this.privateRenderer.removeClass(document.body,"dialog-open"),setTimeout((function(){t.visibleChange.emit(t.visible),t.visible=!1,t.overlayVisible=!1,t.privateChangeDetectorRef.markForCheck(),t.onCloseFinished.emit(t),t.onAnyCloseEventFinished.emit(t)}),this.hideDelay),window.removeEventListener("keyup",this.escapeKeyboardEvent)},t.prototype.dismiss=function(t){var e=this;this.dismissable&&t.target.classList.contains("overlay")&&(this.openedClass=!1,this.onDismiss.emit(this),this.onAnyCloseEvent.emit(this),this.privateNtkSmartModalService.getOpenedModals().length<2&&this.privateRenderer.removeClass(document.body,"dialog-open"),setTimeout((function(){e.visible=!1,e.visibleChange.emit(e.visible),e.overlayVisible=!1,e.privateChangeDetectorRef.markForCheck(),e.onDismissFinished.emit(e),e.onAnyCloseEventFinished.emit(e)}),this.hideDelay),window.removeEventListener("keyup",this.escapeKeyboardEvent))},t.prototype.toggle=function(t){this.visible?this.close():this.open(t)},t.prototype.addCustomClass=function(t){this.customClass.length?this.customClass+=" "+t:this.customClass=t},t.prototype.removeCustomClass=function(t){this.customClass=t?this.customClass.replace(t,"").trim():""},t.prototype.isVisible=function(){return this.visible},t.prototype.hasData=function(){return void 0!==this.privateData},t.prototype.setData=function(t,e){(!this.hasData()||this.hasData()&&e)&&(this.privateData=t,this.onDataAdded.emit(this.privateData),this.privateChangeDetectorRef.markForCheck())},t.prototype.getData=function(){return this.privateData},t.prototype.removeData=function(){this.privateData=void 0,this.onDataRemoved.emit(!0),this.privateChangeDetectorRef.markForCheck()},t.prototype.targetPlacement=function(){if(this.nsmDialog&&this.nsmContent&&this.nsmOverlay&&this.target){var t=document.querySelector(this.target).getBoundingClientRect(),e=this.nsmOverlay.nativeElement.getBoundingClientRect(),i=this.nsmContent.nativeElement.getBoundingClientRect(),o=this.nsmDialog.nativeElement.getBoundingClientRect(),n=parseInt(getComputedStyle(this.nsmContent.nativeElement).marginLeft,10),s=parseInt(getComputedStyle(this.nsmContent.nativeElement).marginTop,10),r=t.top-o.top-(i.height-t.height)/2,a=t.left-o.left-(i.width-t.width)/2;a+o.left+i.width+2*n>e.width?a=e.width-(o.left+i.width)-2*n:a+o.left<0&&(a=-o.left),r+o.top+i.height+s>e.height&&(r=e.height-(o.top+i.height)-s),r<0&&(r=0),this.privateRenderer.setStyle(this.nsmContent.nativeElement,"top",r+"px"),this.privateRenderer.setStyle(this.nsmContent.nativeElement,"left",a+"px")}},t}();r.decorators=[{type:e.Component,args:[{selector:"ntk-smart-modal",template:'\n <div\n *ngIf="overlayVisible"\n [style.z-index]="visible ? layerPosition - 1 : -1"\n [ngClass]="{ transparent: !backdrop, overlay: true, \'nsm-overlay-open\': openedClass }"\n (click)="dismiss($event)"\n #nsmOverlay\n >\n <div\n [style.z-index]="visible ? layerPosition : -1"\n [ngClass]="[\'nsm-dialog\', customClass, openedClass ? \'nsm-dialog-open\' : \'nsm-dialog-close\']"\n #nsmDialog\n >\n <div class="nsm-content" #nsmContent>\n <div class="nsm-body">\n <ng-content></ng-content>\n </div>\n <button type="button" *ngIf="closable" (click)="close()" aria-label="Close" class="nsm-dialog-btn-close">\n <img\n src="data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MTIgNTEyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCA1MTIgNTEyOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjE2cHgiIGhlaWdodD0iMTZweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDMsNi4wNThjLTguMDc3LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDksMEw2LjA1OCw0NzYuNjkzYy04LjA3Nyw4LjA3Ny04LjA3NywyMS4xNzIsMCwyOS4yNDkgICAgQzEwLjA5Niw1MDkuOTgyLDE1LjM5LDUxMiwyMC42ODMsNTEyYzUuMjkzLDAsMTAuNTg2LTIuMDE5LDE0LjYyNS02LjA1OUw1MDUuOTQzLDM1LjMwNiAgICBDNTE0LjAxOSwyNy4yMyw1MTQuMDE5LDE0LjEzNSw1MDUuOTQzLDYuMDU4eiIgZmlsbD0iIzAwMDAwMCIvPgoJPC9nPgo8L2c+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDIsNDc2LjY5NEwzNS4zMDYsNi4wNTljLTguMDc2LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDgsMGMtOC4wNzcsOC4wNzYtOC4wNzcsMjEuMTcxLDAsMjkuMjQ4bDQ3MC42MzYsNDcwLjYzNiAgICBjNC4wMzgsNC4wMzksOS4zMzIsNi4wNTgsMTQuNjI1LDYuMDU4YzUuMjkzLDAsMTAuNTg3LTIuMDE5LDE0LjYyNC02LjA1N0M1MTQuMDE4LDQ5Ny44NjYsNTE0LjAxOCw0ODQuNzcxLDUwNS45NDIsNDc2LjY5NHoiIGZpbGw9IiMwMDAwMDAiLz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K"\n />\n </button>\n </div>\n </div>\n </div>\n '}]}],r.ctorParameters=function(){return[{type:e.Renderer2},{type:e.ChangeDetectorRef},{type:s}]},r.propDecorators={closable:[{type:e.Input}],escapable:[{type:e.Input}],dismissable:[{type:e.Input}],identifier:[{type:e.Input}],customClass:[{type:e.Input}],visible:[{type:e.Input}],backdrop:[{type:e.Input}],force:[{type:e.Input}],hideDelay:[{type:e.Input}],autostart:[{type:e.Input}],target:[{type:e.Input}],visibleChange:[{type:e.Output}],onClose:[{type:e.Output}],onCloseFinished:[{type:e.Output}],onDismiss:[{type:e.Output}],onDismissFinished:[{type:e.Output}],onAnyCloseEvent:[{type:e.Output}],onAnyCloseEventFinished:[{type:e.Output}],onOpen:[{type:e.Output}],onEscape:[{type:e.Output}],onDataAdded:[{type:e.Output}],onDataRemoved:[{type:e.Output}],nsmContent:[{type:e.ViewChild,args:["nsmContent"]}],nsmDialog:[{type:e.ViewChild,args:["nsmDialog"]}],nsmOverlay:[{type:e.ViewChild,args:["nsmOverlay"]}],targetPlacement:[{type:e.HostListener,args:["window:resize"]}]};var a=function(){function t(){}return t.forRoot=function(){return{ngModule:t,providers:[s]}},t.forChild=function(){return{ngModule:t,providers:[s]}},t}();a.decorators=[{type:e.NgModule,args:[{declarations:[r],exports:[r],imports:[i.CommonModule]}]}];var d=function(){function t(){this.privateloaderStack=[],this.privateActions=[]}return t.prototype.addLoader=function(t,e){if(e){var i=this.privateloaderStack.findIndex((function(e){return e.id===t.id}));i>-1?this.privateloaderStack[i].component=t.component:this.privateloaderStack.push(t)}else{if(this._getLoader(t.id))throw new Error("Loader with "+t.id+" identifier already exist");this.privateloaderStack.push(t)}},t.prototype.removeLoader=function(t){this.privateloaderStack=this.privateloaderStack.filter((function(e){return e.id!==t})),this._removeAction(t,"*")},t.prototype.getLoaderStack=function(){return this.privateloaderStack},t.prototype.getLoaderStackCount=function(){return this.privateloaderStack.length},t.prototype.getOpenedLoaders=function(){return this.privateloaderStack.filter((function(t){return t.component.visible}))},t.prototype.getActiveLoaders=function(){return this.privateloaderStack.filter((function(t){return t.component.loading}))},t.prototype.getHigherIndex=function(){var t=this.getOpenedLoaders().map((function(t){return t.component.layerPosition}));return Math.max.apply(Math,n(t))+1},t.prototype.start=function(t){var e,i=this;Array.isArray(t)?t.forEach((function(t){i.start(t)})):(e=this._getLoader(t))?(e.component.start(),this._removeAction(t,"start")):this._addAction(t,"start")},t.prototype.startAll=function(){var t=this;this.privateloaderStack.forEach((function(e){return t.start(e.id)}))},t.prototype.stop=function(t){var e,i=this;Array.isArray(t)?t.forEach((function(t){i.stop(t)})):(e=this._getLoader(t))?(e.component.stop(),this._removeAction(t,"stop")):this._addAction(t,"stop")},t.prototype.stopAll=function(){var t=this;this.privateloaderStack.forEach((function(e){return t.stop(e.id)}))},t.prototype.isLoading=function(t){var e,i=this;if(Array.isArray(t)){var o=[];return t.forEach((function(t){i.privateloaderStack.forEach((function(e){e.id===t&&o.push(e.component.loading)}))})),-1===o.indexOf(!1)}return!!(e=this._getLoader(t))&&e.component.loading},t.prototype.executeAction=function(t,e){if(this.privateActions.find((function(i){return i.identifier===t&&i.action===e})))switch(e){case"start":this.start(t);break;case"stop":this.stop(t)}},t.prototype._getLoader=function(t){return this.privateloaderStack.find((function(e){return e.id===t}))||null},t.prototype._addAction=function(t,e){var i=this;Array.isArray(t)?t.forEach((function(t){i._addAction(t,e)})):this.privateActions.push({identifier:t,action:e})},t.prototype._removeAction=function(t,e){var i=this;Array.isArray(t)?t.forEach((function(t){i._removeAction(t,e)})):this.privateActions=this.privateActions.filter((function(i){return i.identifier!==t||i.action!==e&&"*"!==e}))},t}();d.decorators=[{type:e.Injectable}];var l=function(t){this.id=t.identifier,this.component=t},c=function(){function t(t,i){this.ntkSmartLoaderService=t,this.changeDetectorRef=i,this.identifier="",this.customClass="",this.force=!1,this.delayIn=0,this.delayOut=0,this.autostart=!1,this.onStart=new e.EventEmitter,this.onStop=new e.EventEmitter,this.onVisibleChange=new e.EventEmitter,this.loading=!1,this.visible=!1,this.layerPosition=999,this.privateIsProcessing=!1,this.privateLoaderBodyClass="loader-open",this.privateEnterClass="enter",this.privateLeaveClass="leave"}return t.prototype.ngOnInit=function(){try{var t=new l(this);this.ntkSmartLoaderService.addLoader(t,this.force),this.layerPosition+=this.ntkSmartLoaderService.getLoaderStackCount(),this.addCustomClass(this.identifier.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()),this.autostart?this.ntkSmartLoaderService.start(this.identifier):this.ntkSmartLoaderService.executeAction(this.identifier,"start")}catch(t){throw t}},t.prototype.ngOnDestroy=function(){this.ntkSmartLoaderService.removeLoader(this.identifier)},t.prototype.start=function(t){var e=this;this.privateIsProcessing=!0,clearInterval(this.privateDebouncer),this.visible=!0,setTimeout((function(){e.addCustomClass(e.privateEnterClass)})),this.privateDebouncer=setTimeout((function(){t&&(e.layerPosition=e.ntkSmartLoaderService.getHigherIndex()),document.body.classList.contains(e.privateLoaderBodyClass)||document.body.classList.add(e.privateLoaderBodyClass),e.loading=!0,e.onStart.emit(e),e.onVisibleChange.emit(e),e.removeCustomClass(e.privateEnterClass),e.privateIsProcessing=!1}),this.delayIn)},t.prototype.stop=function(){var t=this;this.privateIsProcessing&&(this.visible=!1,this.loading=!1),clearInterval(this.privateDebouncer),this.addCustomClass(this.privateLeaveClass),this.loading=!1,this.privateDebouncer=setTimeout((function(){document.body.classList.contains(t.privateLoaderBodyClass)&&document.body.classList.remove(t.privateLoaderBodyClass),t.visible=!1,t.onStop.emit(t),t.onVisibleChange.emit(t),t.removeCustomClass(t.privateLeaveClass),setTimeout((function(){t.changeDetectorRef.markForCheck()}))}),this.delayOut)},t.prototype.addCustomClass=function(t){this.customClass.length?-1===this.customClass.indexOf(t)&&(this.customClass+=" "+t):this.customClass=t},t.prototype.removeCustomClass=function(t){this.customClass=t?this.customClass.replace(t,"").trim():""},t}();c.decorators=[{type:e.Component,args:[{selector:"ntk-smart-loader",template:'\n <div class="loader-container {{customClass}}" [ngClass]="{\'active\': loading}"\n [style.z-index]="layerPosition - 1" *ngIf="visible">\n <ng-content></ng-content>\n </div>\n '}]}],c.ctorParameters=function(){return[{type:d},{type:e.ChangeDetectorRef}]},c.propDecorators={identifier:[{type:e.Input}],customClass:[{type:e.Input}],force:[{type:e.Input}],delayIn:[{type:e.Input}],delayOut:[{type:e.Input}],autostart:[{type:e.Input}],onStart:[{type:e.Output}],onStop:[{type:e.Output}],onVisibleChange:[{type:e.Output}]};var p=function(){function t(){}return t.forRoot=function(){return{ngModule:t,providers:[d]}},t.forChild=function(){return{ngModule:t,providers:[d]}},t}();p.decorators=[{type:e.NgModule,args:[{declarations:[c],exports:[c],imports:[i.CommonModule]}]}],t.NtkSmartLoaderComponent=c,t.NtkSmartLoaderModule=p,t.NtkSmartLoaderService=d,t.NtkSmartModalComponent=r,t.NtkSmartModalModule=a,t.NtkSmartModalService=s,Object.defineProperty(t,"__esModule",{value:!0})}));
***************************************************************************** */Object.create;function o(t,e){var n="function"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var o,i,r=n.call(t),a=[];try{for(;(void 0===e||e-- >0)&&!(o=r.next()).done;)a.push(o.value)}catch(t){i={error:t}}finally{try{o&&!o.done&&(n=r.return)&&n.call(r)}finally{if(i)throw i.error}}return a}function i(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(o(arguments[e]));return t}Object.create;var r=function(){function t(){this._modalStack=[]}return t.prototype.addModal=function(t,e){if(e){var n=this._modalStack.findIndex((function(e){return e.id===t.id}));n>-1?this._modalStack[n].modal=t.modal:this._modalStack.push(t)}else this._modalStack.push(t)},t.prototype.getModal=function(t){var e=this._modalStack.find((function(e){return e.id===t}));if(void 0!==e)return e.modal;throw new Error("Cannot find modal with identifier "+t)},t.prototype.getModalStack=function(){return this._modalStack},t.prototype.getOpenedModals=function(){return this._modalStack.filter((function(t){return t.modal.visible}))},t.prototype.getTopOpenedModal=function(){if(!this.getOpenedModals().length)throw new Error("No modal is opened");return this.getOpenedModals().map((function(t){return t.modal})).reduce((function(t,e){return e.layerPosition>t.layerPosition?e:t}),this.getOpenedModals()[0].modal)},t.prototype.getHigherIndex=function(){return Math.max.apply(Math,i(this._modalStack.map((function(t){return t.modal.layerPosition})),[1041]))+1},t.prototype.getModalStackCount=function(){return this._modalStack.length},t.prototype.removeModal=function(t){var e=this._modalStack.findIndex((function(e){return e.id===t}));e>-1&&this._modalStack.splice(e,1)},t}();r.decorators=[{type:e.Injectable}],r.ctorParameters=function(){return[]};var a="dialog-open",s="ntk-smart-modal.",l=function(){function t(t,n,o,i,r){this._renderer=t,this._changeDetectorRef=n,this.componentFactoryResolver=o,this._document=i,this._platformId=r,this.closable=!0,this.escapable=!0,this.dismissable=!0,this.identifier="",this.customClass="nsm-dialog-animation-fade",this.visible=!1,this.backdrop=!0,this.force=!0,this.hideDelay=500,this.autostart=!1,this.target="",this.ariaLabel=null,this.ariaLabelledBy=null,this.ariaDescribedBy=null,this.refocus=!0,this.visibleChange=new e.EventEmitter,this.onClose=new e.EventEmitter,this.onCloseFinished=new e.EventEmitter,this.onDismiss=new e.EventEmitter,this.onDismissFinished=new e.EventEmitter,this.onAnyCloseEvent=new e.EventEmitter,this.onAnyCloseEventFinished=new e.EventEmitter,this.onOpen=new e.EventEmitter,this.onOpenFinished=new e.EventEmitter,this.onEscape=new e.EventEmitter,this.onDataAdded=new e.EventEmitter,this.onDataRemoved=new e.EventEmitter,this.layerPosition=1041,this.overlayVisible=!1,this.openedClass=!1,this.createFrom="html"}return t.prototype.ngOnInit=function(){if(!this.identifier||!this.identifier.length)throw new Error("identifier field isn’t set. Please set one before calling <ngx-smart-modal> in a template.");this._sendEvent("create")},t.prototype.ngAfterViewInit=function(){var t=this;if(this.contentComponent){var e=this.componentFactoryResolver.resolveComponentFactory(this.contentComponent);this.createDynamicContent(this.dynamicContentContainer,e),this.dynamicContentContainer.changes.subscribe((function(n){t.createDynamicContent(n,e)}))}},t.prototype.ngOnDestroy=function(){this._sendEvent("delete")},t.prototype.open=function(t){return this._sendEvent("open",{top:t}),this},t.prototype.close=function(){return this._sendEvent("close"),this},t.prototype.dismiss=function(t){return this.dismissable&&t.target.classList.contains("overlay")?(this._sendEvent("dismiss"),this):this},t.prototype.toggle=function(t){return this._sendEvent("toggle",{top:t}),this},t.prototype.addCustomClass=function(t){return this.customClass.length?this.customClass+=" "+t:this.customClass=t,this},t.prototype.removeCustomClass=function(t){return this.customClass=t?this.customClass.replace(t,"").trim():"",this},t.prototype.isVisible=function(){return this.visible},t.prototype.hasData=function(){return void 0!==this._data},t.prototype.setData=function(t,e){return(!this.hasData()||this.hasData()&&e)&&(this._data=t,this.onDataAdded.emit(this._data),this.markForCheck()),this},t.prototype.getData=function(){return this._data},t.prototype.removeData=function(){return this._data=void 0,this.onDataRemoved.emit(!0),this.markForCheck(),this},t.prototype.addBodyClass=function(){return this._renderer.addClass(this._document.body,a),this},t.prototype.removeBodyClass=function(){return this._renderer.removeClass(this._document.body,a),this},t.prototype.markForCheck=function(){try{this._changeDetectorRef.detectChanges()}catch(t){}this._changeDetectorRef.markForCheck()},t.prototype.targetPlacement=function(){if(!(this.isBrowser&&this.nsmDialog.length&&this.nsmContent.length&&this.nsmOverlay.length&&this.target))return!1;var t=this._document.querySelector(this.target);if(!t)return!1;var e=t.getBoundingClientRect(),n=this.nsmOverlay.first.nativeElement.getBoundingClientRect(),o=this.nsmContent.first.nativeElement.getBoundingClientRect(),i=this.nsmDialog.first.nativeElement.getBoundingClientRect(),r=parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginLeft,10),a=parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginTop,10),s=e.top-i.top-(o.height-e.height)/2,l=e.left-i.left-(o.width-e.width)/2;l+i.left+o.width+2*r>n.width?l=n.width-(i.left+o.width)-2*r:l+i.left<0&&(l=-i.left),s+i.top+o.height+a>n.height&&(s=n.height-(i.top+o.height)-a),this._renderer.setStyle(this.nsmContent.first.nativeElement,"top",(s<0?0:s)+"px"),this._renderer.setStyle(this.nsmContent.first.nativeElement,"left",l+"px")},t.prototype._sendEvent=function(t,e){if(!this.isBrowser)return!1;var n={extraData:e,instance:{id:this.identifier,modal:this}},o=new CustomEvent(s+t,{detail:n});return window.dispatchEvent(o)},Object.defineProperty(t.prototype,"isBrowser",{get:function(){return n.isPlatformBrowser(this._platformId)},enumerable:!1,configurable:!0}),t.prototype.createDynamicContent=function(t,e){var n=this;t.forEach((function(t){t.clear(),t.createComponent(e),n.markForCheck()}))},t}();l.decorators=[{type:e.Component,args:[{selector:"ntk-smart-modal",template:'\n <div *ngIf="overlayVisible"\n [style.z-index]="visible ? layerPosition-1 : -1"\n [ngClass]="{\'transparent\':!backdrop, \'overlay\':true, \'nsm-overlay-open\':openedClass}"\n (click)="dismiss($event)" #nsmOverlay>\n <div [style.z-index]="visible ? layerPosition : -1"\n [ngClass]="[\'nsm-dialog\', customClass, openedClass ? \'nsm-dialog-open\': \'nsm-dialog-close\']" #nsmDialog\n [attr.aria-hidden]="openedClass ? false : true"\n [attr.aria-label]="ariaLabel"\n [attr.aria-labelledby]="ariaLabelledBy"\n [attr.aria-describedby]="ariaDescribedBy">\n <div class="nsm-content" #nsmContent>\n <div class="nsm-body">\n <ng-template #dynamicContent></ng-template>\n <ng-content></ng-content>\n\n </div>\n <button type="button" *ngIf="closable" (click)="close()" aria-label="Close" class="nsm-dialog-btn-close">\n <svg xmlns="http://www.w3.org/2000/svg" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 512 512"\n xml:space="preserve" width="16px" height="16px" role="img" aria-labelledby="closeIconTitle closeIconDesc">\n <title id="closeIconTitle">Close Icon</title>\n <desc id="closeIconDesc">A light-gray close icon used to close the modal</desc>\n <g>\n <path d="M505.943,6.058c-8.077-8.077-21.172-8.077-29.249,0L6.058,476.693c-8.077,8.077-8.077,21.172,0,29.249 C10.096,509.982,15.39,512,20.683,512c5.293,0,10.586-2.019,14.625-6.059L505.943,35.306 C514.019,27.23,514.019,14.135,505.943,6.058z"\n fill="currentColor"/>\n </g>\n <g>\n <path d="M505.942,476.694L35.306,6.059c-8.076-8.077-21.172-8.077-29.248,0c-8.077,8.076-8.077,21.171,0,29.248l470.636,470.636 c4.038,4.039,9.332,6.058,14.625,6.058c5.293,0,10.587-2.019,14.624-6.057C514.018,497.866,514.018,484.771,505.942,476.694z"\n fill="currentColor"/>\n </g>\n </svg>\n </button>\n </div>\n </div>\n </div>\n '}]}],l.ctorParameters=function(){return[{type:e.Renderer2},{type:e.ChangeDetectorRef},{type:e.ComponentFactoryResolver},{type:void 0,decorators:[{type:e.Inject,args:[n.DOCUMENT]}]},{type:void 0,decorators:[{type:e.Inject,args:[e.PLATFORM_ID]}]}]},l.propDecorators={closable:[{type:e.Input}],escapable:[{type:e.Input}],dismissable:[{type:e.Input}],identifier:[{type:e.Input}],customClass:[{type:e.Input}],visible:[{type:e.Input}],backdrop:[{type:e.Input}],force:[{type:e.Input}],hideDelay:[{type:e.Input}],autostart:[{type:e.Input}],target:[{type:e.Input}],ariaLabel:[{type:e.Input}],ariaLabelledBy:[{type:e.Input}],ariaDescribedBy:[{type:e.Input}],refocus:[{type:e.Input}],visibleChange:[{type:e.Output}],onClose:[{type:e.Output}],onCloseFinished:[{type:e.Output}],onDismiss:[{type:e.Output}],onDismissFinished:[{type:e.Output}],onAnyCloseEvent:[{type:e.Output}],onAnyCloseEventFinished:[{type:e.Output}],onOpen:[{type:e.Output}],onOpenFinished:[{type:e.Output}],onEscape:[{type:e.Output}],onDataAdded:[{type:e.Output}],onDataRemoved:[{type:e.Output}],nsmContent:[{type:e.ViewChildren,args:["nsmContent"]}],nsmDialog:[{type:e.ViewChildren,args:["nsmDialog"]}],nsmOverlay:[{type:e.ViewChildren,args:["nsmOverlay"]}],dynamicContentContainer:[{type:e.ViewChildren,args:["dynamicContent",{read:e.ViewContainerRef}]}],targetPlacement:[{type:e.HostListener,args:["window:resize"]}]};var d=function(){function t(t,e,n,o,i,r,a){var s=this;this._componentFactoryResolver=t,this._appRef=e,this._injector=n,this._modalStack=o,this.applicationRef=i,this._document=r,this._platformId=a,this._escapeKeyboardEvent=function(t){if("Escape"===t.key)try{var e=s.getTopOpenedModal();return!!e.escapable&&(e.onEscape.emit(e),s.closeLatestModal(),!0)}catch(t){return!1}return!1},this._trapFocusModal=function(t){if("Tab"===t.key)try{var e=s.getTopOpenedModal();return e.nsmDialog.first.nativeElement.contains(document.activeElement)||(t.preventDefault(),t.stopPropagation(),e.nsmDialog.first.nativeElement.focus()),!0}catch(t){return!1}return!1},this._addEvents()}return t.prototype.addModal=function(t,e){this._modalStack.addModal(t,e)},t.prototype.getModal=function(t){return this._modalStack.getModal(t)},t.prototype.get=function(t){return this.getModal(t)},t.prototype.open=function(t,e){return void 0===e&&(e=!1),this._openModal(this.get(t),e)},t.prototype.close=function(t){return this._closeModal(this.get(t))},t.prototype.closeAll=function(){var t=this;this.getOpenedModals().forEach((function(e){t._closeModal(e.modal)}))},t.prototype.toggle=function(t,e){return void 0===e&&(e=!1),this._toggleModal(this.get(t),e)},t.prototype.getModalStack=function(){return this._modalStack.getModalStack()},t.prototype.getOpenedModals=function(){return this._modalStack.getOpenedModals()},t.prototype.getTopOpenedModal=function(){return this._modalStack.getTopOpenedModal()},t.prototype.getHigherIndex=function(){return this._modalStack.getHigherIndex()},t.prototype.getModalStackCount=function(){return this._modalStack.getModalStackCount()},t.prototype.removeModal=function(t){this._modalStack.removeModal(t)},t.prototype.setModalData=function(t,e,n){var o;return!!(o=this.get(e))&&(o.setData(t,n),!0)},t.prototype.getModalData=function(t){var e;return(e=this.get(t))?e.getData():null},t.prototype.resetModalData=function(t){if(this._modalStack.getModalStack().find((function(e){return e.id===t}))){var e=this.getModal(t).getData();return this.getModal(t).removeData(),e}return!1},t.prototype.closeLatestModal=function(){this.getTopOpenedModal().close()},t.prototype.create=function(t,n,o){void 0===o&&(o={});try{return this.getModal(t)}catch(d){var i=this._componentFactoryResolver.resolveComponentFactory(l),r=this._resolveNgContent(n),a=i.create(this._injector,r);n instanceof e.Type&&(a.instance.contentComponent=n),a.instance.identifier=t,a.instance.createFrom="service","boolean"==typeof o.closable&&(a.instance.closable=o.closable),"boolean"==typeof o.escapable&&(a.instance.escapable=o.escapable),"boolean"==typeof o.dismissable&&(a.instance.dismissable=o.dismissable),"string"==typeof o.customClass&&(a.instance.customClass=o.customClass),"boolean"==typeof o.backdrop&&(a.instance.backdrop=o.backdrop),"boolean"==typeof o.force&&(a.instance.force=o.force),"number"==typeof o.hideDelay&&(a.instance.hideDelay=o.hideDelay),"boolean"==typeof o.autostart&&(a.instance.autostart=o.autostart),"string"==typeof o.target&&(a.instance.target=o.target),"string"==typeof o.ariaLabel&&(a.instance.ariaLabel=o.ariaLabel),"string"==typeof o.ariaLabelledBy&&(a.instance.ariaLabelledBy=o.ariaLabelledBy),"string"==typeof o.ariaDescribedBy&&(a.instance.ariaDescribedBy=o.ariaDescribedBy),"boolean"==typeof o.refocus&&(a.instance.refocus=o.refocus),this._appRef.attachView(a.hostView);var s=a.hostView.rootNodes[0];return this._document.body.appendChild(s),a.instance}},t.prototype._addEvents=function(){var t=this;return!!this.isBrowser&&(window.addEventListener(s+"create",(function(e){t._initModal(e.detail.instance)})),window.addEventListener(s+"delete",(function(e){t._deleteModal(e.detail.instance)})),window.addEventListener(s+"open",(function(e){t._openModal(e.detail.instance.modal,e.detail.top)})),window.addEventListener(s+"toggle",(function(e){t._toggleModal(e.detail.instance.modal,e.detail.top)})),window.addEventListener(s+"close",(function(e){t._closeModal(e.detail.instance.modal)})),window.addEventListener(s+"dismiss",(function(e){t._dismissModal(e.detail.instance.modal)})),window.addEventListener("keyup",this._escapeKeyboardEvent),!0)},t.prototype._initModal=function(t){t.modal.layerPosition+=this.getModalStackCount(),this.addModal(t,t.modal.force),t.modal.autostart&&this.open(t.id)},t.prototype._openModal=function(t,e){return!t.visible&&(this.lastElementFocused=document.activeElement,t.escapable&&window.addEventListener("keyup",this._escapeKeyboardEvent),t.backdrop&&window.addEventListener("keydown",this._trapFocusModal),e&&(t.layerPosition=this.getHigherIndex()),t.addBodyClass(),t.overlayVisible=!0,t.visible=!0,t.onOpen.emit(t),t.markForCheck(),setTimeout((function(){t.openedClass=!0,t.target&&t.targetPlacement(),t.nsmDialog.first.nativeElement.setAttribute("role","dialog"),t.nsmDialog.first.nativeElement.setAttribute("tabIndex","-1"),t.nsmDialog.first.nativeElement.setAttribute("aria-modal","true"),t.nsmDialog.first.nativeElement.focus(),t.markForCheck(),t.onOpenFinished.emit(t)})),!0)},t.prototype._toggleModal=function(t,e){return t.visible?this._closeModal(t):this._openModal(t,e)},t.prototype._closeModal=function(t){var e=this;return!!t.openedClass&&(t.openedClass=!1,t.onClose.emit(t),t.onAnyCloseEvent.emit(t),this.getOpenedModals().length<2&&(t.removeBodyClass(),window.removeEventListener("keyup",this._escapeKeyboardEvent),window.removeEventListener("keydown",this._trapFocusModal)),setTimeout((function(){t.visibleChange.emit(t.visible),t.visible=!1,t.overlayVisible=!1,t.nsmDialog.first.nativeElement.removeAttribute("tabIndex"),t.markForCheck(),t.onCloseFinished.emit(t),t.onAnyCloseEventFinished.emit(t),t.refocus&&e.lastElementFocused.focus()}),t.hideDelay),!0)},t.prototype._dismissModal=function(t){return!!t.openedClass&&(t.openedClass=!1,t.onDismiss.emit(t),t.onAnyCloseEvent.emit(t),this.getOpenedModals().length<2&&t.removeBodyClass(),setTimeout((function(){t.visible=!1,t.visibleChange.emit(t.visible),t.overlayVisible=!1,t.markForCheck(),t.onDismissFinished.emit(t),t.onAnyCloseEventFinished.emit(t)}),t.hideDelay),!0)},t.prototype._deleteModal=function(t){this.removeModal(t.id),this.getModalStack().length||t.modal.removeBodyClass()},t.prototype._resolveNgContent=function(t){if("string"==typeof t)return[[this._document.createTextNode(t)]];if(t instanceof e.TemplateRef){var n=t.createEmbeddedView(null);return this.applicationRef.attachView(n),[n.rootNodes]}return[]},Object.defineProperty(t.prototype,"isBrowser",{get:function(){return n.isPlatformBrowser(this._platformId)},enumerable:!1,configurable:!0}),t}();d.decorators=[{type:e.Injectable}],d.ctorParameters=function(){return[{type:e.ComponentFactoryResolver},{type:e.ApplicationRef},{type:e.Injector},{type:r},{type:e.ApplicationRef},{type:void 0,decorators:[{type:e.Inject,args:[n.DOCUMENT]}]},{type:void 0,decorators:[{type:e.Inject,args:[e.PLATFORM_ID]}]}]};var c=function(){function t(){}return t.forRoot=function(){return{ngModule:t,providers:[d,r]}},t.forChild=function(){return{ngModule:t,providers:[d,r]}},t}();c.decorators=[{type:e.NgModule,args:[{declarations:[l],exports:[l],imports:[n.CommonModule]}]}];var p=function(){function t(){this.privateloaderStack=[],this.privateActions=[]}return t.prototype.addLoader=function(t,e){if(e){var n=this.privateloaderStack.findIndex((function(e){return e.id===t.id}));n>-1?this.privateloaderStack[n].component=t.component:this.privateloaderStack.push(t)}else{if(this._getLoader(t.id))throw new Error("Loader with "+t.id+" identifier already exist");this.privateloaderStack.push(t)}},t.prototype.removeLoader=function(t){this.privateloaderStack=this.privateloaderStack.filter((function(e){return e.id!==t})),this._removeAction(t,"*")},t.prototype.getLoaderStack=function(){return this.privateloaderStack},t.prototype.getLoaderStackCount=function(){return this.privateloaderStack.length},t.prototype.getOpenedLoaders=function(){return this.privateloaderStack.filter((function(t){return t.component.visible}))},t.prototype.getActiveLoaders=function(){return this.privateloaderStack.filter((function(t){return t.component.loading}))},t.prototype.getHigherIndex=function(){var t=this.getOpenedLoaders().map((function(t){return t.component.layerPosition}));return Math.max.apply(Math,i(t))+1},t.prototype.start=function(t){var e,n=this;Array.isArray(t)?t.forEach((function(t){n.start(t)})):(e=this._getLoader(t))?(e.component.start(),this._removeAction(t,"start")):this._addAction(t,"start")},t.prototype.startAll=function(){var t=this;this.privateloaderStack.forEach((function(e){return t.start(e.id)}))},t.prototype.stop=function(t){var e,n=this;Array.isArray(t)?t.forEach((function(t){n.stop(t)})):(e=this._getLoader(t))?(e.component.stop(),this._removeAction(t,"stop")):this._addAction(t,"stop")},t.prototype.stopAll=function(){var t=this;this.privateloaderStack.forEach((function(e){return t.stop(e.id)}))},t.prototype.isLoading=function(t){var e,n=this;if(Array.isArray(t)){var o=[];return t.forEach((function(t){n.privateloaderStack.forEach((function(e){e.id===t&&o.push(e.component.loading)}))})),-1===o.indexOf(!1)}return!!(e=this._getLoader(t))&&e.component.loading},t.prototype.executeAction=function(t,e){if(this.privateActions.find((function(n){return n.identifier===t&&n.action===e})))switch(e){case"start":this.start(t);break;case"stop":this.stop(t)}},t.prototype._getLoader=function(t){return this.privateloaderStack.find((function(e){return e.id===t}))||null},t.prototype._addAction=function(t,e){var n=this;Array.isArray(t)?t.forEach((function(t){n._addAction(t,e)})):this.privateActions.push({identifier:t,action:e})},t.prototype._removeAction=function(t,e){var n=this;Array.isArray(t)?t.forEach((function(t){n._removeAction(t,e)})):this.privateActions=this.privateActions.filter((function(n){return n.identifier!==t||n.action!==e&&"*"!==e}))},t}();p.ɵprov=e.ɵɵdefineInjectable({factory:function(){return new p},token:p,providedIn:"root"}),p.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}];var u=function(t){this.id=t.identifier,this.component=t},h=function(){function t(t,n){this.ntkSmartLoaderService=t,this.changeDetectorRef=n,this.identifier="",this.customClass="",this.force=!1,this.delayIn=0,this.delayOut=0,this.autostart=!1,this.onStart=new e.EventEmitter,this.onStop=new e.EventEmitter,this.onVisibleChange=new e.EventEmitter,this.loading=!1,this.visible=!1,this.layerPosition=999,this.privateIsProcessing=!1,this.privateLoaderBodyClass="loader-open",this.privateEnterClass="enter",this.privateLeaveClass="leave"}return t.prototype.ngOnInit=function(){try{var t=new u(this);this.ntkSmartLoaderService.addLoader(t,this.force),this.layerPosition+=this.ntkSmartLoaderService.getLoaderStackCount(),this.addCustomClass(this.identifier.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()),this.autostart?this.ntkSmartLoaderService.start(this.identifier):this.ntkSmartLoaderService.executeAction(this.identifier,"start")}catch(t){throw t}},t.prototype.ngOnDestroy=function(){this.ntkSmartLoaderService.removeLoader(this.identifier)},t.prototype.start=function(t){var e=this;this.privateIsProcessing=!0,clearInterval(this.privateDebouncer),this.visible=!0,setTimeout((function(){e.addCustomClass(e.privateEnterClass)})),this.privateDebouncer=setTimeout((function(){t&&(e.layerPosition=e.ntkSmartLoaderService.getHigherIndex()),document.body.classList.contains(e.privateLoaderBodyClass)||document.body.classList.add(e.privateLoaderBodyClass),e.loading=!0,e.onStart.emit(e),e.onVisibleChange.emit(e),e.removeCustomClass(e.privateEnterClass),e.privateIsProcessing=!1}),this.delayIn)},t.prototype.stop=function(){var t=this;this.privateIsProcessing&&(this.visible=!1,this.loading=!1),clearInterval(this.privateDebouncer),this.addCustomClass(this.privateLeaveClass),this.loading=!1,this.privateDebouncer=setTimeout((function(){document.body.classList.contains(t.privateLoaderBodyClass)&&document.body.classList.remove(t.privateLoaderBodyClass),t.visible=!1,t.onStop.emit(t),t.onVisibleChange.emit(t),t.removeCustomClass(t.privateLeaveClass),setTimeout((function(){t.changeDetectorRef.markForCheck()}))}),this.delayOut)},t.prototype.addCustomClass=function(t){this.customClass.length?-1===this.customClass.indexOf(t)&&(this.customClass+=" "+t):this.customClass=t},t.prototype.removeCustomClass=function(t){this.customClass=t?this.customClass.replace(t,"").trim():""},t}();h.decorators=[{type:e.Component,args:[{selector:"ntk-smart-loader",template:'\n <div class="loader-container {{customClass}}" [ngClass]="{\'active\': loading}"\n [style.z-index]="layerPosition - 1" *ngIf="visible">\n <ng-content></ng-content>\n </div>\n '}]}],h.ctorParameters=function(){return[{type:p},{type:e.ChangeDetectorRef}]},h.propDecorators={identifier:[{type:e.Input}],customClass:[{type:e.Input}],force:[{type:e.Input}],delayIn:[{type:e.Input}],delayOut:[{type:e.Input}],autostart:[{type:e.Input}],onStart:[{type:e.Output}],onStop:[{type:e.Output}],onVisibleChange:[{type:e.Output}]};var m=function(){function t(){}return t.forRoot=function(){return{ngModule:t,providers:[p]}},t.forChild=function(){return{ngModule:t,providers:[p]}},t}();m.decorators=[{type:e.NgModule,args:[{declarations:[h],exports:[h],imports:[n.CommonModule]}]}],t.NtkSmartLoaderComponent=h,t.NtkSmartLoaderModule=m,t.NtkSmartLoaderService=p,t.NtkSmartModalComponent=l,t.NtkSmartModalModule=c,t.NtkSmartModalService=d,t.ɵa=r,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=ngx-ntk-smart-module.umd.min.js.map
import { Injectable } from '@angular/core';
import * as i0 from "@angular/core";
export class NtkSmartLoaderService {

@@ -221,5 +222,8 @@ constructor() {

}
NtkSmartLoaderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function NtkSmartLoaderService_Factory() { return new NtkSmartLoaderService(); }, token: NtkSmartLoaderService, providedIn: "root" });
NtkSmartLoaderService.decorators = [
{ type: Injectable }
{ type: Injectable, args: [{
providedIn: 'root',
},] }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ntk-smart-loader.service.js","sourceRoot":"D:/SourceKaravi/GitHub/npm-ntk-cms-angular/projects/ngx-ntk-smart-module/src/","sources":["lib/loader/ntk-smart-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\nimport { LoaderInstance } from './loader-instance';\r\n\r\n@Injectable()\r\nexport class NtkSmartLoaderService {\r\n  private privateloaderStack: LoaderInstance[] = [];\r\n  private privateActions: Array<{ identifier: string, action: string }> = [];\r\n\r\n  /**\r\n   * Add a new loader instance. This step is essential and allows to retrieve any loader at any time.\r\n   * It stores an object that contains the given loader identifier and the loader itself directly in the `loaderStack`.\r\n   *\r\n   * @param loaderInstance The object that contains the given loader identifier and the loader itself.\r\n   * @param force Optional parameter that forces the overriding of loader instance if it already exists.\r\n   * @returns Returns nothing special.\r\n   */\r\n  public addLoader(loaderInstance: LoaderInstance, force?: boolean): void {\r\n    if (force) {\r\n      const i: number = this.privateloaderStack.findIndex((o: LoaderInstance) => {\r\n        return o.id === loaderInstance.id;\r\n      });\r\n      if (i > -1) {\r\n        this.privateloaderStack[i].component = loaderInstance.component;\r\n      } else {\r\n        this.privateloaderStack.push(loaderInstance);\r\n      }\r\n      return;\r\n    }\r\n    let loader;\r\n    // tslint:disable-next-line: no-conditional-assignment\r\n    if (loader = this._getLoader(loaderInstance.id)) {\r\n      throw (new Error('Loader with ' + loaderInstance.id + ' identifier already exist'));\r\n    } else {\r\n      this.privateloaderStack.push(loaderInstance);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove a loader instance from the loader stack.\r\n   *\r\n   * @param id The loader identifier.\r\n   */\r\n  public removeLoader(id: string): void {\r\n    this.privateloaderStack = this.privateloaderStack.filter((loader) => loader.id !== id);\r\n\r\n    this._removeAction(id, '*');\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the created loaders.\r\n   *\r\n   * @returns Returns an array that contains all loader instances.\r\n   */\r\n  public getLoaderStack(): LoaderInstance[] {\r\n    return this.privateloaderStack;\r\n  }\r\n\r\n  /**\r\n   * It gives the number of loader instances. It's helpful to know if the loader stack is empty or not.\r\n   *\r\n   * @returns Returns the number of loader instances.\r\n   */\r\n  public getLoaderStackCount(): number {\r\n    return this.privateloaderStack.length;\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the opened loaders. It looks for all loader instances with their `visible` property set to `true`.\r\n   *\r\n   * @returns Returns an array that contains all the opened loaders.\r\n   */\r\n  public getOpenedLoaders(): LoaderInstance[] {\r\n    return this.privateloaderStack.filter((loader) => loader.component.visible);\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the active loaders. It looks for all loader instances with their `loading` property set to `true`.\r\n   *\r\n   * @returns Returns an array that contains all the active loaders.\r\n   */\r\n  public getActiveLoaders(): LoaderInstance[] {\r\n    return this.privateloaderStack.filter((loader) => loader.component.loading);\r\n  }\r\n\r\n  /**\r\n   * Get the higher `z-index` value between all the loader instances. It iterates over the `LoaderStack` array and\r\n   * calculates a higher value (it takes the highest index value between all the loader instances and adds 1).\r\n   * Use it to make a loader appear foreground.\r\n   *\r\n   * @returns Returns a higher index from all the existing loader instances.\r\n   */\r\n  public getHigherIndex(): number {\r\n    const index: number[] = this.getOpenedLoaders().map((loader) => loader.component.layerPosition);\r\n\r\n    return Math.max(...index) + 1;\r\n  }\r\n\r\n  /**\r\n   * Enable loading state to one or several loaders.\r\n   *\r\n   * @param id The loader identifier.\r\n   */\r\n  public start(id: string | string[]): void {\r\n    let loader;\r\n\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this.start(i);\r\n      });\r\n    } else if (loader = this._getLoader(id)) {\r\n      loader.component.start();\r\n      this._removeAction(id, 'start');\r\n    } else {\r\n      this._addAction(id, 'start');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Enable loading state to all loaders.\r\n   */\r\n  public startAll(): void {\r\n    this.privateloaderStack.forEach((loader) => this.start(loader.id));\r\n  }\r\n\r\n  /**\r\n   * Disable loading state to one or several loaders.\r\n   *\r\n   * @param id The loader identifier.\r\n   */\r\n  public stop(id: string | string[]): void {\r\n    let loader;\r\n\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this.stop(i);\r\n      });\r\n    } else if (loader = this._getLoader(id)) {\r\n      loader.component.stop();\r\n      this._removeAction(id, 'stop');\r\n    } else {\r\n      this._addAction(id, 'stop');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Disable loading state to all loaders.\r\n   */\r\n  public stopAll(): void {\r\n    this.privateloaderStack.forEach((loader) => this.stop(loader.id));\r\n  }\r\n\r\n  public isLoading(id: string | string[]): boolean {\r\n    let loader;\r\n    if (Array.isArray(id)) {\r\n      const tmp: any = [];\r\n\r\n      id.forEach((i: string) => {\r\n        this.privateloaderStack.forEach((load) => {\r\n          if (load.id === i) {\r\n            tmp.push(load.component.loading);\r\n          }\r\n        });\r\n      });\r\n      return tmp.indexOf(false) === -1;\r\n    } else if (loader = this._getLoader(id)) {\r\n      return loader.component.loading;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Execute an action on loaders\r\n   *\r\n   * @param id The loader identifier.\r\n   * @param action Name of the action.\r\n   */\r\n  public executeAction(id: string, action: string): void {\r\n    if (this.privateActions.find((act) => act.identifier === id && act.action === action)) {\r\n      switch (action) {\r\n        case 'start':\r\n          this.start(id);\r\n          break;\r\n        case 'stop':\r\n          this.stop(id);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieve a loader instance by its identifier.\r\n   * If there's several loaders with same identifier, the first is returned.\r\n   *\r\n   * @param id The loader identifier used at creation time.\r\n   */\r\n  private _getLoader(id: string): LoaderInstance | null {\r\n    return this.privateloaderStack.find((load) => load.id === id) || null;\r\n  }\r\n\r\n  /**\r\n   * Adds an action on one or more loaders\r\n   *\r\n   * @param id The loader identifier.\r\n   * @param action Name of the action.\r\n   */\r\n  private _addAction(id: string | string[], action: string): void {\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this._addAction(i, action);\r\n      });\r\n    } else {\r\n      this.privateActions.push({ identifier: id, action: action });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove an action on one or more loaders\r\n   *\r\n   * @param id The loader identifier.\r\n   * @param action Name of the action.\r\n   */\r\n  private _removeAction(id: string | string[], action: string): void {\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this._removeAction(i, action);\r\n      });\r\n    } else {\r\n      this.privateActions = this.privateActions.filter((act) => act.identifier !== id || (act.action !== action && action !== '*'));\r\n    }\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ntk-smart-loader.service.js","sourceRoot":"D:/SourceKaravi/GitHub/npm-ntk-cms-angular/projects/ngx-ntk-smart-module/src/","sources":["lib/loader/ntk-smart-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\nimport { LoaderInstance } from './loader-instance';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class NtkSmartLoaderService {\r\n  private privateloaderStack: LoaderInstance[] = [];\r\n  private privateActions: Array<{ identifier: string, action: string }> = [];\r\n\r\n  /**\r\n   * Add a new loader instance. This step is essential and allows to retrieve any loader at any time.\r\n   * It stores an object that contains the given loader identifier and the loader itself directly in the `loaderStack`.\r\n   *\r\n   * @param loaderInstance The object that contains the given loader identifier and the loader itself.\r\n   * @param force Optional parameter that forces the overriding of loader instance if it already exists.\r\n   * @returns Returns nothing special.\r\n   */\r\n  public addLoader(loaderInstance: LoaderInstance, force?: boolean): void {\r\n    if (force) {\r\n      const i: number = this.privateloaderStack.findIndex((o: LoaderInstance) => {\r\n        return o.id === loaderInstance.id;\r\n      });\r\n      if (i > -1) {\r\n        this.privateloaderStack[i].component = loaderInstance.component;\r\n      } else {\r\n        this.privateloaderStack.push(loaderInstance);\r\n      }\r\n      return;\r\n    }\r\n    let loader;\r\n    // tslint:disable-next-line: no-conditional-assignment\r\n    if (loader = this._getLoader(loaderInstance.id)) {\r\n      throw (new Error('Loader with ' + loaderInstance.id + ' identifier already exist'));\r\n    } else {\r\n      this.privateloaderStack.push(loaderInstance);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove a loader instance from the loader stack.\r\n   *\r\n   * @param id The loader identifier.\r\n   */\r\n  public removeLoader(id: string): void {\r\n    this.privateloaderStack = this.privateloaderStack.filter((loader) => loader.id !== id);\r\n\r\n    this._removeAction(id, '*');\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the created loaders.\r\n   *\r\n   * @returns Returns an array that contains all loader instances.\r\n   */\r\n  public getLoaderStack(): LoaderInstance[] {\r\n    return this.privateloaderStack;\r\n  }\r\n\r\n  /**\r\n   * It gives the number of loader instances. It's helpful to know if the loader stack is empty or not.\r\n   *\r\n   * @returns Returns the number of loader instances.\r\n   */\r\n  public getLoaderStackCount(): number {\r\n    return this.privateloaderStack.length;\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the opened loaders. It looks for all loader instances with their `visible` property set to `true`.\r\n   *\r\n   * @returns Returns an array that contains all the opened loaders.\r\n   */\r\n  public getOpenedLoaders(): LoaderInstance[] {\r\n    return this.privateloaderStack.filter((loader) => loader.component.visible);\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the active loaders. It looks for all loader instances with their `loading` property set to `true`.\r\n   *\r\n   * @returns Returns an array that contains all the active loaders.\r\n   */\r\n  public getActiveLoaders(): LoaderInstance[] {\r\n    return this.privateloaderStack.filter((loader) => loader.component.loading);\r\n  }\r\n\r\n  /**\r\n   * Get the higher `z-index` value between all the loader instances. It iterates over the `LoaderStack` array and\r\n   * calculates a higher value (it takes the highest index value between all the loader instances and adds 1).\r\n   * Use it to make a loader appear foreground.\r\n   *\r\n   * @returns Returns a higher index from all the existing loader instances.\r\n   */\r\n  public getHigherIndex(): number {\r\n    const index: number[] = this.getOpenedLoaders().map((loader) => loader.component.layerPosition);\r\n\r\n    return Math.max(...index) + 1;\r\n  }\r\n\r\n  /**\r\n   * Enable loading state to one or several loaders.\r\n   *\r\n   * @param id The loader identifier.\r\n   */\r\n  public start(id: string | string[]): void {\r\n    let loader;\r\n\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this.start(i);\r\n      });\r\n    } else if (loader = this._getLoader(id)) {\r\n      loader.component.start();\r\n      this._removeAction(id, 'start');\r\n    } else {\r\n      this._addAction(id, 'start');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Enable loading state to all loaders.\r\n   */\r\n  public startAll(): void {\r\n    this.privateloaderStack.forEach((loader) => this.start(loader.id));\r\n  }\r\n\r\n  /**\r\n   * Disable loading state to one or several loaders.\r\n   *\r\n   * @param id The loader identifier.\r\n   */\r\n  public stop(id: string | string[]): void {\r\n    let loader;\r\n\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this.stop(i);\r\n      });\r\n    } else if (loader = this._getLoader(id)) {\r\n      loader.component.stop();\r\n      this._removeAction(id, 'stop');\r\n    } else {\r\n      this._addAction(id, 'stop');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Disable loading state to all loaders.\r\n   */\r\n  public stopAll(): void {\r\n    this.privateloaderStack.forEach((loader) => this.stop(loader.id));\r\n  }\r\n\r\n  public isLoading(id: string | string[]): boolean {\r\n    let loader;\r\n    if (Array.isArray(id)) {\r\n      const tmp: any = [];\r\n\r\n      id.forEach((i: string) => {\r\n        this.privateloaderStack.forEach((load) => {\r\n          if (load.id === i) {\r\n            tmp.push(load.component.loading);\r\n          }\r\n        });\r\n      });\r\n      return tmp.indexOf(false) === -1;\r\n    } else if (loader = this._getLoader(id)) {\r\n      return loader.component.loading;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Execute an action on loaders\r\n   *\r\n   * @param id The loader identifier.\r\n   * @param action Name of the action.\r\n   */\r\n  public executeAction(id: string, action: string): void {\r\n    if (this.privateActions.find((act) => act.identifier === id && act.action === action)) {\r\n      switch (action) {\r\n        case 'start':\r\n          this.start(id);\r\n          break;\r\n        case 'stop':\r\n          this.stop(id);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieve a loader instance by its identifier.\r\n   * If there's several loaders with same identifier, the first is returned.\r\n   *\r\n   * @param id The loader identifier used at creation time.\r\n   */\r\n  private _getLoader(id: string): LoaderInstance | null {\r\n    return this.privateloaderStack.find((load) => load.id === id) || null;\r\n  }\r\n\r\n  /**\r\n   * Adds an action on one or more loaders\r\n   *\r\n   * @param id The loader identifier.\r\n   * @param action Name of the action.\r\n   */\r\n  private _addAction(id: string | string[], action: string): void {\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this._addAction(i, action);\r\n      });\r\n    } else {\r\n      this.privateActions.push({ identifier: id, action: action });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove an action on one or more loaders\r\n   *\r\n   * @param id The loader identifier.\r\n   * @param action Name of the action.\r\n   */\r\n  private _removeAction(id: string | string[], action: string): void {\r\n    if (Array.isArray(id)) {\r\n      id.forEach((i: string) => {\r\n        this._removeAction(i, action);\r\n      });\r\n    } else {\r\n      this.privateActions = this.privateActions.filter((act) => act.identifier !== id || (act.action !== action && action !== '*'));\r\n    }\r\n  }\r\n}\r\n"]}

@@ -1,8 +0,11 @@

import { Input, Output, Renderer2, Component, EventEmitter, HostListener, ChangeDetectorRef, ViewChild, ElementRef, } from '@angular/core';
import { NtkSmartModalService } from './ntk-smart-modal.service';
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
import { ChangeDetectorRef, Component, ComponentFactoryResolver, EventEmitter, HostListener, Inject, Input, Output, PLATFORM_ID, QueryList, Renderer2, ViewChildren, ViewContainerRef } from '@angular/core';
import { NtkSmartModalConfig } from './ntk-smart-modal.config';
export class NtkSmartModalComponent {
constructor(privateRenderer, privateChangeDetectorRef, privateNtkSmartModalService) {
this.privateRenderer = privateRenderer;
this.privateChangeDetectorRef = privateChangeDetectorRef;
this.privateNtkSmartModalService = privateNtkSmartModalService;
constructor(_renderer, _changeDetectorRef, componentFactoryResolver, _document, _platformId) {
this._renderer = _renderer;
this._changeDetectorRef = _changeDetectorRef;
this.componentFactoryResolver = componentFactoryResolver;
this._document = _document;
this._platformId = _platformId;
this.closable = true;

@@ -18,2 +21,7 @@ this.escapable = true;

this.autostart = false;
this.target = '';
this.ariaLabel = null;
this.ariaLabelledBy = null;
this.ariaDescribedBy = null;
this.refocus = true;
this.visibleChange = new EventEmitter();

@@ -27,2 +35,3 @@ this.onClose = new EventEmitter();

this.onOpen = new EventEmitter();
this.onOpenFinished = new EventEmitter();
this.onEscape = new EventEmitter();

@@ -34,96 +43,70 @@ this.onDataAdded = new EventEmitter();

this.openedClass = false;
this.escapeKeyboardEvent = (event) => {
if (event.keyCode === 27) {
this.onEscape.emit(this);
this.privateNtkSmartModalService.closeLatestModal();
}
};
this.createFrom = 'html';
}
ngOnInit() {
if (!!this.identifier && this.identifier.length) {
this.layerPosition += this.privateNtkSmartModalService.getModalStackCount();
this.privateNtkSmartModalService.addModal({ id: this.identifier, modal: this }, this.force);
if (this.autostart) {
this.privateNtkSmartModalService.open(this.identifier);
}
if (!this.identifier || !this.identifier.length) {
throw new Error('identifier field isn’t set. Please set one before calling <ngx-smart-modal> in a template.');
}
else {
throw new Error('identifier field isn’t set. Please set one before calling <ntk-smart-modal> in a template.');
this._sendEvent('create');
}
ngAfterViewInit() {
if (this.contentComponent) {
const factory = this.componentFactoryResolver.resolveComponentFactory(this.contentComponent);
this.createDynamicContent(this.dynamicContentContainer, factory);
this.dynamicContentContainer.changes.subscribe((contentViewContainers) => {
this.createDynamicContent(contentViewContainers, factory);
});
}
}
ngOnDestroy() {
this.privateNtkSmartModalService.removeModal(this.identifier);
window.removeEventListener('keyup', this.escapeKeyboardEvent);
if (!this.privateNtkSmartModalService.getModalStack.length) {
this.privateRenderer.removeClass(document.body, 'dialog-open');
}
this._sendEvent('delete');
}
/**
* Open the modal instance
*
* @param top open the modal top of all other
* @returns the modal component
*/
open(top) {
if (top) {
this.layerPosition = this.privateNtkSmartModalService.getHigherIndex();
}
this.privateRenderer.addClass(document.body, 'dialog-open');
this.overlayVisible = true;
this.visible = true;
setTimeout(() => {
this.openedClass = true;
if (this.target) {
this.targetPlacement();
}
this.privateChangeDetectorRef.markForCheck();
});
this.onOpen.emit(this);
if (this.escapable) {
window.addEventListener('keyup', this.escapeKeyboardEvent);
}
this._sendEvent('open', { top: top });
return this;
}
/**
* Close the modal instance
*
* @returns the modal component
*/
close() {
const me = this;
this.openedClass = false;
this.onClose.emit(this);
this.onAnyCloseEvent.emit(this);
if (this.privateNtkSmartModalService.getOpenedModals().length < 2) {
this.privateRenderer.removeClass(document.body, 'dialog-open');
}
setTimeout(() => {
me.visibleChange.emit(me.visible);
me.visible = false;
me.overlayVisible = false;
me.privateChangeDetectorRef.markForCheck();
me.onCloseFinished.emit(me);
me.onAnyCloseEventFinished.emit(me);
}, this.hideDelay);
window.removeEventListener('keyup', this.escapeKeyboardEvent);
this._sendEvent('close');
return this;
}
/**
* Dismiss the modal instance
*
* @param e the event sent by the browser
* @returns the modal component
*/
dismiss(e) {
const me = this;
if (!this.dismissable) {
return;
if (!this.dismissable || !e.target.classList.contains('overlay')) {
return this;
}
if (e.target.classList.contains('overlay')) {
this.openedClass = false;
this.onDismiss.emit(this);
this.onAnyCloseEvent.emit(this);
if (this.privateNtkSmartModalService.getOpenedModals().length < 2) {
this.privateRenderer.removeClass(document.body, 'dialog-open');
}
setTimeout(() => {
me.visible = false;
me.visibleChange.emit(me.visible);
me.overlayVisible = false;
me.privateChangeDetectorRef.markForCheck();
me.onDismissFinished.emit(me);
me.onAnyCloseEventFinished.emit(me);
}, this.hideDelay);
window.removeEventListener('keyup', this.escapeKeyboardEvent);
}
this._sendEvent('dismiss');
return this;
}
/**
* Toggle visibility of the modal instance
*
* @param top open the modal top of all other
* @returns the modal component
*/
toggle(top) {
if (this.visible) {
this.close();
}
else {
this.open(top);
}
this._sendEvent('toggle', { top: top });
return this;
}
/**
* Add a custom class to the modal instance
*
* @param className the class to add
* @returns the modal component
*/
addCustomClass(className) {

@@ -136,3 +119,10 @@ if (!this.customClass.length) {

}
return this;
}
/**
* Remove a custom class to the modal instance
*
* @param className the class to remove
* @returns the modal component
*/
removeCustomClass(className) {

@@ -145,39 +135,96 @@ if (className) {

}
return this;
}
/**
* Returns the visibility state of the modal instance
*/
isVisible() {
return this.visible;
}
/**
* Checks if data is attached to the modal instance
*/
hasData() {
return this.privateData !== undefined;
return this._data !== undefined;
}
/**
* Attach data to the modal instance
*
* @param data the data to attach
* @param force override potentially attached data
* @returns the modal component
*/
setData(data, force) {
if (!this.hasData() || (this.hasData() && force)) {
this.privateData = data;
this.onDataAdded.emit(this.privateData);
this.privateChangeDetectorRef.markForCheck();
this._data = data;
this.onDataAdded.emit(this._data);
this.markForCheck();
}
return this;
}
/**
* Retrieve the data attached to the modal instance
*/
getData() {
return this.privateData;
return this._data;
}
/**
* Remove the data attached to the modal instance
*
* @returns the modal component
*/
removeData() {
this.privateData = undefined;
this._data = undefined;
this.onDataRemoved.emit(true);
this.privateChangeDetectorRef.markForCheck();
this.markForCheck();
return this;
}
/**
* Add body class modal opened
*
* @returns the modal component
*/
addBodyClass() {
this._renderer.addClass(this._document.body, NtkSmartModalConfig.bodyClassOpen);
return this;
}
/**
* Add body class modal opened
*
* @returns the modal component
*/
removeBodyClass() {
this._renderer.removeClass(this._document.body, NtkSmartModalConfig.bodyClassOpen);
return this;
}
markForCheck() {
try {
this._changeDetectorRef.detectChanges();
}
catch (e) {
}
this._changeDetectorRef.markForCheck();
}
/**
* Listens for window resize event and recalculates modal instance position if it is element-relative
*/
targetPlacement() {
if (!this.nsmDialog || !this.nsmContent || !this.nsmOverlay || !this.target) {
return;
if (!this.isBrowser || !this.nsmDialog.length || !this.nsmContent.length || !this.nsmOverlay.length || !this.target) {
return false;
}
const targetElementRect = document.querySelector(this.target).getBoundingClientRect();
const bodyRect = this.nsmOverlay.nativeElement.getBoundingClientRect();
const nsmContentRect = this.nsmContent.nativeElement.getBoundingClientRect();
const nsmDialogRect = this.nsmDialog.nativeElement.getBoundingClientRect();
const marginLeft = parseInt(getComputedStyle(this.nsmContent.nativeElement).marginLeft, 10);
const marginTop = parseInt(getComputedStyle(this.nsmContent.nativeElement).marginTop, 10);
let offsetTop = targetElementRect.top - nsmDialogRect.top - (nsmContentRect.height - targetElementRect.height) / 2;
let offsetLeft = targetElementRect.left - nsmDialogRect.left - (nsmContentRect.width - targetElementRect.width) / 2;
if (offsetLeft + nsmDialogRect.left + nsmContentRect.width + marginLeft * 2 > bodyRect.width) {
offsetLeft = bodyRect.width - (nsmDialogRect.left + nsmContentRect.width) - marginLeft * 2;
const targetElement = this._document.querySelector(this.target);
if (!targetElement) {
return false;
}
const targetElementRect = targetElement.getBoundingClientRect();
const bodyRect = this.nsmOverlay.first.nativeElement.getBoundingClientRect();
const nsmContentRect = this.nsmContent.first.nativeElement.getBoundingClientRect();
const nsmDialogRect = this.nsmDialog.first.nativeElement.getBoundingClientRect();
const marginLeft = parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginLeft, 10);
const marginTop = parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginTop, 10);
let offsetTop = targetElementRect.top - nsmDialogRect.top - ((nsmContentRect.height - targetElementRect.height) / 2);
let offsetLeft = targetElementRect.left - nsmDialogRect.left - ((nsmContentRect.width - targetElementRect.width) / 2);
if (offsetLeft + nsmDialogRect.left + nsmContentRect.width + (marginLeft * 2) > bodyRect.width) {
offsetLeft = bodyRect.width - (nsmDialogRect.left + nsmContentRect.width) - (marginLeft * 2);
}
else if (offsetLeft + nsmDialogRect.left < 0) {

@@ -189,8 +236,32 @@ offsetLeft = -nsmDialogRect.left;

}
if (offsetTop < 0) {
offsetTop = 0;
this._renderer.setStyle(this.nsmContent.first.nativeElement, 'top', (offsetTop < 0 ? 0 : offsetTop) + 'px');
this._renderer.setStyle(this.nsmContent.first.nativeElement, 'left', offsetLeft + 'px');
}
_sendEvent(name, extraData) {
if (!this.isBrowser) {
return false;
}
this.privateRenderer.setStyle(this.nsmContent.nativeElement, 'top', offsetTop + 'px');
this.privateRenderer.setStyle(this.nsmContent.nativeElement, 'left', offsetLeft + 'px');
const data = {
extraData: extraData,
instance: { id: this.identifier, modal: this }
};
const event = new CustomEvent(NtkSmartModalConfig.prefixEvent + name, { detail: data });
return window.dispatchEvent(event);
}
/**
* Is current platform browser
*/
get isBrowser() {
return isPlatformBrowser(this._platformId);
}
/**
* Creates content inside provided ViewContainerRef
*/
createDynamicContent(changes, factory) {
changes.forEach((viewContainerRef) => {
viewContainerRef.clear();
viewContainerRef.createComponent(factory);
this.markForCheck();
});
}
}

@@ -201,22 +272,32 @@ NtkSmartModalComponent.decorators = [

template: `
<div
*ngIf="overlayVisible"
[style.z-index]="visible ? layerPosition - 1 : -1"
[ngClass]="{ transparent: !backdrop, overlay: true, 'nsm-overlay-open': openedClass }"
(click)="dismiss($event)"
#nsmOverlay
>
<div
[style.z-index]="visible ? layerPosition : -1"
[ngClass]="['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open' : 'nsm-dialog-close']"
#nsmDialog
>
<div *ngIf="overlayVisible"
[style.z-index]="visible ? layerPosition-1 : -1"
[ngClass]="{'transparent':!backdrop, 'overlay':true, 'nsm-overlay-open':openedClass}"
(click)="dismiss($event)" #nsmOverlay>
<div [style.z-index]="visible ? layerPosition : -1"
[ngClass]="['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open': 'nsm-dialog-close']" #nsmDialog
[attr.aria-hidden]="openedClass ? false : true"
[attr.aria-label]="ariaLabel"
[attr.aria-labelledby]="ariaLabelledBy"
[attr.aria-describedby]="ariaDescribedBy">
<div class="nsm-content" #nsmContent>
<div class="nsm-body">
<ng-template #dynamicContent></ng-template>
<ng-content></ng-content>
</div>
<button type="button" *ngIf="closable" (click)="close()" aria-label="Close" class="nsm-dialog-btn-close">
<img
src="data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MTIgNTEyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCA1MTIgNTEyOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjE2cHgiIGhlaWdodD0iMTZweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDMsNi4wNThjLTguMDc3LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDksMEw2LjA1OCw0NzYuNjkzYy04LjA3Nyw4LjA3Ny04LjA3NywyMS4xNzIsMCwyOS4yNDkgICAgQzEwLjA5Niw1MDkuOTgyLDE1LjM5LDUxMiwyMC42ODMsNTEyYzUuMjkzLDAsMTAuNTg2LTIuMDE5LDE0LjYyNS02LjA1OUw1MDUuOTQzLDM1LjMwNiAgICBDNTE0LjAxOSwyNy4yMyw1MTQuMDE5LDE0LjEzNSw1MDUuOTQzLDYuMDU4eiIgZmlsbD0iIzAwMDAwMCIvPgoJPC9nPgo8L2c+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDIsNDc2LjY5NEwzNS4zMDYsNi4wNTljLTguMDc2LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDgsMGMtOC4wNzcsOC4wNzYtOC4wNzcsMjEuMTcxLDAsMjkuMjQ4bDQ3MC42MzYsNDcwLjYzNiAgICBjNC4wMzgsNC4wMzksOS4zMzIsNi4wNTgsMTQuNjI1LDYuMDU4YzUuMjkzLDAsMTAuNTg3LTIuMDE5LDE0LjYyNC02LjA1N0M1MTQuMDE4LDQ5Ny44NjYsNTE0LjAxOCw0ODQuNzcxLDUwNS45NDIsNDc2LjY5NHoiIGZpbGw9IiMwMDAwMDAiLz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K"
/>
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 512 512"
xml:space="preserve" width="16px" height="16px" role="img" aria-labelledby="closeIconTitle closeIconDesc">
<title id="closeIconTitle">Close Icon</title>
<desc id="closeIconDesc">A light-gray close icon used to close the modal</desc>
<g>
<path d="M505.943,6.058c-8.077-8.077-21.172-8.077-29.249,0L6.058,476.693c-8.077,8.077-8.077,21.172,0,29.249 C10.096,509.982,15.39,512,20.683,512c5.293,0,10.586-2.019,14.625-6.059L505.943,35.306 C514.019,27.23,514.019,14.135,505.943,6.058z"
fill="currentColor"/>
</g>
<g>
<path d="M505.942,476.694L35.306,6.059c-8.076-8.077-21.172-8.077-29.248,0c-8.077,8.076-8.077,21.171,0,29.248l470.636,470.636 c4.038,4.039,9.332,6.058,14.625,6.058c5.293,0,10.587-2.019,14.624-6.057C514.018,497.866,514.018,484.771,505.942,476.694z"
fill="currentColor"/>
</g>
</svg>
</button>

@@ -232,3 +313,5 @@ </div>

{ type: ChangeDetectorRef },
{ type: NtkSmartModalService }
{ type: ComponentFactoryResolver },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
];

@@ -247,2 +330,6 @@ NtkSmartModalComponent.propDecorators = {

target: [{ type: Input }],
ariaLabel: [{ type: Input }],
ariaLabelledBy: [{ type: Input }],
ariaDescribedBy: [{ type: Input }],
refocus: [{ type: Input }],
visibleChange: [{ type: Output }],

@@ -256,10 +343,12 @@ onClose: [{ type: Output }],

onOpen: [{ type: Output }],
onOpenFinished: [{ type: Output }],
onEscape: [{ type: Output }],
onDataAdded: [{ type: Output }],
onDataRemoved: [{ type: Output }],
nsmContent: [{ type: ViewChild, args: ['nsmContent',] }],
nsmDialog: [{ type: ViewChild, args: ['nsmDialog',] }],
nsmOverlay: [{ type: ViewChild, args: ['nsmOverlay',] }],
nsmContent: [{ type: ViewChildren, args: ['nsmContent',] }],
nsmDialog: [{ type: ViewChildren, args: ['nsmDialog',] }],
nsmOverlay: [{ type: ViewChildren, args: ['nsmOverlay',] }],
dynamicContentContainer: [{ type: ViewChildren, args: ['dynamicContent', { read: ViewContainerRef },] }],
targetPlacement: [{ type: HostListener, args: ['window:resize',] }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ntk-smart-modal.component.js","sourceRoot":"D:/SourceKaravi/GitHub/npm-ntk-cms-angular/projects/ngx-ntk-smart-module/src/","sources":["lib/modal/ntk-smart-modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Input,\r\n  Output,\r\n  OnInit,\r\n  OnDestroy,\r\n  Renderer2,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  ChangeDetectorRef,\r\n  ViewChild,\r\n  ElementRef,\r\n} from '@angular/core';\r\n\r\nimport { NtkSmartModalService } from './ntk-smart-modal.service';\r\n\r\n@Component({\r\n  selector: 'ntk-smart-modal',\r\n  template: `\r\n    <div\r\n      *ngIf=\"overlayVisible\"\r\n      [style.z-index]=\"visible ? layerPosition - 1 : -1\"\r\n      [ngClass]=\"{ transparent: !backdrop, overlay: true, 'nsm-overlay-open': openedClass }\"\r\n      (click)=\"dismiss($event)\"\r\n      #nsmOverlay\r\n    >\r\n      <div\r\n        [style.z-index]=\"visible ? layerPosition : -1\"\r\n        [ngClass]=\"['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open' : 'nsm-dialog-close']\"\r\n        #nsmDialog\r\n      >\r\n        <div class=\"nsm-content\" #nsmContent>\r\n          <div class=\"nsm-body\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n          <button type=\"button\" *ngIf=\"closable\" (click)=\"close()\" aria-label=\"Close\" class=\"nsm-dialog-btn-close\">\r\n            <img\r\n              src=\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MTIgNTEyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCA1MTIgNTEyOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjE2cHgiIGhlaWdodD0iMTZweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDMsNi4wNThjLTguMDc3LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDksMEw2LjA1OCw0NzYuNjkzYy04LjA3Nyw4LjA3Ny04LjA3NywyMS4xNzIsMCwyOS4yNDkgICAgQzEwLjA5Niw1MDkuOTgyLDE1LjM5LDUxMiwyMC42ODMsNTEyYzUuMjkzLDAsMTAuNTg2LTIuMDE5LDE0LjYyNS02LjA1OUw1MDUuOTQzLDM1LjMwNiAgICBDNTE0LjAxOSwyNy4yMyw1MTQuMDE5LDE0LjEzNSw1MDUuOTQzLDYuMDU4eiIgZmlsbD0iIzAwMDAwMCIvPgoJPC9nPgo8L2c+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDIsNDc2LjY5NEwzNS4zMDYsNi4wNTljLTguMDc2LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDgsMGMtOC4wNzcsOC4wNzYtOC4wNzcsMjEuMTcxLDAsMjkuMjQ4bDQ3MC42MzYsNDcwLjYzNiAgICBjNC4wMzgsNC4wMzksOS4zMzIsNi4wNTgsMTQuNjI1LDYuMDU4YzUuMjkzLDAsMTAuNTg3LTIuMDE5LDE0LjYyNC02LjA1N0M1MTQuMDE4LDQ5Ny44NjYsNTE0LjAxOCw0ODQuNzcxLDUwNS45NDIsNDc2LjY5NHoiIGZpbGw9IiMwMDAwMDAiLz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K\"\r\n            />\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n})\r\nexport class NtkSmartModalComponent implements OnInit, OnDestroy {\r\n  @Input() public closable = true;\r\n  @Input() public escapable = true;\r\n  @Input() public dismissable = true;\r\n  @Input() public identifier = '';\r\n  @Input() public customClass = 'nsm-dialog-animation-fade';\r\n  @Input() public visible = false;\r\n  @Input() public backdrop = true;\r\n  @Input() public force = true;\r\n  @Input() public hideDelay = 500;\r\n  @Input() public autostart = false;\r\n  @Input() public target: any;\r\n\r\n  @Output() public visibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n  @Output() public onClose: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onCloseFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDismiss: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDismissFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onAnyCloseEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onAnyCloseEventFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onOpen: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onEscape: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDataAdded: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDataRemoved: EventEmitter<any> = new EventEmitter();\r\n\r\n  public layerPosition = 1041;\r\n  public overlayVisible = false;\r\n  public openedClass = false;\r\n\r\n  private privateData: any;\r\n\r\n  @ViewChild('nsmContent') private nsmContent: ElementRef | undefined;\r\n  @ViewChild('nsmDialog') private nsmDialog: ElementRef | undefined;\r\n  @ViewChild('nsmOverlay') private nsmOverlay: ElementRef | undefined;\r\n\r\n  constructor(\r\n    private privateRenderer: Renderer2,\r\n    private privateChangeDetectorRef: ChangeDetectorRef,\r\n    private privateNtkSmartModalService: NtkSmartModalService,\r\n  ) { }\r\n\r\n  public ngOnInit(): void {\r\n    if (!!this.identifier && this.identifier.length) {\r\n      this.layerPosition += this.privateNtkSmartModalService.getModalStackCount();\r\n      this.privateNtkSmartModalService.addModal({ id: this.identifier, modal: this }, this.force);\r\n\r\n      if (this.autostart) {\r\n        this.privateNtkSmartModalService.open(this.identifier);\r\n      }\r\n    } else {\r\n      throw new Error('identifier field isn’t set. Please set one before calling <ntk-smart-modal> in a template.');\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.privateNtkSmartModalService.removeModal(this.identifier);\r\n    window.removeEventListener('keyup', this.escapeKeyboardEvent);\r\n    if (!this.privateNtkSmartModalService.getModalStack.length) {\r\n      this.privateRenderer.removeClass(document.body, 'dialog-open');\r\n    }\r\n  }\r\n\r\n  public open(top?: boolean): void {\r\n    if (top) {\r\n      this.layerPosition = this.privateNtkSmartModalService.getHigherIndex();\r\n    }\r\n\r\n    this.privateRenderer.addClass(document.body, 'dialog-open');\r\n    this.overlayVisible = true;\r\n    this.visible = true;\r\n\r\n    setTimeout(() => {\r\n      this.openedClass = true;\r\n\r\n      if (this.target) {\r\n        this.targetPlacement();\r\n      }\r\n\r\n      this.privateChangeDetectorRef.markForCheck();\r\n    });\r\n\r\n    this.onOpen.emit(this);\r\n\r\n    if (this.escapable) {\r\n      window.addEventListener('keyup', this.escapeKeyboardEvent);\r\n    }\r\n  }\r\n\r\n  public close(): void {\r\n    const me = this;\r\n\r\n    this.openedClass = false;\r\n    this.onClose.emit(this);\r\n    this.onAnyCloseEvent.emit(this);\r\n\r\n    if (this.privateNtkSmartModalService.getOpenedModals().length < 2) {\r\n      this.privateRenderer.removeClass(document.body, 'dialog-open');\r\n    }\r\n\r\n    setTimeout(() => {\r\n      me.visibleChange.emit(me.visible);\r\n      me.visible = false;\r\n      me.overlayVisible = false;\r\n      me.privateChangeDetectorRef.markForCheck();\r\n      me.onCloseFinished.emit(me);\r\n      me.onAnyCloseEventFinished.emit(me);\r\n    }, this.hideDelay);\r\n\r\n    window.removeEventListener('keyup', this.escapeKeyboardEvent);\r\n  }\r\n\r\n  public dismiss(e: any): void {\r\n    const me = this;\r\n\r\n    if (!this.dismissable) {\r\n      return;\r\n    }\r\n\r\n    if (e.target.classList.contains('overlay')) {\r\n      this.openedClass = false;\r\n      this.onDismiss.emit(this);\r\n      this.onAnyCloseEvent.emit(this);\r\n\r\n      if (this.privateNtkSmartModalService.getOpenedModals().length < 2) {\r\n        this.privateRenderer.removeClass(document.body, 'dialog-open');\r\n      }\r\n\r\n      setTimeout(() => {\r\n        me.visible = false;\r\n        me.visibleChange.emit(me.visible);\r\n        me.overlayVisible = false;\r\n        me.privateChangeDetectorRef.markForCheck();\r\n        me.onDismissFinished.emit(me);\r\n        me.onAnyCloseEventFinished.emit(me);\r\n      }, this.hideDelay);\r\n\r\n      window.removeEventListener('keyup', this.escapeKeyboardEvent);\r\n    }\r\n  }\r\n\r\n  public toggle(top?: boolean): void {\r\n    if (this.visible) {\r\n      this.close();\r\n    } else {\r\n      this.open(top);\r\n    }\r\n  }\r\n\r\n  public addCustomClass(className: string): void {\r\n    if (!this.customClass.length) {\r\n      this.customClass = className;\r\n    } else {\r\n      this.customClass += ' ' + className;\r\n    }\r\n  }\r\n\r\n  public removeCustomClass(className?: string): void {\r\n    if (className) {\r\n      this.customClass = this.customClass.replace(className, '').trim();\r\n    } else {\r\n      this.customClass = '';\r\n    }\r\n  }\r\n\r\n  public isVisible(): boolean {\r\n    return this.visible;\r\n  }\r\n\r\n  public hasData(): boolean {\r\n    return this.privateData !== undefined;\r\n  }\r\n\r\n  public setData(data: any, force?: boolean): any {\r\n    if (!this.hasData() || (this.hasData() && force)) {\r\n      this.privateData = data;\r\n      this.onDataAdded.emit(this.privateData);\r\n      this.privateChangeDetectorRef.markForCheck();\r\n    }\r\n  }\r\n\r\n  public getData(): any {\r\n    return this.privateData;\r\n  }\r\n\r\n  public removeData(): void {\r\n    this.privateData = undefined;\r\n    this.onDataRemoved.emit(true);\r\n    this.privateChangeDetectorRef.markForCheck();\r\n  }\r\n\r\n  public escapeKeyboardEvent = (event: KeyboardEvent) => {\r\n    if (event.keyCode === 27) {\r\n      this.onEscape.emit(this);\r\n      this.privateNtkSmartModalService.closeLatestModal();\r\n    }\r\n  }\r\n\r\n  @HostListener('window:resize')\r\n  public targetPlacement(): void {\r\n    if (!this.nsmDialog || !this.nsmContent || !this.nsmOverlay || !this.target) {\r\n      return;\r\n    }\r\n\r\n    const targetElementRect = document.querySelector(this.target).getBoundingClientRect();\r\n    const bodyRect = this.nsmOverlay.nativeElement.getBoundingClientRect();\r\n\r\n    const nsmContentRect = this.nsmContent.nativeElement.getBoundingClientRect();\r\n    const nsmDialogRect = this.nsmDialog.nativeElement.getBoundingClientRect();\r\n\r\n    const marginLeft = parseInt(getComputedStyle(this.nsmContent.nativeElement).marginLeft as any, 10);\r\n    const marginTop = parseInt(getComputedStyle(this.nsmContent.nativeElement).marginTop as any, 10);\r\n\r\n    let offsetTop = targetElementRect.top - nsmDialogRect.top - (nsmContentRect.height - targetElementRect.height) / 2;\r\n    let offsetLeft = targetElementRect.left - nsmDialogRect.left - (nsmContentRect.width - targetElementRect.width) / 2;\r\n\r\n    if (offsetLeft + nsmDialogRect.left + nsmContentRect.width + marginLeft * 2 > bodyRect.width) {\r\n      offsetLeft = bodyRect.width - (nsmDialogRect.left + nsmContentRect.width) - marginLeft * 2;\r\n    } else if (offsetLeft + nsmDialogRect.left < 0) {\r\n      offsetLeft = -nsmDialogRect.left;\r\n    }\r\n\r\n    if (offsetTop + nsmDialogRect.top + nsmContentRect.height + marginTop > bodyRect.height) {\r\n      offsetTop = bodyRect.height - (nsmDialogRect.top + nsmContentRect.height) - marginTop;\r\n    }\r\n\r\n    if (offsetTop < 0) {\r\n      offsetTop = 0;\r\n    }\r\n\r\n    this.privateRenderer.setStyle(this.nsmContent.nativeElement, 'top', offsetTop + 'px');\r\n    this.privateRenderer.setStyle(this.nsmContent.nativeElement, 'left', offsetLeft + 'px');\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ntk-smart-modal.component.js","sourceRoot":"D:/SourceKaravi/GitHub/npm-ntk-cms-angular/projects/ngx-ntk-smart-module/src/","sources":["lib/modal/ntk-smart-modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactory,\r\n  ComponentFactoryResolver,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  PLATFORM_ID,\r\n  QueryList,\r\n  Renderer2,\r\n  Type,\r\n  ViewChildren,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { NtkSmartModalConfig } from './ntk-smart-modal.config';\r\n\r\n\r\n@Component({\r\n  selector: 'ntk-smart-modal',\r\n  template: `\r\n    <div *ngIf=\"overlayVisible\"\r\n         [style.z-index]=\"visible ? layerPosition-1 : -1\"\r\n         [ngClass]=\"{'transparent':!backdrop, 'overlay':true, 'nsm-overlay-open':openedClass}\"\r\n         (click)=\"dismiss($event)\" #nsmOverlay>\r\n      <div [style.z-index]=\"visible ? layerPosition : -1\"\r\n           [ngClass]=\"['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open': 'nsm-dialog-close']\" #nsmDialog\r\n           [attr.aria-hidden]=\"openedClass ? false : true\"\r\n           [attr.aria-label]=\"ariaLabel\"\r\n           [attr.aria-labelledby]=\"ariaLabelledBy\"\r\n           [attr.aria-describedby]=\"ariaDescribedBy\">\r\n        <div class=\"nsm-content\" #nsmContent>\r\n          <div class=\"nsm-body\">\r\n            <ng-template #dynamicContent></ng-template>\r\n            <ng-content></ng-content>\r\n\r\n          </div>\r\n          <button type=\"button\" *ngIf=\"closable\" (click)=\"close()\" aria-label=\"Close\" class=\"nsm-dialog-btn-close\">\r\n            <svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" viewBox=\"0 0 512 512\"\r\n                 xml:space=\"preserve\" width=\"16px\" height=\"16px\" role=\"img\" aria-labelledby=\"closeIconTitle closeIconDesc\">\r\n              <title id=\"closeIconTitle\">Close Icon</title>\r\n              <desc id=\"closeIconDesc\">A light-gray close icon used to close the modal</desc>\r\n              <g>\r\n                <path d=\"M505.943,6.058c-8.077-8.077-21.172-8.077-29.249,0L6.058,476.693c-8.077,8.077-8.077,21.172,0,29.249    C10.096,509.982,15.39,512,20.683,512c5.293,0,10.586-2.019,14.625-6.059L505.943,35.306    C514.019,27.23,514.019,14.135,505.943,6.058z\"\r\n                      fill=\"currentColor\"/>\r\n              </g>\r\n              <g>\r\n                <path d=\"M505.942,476.694L35.306,6.059c-8.076-8.077-21.172-8.077-29.248,0c-8.077,8.076-8.077,21.171,0,29.248l470.636,470.636    c4.038,4.039,9.332,6.058,14.625,6.058c5.293,0,10.587-2.019,14.624-6.057C514.018,497.866,514.018,484.771,505.942,476.694z\"\r\n                      fill=\"currentColor\"/>\r\n              </g>\r\n            </svg>\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `\r\n})\r\nexport class NtkSmartModalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @Input() public closable: boolean = true;\r\n  @Input() public escapable: boolean = true;\r\n  @Input() public dismissable: boolean = true;\r\n  @Input() public identifier: string = '';\r\n  @Input() public customClass: string = 'nsm-dialog-animation-fade';\r\n  @Input() public visible: boolean = false;\r\n  @Input() public backdrop: boolean = true;\r\n  @Input() public force: boolean = true;\r\n  @Input() public hideDelay: number = 500;\r\n  @Input() public autostart: boolean = false;\r\n  @Input() public target: string = '';\r\n  @Input() public ariaLabel: string | null = null;\r\n  @Input() public ariaLabelledBy: string | null = null;\r\n  @Input() public ariaDescribedBy: string | null = null;\r\n  @Input() public refocus: boolean = true;\r\n\r\n  @Output() public visibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n  @Output() public onClose: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onCloseFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDismiss: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDismissFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onAnyCloseEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onAnyCloseEventFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onOpen: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onOpenFinished: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onEscape: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDataAdded: EventEmitter<any> = new EventEmitter();\r\n  @Output() public onDataRemoved: EventEmitter<any> = new EventEmitter();\r\n\r\n  public contentComponent: Type<Component>;\r\n  public layerPosition: number = 1041;\r\n  public overlayVisible: boolean = false;\r\n  public openedClass: boolean = false;\r\n\r\n  public createFrom = 'html';\r\n\r\n  private _data: any;\r\n\r\n  @ViewChildren('nsmContent') private nsmContent: QueryList<ElementRef>;\r\n  @ViewChildren('nsmDialog') public nsmDialog: QueryList<ElementRef>;\r\n  @ViewChildren('nsmOverlay') private nsmOverlay: QueryList<ElementRef>;\r\n  @ViewChildren('dynamicContent', { read: ViewContainerRef }) dynamicContentContainer: QueryList<ViewContainerRef>;\r\n\r\n  constructor(\r\n    private _renderer: Renderer2,\r\n    private _changeDetectorRef: ChangeDetectorRef,\r\n    private componentFactoryResolver: ComponentFactoryResolver,\r\n    @Inject(DOCUMENT) private _document: any,\r\n    @Inject(PLATFORM_ID) private _platformId: any,\r\n  ) { }\r\n\r\n  public ngOnInit(): void {\r\n    if (!this.identifier || !this.identifier.length) {\r\n      throw new Error('identifier field isn’t set. Please set one before calling <ngx-smart-modal> in a template.');\r\n    }\r\n\r\n    this._sendEvent('create');\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    if (this.contentComponent) {\r\n      const factory = this.componentFactoryResolver.resolveComponentFactory(this.contentComponent);\r\n      this.createDynamicContent(this.dynamicContentContainer, factory);\r\n      this.dynamicContentContainer.changes.subscribe((contentViewContainers: QueryList<ViewContainerRef>) => {\r\n        this.createDynamicContent(contentViewContainers, factory);\r\n      });\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this._sendEvent('delete');\r\n  }\r\n\r\n  /**\r\n   * Open the modal instance\r\n   *\r\n   * @param top open the modal top of all other\r\n   * @returns the modal component\r\n   */\r\n  public open(top?: boolean): NtkSmartModalComponent {\r\n    this._sendEvent('open', { top: top });\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Close the modal instance\r\n   *\r\n   * @returns the modal component\r\n   */\r\n  public close(): NtkSmartModalComponent {\r\n    this._sendEvent('close');\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Dismiss the modal instance\r\n   *\r\n   * @param e the event sent by the browser\r\n   * @returns the modal component\r\n   */\r\n  public dismiss(e: any): NtkSmartModalComponent {\r\n    if (!this.dismissable || !e.target.classList.contains('overlay')) {\r\n      return this;\r\n    }\r\n\r\n    this._sendEvent('dismiss');\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Toggle visibility of the modal instance\r\n   *\r\n   * @param top open the modal top of all other\r\n   * @returns the modal component\r\n   */\r\n  public toggle(top?: boolean): NtkSmartModalComponent {\r\n    this._sendEvent('toggle', { top: top });\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Add a custom class to the modal instance\r\n   *\r\n   * @param className the class to add\r\n   * @returns the modal component\r\n   */\r\n  public addCustomClass(className: string): NtkSmartModalComponent {\r\n    if (!this.customClass.length) {\r\n      this.customClass = className;\r\n    } else {\r\n      this.customClass += ' ' + className;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Remove a custom class to the modal instance\r\n   *\r\n   * @param className the class to remove\r\n   * @returns the modal component\r\n   */\r\n  public removeCustomClass(className?: string): NtkSmartModalComponent {\r\n    if (className) {\r\n      this.customClass = this.customClass.replace(className, '').trim();\r\n    } else {\r\n      this.customClass = '';\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns the visibility state of the modal instance\r\n   */\r\n  public isVisible(): boolean {\r\n    return this.visible;\r\n  }\r\n\r\n  /**\r\n   * Checks if data is attached to the modal instance\r\n   */\r\n  public hasData(): boolean {\r\n    return this._data !== undefined;\r\n  }\r\n\r\n  /**\r\n   * Attach data to the modal instance\r\n   *\r\n   * @param data the data to attach\r\n   * @param force override potentially attached data\r\n   * @returns the modal component\r\n   */\r\n  public setData(data: any, force?: boolean): NtkSmartModalComponent {\r\n    if (!this.hasData() || (this.hasData() && force)) {\r\n      this._data = data;\r\n      this.onDataAdded.emit(this._data);\r\n      this.markForCheck();\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Retrieve the data attached to the modal instance\r\n   */\r\n  public getData(): any {\r\n    return this._data;\r\n  }\r\n\r\n  /**\r\n   * Remove the data attached to the modal instance\r\n   *\r\n   * @returns the modal component\r\n   */\r\n  public removeData(): NtkSmartModalComponent {\r\n    this._data = undefined;\r\n    this.onDataRemoved.emit(true);\r\n    this.markForCheck();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Add body class modal opened\r\n   *\r\n   * @returns the modal component\r\n   */\r\n  public addBodyClass(): NtkSmartModalComponent {\r\n    this._renderer.addClass(this._document.body, NtkSmartModalConfig.bodyClassOpen);\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Add body class modal opened\r\n   *\r\n   * @returns the modal component\r\n   */\r\n  public removeBodyClass(): NtkSmartModalComponent {\r\n    this._renderer.removeClass(this._document.body, NtkSmartModalConfig.bodyClassOpen);\r\n\r\n    return this;\r\n  }\r\n\r\n  public markForCheck() {\r\n    try {\r\n      this._changeDetectorRef.detectChanges();\r\n    } catch (e) {\r\n    }\r\n\r\n    this._changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Listens for window resize event and recalculates modal instance position if it is element-relative\r\n   */\r\n  @HostListener('window:resize')\r\n  public targetPlacement(): boolean | void {\r\n    if (!this.isBrowser || !this.nsmDialog.length || !this.nsmContent.length || !this.nsmOverlay.length || !this.target) {\r\n      return false;\r\n    }\r\n    const targetElement = this._document.querySelector(this.target);\r\n\r\n    if (!targetElement) {\r\n      return false;\r\n    }\r\n\r\n    const targetElementRect = targetElement.getBoundingClientRect();\r\n    const bodyRect = this.nsmOverlay.first.nativeElement.getBoundingClientRect();\r\n\r\n    const nsmContentRect = this.nsmContent.first.nativeElement.getBoundingClientRect();\r\n    const nsmDialogRect = this.nsmDialog.first.nativeElement.getBoundingClientRect();\r\n\r\n    const marginLeft = parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginLeft as any, 10);\r\n    const marginTop = parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginTop as any, 10);\r\n\r\n    let offsetTop = targetElementRect.top - nsmDialogRect.top - ((nsmContentRect.height - targetElementRect.height) / 2);\r\n    let offsetLeft = targetElementRect.left - nsmDialogRect.left - ((nsmContentRect.width - targetElementRect.width) / 2);\r\n\r\n    if (offsetLeft + nsmDialogRect.left + nsmContentRect.width + (marginLeft * 2) > bodyRect.width) {\r\n      offsetLeft = bodyRect.width - (nsmDialogRect.left + nsmContentRect.width) - (marginLeft * 2);\r\n    } else if (offsetLeft + nsmDialogRect.left < 0) {\r\n      offsetLeft = -nsmDialogRect.left;\r\n    }\r\n\r\n    if (offsetTop + nsmDialogRect.top + nsmContentRect.height + marginTop > bodyRect.height) {\r\n      offsetTop = bodyRect.height - (nsmDialogRect.top + nsmContentRect.height) - marginTop;\r\n    }\r\n\r\n    this._renderer.setStyle(this.nsmContent.first.nativeElement, 'top', (offsetTop < 0 ? 0 : offsetTop) + 'px');\r\n    this._renderer.setStyle(this.nsmContent.first.nativeElement, 'left', offsetLeft + 'px');\r\n  }\r\n\r\n  private _sendEvent(name: string, extraData?: any): boolean {\r\n    if (!this.isBrowser) {\r\n      return false;\r\n    }\r\n\r\n    const data = {\r\n      extraData: extraData,\r\n      instance: { id: this.identifier, modal: this }\r\n    };\r\n\r\n    const event = new CustomEvent(NtkSmartModalConfig.prefixEvent + name, { detail: data });\r\n\r\n    return window.dispatchEvent(event);\r\n  }\r\n\r\n  /**\r\n   * Is current platform browser\r\n   */\r\n  private get isBrowser(): boolean {\r\n    return isPlatformBrowser(this._platformId);\r\n  }\r\n\r\n  /**\r\n   * Creates content inside provided ViewContainerRef\r\n   */\r\n  private createDynamicContent(changes: QueryList<ViewContainerRef>, factory: ComponentFactory<Component>): void {\r\n    changes.forEach((viewContainerRef: ViewContainerRef) => {\r\n      viewContainerRef.clear();\r\n      viewContainerRef.createComponent(factory);\r\n      this.markForCheck();\r\n    });\r\n  }\r\n}\r\n"]}
import { CommonModule } from '@angular/common';
import { NgModule } from '@angular/core';
import { NtkSmartModalStackService } from './ntk-smart-modal-stack.service';
import { NtkSmartModalComponent } from './ntk-smart-modal.component';
import { NtkSmartModalService } from './ntk-smart-modal.service';
import { NtkSmartModalComponent } from './ntk-smart-modal.component';
export class NtkSmartModalModule {

@@ -12,3 +13,6 @@ /**

ngModule: NtkSmartModalModule,
providers: [NtkSmartModalService],
providers: [
NtkSmartModalService,
NtkSmartModalStackService
],
};

@@ -22,3 +26,6 @@ }

ngModule: NtkSmartModalModule,
providers: [NtkSmartModalService],
providers: [
NtkSmartModalService,
NtkSmartModalStackService
],
};

@@ -34,2 +41,2 @@ }

];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnRrLXNtYXJ0LW1vZGFsLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJEOi9Tb3VyY2VLYXJhdmkvR2l0SHViL25wbS1udGstY21zLWFuZ3VsYXIvcHJvamVjdHMvbmd4LW50ay1zbWFydC1tb2R1bGUvc3JjLyIsInNvdXJjZXMiOlsibGliL21vZGFsL250ay1zbWFydC1tb2RhbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBT3JFLE1BQU0sT0FBTyxtQkFBbUI7SUFDOUI7O09BRUc7SUFDSSxNQUFNLENBQUMsT0FBTztRQUNuQixPQUFPO1lBQ0wsUUFBUSxFQUFFLG1CQUFtQjtZQUM3QixTQUFTLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztTQUNsQyxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLFFBQVE7UUFDcEIsT0FBTztZQUNMLFFBQVEsRUFBRSxtQkFBbUI7WUFDN0IsU0FBUyxFQUFFLENBQUMsb0JBQW9CLENBQUM7U0FDbEMsQ0FBQztJQUNKLENBQUM7OztZQXhCRixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Z0JBQ3RDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2dCQUNqQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7YUFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOdGtTbWFydE1vZGFsU2VydmljZSB9IGZyb20gJy4vbnRrLXNtYXJ0LW1vZGFsLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBOdGtTbWFydE1vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9udGstc21hcnQtbW9kYWwuY29tcG9uZW50JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbTnRrU21hcnRNb2RhbENvbXBvbmVudF0sXHJcbiAgZXhwb3J0czogW050a1NtYXJ0TW9kYWxDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgTnRrU21hcnRNb2RhbE1vZHVsZSB7XHJcbiAgLyoqXHJcbiAgICogVXNlIGluIEFwcE1vZHVsZTogbmV3IGluc3RhbmNlIG9mIE50a1NtYXJ0TW9kYWwuXHJcbiAgICovXHJcbiAgcHVibGljIHN0YXRpYyBmb3JSb290KCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TnRrU21hcnRNb2RhbE1vZHVsZT4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbmdNb2R1bGU6IE50a1NtYXJ0TW9kYWxNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogW050a1NtYXJ0TW9kYWxTZXJ2aWNlXSxcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBVc2UgaW4gZmVhdHVyZXMgbW9kdWxlcyB3aXRoIGxhenkgbG9hZGluZzogbmV3IGluc3RhbmNlIG9mIE50a1NtYXJ0TW9kYWwuXHJcbiAgICovXHJcbiAgcHVibGljIHN0YXRpYyBmb3JDaGlsZCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPE50a1NtYXJ0TW9kYWxNb2R1bGU+IHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIG5nTW9kdWxlOiBOdGtTbWFydE1vZGFsTW9kdWxlLFxyXG4gICAgICBwcm92aWRlcnM6IFtOdGtTbWFydE1vZGFsU2VydmljZV0sXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnRrLXNtYXJ0LW1vZGFsLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJEOi9Tb3VyY2VLYXJhdmkvR2l0SHViL25wbS1udGstY21zLWFuZ3VsYXIvcHJvamVjdHMvbmd4LW50ay1zbWFydC1tb2R1bGUvc3JjLyIsInNvdXJjZXMiOlsibGliL21vZGFsL250ay1zbWFydC1tb2RhbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBT2pFLE1BQU0sT0FBTyxtQkFBbUI7SUFDOUI7O09BRUc7SUFDSSxNQUFNLENBQUMsT0FBTztRQUNuQixPQUFPO1lBQ0wsUUFBUSxFQUFFLG1CQUFtQjtZQUM3QixTQUFTLEVBQUU7Z0JBQ1Qsb0JBQW9CO2dCQUNwQix5QkFBeUI7YUFDMUI7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLFFBQVE7UUFDcEIsT0FBTztZQUNMLFFBQVEsRUFBRSxtQkFBbUI7WUFDN0IsU0FBUyxFQUFFO2dCQUNULG9CQUFvQjtnQkFDcEIseUJBQXlCO2FBQzFCO1NBQ0YsQ0FBQztJQUNKLENBQUM7OztZQTlCRixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Z0JBQ3RDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2dCQUNqQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7YUFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOdGtTbWFydE1vZGFsU3RhY2tTZXJ2aWNlIH0gZnJvbSAnLi9udGstc21hcnQtbW9kYWwtc3RhY2suc2VydmljZSc7XHJcbmltcG9ydCB7IE50a1NtYXJ0TW9kYWxDb21wb25lbnQgfSBmcm9tICcuL250ay1zbWFydC1tb2RhbC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBOdGtTbWFydE1vZGFsU2VydmljZSB9IGZyb20gJy4vbnRrLXNtYXJ0LW1vZGFsLnNlcnZpY2UnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtOdGtTbWFydE1vZGFsQ29tcG9uZW50XSxcclxuICBleHBvcnRzOiBbTnRrU21hcnRNb2RhbENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOdGtTbWFydE1vZGFsTW9kdWxlIHtcclxuICAvKipcclxuICAgKiBVc2UgaW4gQXBwTW9kdWxlOiBuZXcgaW5zdGFuY2Ugb2YgTnRrU21hcnRNb2RhbC5cclxuICAgKi9cclxuICBwdWJsaWMgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxOdGtTbWFydE1vZGFsTW9kdWxlPiB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICBuZ01vZHVsZTogTnRrU21hcnRNb2RhbE1vZHVsZSxcclxuICAgICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgICAgTnRrU21hcnRNb2RhbFNlcnZpY2UsXHJcbiAgICAgICAgTnRrU21hcnRNb2RhbFN0YWNrU2VydmljZVxyXG4gICAgICBdLFxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFVzZSBpbiBmZWF0dXJlcyBtb2R1bGVzIHdpdGggbGF6eSBsb2FkaW5nOiBuZXcgaW5zdGFuY2Ugb2YgTnRrU21hcnRNb2RhbC5cclxuICAgKi9cclxuICBwdWJsaWMgc3RhdGljIGZvckNoaWxkKCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TnRrU21hcnRNb2RhbE1vZHVsZT4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbmdNb2R1bGU6IE50a1NtYXJ0TW9kYWxNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIE50a1NtYXJ0TW9kYWxTZXJ2aWNlLFxyXG4gICAgICAgIE50a1NtYXJ0TW9kYWxTdGFja1NlcnZpY2VcclxuICAgICAgXSxcclxuICAgIH07XHJcbiAgfVxyXG59XHJcbiJdfQ==

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

import { Injectable } from '@angular/core';
import { Injectable, ComponentFactoryResolver, ApplicationRef, Injector, Inject, TemplateRef, Type, PLATFORM_ID } from '@angular/core';
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
import { NtkSmartModalStackService } from './ntk-smart-modal-stack.service';
import { NtkSmartModalComponent } from './ntk-smart-modal.component';
import { NtkSmartModalConfig } from './ntk-smart-modal.config';
export class NtkSmartModalService {
constructor() {
this.modalStack = [];
constructor(_componentFactoryResolver, _appRef, _injector, _modalStack, applicationRef, _document, _platformId) {
this._componentFactoryResolver = _componentFactoryResolver;
this._appRef = _appRef;
this._injector = _injector;
this._modalStack = _modalStack;
this.applicationRef = applicationRef;
this._document = _document;
this._platformId = _platformId;
/**
* Close the latest opened modal if escape key event is emitted
* @param event The Keyboard Event
*/
this._escapeKeyboardEvent = (event) => {
if (event.key === 'Escape') {
try {
const modal = this.getTopOpenedModal();
if (!modal.escapable) {
return false;
}
modal.onEscape.emit(modal);
this.closeLatestModal();
return true;
}
catch (e) {
return false;
}
}
return false;
};
/**
* While modal is open, the focus stay on it
* @param event The Keyboar dEvent
*/
this._trapFocusModal = (event) => {
if (event.key === 'Tab') {
try {
const modal = this.getTopOpenedModal();
if (!modal.nsmDialog.first.nativeElement.contains(document.activeElement)) {
event.preventDefault();
event.stopPropagation();
modal.nsmDialog.first.nativeElement.focus();
}
return true;
}
catch (e) {
return false;
}
}
return false;
};
this._addEvents();
}

@@ -15,15 +68,3 @@ /**

addModal(modalInstance, force) {
if (force) {
const i = this.modalStack.findIndex((o) => {
return o.id === modalInstance.id;
});
if (i > -1) {
this.modalStack[i].modal = modalInstance.modal;
}
else {
this.modalStack.push(modalInstance);
}
return;
}
this.modalStack.push(modalInstance);
this._modalStack.addModal(modalInstance, force);
}

@@ -36,12 +77,3 @@ /**

getModal(id) {
if (!this.modalStack || this.modalStack.length === 0) {
return null;
}
const ret = this.modalStack.filter((o) => {
return o.id === id;
})[0];
if (!ret) {
return null;
}
return ret.modal;
return this._modalStack.getModal(id);
}

@@ -63,11 +95,3 @@ /**

open(id, force = false) {
const instance = this.modalStack.find((o) => {
return o.id === id;
});
if (!!instance) {
instance.modal.open(force);
}
else {
throw new Error('Modal not found');
}
return this._openModal(this.get(id), force);
}

@@ -80,11 +104,11 @@ /**

close(id) {
const instance = this.modalStack.find((o) => {
return o.id === id;
return this._closeModal(this.get(id));
}
/**
* Close all opened modals
*/
closeAll() {
this.getOpenedModals().forEach((instance) => {
this._closeModal(instance.modal);
});
if (!!instance) {
instance.modal.close();
}
else {
throw new Error('Modal not found');
}
}

@@ -99,11 +123,3 @@ /**

toggle(id, force = false) {
const instance = this.modalStack.find((o) => {
return o.id === id;
});
if (!!instance) {
instance.modal.toggle(force);
}
else {
throw new Error('Modal not found');
}
return this._toggleModal(this.get(id), force);
}

@@ -116,3 +132,3 @@ /**

getModalStack() {
return this.modalStack;
return this._modalStack.getModalStack();
}

@@ -125,11 +141,13 @@ /**

getOpenedModals() {
const modals = [];
this.modalStack.forEach((o) => {
if (o.modal.visible) {
modals.push(o);
}
});
return modals;
return this._modalStack.getOpenedModals();
}
/**
* Retrieve the opened modal with highest z-index.
*
* @returns the opened modal with highest z-index.
*/
getTopOpenedModal() {
return this._modalStack.getTopOpenedModal();
}
/**
* Get the higher `z-index` value between all the modal instances. It iterates over the `ModalStack` array and

@@ -142,8 +160,3 @@ * calculates a higher value (it takes the highest index value between all the modal instances and adds 1).

getHigherIndex() {
const index = [1041];
const modals = this.getModalStack();
modals.forEach((o) => {
index.push(o.modal.layerPosition);
});
return Math.max(...index) + 1;
return this._modalStack.getHigherIndex();
}

@@ -156,3 +169,3 @@ /**

getModalStackCount() {
return this.modalStack.length;
return this._modalStack.getModalStackCount();
}

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

removeModal(id) {
const i = this.modalStack.findIndex((o) => {
return o.id === id;
});
if (i > -1) {
this.modalStack.splice(i, 1);
}
this._modalStack.removeModal(id);
}

@@ -186,6 +194,5 @@ /**

setModalData(data, id, force) {
if (!!this.modalStack.find((o) => {
return o.id === id;
})) {
this.getModal(id).setData(data, force);
let i;
if (i = this.get(id)) {
i.setData(data, force);
return true;

@@ -204,3 +211,7 @@ }

getModalData(id) {
return this.getModal(id).getData();
let i;
if (i = this.get(id)) {
return i.getData();
}
return null;
}

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

resetModalData(id) {
if (!!this.modalStack.find((o) => {
return o.id === id;
})) {
if (!!this._modalStack.getModalStack().find((o) => o.id === id)) {
const removed = this.getModal(id).getData();

@@ -232,14 +241,214 @@ this.getModal(id).removeData();

closeLatestModal() {
const me = this;
clearTimeout(this.debouncer);
this.debouncer = setTimeout(() => {
let tmp;
me.getOpenedModals().forEach((m) => {
if (m.modal.layerPosition > (!!tmp ? tmp.modal.layerPosition : 0 && m.modal.escapable)) {
tmp = m;
}
});
return !!tmp ? tmp.modal.close() : false;
}, 100);
this.getTopOpenedModal().close();
}
/**
* Create dynamic NtkSmartModalComponent
* @param id The modal identifier used at creation time.
* @param content The modal content ( string, templateRef or Component )
*/
create(id, content, options = {}) {
try {
return this.getModal(id);
}
catch (e) {
const componentFactory = this._componentFactoryResolver.resolveComponentFactory(NtkSmartModalComponent);
const ngContent = this._resolveNgContent(content);
const componentRef = componentFactory.create(this._injector, ngContent);
if (content instanceof Type) {
componentRef.instance.contentComponent = content;
}
componentRef.instance.identifier = id;
componentRef.instance.createFrom = 'service';
if (typeof options.closable === 'boolean') {
componentRef.instance.closable = options.closable;
}
if (typeof options.escapable === 'boolean') {
componentRef.instance.escapable = options.escapable;
}
if (typeof options.dismissable === 'boolean') {
componentRef.instance.dismissable = options.dismissable;
}
if (typeof options.customClass === 'string') {
componentRef.instance.customClass = options.customClass;
}
if (typeof options.backdrop === 'boolean') {
componentRef.instance.backdrop = options.backdrop;
}
if (typeof options.force === 'boolean') {
componentRef.instance.force = options.force;
}
if (typeof options.hideDelay === 'number') {
componentRef.instance.hideDelay = options.hideDelay;
}
if (typeof options.autostart === 'boolean') {
componentRef.instance.autostart = options.autostart;
}
if (typeof options.target === 'string') {
componentRef.instance.target = options.target;
}
if (typeof options.ariaLabel === 'string') {
componentRef.instance.ariaLabel = options.ariaLabel;
}
if (typeof options.ariaLabelledBy === 'string') {
componentRef.instance.ariaLabelledBy = options.ariaLabelledBy;
}
if (typeof options.ariaDescribedBy === 'string') {
componentRef.instance.ariaDescribedBy = options.ariaDescribedBy;
}
if (typeof options.refocus === 'boolean') {
componentRef.instance.refocus = options.refocus;
}
this._appRef.attachView(componentRef.hostView);
const domElem = componentRef.hostView.rootNodes[0];
this._document.body.appendChild(domElem);
return componentRef.instance;
}
}
_addEvents() {
if (!this.isBrowser) {
return false;
}
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'create', ((e) => {
this._initModal(e.detail.instance);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'delete', ((e) => {
this._deleteModal(e.detail.instance);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'open', ((e) => {
this._openModal(e.detail.instance.modal, e.detail.top);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'toggle', ((e) => {
this._toggleModal(e.detail.instance.modal, e.detail.top);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'close', ((e) => {
this._closeModal(e.detail.instance.modal);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'dismiss', ((e) => {
this._dismissModal(e.detail.instance.modal);
}));
window.addEventListener('keyup', this._escapeKeyboardEvent);
return true;
}
_initModal(modalInstance) {
modalInstance.modal.layerPosition += this.getModalStackCount();
this.addModal(modalInstance, modalInstance.modal.force);
if (modalInstance.modal.autostart) {
this.open(modalInstance.id);
}
}
_openModal(modal, top) {
if (modal.visible) {
return false;
}
this.lastElementFocused = document.activeElement;
if (modal.escapable) {
window.addEventListener('keyup', this._escapeKeyboardEvent);
}
if (modal.backdrop) {
window.addEventListener('keydown', this._trapFocusModal);
}
if (top) {
modal.layerPosition = this.getHigherIndex();
}
modal.addBodyClass();
modal.overlayVisible = true;
modal.visible = true;
modal.onOpen.emit(modal);
modal.markForCheck();
setTimeout(() => {
modal.openedClass = true;
if (modal.target) {
modal.targetPlacement();
}
modal.nsmDialog.first.nativeElement.setAttribute('role', 'dialog');
modal.nsmDialog.first.nativeElement.setAttribute('tabIndex', '-1');
modal.nsmDialog.first.nativeElement.setAttribute('aria-modal', 'true');
modal.nsmDialog.first.nativeElement.focus();
modal.markForCheck();
modal.onOpenFinished.emit(modal);
});
return true;
}
_toggleModal(modal, top) {
if (modal.visible) {
return this._closeModal(modal);
}
else {
return this._openModal(modal, top);
}
}
_closeModal(modal) {
if (!modal.openedClass) {
return false;
}
modal.openedClass = false;
modal.onClose.emit(modal);
modal.onAnyCloseEvent.emit(modal);
if (this.getOpenedModals().length < 2) {
modal.removeBodyClass();
window.removeEventListener('keyup', this._escapeKeyboardEvent);
window.removeEventListener('keydown', this._trapFocusModal);
}
setTimeout(() => {
modal.visibleChange.emit(modal.visible);
modal.visible = false;
modal.overlayVisible = false;
modal.nsmDialog.first.nativeElement.removeAttribute('tabIndex');
modal.markForCheck();
modal.onCloseFinished.emit(modal);
modal.onAnyCloseEventFinished.emit(modal);
if (modal.refocus) {
this.lastElementFocused.focus();
}
}, modal.hideDelay);
return true;
}
_dismissModal(modal) {
if (!modal.openedClass) {
return false;
}
modal.openedClass = false;
modal.onDismiss.emit(modal);
modal.onAnyCloseEvent.emit(modal);
if (this.getOpenedModals().length < 2) {
modal.removeBodyClass();
}
setTimeout(() => {
modal.visible = false;
modal.visibleChange.emit(modal.visible);
modal.overlayVisible = false;
modal.markForCheck();
modal.onDismissFinished.emit(modal);
modal.onAnyCloseEventFinished.emit(modal);
}, modal.hideDelay);
return true;
}
_deleteModal(modalInstance) {
this.removeModal(modalInstance.id);
if (!this.getModalStack().length) {
modalInstance.modal.removeBodyClass();
}
}
/**
* Resolve content according to the types
* @param content The modal content ( string, templateRef or Component )
*/
_resolveNgContent(content) {
if (typeof content === 'string') {
const element = this._document.createTextNode(content);
return [[element]];
}
if (content instanceof TemplateRef) {
const viewRef = content.createEmbeddedView(null);
this.applicationRef.attachView(viewRef);
return [viewRef.rootNodes];
}
return [];
}
/**
* Is current platform browser
*/
get isBrowser() {
return isPlatformBrowser(this._platformId);
}
}

@@ -249,2 +458,11 @@ NtkSmartModalService.decorators = [

];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ntk-smart-modal.service.js","sourceRoot":"D:/SourceKaravi/GitHub/npm-ntk-cms-angular/projects/ngx-ntk-smart-module/src/","sources":["lib/modal/ntk-smart-modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { NtkSmartModalComponent } from './ntk-smart-modal.component';\r\nimport { ModalInstance } from './modal-instance';\r\n\r\n@Injectable()\r\nexport class NtkSmartModalService {\r\n  public modalStack: ModalInstance[] = [];\r\n  private debouncer: any;\r\n\r\n  /**\r\n   * Add a new modal instance. This step is essential and allows to retrieve any modal at any time.\r\n   * It stores an object that contains the given modal identifier and the modal itself directly in the `modalStack`.\r\n   *\r\n   * @param modalInstance The object that contains the given modal identifier and the modal itself.\r\n   * @param force Optional parameter that forces the overriding of modal instance if it already exists.\r\n   * @returns nothing special.\r\n   */\r\n  public addModal(modalInstance: ModalInstance, force?: boolean): void {\r\n    if (force) {\r\n      const i: number = this.modalStack.findIndex((o: ModalInstance) => {\r\n        return o.id === modalInstance.id;\r\n      });\r\n      if (i > -1) {\r\n        this.modalStack[i].modal = modalInstance.modal;\r\n      } else {\r\n        this.modalStack.push(modalInstance);\r\n      }\r\n      return;\r\n    }\r\n    this.modalStack.push(modalInstance);\r\n  }\r\n\r\n  /**\r\n   * Retrieve a modal instance by its identifier.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   */\r\n  public getModal(id: string): NtkSmartModalComponent | null {\r\n    if (!this.modalStack || this.modalStack.length === 0) {\r\n      return null;\r\n    }\r\n    const ret = this.modalStack.filter((o: any) => {\r\n      return o.id === id;\r\n    })[0];\r\n    if (!ret) {\r\n      return null;\r\n    }\r\n    return ret.modal;\r\n  }\r\n\r\n  /**\r\n   * Alias of `getModal` to retrieve a modal instance by its identifier.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   */\r\n  public get(id: string): NtkSmartModalComponent {\r\n    return this.getModal(id);\r\n  }\r\n\r\n  /**\r\n   * Open a given modal\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @param force Tell the modal to open top of all other opened modals\r\n   */\r\n  public open(id: string, force = false): void {\r\n    const instance = this.modalStack.find((o: ModalInstance) => {\r\n      return o.id === id;\r\n    });\r\n    if (!!instance) {\r\n      instance.modal.open(force);\r\n    } else {\r\n      throw new Error('Modal not found');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Close a given modal\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   */\r\n  public close(id: string): void {\r\n    const instance = this.modalStack.find((o: ModalInstance) => {\r\n      return o.id === id;\r\n    });\r\n    if (!!instance) {\r\n      instance.modal.close();\r\n    } else {\r\n      throw new Error('Modal not found');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Toggles a given modal\r\n   * If the retrieved modal is opened it closes it, else it opens it.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @param force Tell the modal to open top of all other opened modals\r\n   */\r\n  public toggle(id: string, force = false): any {\r\n    const instance = this.modalStack.find((o: ModalInstance) => {\r\n      return o.id === id;\r\n    });\r\n    if (!!instance) {\r\n      instance.modal.toggle(force);\r\n    } else {\r\n      throw new Error('Modal not found');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the created modals.\r\n   *\r\n   * @returns an array that contains all modal instances.\r\n   */\r\n  public getModalStack(): ModalInstance[] {\r\n    return this.modalStack;\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the opened modals. It looks for all modal instances with their `visible` property set to `true`.\r\n   *\r\n   * @returns an array that contains all the opened modals.\r\n   */\r\n  public getOpenedModals(): ModalInstance[] {\r\n    const modals: ModalInstance[] = [];\r\n    this.modalStack.forEach((o: ModalInstance) => {\r\n      if (o.modal.visible) {\r\n        modals.push(o);\r\n      }\r\n    });\r\n    return modals;\r\n  }\r\n\r\n  /**\r\n   * Get the higher `z-index` value between all the modal instances. It iterates over the `ModalStack` array and\r\n   * calculates a higher value (it takes the highest index value between all the modal instances and adds 1).\r\n   * Use it to make a modal appear foreground.\r\n   *\r\n   * @returns a higher index from all the existing modal instances.\r\n   */\r\n  public getHigherIndex(): number {\r\n    const index: number[] = [1041];\r\n    const modals: ModalInstance[] = this.getModalStack();\r\n    modals.forEach((o: ModalInstance) => {\r\n      index.push(o.modal.layerPosition);\r\n    });\r\n    return Math.max(...index) + 1;\r\n  }\r\n\r\n  /**\r\n   * It gives the number of modal instances. It's helpful to know if the modal stack is empty or not.\r\n   *\r\n   * @returns the number of modal instances.\r\n   */\r\n  public getModalStackCount(): number {\r\n    return this.modalStack.length;\r\n  }\r\n\r\n  /**\r\n   * Remove a modal instance from the modal stack.\r\n   *\r\n   * @param id The modal identifier.\r\n   * @returns the removed modal instance.\r\n   */\r\n  public removeModal(id: string): void {\r\n    const i: number = this.modalStack.findIndex((o: any) => {\r\n      return o.id === id;\r\n    });\r\n    if (i > -1) {\r\n      this.modalStack.splice(i, 1);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Associate data to an identified modal. If the modal isn't already associated to some data, it creates a new\r\n   * entry in the `modalData` array with its `id` and the given `data`. If the modal already has data, it rewrites\r\n   * them with the new ones. Finally if no modal found it returns an error message in the console and false value\r\n   * as method output.\r\n   *\r\n   * @param data The data you want to associate to the modal.\r\n   * @param id The modal identifier.\r\n   * @param force If true, overrides the previous stored data if there was.\r\n   * @returns true if the given modal exists and the process has been tried, either false.\r\n   */\r\n  public setModalData(data: any, id: string, force?: boolean): boolean {\r\n    if (\r\n      !!this.modalStack.find((o: ModalInstance) => {\r\n        return o.id === id;\r\n      })\r\n    ) {\r\n      this.getModal(id).setData(data, force);\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieve modal data by its identifier.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @returns the associated modal data.\r\n   */\r\n  public getModalData(id: string): any {\r\n    return this.getModal(id).getData();\r\n  }\r\n\r\n  /**\r\n   * Reset the data attached to a given modal.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @returns the removed data or false if modal doesn't exist.\r\n   */\r\n  public resetModalData(id: string): any | boolean {\r\n    if (\r\n      !!this.modalStack.find((o: ModalInstance) => {\r\n        return o.id === id;\r\n      })\r\n    ) {\r\n      const removed: any = this.getModal(id).getData();\r\n      this.getModal(id).removeData();\r\n      return removed;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Close the latest opened modal if it has been declared as escapable\r\n   * Using a debounce system because one or more modals could be listening\r\n   * escape key press event.\r\n   */\r\n  public closeLatestModal(): void {\r\n    const me = this;\r\n    clearTimeout(this.debouncer);\r\n    this.debouncer = setTimeout(() => {\r\n      let tmp: ModalInstance | undefined;\r\n      me.getOpenedModals().forEach((m: ModalInstance) => {\r\n        if (m.modal.layerPosition > (!!tmp ? tmp.modal.layerPosition : 0 && m.modal.escapable)) {\r\n          tmp = m;\r\n        }\r\n      });\r\n      return !!tmp ? tmp.modal.close() : false;\r\n    }, 100);\r\n  }\r\n}\r\n"]}
NtkSmartModalService.ctorParameters = () => [
{ type: ComponentFactoryResolver },
{ type: ApplicationRef },
{ type: Injector },
{ type: NtkSmartModalStackService },
{ type: ApplicationRef },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ntk-smart-modal.service.js","sourceRoot":"D:/SourceKaravi/GitHub/npm-ntk-cms-angular/projects/ngx-ntk-smart-module/src/","sources":["lib/modal/ntk-smart-modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Injectable,\r\n  ComponentFactoryResolver,\r\n  ApplicationRef,\r\n  Injector,\r\n  EmbeddedViewRef,\r\n  Inject,\r\n  TemplateRef,\r\n  Type,\r\n  PLATFORM_ID\r\n} from '@angular/core';\r\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\n\r\n\r\nimport { ModalInstance } from './modal-instance';\r\nimport { NtkSmartModalStackService } from './ntk-smart-modal-stack.service';\r\nimport { NtkSmartModalComponent } from './ntk-smart-modal.component';\r\nimport { INtkSmartModalOptions, NtkSmartModalConfig } from './ntk-smart-modal.config';\r\n\r\nexport type Content<T> = string | TemplateRef<T> | Type<T>;\r\n\r\n@Injectable()\r\nexport class NtkSmartModalService {\r\n  private lastElementFocused: any;\r\n\r\n  constructor(\r\n    private _componentFactoryResolver: ComponentFactoryResolver,\r\n    private _appRef: ApplicationRef,\r\n    private _injector: Injector,\r\n    private _modalStack: NtkSmartModalStackService,\r\n    private applicationRef: ApplicationRef,\r\n    @Inject(DOCUMENT) private _document: any,\r\n    @Inject(PLATFORM_ID) private _platformId: any\r\n  ) {\r\n    this._addEvents();\r\n  }\r\n\r\n  /**\r\n   * Add a new modal instance. This step is essential and allows to retrieve any modal at any time.\r\n   * It stores an object that contains the given modal identifier and the modal itself directly in the `modalStack`.\r\n   *\r\n   * @param modalInstance The object that contains the given modal identifier and the modal itself.\r\n   * @param force Optional parameter that forces the overriding of modal instance if it already exists.\r\n   * @returns nothing special.\r\n   */\r\n  public addModal(modalInstance: ModalInstance, force?: boolean): void {\r\n    this._modalStack.addModal(modalInstance, force);\r\n  }\r\n\r\n  /**\r\n   * Retrieve a modal instance by its identifier.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   */\r\n  public getModal(id: string): NtkSmartModalComponent {\r\n    return this._modalStack.getModal(id);\r\n  }\r\n\r\n  /**\r\n   * Alias of `getModal` to retrieve a modal instance by its identifier.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   */\r\n  public get(id: string): NtkSmartModalComponent {\r\n    return this.getModal(id);\r\n  }\r\n\r\n  /**\r\n   * Open a given modal\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @param force Tell the modal to open top of all other opened modals\r\n   */\r\n  public open(id: string, force = false): boolean {\r\n    return this._openModal(this.get(id), force);\r\n  }\r\n\r\n  /**\r\n   * Close a given modal\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   */\r\n  public close(id: string): boolean {\r\n    return this._closeModal(this.get(id));\r\n  }\r\n\r\n  /**\r\n   * Close all opened modals\r\n   */\r\n  public closeAll(): void {\r\n    this.getOpenedModals().forEach((instance: ModalInstance) => {\r\n      this._closeModal(instance.modal);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Toggles a given modal\r\n   * If the retrieved modal is opened it closes it, else it opens it.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @param force Tell the modal to open top of all other opened modals\r\n   */\r\n  public toggle(id: string, force = false): boolean {\r\n    return this._toggleModal(this.get(id), force);\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the created modals.\r\n   *\r\n   * @returns an array that contains all modal instances.\r\n   */\r\n  public getModalStack(): ModalInstance[] {\r\n    return this._modalStack.getModalStack();\r\n  }\r\n\r\n  /**\r\n   * Retrieve all the opened modals. It looks for all modal instances with their `visible` property set to `true`.\r\n   *\r\n   * @returns an array that contains all the opened modals.\r\n   */\r\n  public getOpenedModals(): ModalInstance[] {\r\n    return this._modalStack.getOpenedModals();\r\n  }\r\n\r\n  /**\r\n   * Retrieve the opened modal with highest z-index.\r\n   *\r\n   * @returns the opened modal with highest z-index.\r\n   */\r\n  public getTopOpenedModal(): NtkSmartModalComponent {\r\n    return this._modalStack.getTopOpenedModal();\r\n  }\r\n\r\n  /**\r\n   * Get the higher `z-index` value between all the modal instances. It iterates over the `ModalStack` array and\r\n   * calculates a higher value (it takes the highest index value between all the modal instances and adds 1).\r\n   * Use it to make a modal appear foreground.\r\n   *\r\n   * @returns a higher index from all the existing modal instances.\r\n   */\r\n  public getHigherIndex(): number {\r\n    return this._modalStack.getHigherIndex();\r\n  }\r\n\r\n  /**\r\n   * It gives the number of modal instances. It's helpful to know if the modal stack is empty or not.\r\n   *\r\n   * @returns the number of modal instances.\r\n   */\r\n  public getModalStackCount(): number {\r\n    return this._modalStack.getModalStackCount();\r\n  }\r\n\r\n  /**\r\n   * Remove a modal instance from the modal stack.\r\n   *\r\n   * @param id The modal identifier.\r\n   * @returns the removed modal instance.\r\n   */\r\n  public removeModal(id: string): void {\r\n    this._modalStack.removeModal(id);\r\n  }\r\n\r\n  /**\r\n   * Associate data to an identified modal. If the modal isn't already associated to some data, it creates a new\r\n   * entry in the `modalData` array with its `id` and the given `data`. If the modal already has data, it rewrites\r\n   * them with the new ones. Finally if no modal found it returns an error message in the console and false value\r\n   * as method output.\r\n   *\r\n   * @param data The data you want to associate to the modal.\r\n   * @param id The modal identifier.\r\n   * @param force If true, overrides the previous stored data if there was.\r\n   * @returns true if the given modal exists and the process has been tried, either false.\r\n   */\r\n  public setModalData(data: any, id: string, force?: boolean): boolean {\r\n    let i;\r\n    if (i = this.get(id)) {\r\n      i.setData(data, force);\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieve modal data by its identifier.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @returns the associated modal data.\r\n   */\r\n  public getModalData(id: string): any {\r\n    let i;\r\n    if (i = this.get(id)) {\r\n      return i.getData();\r\n    }\r\n\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * Reset the data attached to a given modal.\r\n   *\r\n   * @param id The modal identifier used at creation time.\r\n   * @returns the removed data or false if modal doesn't exist.\r\n   */\r\n  public resetModalData(id: string): any | boolean {\r\n    if (!!this._modalStack.getModalStack().find((o: ModalInstance) => o.id === id)) {\r\n      const removed: any = this.getModal(id).getData();\r\n      this.getModal(id).removeData();\r\n      return removed;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Close the latest opened modal if it has been declared as escapable\r\n   * Using a debounce system because one or more modals could be listening\r\n   * escape key press event.\r\n   */\r\n  public closeLatestModal(): void {\r\n    this.getTopOpenedModal().close();\r\n  }\r\n\r\n  /**\r\n   * Create dynamic NtkSmartModalComponent\r\n   * @param id The modal identifier used at creation time.\r\n   * @param content The modal content ( string, templateRef or Component )\r\n   */\r\n  public create<T>(id: string, content: Content<T>, options: INtkSmartModalOptions = {}) {\r\n    try {\r\n      return this.getModal(id);\r\n    } catch (e) {\r\n      const componentFactory = this._componentFactoryResolver.resolveComponentFactory(NtkSmartModalComponent);\r\n      const ngContent = this._resolveNgContent(content);\r\n\r\n      const componentRef = componentFactory.create(this._injector, ngContent);\r\n\r\n      if (content instanceof Type) {\r\n        componentRef.instance.contentComponent = content;\r\n      }\r\n\r\n      componentRef.instance.identifier = id;\r\n      componentRef.instance.createFrom = 'service';\r\n\r\n      if (typeof options.closable === 'boolean') { componentRef.instance.closable = options.closable; }\r\n      if (typeof options.escapable === 'boolean') { componentRef.instance.escapable = options.escapable; }\r\n      if (typeof options.dismissable === 'boolean') { componentRef.instance.dismissable = options.dismissable; }\r\n      if (typeof options.customClass === 'string') { componentRef.instance.customClass = options.customClass; }\r\n      if (typeof options.backdrop === 'boolean') { componentRef.instance.backdrop = options.backdrop; }\r\n      if (typeof options.force === 'boolean') { componentRef.instance.force = options.force; }\r\n      if (typeof options.hideDelay === 'number') { componentRef.instance.hideDelay = options.hideDelay; }\r\n      if (typeof options.autostart === 'boolean') { componentRef.instance.autostart = options.autostart; }\r\n      if (typeof options.target === 'string') { componentRef.instance.target = options.target; }\r\n      if (typeof options.ariaLabel === 'string') { componentRef.instance.ariaLabel = options.ariaLabel; }\r\n      if (typeof options.ariaLabelledBy === 'string') { componentRef.instance.ariaLabelledBy = options.ariaLabelledBy; }\r\n      if (typeof options.ariaDescribedBy === 'string') { componentRef.instance.ariaDescribedBy = options.ariaDescribedBy; }\r\n      if (typeof options.refocus === 'boolean') { componentRef.instance.refocus = options.refocus; }\r\n\r\n      this._appRef.attachView(componentRef.hostView);\r\n\r\n      const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\r\n      this._document.body.appendChild(domElem);\r\n\r\n      return componentRef.instance;\r\n    }\r\n  }\r\n\r\n  private _addEvents(): boolean {\r\n    if (!this.isBrowser) {\r\n      return false;\r\n    }\r\n\r\n    window.addEventListener(NtkSmartModalConfig.prefixEvent + 'create', ((e: CustomEvent) => {\r\n      this._initModal(e.detail.instance);\r\n    }) as EventListener);\r\n\r\n    window.addEventListener(NtkSmartModalConfig.prefixEvent + 'delete', ((e: CustomEvent) => {\r\n      this._deleteModal(e.detail.instance);\r\n    }) as EventListener);\r\n\r\n    window.addEventListener(NtkSmartModalConfig.prefixEvent + 'open', ((e: CustomEvent) => {\r\n      this._openModal(e.detail.instance.modal, e.detail.top);\r\n    }) as EventListener);\r\n\r\n    window.addEventListener(NtkSmartModalConfig.prefixEvent + 'toggle', ((e: CustomEvent) => {\r\n      this._toggleModal(e.detail.instance.modal, e.detail.top);\r\n    }) as EventListener);\r\n\r\n    window.addEventListener(NtkSmartModalConfig.prefixEvent + 'close', ((e: CustomEvent) => {\r\n      this._closeModal(e.detail.instance.modal);\r\n    }) as EventListener);\r\n\r\n    window.addEventListener(NtkSmartModalConfig.prefixEvent + 'dismiss', ((e: CustomEvent) => {\r\n      this._dismissModal(e.detail.instance.modal);\r\n    }) as EventListener);\r\n\r\n    window.addEventListener('keyup', this._escapeKeyboardEvent);\r\n\r\n    return true;\r\n  }\r\n\r\n  private _initModal(modalInstance: ModalInstance) {\r\n    modalInstance.modal.layerPosition += this.getModalStackCount();\r\n    this.addModal(modalInstance, modalInstance.modal.force);\r\n\r\n    if (modalInstance.modal.autostart) {\r\n      this.open(modalInstance.id);\r\n    }\r\n  }\r\n\r\n  private _openModal(modal: NtkSmartModalComponent, top?: boolean): boolean {\r\n    if (modal.visible) {\r\n      return false;\r\n    }\r\n\r\n    this.lastElementFocused = document.activeElement;\r\n\r\n    if (modal.escapable) {\r\n      window.addEventListener('keyup', this._escapeKeyboardEvent);\r\n    }\r\n\r\n    if (modal.backdrop) {\r\n      window.addEventListener('keydown', this._trapFocusModal);\r\n    }\r\n\r\n    if (top) {\r\n      modal.layerPosition = this.getHigherIndex();\r\n    }\r\n\r\n    modal.addBodyClass();\r\n    modal.overlayVisible = true;\r\n    modal.visible = true;\r\n    modal.onOpen.emit(modal);\r\n    modal.markForCheck();\r\n\r\n    setTimeout(() => {\r\n      modal.openedClass = true;\r\n\r\n      if (modal.target) {\r\n        modal.targetPlacement();\r\n      }\r\n\r\n      modal.nsmDialog.first.nativeElement.setAttribute('role', 'dialog');\r\n      modal.nsmDialog.first.nativeElement.setAttribute('tabIndex', '-1');\r\n      modal.nsmDialog.first.nativeElement.setAttribute('aria-modal', 'true');\r\n      modal.nsmDialog.first.nativeElement.focus();\r\n\r\n      modal.markForCheck();\r\n      modal.onOpenFinished.emit(modal);\r\n    });\r\n\r\n    return true;\r\n  }\r\n\r\n  private _toggleModal(modal: NtkSmartModalComponent, top?: boolean): boolean {\r\n    if (modal.visible) {\r\n      return this._closeModal(modal);\r\n    } else {\r\n      return this._openModal(modal, top);\r\n    }\r\n  }\r\n\r\n  private _closeModal(modal: NtkSmartModalComponent): boolean {\r\n    if (!modal.openedClass) {\r\n      return false;\r\n    }\r\n\r\n    modal.openedClass = false;\r\n    modal.onClose.emit(modal);\r\n    modal.onAnyCloseEvent.emit(modal);\r\n\r\n    if (this.getOpenedModals().length < 2) {\r\n      modal.removeBodyClass();\r\n      window.removeEventListener('keyup', this._escapeKeyboardEvent);\r\n      window.removeEventListener('keydown', this._trapFocusModal);\r\n    }\r\n\r\n    setTimeout(() => {\r\n      modal.visibleChange.emit(modal.visible);\r\n      modal.visible = false;\r\n      modal.overlayVisible = false;\r\n      modal.nsmDialog.first.nativeElement.removeAttribute('tabIndex');\r\n      modal.markForCheck();\r\n      modal.onCloseFinished.emit(modal);\r\n      modal.onAnyCloseEventFinished.emit(modal);\r\n      if (modal.refocus) {\r\n        this.lastElementFocused.focus();\r\n      }\r\n    }, modal.hideDelay);\r\n\r\n    return true;\r\n  }\r\n\r\n  private _dismissModal(modal: NtkSmartModalComponent): boolean {\r\n    if (!modal.openedClass) {\r\n      return false;\r\n    }\r\n\r\n    modal.openedClass = false;\r\n    modal.onDismiss.emit(modal);\r\n    modal.onAnyCloseEvent.emit(modal);\r\n\r\n    if (this.getOpenedModals().length < 2) {\r\n      modal.removeBodyClass();\r\n    }\r\n\r\n    setTimeout(() => {\r\n      modal.visible = false;\r\n      modal.visibleChange.emit(modal.visible);\r\n      modal.overlayVisible = false;\r\n      modal.markForCheck();\r\n      modal.onDismissFinished.emit(modal);\r\n      modal.onAnyCloseEventFinished.emit(modal);\r\n    }, modal.hideDelay);\r\n\r\n    return true;\r\n  }\r\n\r\n  private _deleteModal(modalInstance: ModalInstance) {\r\n    this.removeModal(modalInstance.id);\r\n\r\n    if (!this.getModalStack().length) {\r\n      modalInstance.modal.removeBodyClass();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Resolve content according to the types\r\n   * @param content The modal content ( string, templateRef or Component )\r\n   */\r\n  private _resolveNgContent<T>(content: Content<T>): any[][] | Text[][] {\r\n    if (typeof content === 'string') {\r\n      const element = this._document.createTextNode(content);\r\n      return [[element]];\r\n    }\r\n\r\n    if (content instanceof TemplateRef) {\r\n      const viewRef = content.createEmbeddedView(null as any);\r\n      this.applicationRef.attachView(viewRef);\r\n      return [viewRef.rootNodes];\r\n    }\r\n\r\n    return [];\r\n  }\r\n\r\n  /**\r\n   * Close the latest opened modal if escape key event is emitted\r\n   * @param event The Keyboard Event\r\n   */\r\n  private _escapeKeyboardEvent = (event: KeyboardEvent) => {\r\n    if (event.key === 'Escape') {\r\n      try {\r\n        const modal = this.getTopOpenedModal();\r\n\r\n        if (!modal.escapable) {\r\n          return false;\r\n        }\r\n\r\n        modal.onEscape.emit(modal);\r\n        this.closeLatestModal();\r\n\r\n        return true;\r\n      } catch (e) {\r\n        return false;\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Is current platform browser\r\n   */\r\n  private get isBrowser(): boolean {\r\n    return isPlatformBrowser(this._platformId);\r\n  }\r\n\r\n  /**\r\n   * While modal is open, the focus stay on it\r\n   * @param event The Keyboar dEvent\r\n   */\r\n  private _trapFocusModal = (event: KeyboardEvent) => {\r\n    if (event.key === 'Tab') {\r\n      try {\r\n        const modal = this.getTopOpenedModal();\r\n\r\n        if (!modal.nsmDialog.first.nativeElement.contains(document.activeElement)) {\r\n          event.preventDefault();\r\n          event.stopPropagation();\r\n          modal.nsmDialog.first.nativeElement.focus();\r\n        }\r\n\r\n        return true;\r\n      } catch (e) {\r\n        return false;\r\n      }\r\n    }\r\n\r\n    return false;\r\n  }\r\n}\r\n"]}

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

export * from './public-api';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LW50ay1zbWFydC1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiRDovU291cmNlS2FyYXZpL0dpdEh1Yi9ucG0tbnRrLWNtcy1hbmd1bGFyL3Byb2plY3RzL25neC1udGstc21hcnQtbW9kdWxlL3NyYy8iLCJzb3VyY2VzIjpbIm5neC1udGstc21hcnQtbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
export { NtkSmartModalStackService as ɵa } from './lib/modal/ntk-smart-modal-stack.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LW50ay1zbWFydC1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiRDovU291cmNlS2FyYXZpL0dpdEh1Yi9ucG0tbnRrLWNtcy1hbmd1bGFyL3Byb2plY3RzL25neC1udGstc21hcnQtbW9kdWxlL3NyYy8iLCJzb3VyY2VzIjpbIm5neC1udGstc21hcnQtbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUM7QUFFN0IsT0FBTyxFQUFDLHlCQUF5QixJQUFJLEVBQUUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuXG5leHBvcnQge050a1NtYXJ0TW9kYWxTdGFja1NlcnZpY2UgYXMgybVhfSBmcm9tICcuL2xpYi9tb2RhbC9udGstc21hcnQtbW9kYWwtc3RhY2suc2VydmljZSc7Il19

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

import { Injectable, EventEmitter, Component, Renderer2, ChangeDetectorRef, Input, Output, ViewChild, HostListener, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Injectable, EventEmitter, Component, Renderer2, ChangeDetectorRef, ComponentFactoryResolver, Inject, PLATFORM_ID, Input, Output, ViewChildren, ViewContainerRef, HostListener, Type, TemplateRef, ApplicationRef, Injector, NgModule, ɵɵdefineInjectable } from '@angular/core';
import { isPlatformBrowser, DOCUMENT, CommonModule } from '@angular/common';
class NtkSmartModalService {
class NtkSmartModalStackService {
constructor() {
this.modalStack = [];
this._modalStack = [];
}

@@ -18,14 +18,12 @@ /**

if (force) {
const i = this.modalStack.findIndex((o) => {
return o.id === modalInstance.id;
});
const i = this._modalStack.findIndex((o) => o.id === modalInstance.id);
if (i > -1) {
this.modalStack[i].modal = modalInstance.modal;
this._modalStack[i].modal = modalInstance.modal;
}
else {
this.modalStack.push(modalInstance);
this._modalStack.push(modalInstance);
}
return;
}
this.modalStack.push(modalInstance);
this._modalStack.push(modalInstance);
}

@@ -38,73 +36,11 @@ /**

getModal(id) {
if (!this.modalStack || this.modalStack.length === 0) {
return null;
const i = this._modalStack.find((o) => o.id === id);
if (i !== undefined) {
return i.modal;
}
const ret = this.modalStack.filter((o) => {
return o.id === id;
})[0];
if (!ret) {
return null;
}
return ret.modal;
}
/**
* Alias of `getModal` to retrieve a modal instance by its identifier.
*
* @param id The modal identifier used at creation time.
*/
get(id) {
return this.getModal(id);
}
/**
* Open a given modal
*
* @param id The modal identifier used at creation time.
* @param force Tell the modal to open top of all other opened modals
*/
open(id, force = false) {
const instance = this.modalStack.find((o) => {
return o.id === id;
});
if (!!instance) {
instance.modal.open(force);
}
else {
throw new Error('Modal not found');
throw new Error(`Cannot find modal with identifier ${id}`);
}
}
/**
* Close a given modal
*
* @param id The modal identifier used at creation time.
*/
close(id) {
const instance = this.modalStack.find((o) => {
return o.id === id;
});
if (!!instance) {
instance.modal.close();
}
else {
throw new Error('Modal not found');
}
}
/**
* Toggles a given modal
* If the retrieved modal is opened it closes it, else it opens it.
*
* @param id The modal identifier used at creation time.
* @param force Tell the modal to open top of all other opened modals
*/
toggle(id, force = false) {
const instance = this.modalStack.find((o) => {
return o.id === id;
});
if (!!instance) {
instance.modal.toggle(force);
}
else {
throw new Error('Modal not found');
}
}
/**
* Retrieve all the created modals.

@@ -115,3 +51,3 @@ *

getModalStack() {
return this.modalStack;
return this._modalStack;
}

@@ -124,11 +60,18 @@ /**

getOpenedModals() {
const modals = [];
this.modalStack.forEach((o) => {
if (o.modal.visible) {
modals.push(o);
}
});
return modals;
return this._modalStack.filter((o) => o.modal.visible);
}
/**
* Retrieve the opened modal with highest z-index.
*
* @returns the opened modal with highest z-index.
*/
getTopOpenedModal() {
if (!this.getOpenedModals().length) {
throw new Error('No modal is opened');
}
return this.getOpenedModals()
.map((o) => o.modal)
.reduce((highest, item) => item.layerPosition > highest.layerPosition ? item : highest, this.getOpenedModals()[0].modal);
}
/**
* Get the higher `z-index` value between all the modal instances. It iterates over the `ModalStack` array and

@@ -141,8 +84,3 @@ * calculates a higher value (it takes the highest index value between all the modal instances and adds 1).

getHigherIndex() {
const index = [1041];
const modals = this.getModalStack();
modals.forEach((o) => {
index.push(o.modal.layerPosition);
});
return Math.max(...index) + 1;
return Math.max(...this._modalStack.map((o) => o.modal.layerPosition), 1041) + 1;
}

@@ -155,3 +93,3 @@ /**

getModalStackCount() {
return this.modalStack.length;
return this._modalStack.length;
}

@@ -165,86 +103,25 @@ /**

removeModal(id) {
const i = this.modalStack.findIndex((o) => {
return o.id === id;
});
const i = this._modalStack.findIndex((o) => o.id === id);
if (i > -1) {
this.modalStack.splice(i, 1);
this._modalStack.splice(i, 1);
}
}
/**
* Associate data to an identified modal. If the modal isn't already associated to some data, it creates a new
* entry in the `modalData` array with its `id` and the given `data`. If the modal already has data, it rewrites
* them with the new ones. Finally if no modal found it returns an error message in the console and false value
* as method output.
*
* @param data The data you want to associate to the modal.
* @param id The modal identifier.
* @param force If true, overrides the previous stored data if there was.
* @returns true if the given modal exists and the process has been tried, either false.
*/
setModalData(data, id, force) {
if (!!this.modalStack.find((o) => {
return o.id === id;
})) {
this.getModal(id).setData(data, force);
return true;
}
else {
return false;
}
}
/**
* Retrieve modal data by its identifier.
*
* @param id The modal identifier used at creation time.
* @returns the associated modal data.
*/
getModalData(id) {
return this.getModal(id).getData();
}
/**
* Reset the data attached to a given modal.
*
* @param id The modal identifier used at creation time.
* @returns the removed data or false if modal doesn't exist.
*/
resetModalData(id) {
if (!!this.modalStack.find((o) => {
return o.id === id;
})) {
const removed = this.getModal(id).getData();
this.getModal(id).removeData();
return removed;
}
else {
return false;
}
}
/**
* Close the latest opened modal if it has been declared as escapable
* Using a debounce system because one or more modals could be listening
* escape key press event.
*/
closeLatestModal() {
const me = this;
clearTimeout(this.debouncer);
this.debouncer = setTimeout(() => {
let tmp;
me.getOpenedModals().forEach((m) => {
if (m.modal.layerPosition > (!!tmp ? tmp.modal.layerPosition : 0 && m.modal.escapable)) {
tmp = m;
}
});
return !!tmp ? tmp.modal.close() : false;
}, 100);
}
}
NtkSmartModalService.decorators = [
NtkSmartModalStackService.decorators = [
{ type: Injectable }
];
NtkSmartModalStackService.ctorParameters = () => [];
const NtkSmartModalConfig = {
bodyClassOpen: 'dialog-open',
prefixEvent: 'ntk-smart-modal.'
};
class NtkSmartModalComponent {
constructor(privateRenderer, privateChangeDetectorRef, privateNtkSmartModalService) {
this.privateRenderer = privateRenderer;
this.privateChangeDetectorRef = privateChangeDetectorRef;
this.privateNtkSmartModalService = privateNtkSmartModalService;
constructor(_renderer, _changeDetectorRef, componentFactoryResolver, _document, _platformId) {
this._renderer = _renderer;
this._changeDetectorRef = _changeDetectorRef;
this.componentFactoryResolver = componentFactoryResolver;
this._document = _document;
this._platformId = _platformId;
this.closable = true;

@@ -260,2 +137,7 @@ this.escapable = true;

this.autostart = false;
this.target = '';
this.ariaLabel = null;
this.ariaLabelledBy = null;
this.ariaDescribedBy = null;
this.refocus = true;
this.visibleChange = new EventEmitter();

@@ -269,2 +151,3 @@ this.onClose = new EventEmitter();

this.onOpen = new EventEmitter();
this.onOpenFinished = new EventEmitter();
this.onEscape = new EventEmitter();

@@ -276,96 +159,70 @@ this.onDataAdded = new EventEmitter();

this.openedClass = false;
this.escapeKeyboardEvent = (event) => {
if (event.keyCode === 27) {
this.onEscape.emit(this);
this.privateNtkSmartModalService.closeLatestModal();
}
};
this.createFrom = 'html';
}
ngOnInit() {
if (!!this.identifier && this.identifier.length) {
this.layerPosition += this.privateNtkSmartModalService.getModalStackCount();
this.privateNtkSmartModalService.addModal({ id: this.identifier, modal: this }, this.force);
if (this.autostart) {
this.privateNtkSmartModalService.open(this.identifier);
}
if (!this.identifier || !this.identifier.length) {
throw new Error('identifier field isn’t set. Please set one before calling <ngx-smart-modal> in a template.');
}
else {
throw new Error('identifier field isn’t set. Please set one before calling <ntk-smart-modal> in a template.');
this._sendEvent('create');
}
ngAfterViewInit() {
if (this.contentComponent) {
const factory = this.componentFactoryResolver.resolveComponentFactory(this.contentComponent);
this.createDynamicContent(this.dynamicContentContainer, factory);
this.dynamicContentContainer.changes.subscribe((contentViewContainers) => {
this.createDynamicContent(contentViewContainers, factory);
});
}
}
ngOnDestroy() {
this.privateNtkSmartModalService.removeModal(this.identifier);
window.removeEventListener('keyup', this.escapeKeyboardEvent);
if (!this.privateNtkSmartModalService.getModalStack.length) {
this.privateRenderer.removeClass(document.body, 'dialog-open');
}
this._sendEvent('delete');
}
/**
* Open the modal instance
*
* @param top open the modal top of all other
* @returns the modal component
*/
open(top) {
if (top) {
this.layerPosition = this.privateNtkSmartModalService.getHigherIndex();
}
this.privateRenderer.addClass(document.body, 'dialog-open');
this.overlayVisible = true;
this.visible = true;
setTimeout(() => {
this.openedClass = true;
if (this.target) {
this.targetPlacement();
}
this.privateChangeDetectorRef.markForCheck();
});
this.onOpen.emit(this);
if (this.escapable) {
window.addEventListener('keyup', this.escapeKeyboardEvent);
}
this._sendEvent('open', { top: top });
return this;
}
/**
* Close the modal instance
*
* @returns the modal component
*/
close() {
const me = this;
this.openedClass = false;
this.onClose.emit(this);
this.onAnyCloseEvent.emit(this);
if (this.privateNtkSmartModalService.getOpenedModals().length < 2) {
this.privateRenderer.removeClass(document.body, 'dialog-open');
}
setTimeout(() => {
me.visibleChange.emit(me.visible);
me.visible = false;
me.overlayVisible = false;
me.privateChangeDetectorRef.markForCheck();
me.onCloseFinished.emit(me);
me.onAnyCloseEventFinished.emit(me);
}, this.hideDelay);
window.removeEventListener('keyup', this.escapeKeyboardEvent);
this._sendEvent('close');
return this;
}
/**
* Dismiss the modal instance
*
* @param e the event sent by the browser
* @returns the modal component
*/
dismiss(e) {
const me = this;
if (!this.dismissable) {
return;
if (!this.dismissable || !e.target.classList.contains('overlay')) {
return this;
}
if (e.target.classList.contains('overlay')) {
this.openedClass = false;
this.onDismiss.emit(this);
this.onAnyCloseEvent.emit(this);
if (this.privateNtkSmartModalService.getOpenedModals().length < 2) {
this.privateRenderer.removeClass(document.body, 'dialog-open');
}
setTimeout(() => {
me.visible = false;
me.visibleChange.emit(me.visible);
me.overlayVisible = false;
me.privateChangeDetectorRef.markForCheck();
me.onDismissFinished.emit(me);
me.onAnyCloseEventFinished.emit(me);
}, this.hideDelay);
window.removeEventListener('keyup', this.escapeKeyboardEvent);
}
this._sendEvent('dismiss');
return this;
}
/**
* Toggle visibility of the modal instance
*
* @param top open the modal top of all other
* @returns the modal component
*/
toggle(top) {
if (this.visible) {
this.close();
}
else {
this.open(top);
}
this._sendEvent('toggle', { top: top });
return this;
}
/**
* Add a custom class to the modal instance
*
* @param className the class to add
* @returns the modal component
*/
addCustomClass(className) {

@@ -378,3 +235,10 @@ if (!this.customClass.length) {

}
return this;
}
/**
* Remove a custom class to the modal instance
*
* @param className the class to remove
* @returns the modal component
*/
removeCustomClass(className) {

@@ -387,39 +251,96 @@ if (className) {

}
return this;
}
/**
* Returns the visibility state of the modal instance
*/
isVisible() {
return this.visible;
}
/**
* Checks if data is attached to the modal instance
*/
hasData() {
return this.privateData !== undefined;
return this._data !== undefined;
}
/**
* Attach data to the modal instance
*
* @param data the data to attach
* @param force override potentially attached data
* @returns the modal component
*/
setData(data, force) {
if (!this.hasData() || (this.hasData() && force)) {
this.privateData = data;
this.onDataAdded.emit(this.privateData);
this.privateChangeDetectorRef.markForCheck();
this._data = data;
this.onDataAdded.emit(this._data);
this.markForCheck();
}
return this;
}
/**
* Retrieve the data attached to the modal instance
*/
getData() {
return this.privateData;
return this._data;
}
/**
* Remove the data attached to the modal instance
*
* @returns the modal component
*/
removeData() {
this.privateData = undefined;
this._data = undefined;
this.onDataRemoved.emit(true);
this.privateChangeDetectorRef.markForCheck();
this.markForCheck();
return this;
}
/**
* Add body class modal opened
*
* @returns the modal component
*/
addBodyClass() {
this._renderer.addClass(this._document.body, NtkSmartModalConfig.bodyClassOpen);
return this;
}
/**
* Add body class modal opened
*
* @returns the modal component
*/
removeBodyClass() {
this._renderer.removeClass(this._document.body, NtkSmartModalConfig.bodyClassOpen);
return this;
}
markForCheck() {
try {
this._changeDetectorRef.detectChanges();
}
catch (e) {
}
this._changeDetectorRef.markForCheck();
}
/**
* Listens for window resize event and recalculates modal instance position if it is element-relative
*/
targetPlacement() {
if (!this.nsmDialog || !this.nsmContent || !this.nsmOverlay || !this.target) {
return;
if (!this.isBrowser || !this.nsmDialog.length || !this.nsmContent.length || !this.nsmOverlay.length || !this.target) {
return false;
}
const targetElementRect = document.querySelector(this.target).getBoundingClientRect();
const bodyRect = this.nsmOverlay.nativeElement.getBoundingClientRect();
const nsmContentRect = this.nsmContent.nativeElement.getBoundingClientRect();
const nsmDialogRect = this.nsmDialog.nativeElement.getBoundingClientRect();
const marginLeft = parseInt(getComputedStyle(this.nsmContent.nativeElement).marginLeft, 10);
const marginTop = parseInt(getComputedStyle(this.nsmContent.nativeElement).marginTop, 10);
let offsetTop = targetElementRect.top - nsmDialogRect.top - (nsmContentRect.height - targetElementRect.height) / 2;
let offsetLeft = targetElementRect.left - nsmDialogRect.left - (nsmContentRect.width - targetElementRect.width) / 2;
if (offsetLeft + nsmDialogRect.left + nsmContentRect.width + marginLeft * 2 > bodyRect.width) {
offsetLeft = bodyRect.width - (nsmDialogRect.left + nsmContentRect.width) - marginLeft * 2;
const targetElement = this._document.querySelector(this.target);
if (!targetElement) {
return false;
}
const targetElementRect = targetElement.getBoundingClientRect();
const bodyRect = this.nsmOverlay.first.nativeElement.getBoundingClientRect();
const nsmContentRect = this.nsmContent.first.nativeElement.getBoundingClientRect();
const nsmDialogRect = this.nsmDialog.first.nativeElement.getBoundingClientRect();
const marginLeft = parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginLeft, 10);
const marginTop = parseInt(getComputedStyle(this.nsmContent.first.nativeElement).marginTop, 10);
let offsetTop = targetElementRect.top - nsmDialogRect.top - ((nsmContentRect.height - targetElementRect.height) / 2);
let offsetLeft = targetElementRect.left - nsmDialogRect.left - ((nsmContentRect.width - targetElementRect.width) / 2);
if (offsetLeft + nsmDialogRect.left + nsmContentRect.width + (marginLeft * 2) > bodyRect.width) {
offsetLeft = bodyRect.width - (nsmDialogRect.left + nsmContentRect.width) - (marginLeft * 2);
}
else if (offsetLeft + nsmDialogRect.left < 0) {

@@ -431,8 +352,32 @@ offsetLeft = -nsmDialogRect.left;

}
if (offsetTop < 0) {
offsetTop = 0;
this._renderer.setStyle(this.nsmContent.first.nativeElement, 'top', (offsetTop < 0 ? 0 : offsetTop) + 'px');
this._renderer.setStyle(this.nsmContent.first.nativeElement, 'left', offsetLeft + 'px');
}
_sendEvent(name, extraData) {
if (!this.isBrowser) {
return false;
}
this.privateRenderer.setStyle(this.nsmContent.nativeElement, 'top', offsetTop + 'px');
this.privateRenderer.setStyle(this.nsmContent.nativeElement, 'left', offsetLeft + 'px');
const data = {
extraData: extraData,
instance: { id: this.identifier, modal: this }
};
const event = new CustomEvent(NtkSmartModalConfig.prefixEvent + name, { detail: data });
return window.dispatchEvent(event);
}
/**
* Is current platform browser
*/
get isBrowser() {
return isPlatformBrowser(this._platformId);
}
/**
* Creates content inside provided ViewContainerRef
*/
createDynamicContent(changes, factory) {
changes.forEach((viewContainerRef) => {
viewContainerRef.clear();
viewContainerRef.createComponent(factory);
this.markForCheck();
});
}
}

@@ -443,22 +388,32 @@ NtkSmartModalComponent.decorators = [

template: `
<div
*ngIf="overlayVisible"
[style.z-index]="visible ? layerPosition - 1 : -1"
[ngClass]="{ transparent: !backdrop, overlay: true, 'nsm-overlay-open': openedClass }"
(click)="dismiss($event)"
#nsmOverlay
>
<div
[style.z-index]="visible ? layerPosition : -1"
[ngClass]="['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open' : 'nsm-dialog-close']"
#nsmDialog
>
<div *ngIf="overlayVisible"
[style.z-index]="visible ? layerPosition-1 : -1"
[ngClass]="{'transparent':!backdrop, 'overlay':true, 'nsm-overlay-open':openedClass}"
(click)="dismiss($event)" #nsmOverlay>
<div [style.z-index]="visible ? layerPosition : -1"
[ngClass]="['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open': 'nsm-dialog-close']" #nsmDialog
[attr.aria-hidden]="openedClass ? false : true"
[attr.aria-label]="ariaLabel"
[attr.aria-labelledby]="ariaLabelledBy"
[attr.aria-describedby]="ariaDescribedBy">
<div class="nsm-content" #nsmContent>
<div class="nsm-body">
<ng-template #dynamicContent></ng-template>
<ng-content></ng-content>
</div>
<button type="button" *ngIf="closable" (click)="close()" aria-label="Close" class="nsm-dialog-btn-close">
<img
src="data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MTIgNTEyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCA1MTIgNTEyOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjE2cHgiIGhlaWdodD0iMTZweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDMsNi4wNThjLTguMDc3LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDksMEw2LjA1OCw0NzYuNjkzYy04LjA3Nyw4LjA3Ny04LjA3NywyMS4xNzIsMCwyOS4yNDkgICAgQzEwLjA5Niw1MDkuOTgyLDE1LjM5LDUxMiwyMC42ODMsNTEyYzUuMjkzLDAsMTAuNTg2LTIuMDE5LDE0LjYyNS02LjA1OUw1MDUuOTQzLDM1LjMwNiAgICBDNTE0LjAxOSwyNy4yMyw1MTQuMDE5LDE0LjEzNSw1MDUuOTQzLDYuMDU4eiIgZmlsbD0iIzAwMDAwMCIvPgoJPC9nPgo8L2c+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDIsNDc2LjY5NEwzNS4zMDYsNi4wNTljLTguMDc2LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDgsMGMtOC4wNzcsOC4wNzYtOC4wNzcsMjEuMTcxLDAsMjkuMjQ4bDQ3MC42MzYsNDcwLjYzNiAgICBjNC4wMzgsNC4wMzksOS4zMzIsNi4wNTgsMTQuNjI1LDYuMDU4YzUuMjkzLDAsMTAuNTg3LTIuMDE5LDE0LjYyNC02LjA1N0M1MTQuMDE4LDQ5Ny44NjYsNTE0LjAxOCw0ODQuNzcxLDUwNS45NDIsNDc2LjY5NHoiIGZpbGw9IiMwMDAwMDAiLz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K"
/>
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 512 512"
xml:space="preserve" width="16px" height="16px" role="img" aria-labelledby="closeIconTitle closeIconDesc">
<title id="closeIconTitle">Close Icon</title>
<desc id="closeIconDesc">A light-gray close icon used to close the modal</desc>
<g>
<path d="M505.943,6.058c-8.077-8.077-21.172-8.077-29.249,0L6.058,476.693c-8.077,8.077-8.077,21.172,0,29.249 C10.096,509.982,15.39,512,20.683,512c5.293,0,10.586-2.019,14.625-6.059L505.943,35.306 C514.019,27.23,514.019,14.135,505.943,6.058z"
fill="currentColor"/>
</g>
<g>
<path d="M505.942,476.694L35.306,6.059c-8.076-8.077-21.172-8.077-29.248,0c-8.077,8.076-8.077,21.171,0,29.248l470.636,470.636 c4.038,4.039,9.332,6.058,14.625,6.058c5.293,0,10.587-2.019,14.624-6.057C514.018,497.866,514.018,484.771,505.942,476.694z"
fill="currentColor"/>
</g>
</svg>
</button>

@@ -474,3 +429,5 @@ </div>

{ type: ChangeDetectorRef },
{ type: NtkSmartModalService }
{ type: ComponentFactoryResolver },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
];

@@ -489,2 +446,6 @@ NtkSmartModalComponent.propDecorators = {

target: [{ type: Input }],
ariaLabel: [{ type: Input }],
ariaLabelledBy: [{ type: Input }],
ariaDescribedBy: [{ type: Input }],
refocus: [{ type: Input }],
visibleChange: [{ type: Output }],

@@ -498,11 +459,461 @@ onClose: [{ type: Output }],

onOpen: [{ type: Output }],
onOpenFinished: [{ type: Output }],
onEscape: [{ type: Output }],
onDataAdded: [{ type: Output }],
onDataRemoved: [{ type: Output }],
nsmContent: [{ type: ViewChild, args: ['nsmContent',] }],
nsmDialog: [{ type: ViewChild, args: ['nsmDialog',] }],
nsmOverlay: [{ type: ViewChild, args: ['nsmOverlay',] }],
nsmContent: [{ type: ViewChildren, args: ['nsmContent',] }],
nsmDialog: [{ type: ViewChildren, args: ['nsmDialog',] }],
nsmOverlay: [{ type: ViewChildren, args: ['nsmOverlay',] }],
dynamicContentContainer: [{ type: ViewChildren, args: ['dynamicContent', { read: ViewContainerRef },] }],
targetPlacement: [{ type: HostListener, args: ['window:resize',] }]
};
class NtkSmartModalService {
constructor(_componentFactoryResolver, _appRef, _injector, _modalStack, applicationRef, _document, _platformId) {
this._componentFactoryResolver = _componentFactoryResolver;
this._appRef = _appRef;
this._injector = _injector;
this._modalStack = _modalStack;
this.applicationRef = applicationRef;
this._document = _document;
this._platformId = _platformId;
/**
* Close the latest opened modal if escape key event is emitted
* @param event The Keyboard Event
*/
this._escapeKeyboardEvent = (event) => {
if (event.key === 'Escape') {
try {
const modal = this.getTopOpenedModal();
if (!modal.escapable) {
return false;
}
modal.onEscape.emit(modal);
this.closeLatestModal();
return true;
}
catch (e) {
return false;
}
}
return false;
};
/**
* While modal is open, the focus stay on it
* @param event The Keyboar dEvent
*/
this._trapFocusModal = (event) => {
if (event.key === 'Tab') {
try {
const modal = this.getTopOpenedModal();
if (!modal.nsmDialog.first.nativeElement.contains(document.activeElement)) {
event.preventDefault();
event.stopPropagation();
modal.nsmDialog.first.nativeElement.focus();
}
return true;
}
catch (e) {
return false;
}
}
return false;
};
this._addEvents();
}
/**
* Add a new modal instance. This step is essential and allows to retrieve any modal at any time.
* It stores an object that contains the given modal identifier and the modal itself directly in the `modalStack`.
*
* @param modalInstance The object that contains the given modal identifier and the modal itself.
* @param force Optional parameter that forces the overriding of modal instance if it already exists.
* @returns nothing special.
*/
addModal(modalInstance, force) {
this._modalStack.addModal(modalInstance, force);
}
/**
* Retrieve a modal instance by its identifier.
*
* @param id The modal identifier used at creation time.
*/
getModal(id) {
return this._modalStack.getModal(id);
}
/**
* Alias of `getModal` to retrieve a modal instance by its identifier.
*
* @param id The modal identifier used at creation time.
*/
get(id) {
return this.getModal(id);
}
/**
* Open a given modal
*
* @param id The modal identifier used at creation time.
* @param force Tell the modal to open top of all other opened modals
*/
open(id, force = false) {
return this._openModal(this.get(id), force);
}
/**
* Close a given modal
*
* @param id The modal identifier used at creation time.
*/
close(id) {
return this._closeModal(this.get(id));
}
/**
* Close all opened modals
*/
closeAll() {
this.getOpenedModals().forEach((instance) => {
this._closeModal(instance.modal);
});
}
/**
* Toggles a given modal
* If the retrieved modal is opened it closes it, else it opens it.
*
* @param id The modal identifier used at creation time.
* @param force Tell the modal to open top of all other opened modals
*/
toggle(id, force = false) {
return this._toggleModal(this.get(id), force);
}
/**
* Retrieve all the created modals.
*
* @returns an array that contains all modal instances.
*/
getModalStack() {
return this._modalStack.getModalStack();
}
/**
* Retrieve all the opened modals. It looks for all modal instances with their `visible` property set to `true`.
*
* @returns an array that contains all the opened modals.
*/
getOpenedModals() {
return this._modalStack.getOpenedModals();
}
/**
* Retrieve the opened modal with highest z-index.
*
* @returns the opened modal with highest z-index.
*/
getTopOpenedModal() {
return this._modalStack.getTopOpenedModal();
}
/**
* Get the higher `z-index` value between all the modal instances. It iterates over the `ModalStack` array and
* calculates a higher value (it takes the highest index value between all the modal instances and adds 1).
* Use it to make a modal appear foreground.
*
* @returns a higher index from all the existing modal instances.
*/
getHigherIndex() {
return this._modalStack.getHigherIndex();
}
/**
* It gives the number of modal instances. It's helpful to know if the modal stack is empty or not.
*
* @returns the number of modal instances.
*/
getModalStackCount() {
return this._modalStack.getModalStackCount();
}
/**
* Remove a modal instance from the modal stack.
*
* @param id The modal identifier.
* @returns the removed modal instance.
*/
removeModal(id) {
this._modalStack.removeModal(id);
}
/**
* Associate data to an identified modal. If the modal isn't already associated to some data, it creates a new
* entry in the `modalData` array with its `id` and the given `data`. If the modal already has data, it rewrites
* them with the new ones. Finally if no modal found it returns an error message in the console and false value
* as method output.
*
* @param data The data you want to associate to the modal.
* @param id The modal identifier.
* @param force If true, overrides the previous stored data if there was.
* @returns true if the given modal exists and the process has been tried, either false.
*/
setModalData(data, id, force) {
let i;
if (i = this.get(id)) {
i.setData(data, force);
return true;
}
else {
return false;
}
}
/**
* Retrieve modal data by its identifier.
*
* @param id The modal identifier used at creation time.
* @returns the associated modal data.
*/
getModalData(id) {
let i;
if (i = this.get(id)) {
return i.getData();
}
return null;
}
/**
* Reset the data attached to a given modal.
*
* @param id The modal identifier used at creation time.
* @returns the removed data or false if modal doesn't exist.
*/
resetModalData(id) {
if (!!this._modalStack.getModalStack().find((o) => o.id === id)) {
const removed = this.getModal(id).getData();
this.getModal(id).removeData();
return removed;
}
else {
return false;
}
}
/**
* Close the latest opened modal if it has been declared as escapable
* Using a debounce system because one or more modals could be listening
* escape key press event.
*/
closeLatestModal() {
this.getTopOpenedModal().close();
}
/**
* Create dynamic NtkSmartModalComponent
* @param id The modal identifier used at creation time.
* @param content The modal content ( string, templateRef or Component )
*/
create(id, content, options = {}) {
try {
return this.getModal(id);
}
catch (e) {
const componentFactory = this._componentFactoryResolver.resolveComponentFactory(NtkSmartModalComponent);
const ngContent = this._resolveNgContent(content);
const componentRef = componentFactory.create(this._injector, ngContent);
if (content instanceof Type) {
componentRef.instance.contentComponent = content;
}
componentRef.instance.identifier = id;
componentRef.instance.createFrom = 'service';
if (typeof options.closable === 'boolean') {
componentRef.instance.closable = options.closable;
}
if (typeof options.escapable === 'boolean') {
componentRef.instance.escapable = options.escapable;
}
if (typeof options.dismissable === 'boolean') {
componentRef.instance.dismissable = options.dismissable;
}
if (typeof options.customClass === 'string') {
componentRef.instance.customClass = options.customClass;
}
if (typeof options.backdrop === 'boolean') {
componentRef.instance.backdrop = options.backdrop;
}
if (typeof options.force === 'boolean') {
componentRef.instance.force = options.force;
}
if (typeof options.hideDelay === 'number') {
componentRef.instance.hideDelay = options.hideDelay;
}
if (typeof options.autostart === 'boolean') {
componentRef.instance.autostart = options.autostart;
}
if (typeof options.target === 'string') {
componentRef.instance.target = options.target;
}
if (typeof options.ariaLabel === 'string') {
componentRef.instance.ariaLabel = options.ariaLabel;
}
if (typeof options.ariaLabelledBy === 'string') {
componentRef.instance.ariaLabelledBy = options.ariaLabelledBy;
}
if (typeof options.ariaDescribedBy === 'string') {
componentRef.instance.ariaDescribedBy = options.ariaDescribedBy;
}
if (typeof options.refocus === 'boolean') {
componentRef.instance.refocus = options.refocus;
}
this._appRef.attachView(componentRef.hostView);
const domElem = componentRef.hostView.rootNodes[0];
this._document.body.appendChild(domElem);
return componentRef.instance;
}
}
_addEvents() {
if (!this.isBrowser) {
return false;
}
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'create', ((e) => {
this._initModal(e.detail.instance);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'delete', ((e) => {
this._deleteModal(e.detail.instance);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'open', ((e) => {
this._openModal(e.detail.instance.modal, e.detail.top);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'toggle', ((e) => {
this._toggleModal(e.detail.instance.modal, e.detail.top);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'close', ((e) => {
this._closeModal(e.detail.instance.modal);
}));
window.addEventListener(NtkSmartModalConfig.prefixEvent + 'dismiss', ((e) => {
this._dismissModal(e.detail.instance.modal);
}));
window.addEventListener('keyup', this._escapeKeyboardEvent);
return true;
}
_initModal(modalInstance) {
modalInstance.modal.layerPosition += this.getModalStackCount();
this.addModal(modalInstance, modalInstance.modal.force);
if (modalInstance.modal.autostart) {
this.open(modalInstance.id);
}
}
_openModal(modal, top) {
if (modal.visible) {
return false;
}
this.lastElementFocused = document.activeElement;
if (modal.escapable) {
window.addEventListener('keyup', this._escapeKeyboardEvent);
}
if (modal.backdrop) {
window.addEventListener('keydown', this._trapFocusModal);
}
if (top) {
modal.layerPosition = this.getHigherIndex();
}
modal.addBodyClass();
modal.overlayVisible = true;
modal.visible = true;
modal.onOpen.emit(modal);
modal.markForCheck();
setTimeout(() => {
modal.openedClass = true;
if (modal.target) {
modal.targetPlacement();
}
modal.nsmDialog.first.nativeElement.setAttribute('role', 'dialog');
modal.nsmDialog.first.nativeElement.setAttribute('tabIndex', '-1');
modal.nsmDialog.first.nativeElement.setAttribute('aria-modal', 'true');
modal.nsmDialog.first.nativeElement.focus();
modal.markForCheck();
modal.onOpenFinished.emit(modal);
});
return true;
}
_toggleModal(modal, top) {
if (modal.visible) {
return this._closeModal(modal);
}
else {
return this._openModal(modal, top);
}
}
_closeModal(modal) {
if (!modal.openedClass) {
return false;
}
modal.openedClass = false;
modal.onClose.emit(modal);
modal.onAnyCloseEvent.emit(modal);
if (this.getOpenedModals().length < 2) {
modal.removeBodyClass();
window.removeEventListener('keyup', this._escapeKeyboardEvent);
window.removeEventListener('keydown', this._trapFocusModal);
}
setTimeout(() => {
modal.visibleChange.emit(modal.visible);
modal.visible = false;
modal.overlayVisible = false;
modal.nsmDialog.first.nativeElement.removeAttribute('tabIndex');
modal.markForCheck();
modal.onCloseFinished.emit(modal);
modal.onAnyCloseEventFinished.emit(modal);
if (modal.refocus) {
this.lastElementFocused.focus();
}
}, modal.hideDelay);
return true;
}
_dismissModal(modal) {
if (!modal.openedClass) {
return false;
}
modal.openedClass = false;
modal.onDismiss.emit(modal);
modal.onAnyCloseEvent.emit(modal);
if (this.getOpenedModals().length < 2) {
modal.removeBodyClass();
}
setTimeout(() => {
modal.visible = false;
modal.visibleChange.emit(modal.visible);
modal.overlayVisible = false;
modal.markForCheck();
modal.onDismissFinished.emit(modal);
modal.onAnyCloseEventFinished.emit(modal);
}, modal.hideDelay);
return true;
}
_deleteModal(modalInstance) {
this.removeModal(modalInstance.id);
if (!this.getModalStack().length) {
modalInstance.modal.removeBodyClass();
}
}
/**
* Resolve content according to the types
* @param content The modal content ( string, templateRef or Component )
*/
_resolveNgContent(content) {
if (typeof content === 'string') {
const element = this._document.createTextNode(content);
return [[element]];
}
if (content instanceof TemplateRef) {
const viewRef = content.createEmbeddedView(null);
this.applicationRef.attachView(viewRef);
return [viewRef.rootNodes];
}
return [];
}
/**
* Is current platform browser
*/
get isBrowser() {
return isPlatformBrowser(this._platformId);
}
}
NtkSmartModalService.decorators = [
{ type: Injectable }
];
NtkSmartModalService.ctorParameters = () => [
{ type: ComponentFactoryResolver },
{ type: ApplicationRef },
{ type: Injector },
{ type: NtkSmartModalStackService },
{ type: ApplicationRef },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
];
class NtkSmartModalModule {

@@ -515,3 +926,6 @@ /**

ngModule: NtkSmartModalModule,
providers: [NtkSmartModalService],
providers: [
NtkSmartModalService,
NtkSmartModalStackService
],
};

@@ -525,3 +939,6 @@ }

ngModule: NtkSmartModalModule,
providers: [NtkSmartModalService],
providers: [
NtkSmartModalService,
NtkSmartModalStackService
],
};

@@ -757,4 +1174,7 @@ }

}
NtkSmartLoaderService.ɵprov = ɵɵdefineInjectable({ factory: function NtkSmartLoaderService_Factory() { return new NtkSmartLoaderService(); }, token: NtkSmartLoaderService, providedIn: "root" });
NtkSmartLoaderService.decorators = [
{ type: Injectable }
{ type: Injectable, args: [{
providedIn: 'root',
},] }
];

@@ -934,3 +1354,3 @@

export { NtkSmartLoaderComponent, NtkSmartLoaderModule, NtkSmartLoaderService, NtkSmartModalComponent, NtkSmartModalModule, NtkSmartModalService };
export { NtkSmartLoaderComponent, NtkSmartLoaderModule, NtkSmartLoaderService, NtkSmartModalComponent, NtkSmartModalModule, NtkSmartModalService, NtkSmartModalStackService as ɵa };
//# sourceMappingURL=ngx-ntk-smart-module.js.map

@@ -1,7 +0,8 @@

import { OnInit, OnDestroy, Renderer2, EventEmitter, ChangeDetectorRef } from '@angular/core';
import { NtkSmartModalService } from './ntk-smart-modal.service';
export declare class NtkSmartModalComponent implements OnInit, OnDestroy {
private privateRenderer;
private privateChangeDetectorRef;
private privateNtkSmartModalService;
import { AfterViewInit, ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, EventEmitter, OnDestroy, OnInit, QueryList, Renderer2, Type, ViewContainerRef } from '@angular/core';
export declare class NtkSmartModalComponent implements OnInit, OnDestroy, AfterViewInit {
private _renderer;
private _changeDetectorRef;
private componentFactoryResolver;
private _document;
private _platformId;
closable: boolean;

@@ -17,3 +18,7 @@ escapable: boolean;

autostart: boolean;
target: any;
target: string;
ariaLabel: string | null;
ariaLabelledBy: string | null;
ariaDescribedBy: string | null;
refocus: boolean;
visibleChange: EventEmitter<boolean>;

@@ -27,28 +32,113 @@ onClose: EventEmitter<any>;

onOpen: EventEmitter<any>;
onOpenFinished: EventEmitter<any>;
onEscape: EventEmitter<any>;
onDataAdded: EventEmitter<any>;
onDataRemoved: EventEmitter<any>;
contentComponent: Type<Component>;
layerPosition: number;
overlayVisible: boolean;
openedClass: boolean;
private privateData;
createFrom: string;
private _data;
private nsmContent;
private nsmDialog;
nsmDialog: QueryList<ElementRef>;
private nsmOverlay;
constructor(privateRenderer: Renderer2, privateChangeDetectorRef: ChangeDetectorRef, privateNtkSmartModalService: NtkSmartModalService);
dynamicContentContainer: QueryList<ViewContainerRef>;
constructor(_renderer: Renderer2, _changeDetectorRef: ChangeDetectorRef, componentFactoryResolver: ComponentFactoryResolver, _document: any, _platformId: any);
ngOnInit(): void;
ngAfterViewInit(): void;
ngOnDestroy(): void;
open(top?: boolean): void;
close(): void;
dismiss(e: any): void;
toggle(top?: boolean): void;
addCustomClass(className: string): void;
removeCustomClass(className?: string): void;
/**
* Open the modal instance
*
* @param top open the modal top of all other
* @returns the modal component
*/
open(top?: boolean): NtkSmartModalComponent;
/**
* Close the modal instance
*
* @returns the modal component
*/
close(): NtkSmartModalComponent;
/**
* Dismiss the modal instance
*
* @param e the event sent by the browser
* @returns the modal component
*/
dismiss(e: any): NtkSmartModalComponent;
/**
* Toggle visibility of the modal instance
*
* @param top open the modal top of all other
* @returns the modal component
*/
toggle(top?: boolean): NtkSmartModalComponent;
/**
* Add a custom class to the modal instance
*
* @param className the class to add
* @returns the modal component
*/
addCustomClass(className: string): NtkSmartModalComponent;
/**
* Remove a custom class to the modal instance
*
* @param className the class to remove
* @returns the modal component
*/
removeCustomClass(className?: string): NtkSmartModalComponent;
/**
* Returns the visibility state of the modal instance
*/
isVisible(): boolean;
/**
* Checks if data is attached to the modal instance
*/
hasData(): boolean;
setData(data: any, force?: boolean): any;
/**
* Attach data to the modal instance
*
* @param data the data to attach
* @param force override potentially attached data
* @returns the modal component
*/
setData(data: any, force?: boolean): NtkSmartModalComponent;
/**
* Retrieve the data attached to the modal instance
*/
getData(): any;
removeData(): void;
escapeKeyboardEvent: (event: KeyboardEvent) => void;
targetPlacement(): void;
/**
* Remove the data attached to the modal instance
*
* @returns the modal component
*/
removeData(): NtkSmartModalComponent;
/**
* Add body class modal opened
*
* @returns the modal component
*/
addBodyClass(): NtkSmartModalComponent;
/**
* Add body class modal opened
*
* @returns the modal component
*/
removeBodyClass(): NtkSmartModalComponent;
markForCheck(): void;
/**
* Listens for window resize event and recalculates modal instance position if it is element-relative
*/
targetPlacement(): boolean | void;
private _sendEvent;
/**
* Is current platform browser
*/
private get isBrowser();
/**
* Creates content inside provided ViewContainerRef
*/
private createDynamicContent;
}

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

import { ComponentFactoryResolver, ApplicationRef, Injector, TemplateRef, Type } from '@angular/core';
import { ModalInstance } from './modal-instance';
import { NtkSmartModalStackService } from './ntk-smart-modal-stack.service';
import { NtkSmartModalComponent } from './ntk-smart-modal.component';
import { ModalInstance } from './modal-instance';
import { INtkSmartModalOptions } from './ntk-smart-modal.config';
export declare type Content<T> = string | TemplateRef<T> | Type<T>;
export declare class NtkSmartModalService {
modalStack: ModalInstance[];
private debouncer;
private _componentFactoryResolver;
private _appRef;
private _injector;
private _modalStack;
private applicationRef;
private _document;
private _platformId;
private lastElementFocused;
constructor(_componentFactoryResolver: ComponentFactoryResolver, _appRef: ApplicationRef, _injector: Injector, _modalStack: NtkSmartModalStackService, applicationRef: ApplicationRef, _document: any, _platformId: any);
/**

@@ -20,3 +31,3 @@ * Add a new modal instance. This step is essential and allows to retrieve any modal at any time.

*/
getModal(id: string): NtkSmartModalComponent | null;
getModal(id: string): NtkSmartModalComponent;
/**

@@ -34,3 +45,3 @@ * Alias of `getModal` to retrieve a modal instance by its identifier.

*/
open(id: string, force?: boolean): void;
open(id: string, force?: boolean): boolean;
/**

@@ -41,4 +52,8 @@ * Close a given modal

*/
close(id: string): void;
close(id: string): boolean;
/**
* Close all opened modals
*/
closeAll(): void;
/**
* Toggles a given modal

@@ -50,3 +65,3 @@ * If the retrieved modal is opened it closes it, else it opens it.

*/
toggle(id: string, force?: boolean): any;
toggle(id: string, force?: boolean): boolean;
/**

@@ -65,2 +80,8 @@ * Retrieve all the created modals.

/**
* Retrieve the opened modal with highest z-index.
*
* @returns the opened modal with highest z-index.
*/
getTopOpenedModal(): NtkSmartModalComponent;
/**
* Get the higher `z-index` value between all the modal instances. It iterates over the `ModalStack` array and

@@ -118,2 +139,34 @@ * calculates a higher value (it takes the highest index value between all the modal instances and adds 1).

closeLatestModal(): void;
/**
* Create dynamic NtkSmartModalComponent
* @param id The modal identifier used at creation time.
* @param content The modal content ( string, templateRef or Component )
*/
create<T>(id: string, content: Content<T>, options?: INtkSmartModalOptions): NtkSmartModalComponent;
private _addEvents;
private _initModal;
private _openModal;
private _toggleModal;
private _closeModal;
private _dismissModal;
private _deleteModal;
/**
* Resolve content according to the types
* @param content The modal content ( string, templateRef or Component )
*/
private _resolveNgContent;
/**
* Close the latest opened modal if escape key event is emitted
* @param event The Keyboard Event
*/
private _escapeKeyboardEvent;
/**
* Is current platform browser
*/
private get isBrowser();
/**
* While modal is open, the focus stay on it
* @param event The Keyboar dEvent
*/
private _trapFocusModal;
}

@@ -5,1 +5,2 @@ /**

export * from './public-api';
export { NtkSmartModalStackService as ɵa } from './lib/modal/ntk-smart-modal-stack.service';

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

{"__symbolic":"module","version":4,"metadata":{"NtkSmartModalService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1}}],"members":{"addModal":[{"__symbolic":"method"}],"getModal":[{"__symbolic":"method"}],"get":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"toggle":[{"__symbolic":"method"}],"getModalStack":[{"__symbolic":"method"}],"getOpenedModals":[{"__symbolic":"method"}],"getHigherIndex":[{"__symbolic":"method"}],"getModalStackCount":[{"__symbolic":"method"}],"removeModal":[{"__symbolic":"method"}],"setModalData":[{"__symbolic":"method"}],"getModalData":[{"__symbolic":"method"}],"resetModalData":[{"__symbolic":"method"}],"closeLatestModal":[{"__symbolic":"method"}]}},"NtkSmartModalComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":16,"character":1},"arguments":[{"selector":"ntk-smart-modal","template":"\n <div\n *ngIf=\"overlayVisible\"\n [style.z-index]=\"visible ? layerPosition - 1 : -1\"\n [ngClass]=\"{ transparent: !backdrop, overlay: true, 'nsm-overlay-open': openedClass }\"\n (click)=\"dismiss($event)\"\n #nsmOverlay\n >\n <div\n [style.z-index]=\"visible ? layerPosition : -1\"\n [ngClass]=\"['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open' : 'nsm-dialog-close']\"\n #nsmDialog\n >\n <div class=\"nsm-content\" #nsmContent>\n <div class=\"nsm-body\">\n <ng-content></ng-content>\n </div>\n <button type=\"button\" *ngIf=\"closable\" (click)=\"close()\" aria-label=\"Close\" class=\"nsm-dialog-btn-close\">\n <img\n src=\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pgo8IS0tIEdlbmVyYXRvcjogQWRvYmUgSWxsdXN0cmF0b3IgMTkuMC4wLCBTVkcgRXhwb3J0IFBsdWctSW4gLiBTVkcgVmVyc2lvbjogNi4wMCBCdWlsZCAwKSAgLS0+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeD0iMHB4IiB5PSIwcHgiIHZpZXdCb3g9IjAgMCA1MTIgNTEyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCA1MTIgNTEyOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgd2lkdGg9IjE2cHgiIGhlaWdodD0iMTZweCI+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDMsNi4wNThjLTguMDc3LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDksMEw2LjA1OCw0NzYuNjkzYy04LjA3Nyw4LjA3Ny04LjA3NywyMS4xNzIsMCwyOS4yNDkgICAgQzEwLjA5Niw1MDkuOTgyLDE1LjM5LDUxMiwyMC42ODMsNTEyYzUuMjkzLDAsMTAuNTg2LTIuMDE5LDE0LjYyNS02LjA1OUw1MDUuOTQzLDM1LjMwNiAgICBDNTE0LjAxOSwyNy4yMyw1MTQuMDE5LDE0LjEzNSw1MDUuOTQzLDYuMDU4eiIgZmlsbD0iIzAwMDAwMCIvPgoJPC9nPgo8L2c+CjxnPgoJPGc+CgkJPHBhdGggZD0iTTUwNS45NDIsNDc2LjY5NEwzNS4zMDYsNi4wNTljLTguMDc2LTguMDc3LTIxLjE3Mi04LjA3Ny0yOS4yNDgsMGMtOC4wNzcsOC4wNzYtOC4wNzcsMjEuMTcxLDAsMjkuMjQ4bDQ3MC42MzYsNDcwLjYzNiAgICBjNC4wMzgsNC4wMzksOS4zMzIsNi4wNTgsMTQuNjI1LDYuMDU4YzUuMjkzLDAsMTAuNTg3LTIuMDE5LDE0LjYyNC02LjA1N0M1MTQuMDE4LDQ5Ny44NjYsNTE0LjAxOCw0ODQuNzcxLDUwNS45NDIsNDc2LjY5NHoiIGZpbGw9IiMwMDAwMDAiLz4KCTwvZz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8Zz4KPC9nPgo8L3N2Zz4K\"\n />\n </button>\n </div>\n </div>\n </div>\n "}]}],"members":{"closable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":46,"character":3}}]}],"escapable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":3}}]}],"dismissable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":48,"character":3}}]}],"identifier":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":3}}]}],"customClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":3}}]}],"visible":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"backdrop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":52,"character":3}}]}],"force":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":53,"character":3}}]}],"hideDelay":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"autostart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":3}}]}],"target":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":56,"character":3}}]}],"visibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":58,"character":3}}]}],"onClose":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":59,"character":3}}]}],"onCloseFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":60,"character":3}}]}],"onDismiss":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":61,"character":3}}]}],"onDismissFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":62,"character":3}}]}],"onAnyCloseEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":63,"character":3}}]}],"onAnyCloseEventFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":64,"character":3}}]}],"onOpen":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":65,"character":3}}]}],"onEscape":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"onDataAdded":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"onDataRemoved":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"nsmContent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":76,"character":3},"arguments":["nsmContent"]}]}],"nsmDialog":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":77,"character":3},"arguments":["nsmDialog"]}]}],"nsmOverlay":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":78,"character":3},"arguments":["nsmOverlay"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":81,"character":29},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":82,"character":38},{"__symbolic":"reference","name":"NtkSmartModalService"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"dismiss":[{"__symbolic":"method"}],"toggle":[{"__symbolic":"method"}],"addCustomClass":[{"__symbolic":"method"}],"removeCustomClass":[{"__symbolic":"method"}],"isVisible":[{"__symbolic":"method"}],"hasData":[{"__symbolic":"method"}],"setData":[{"__symbolic":"method"}],"getData":[{"__symbolic":"method"}],"removeData":[{"__symbolic":"method"}],"targetPlacement":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":242,"character":3},"arguments":["window:resize"]}]}]}},"NtkSmartModalModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"NtkSmartModalComponent"}],"exports":[{"__symbolic":"reference","name":"NtkSmartModalComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":8,"character":12}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartModalModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartModalService"}]}},"forChild":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartModalModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartModalService"}]}}}},"NtkSmartLoaderService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1}}],"members":{"addLoader":[{"__symbolic":"method"}],"removeLoader":[{"__symbolic":"method"}],"getLoaderStack":[{"__symbolic":"method"}],"getLoaderStackCount":[{"__symbolic":"method"}],"getOpenedLoaders":[{"__symbolic":"method"}],"getActiveLoaders":[{"__symbolic":"method"}],"getHigherIndex":[{"__symbolic":"method"}],"start":[{"__symbolic":"method"}],"startAll":[{"__symbolic":"method"}],"stop":[{"__symbolic":"method"}],"stopAll":[{"__symbolic":"method"}],"isLoading":[{"__symbolic":"method"}],"executeAction":[{"__symbolic":"method"}],"_getLoader":[{"__symbolic":"method"}],"_addAction":[{"__symbolic":"method"}],"_removeAction":[{"__symbolic":"method"}]}},"NtkSmartLoaderComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":13,"character":1},"arguments":[{"selector":"ntk-smart-loader","template":"\n <div class=\"loader-container {{customClass}}\" [ngClass]=\"{'active': loading}\"\n [style.z-index]=\"layerPosition - 1\" *ngIf=\"visible\">\n <ng-content></ng-content>\n </div>\n "}]}],"members":{"identifier":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"customClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":25,"character":3}}]}],"force":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"delayIn":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"delayOut":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"autostart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"onStart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":30,"character":3}}]}],"onStop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":31,"character":3}}]}],"onVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":32,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"NtkSmartLoaderService"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":45,"character":94}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"start":[{"__symbolic":"method"}],"stop":[{"__symbolic":"method"}],"addCustomClass":[{"__symbolic":"method"}],"removeCustomClass":[{"__symbolic":"method"}]}},"NtkSmartLoaderModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"NtkSmartLoaderComponent"}],"exports":[{"__symbolic":"reference","name":"NtkSmartLoaderComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":12}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartLoaderModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartLoaderService"}]}},"forChild":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartLoaderModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartLoaderService"}]}}}}},"origins":{"NtkSmartModalService":"./lib/modal/ntk-smart-modal.service","NtkSmartModalComponent":"./lib/modal/ntk-smart-modal.component","NtkSmartModalModule":"./lib/modal/ntk-smart-modal.module","NtkSmartLoaderService":"./lib/loader/ntk-smart-loader.service","NtkSmartLoaderComponent":"./lib/loader/ntk-smart-loader.component","NtkSmartLoaderModule":"./lib/loader/ntk-smart-loader.module"},"importAs":"ngx-ntk-smart-module"}
{"__symbolic":"module","version":4,"metadata":{"NtkSmartModalService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":21,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":31,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":31,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":32,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":32,"character":12}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":26,"character":39},{"__symbolic":"reference","module":"@angular/core","name":"ApplicationRef","line":27,"character":21},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":23},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","module":"@angular/core","name":"ApplicationRef","line":27,"character":21},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"any"}]}],"addModal":[{"__symbolic":"method"}],"getModal":[{"__symbolic":"method"}],"get":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"closeAll":[{"__symbolic":"method"}],"toggle":[{"__symbolic":"method"}],"getModalStack":[{"__symbolic":"method"}],"getOpenedModals":[{"__symbolic":"method"}],"getTopOpenedModal":[{"__symbolic":"method"}],"getHigherIndex":[{"__symbolic":"method"}],"getModalStackCount":[{"__symbolic":"method"}],"removeModal":[{"__symbolic":"method"}],"setModalData":[{"__symbolic":"method"}],"getModalData":[{"__symbolic":"method"}],"resetModalData":[{"__symbolic":"method"}],"closeLatestModal":[{"__symbolic":"method"}],"create":[{"__symbolic":"method"}],"_addEvents":[{"__symbolic":"method"}],"_initModal":[{"__symbolic":"method"}],"_openModal":[{"__symbolic":"method"}],"_toggleModal":[{"__symbolic":"method"}],"_closeModal":[{"__symbolic":"method"}],"_dismissModal":[{"__symbolic":"method"}],"_deleteModal":[{"__symbolic":"method"}],"_resolveNgContent":[{"__symbolic":"method"}]}},"NtkSmartModalComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":25,"character":1},"arguments":[{"selector":"ntk-smart-modal","template":"\n <div *ngIf=\"overlayVisible\"\n [style.z-index]=\"visible ? layerPosition-1 : -1\"\n [ngClass]=\"{'transparent':!backdrop, 'overlay':true, 'nsm-overlay-open':openedClass}\"\n (click)=\"dismiss($event)\" #nsmOverlay>\n <div [style.z-index]=\"visible ? layerPosition : -1\"\n [ngClass]=\"['nsm-dialog', customClass, openedClass ? 'nsm-dialog-open': 'nsm-dialog-close']\" #nsmDialog\n [attr.aria-hidden]=\"openedClass ? false : true\"\n [attr.aria-label]=\"ariaLabel\"\n [attr.aria-labelledby]=\"ariaLabelledBy\"\n [attr.aria-describedby]=\"ariaDescribedBy\">\n <div class=\"nsm-content\" #nsmContent>\n <div class=\"nsm-body\">\n <ng-template #dynamicContent></ng-template>\n <ng-content></ng-content>\n\n </div>\n <button type=\"button\" *ngIf=\"closable\" (click)=\"close()\" aria-label=\"Close\" class=\"nsm-dialog-btn-close\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" id=\"Layer_1\" x=\"0px\" y=\"0px\" viewBox=\"0 0 512 512\"\n xml:space=\"preserve\" width=\"16px\" height=\"16px\" role=\"img\" aria-labelledby=\"closeIconTitle closeIconDesc\">\n <title id=\"closeIconTitle\">Close Icon</title>\n <desc id=\"closeIconDesc\">A light-gray close icon used to close the modal</desc>\n <g>\n <path d=\"M505.943,6.058c-8.077-8.077-21.172-8.077-29.249,0L6.058,476.693c-8.077,8.077-8.077,21.172,0,29.249 C10.096,509.982,15.39,512,20.683,512c5.293,0,10.586-2.019,14.625-6.059L505.943,35.306 C514.019,27.23,514.019,14.135,505.943,6.058z\"\n fill=\"currentColor\"/>\n </g>\n <g>\n <path d=\"M505.942,476.694L35.306,6.059c-8.076-8.077-21.172-8.077-29.248,0c-8.077,8.076-8.077,21.171,0,29.248l470.636,470.636 c4.038,4.039,9.332,6.058,14.625,6.058c5.293,0,10.587-2.019,14.624-6.057C514.018,497.866,514.018,484.771,505.942,476.694z\"\n fill=\"currentColor\"/>\n </g>\n </svg>\n </button>\n </div>\n </div>\n </div>\n "}]}],"members":{"closable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":65,"character":3}}]}],"escapable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":66,"character":3}}]}],"dismissable":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":3}}]}],"identifier":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"customClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":69,"character":3}}]}],"visible":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":70,"character":3}}]}],"backdrop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":71,"character":3}}]}],"force":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":72,"character":3}}]}],"hideDelay":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":73,"character":3}}]}],"autostart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":3}}]}],"target":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"ariaLabel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"ariaLabelledBy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":77,"character":3}}]}],"ariaDescribedBy":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"refocus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":79,"character":3}}]}],"visibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":81,"character":3}}]}],"onClose":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":82,"character":3}}]}],"onCloseFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":83,"character":3}}]}],"onDismiss":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":84,"character":3}}]}],"onDismissFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":85,"character":3}}]}],"onAnyCloseEvent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":86,"character":3}}]}],"onAnyCloseEventFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":87,"character":3}}]}],"onOpen":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":88,"character":3}}]}],"onOpenFinished":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":89,"character":3}}]}],"onEscape":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":90,"character":3}}]}],"onDataAdded":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":91,"character":3}}]}],"onDataRemoved":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":92,"character":3}}]}],"nsmContent":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":103,"character":3},"arguments":["nsmContent"]}]}],"nsmDialog":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":104,"character":3},"arguments":["nsmDialog"]}]}],"nsmOverlay":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":105,"character":3},"arguments":["nsmOverlay"]}]}],"dynamicContentContainer":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":106,"character":3},"arguments":["dynamicContent",{"read":{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":106,"character":42}}]}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":112,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":112,"character":12}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":113,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":113,"character":12}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":109,"character":23},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":110,"character":32},{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":111,"character":38},{"__symbolic":"reference","name":"any"},{"__symbolic":"reference","name":"any"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"dismiss":[{"__symbolic":"method"}],"toggle":[{"__symbolic":"method"}],"addCustomClass":[{"__symbolic":"method"}],"removeCustomClass":[{"__symbolic":"method"}],"isVisible":[{"__symbolic":"method"}],"hasData":[{"__symbolic":"method"}],"setData":[{"__symbolic":"method"}],"getData":[{"__symbolic":"method"}],"removeData":[{"__symbolic":"method"}],"addBodyClass":[{"__symbolic":"method"}],"removeBodyClass":[{"__symbolic":"method"}],"markForCheck":[{"__symbolic":"method"}],"targetPlacement":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":306,"character":3},"arguments":["window:resize"]}]}],"_sendEvent":[{"__symbolic":"method"}],"createDynamicContent":[{"__symbolic":"method"}]}},"NtkSmartModalModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"NtkSmartModalComponent"}],"exports":[{"__symbolic":"reference","name":"NtkSmartModalComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":12}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartModalModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartModalService"},{"__symbolic":"reference","name":"ɵa"}]}},"forChild":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartModalModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartModalService"},{"__symbolic":"reference","name":"ɵa"}]}}}},"NtkSmartLoaderService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"addLoader":[{"__symbolic":"method"}],"removeLoader":[{"__symbolic":"method"}],"getLoaderStack":[{"__symbolic":"method"}],"getLoaderStackCount":[{"__symbolic":"method"}],"getOpenedLoaders":[{"__symbolic":"method"}],"getActiveLoaders":[{"__symbolic":"method"}],"getHigherIndex":[{"__symbolic":"method"}],"start":[{"__symbolic":"method"}],"startAll":[{"__symbolic":"method"}],"stop":[{"__symbolic":"method"}],"stopAll":[{"__symbolic":"method"}],"isLoading":[{"__symbolic":"method"}],"executeAction":[{"__symbolic":"method"}],"_getLoader":[{"__symbolic":"method"}],"_addAction":[{"__symbolic":"method"}],"_removeAction":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"NtkSmartLoaderComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":13,"character":1},"arguments":[{"selector":"ntk-smart-loader","template":"\n <div class=\"loader-container {{customClass}}\" [ngClass]=\"{'active': loading}\"\n [style.z-index]=\"layerPosition - 1\" *ngIf=\"visible\">\n <ng-content></ng-content>\n </div>\n "}]}],"members":{"identifier":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"customClass":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":25,"character":3}}]}],"force":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"delayIn":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"delayOut":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":28,"character":3}}]}],"autostart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"onStart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":30,"character":3}}]}],"onStop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":31,"character":3}}]}],"onVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":32,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"NtkSmartLoaderService"},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":45,"character":94}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"start":[{"__symbolic":"method"}],"stop":[{"__symbolic":"method"}],"addCustomClass":[{"__symbolic":"method"}],"removeCustomClass":[{"__symbolic":"method"}]}},"NtkSmartLoaderModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"NtkSmartLoaderComponent"}],"exports":[{"__symbolic":"reference","name":"NtkSmartLoaderComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":12}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartLoaderModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartLoaderService"}]}},"forChild":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"NtkSmartLoaderModule"},"providers":[{"__symbolic":"reference","name":"NtkSmartLoaderService"}]}}}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":6,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"addModal":[{"__symbolic":"method"}],"getModal":[{"__symbolic":"method"}],"getModalStack":[{"__symbolic":"method"}],"getOpenedModals":[{"__symbolic":"method"}],"getTopOpenedModal":[{"__symbolic":"method"}],"getHigherIndex":[{"__symbolic":"method"}],"getModalStackCount":[{"__symbolic":"method"}],"removeModal":[{"__symbolic":"method"}]}}},"origins":{"NtkSmartModalService":"./lib/modal/ntk-smart-modal.service","NtkSmartModalComponent":"./lib/modal/ntk-smart-modal.component","NtkSmartModalModule":"./lib/modal/ntk-smart-modal.module","NtkSmartLoaderService":"./lib/loader/ntk-smart-loader.service","NtkSmartLoaderComponent":"./lib/loader/ntk-smart-loader.component","NtkSmartLoaderModule":"./lib/loader/ntk-smart-loader.module","ɵa":"./lib/modal/ntk-smart-modal-stack.service"},"importAs":"ngx-ntk-smart-module"}
{
"name": "ngx-ntk-smart-module",
"version": "1.0.3",
"version": "1.1.2",
"description": "Ntk Cms Modal ",

@@ -5,0 +5,0 @@ "author": "Alireza-Karavi",

Sorry, the diff of this file is too big to display

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc