New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

angular-split

Package Overview
Dependencies
Maintainers
1
Versions
102
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

angular-split - npm Package Compare versions

Comparing version 3.0.1 to 3.0.2

0

angular-split.d.ts

@@ -0,0 +0,0 @@ /**

2

bundles/angular-split.umd.min.js

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-split",["exports","@angular/core","rxjs","rxjs/operators","@angular/common"],t):t(e["angular-split"]={},e.ng.core,e.rxjs,e.rxjs.operators,e.ng.common)}(this,function(e,r,s,i,t){"use strict";function n(e,t){var i="function"==typeof Symbol&&e[Symbol.iterator];if(!i)return e;var n,r,s=i.call(e),a=[];try{for(;(void 0===t||0<t--)&&!(n=s.next()).done;)a.push(n.value)}catch(o){r={error:o}}finally{try{n&&!n.done&&(i=s["return"])&&i.call(s)}finally{if(r)throw r.error}}return a}function l(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(n(arguments[t]));return e}function u(e){return e.changedTouches!==undefined&&0<e.changedTouches.length?{x:e.changedTouches[0].clientX,y:e.changedTouches[0].clientY}:e.clientX!==undefined&&e.clientY!==undefined?{x:e.clientX,y:e.clientY}:null}function a(e,t){var i=e.nativeElement.getBoundingClientRect();return"horizontal"===t?i.width:i.height}function o(e){return"boolean"==typeof e?e:"false"!==e}function h(e,t){return null===e||e===undefined?t:(e=Number(e),!isNaN(e)&&0<=e?e:t)}function p(e,t){if("percent"===e){var i=t.reduce(function(e,t){return null!==t?e+t:e},0);return t.every(function(e){return null!==e})&&99.9<i&&i<100.1}if("pixel"===e)return 1===t.filter(function(e){return null===e}).length}function c(e){return null===e.size?null:!0===e.component.lockSize?e.size:null===e.component.minSize?null:e.component.minSize>e.size?e.size:e.component.minSize}function d(e){return null===e.size?null:!0===e.component.lockSize?e.size:null===e.component.maxSize?null:e.component.maxSize<e.size?e.size:e.component.maxSize}function f(n,e,t,r){return e.reduce(function(e,t){var i=function s(e,t,i,n){if(0===i)return{areaSnapshot:t,pixelAbsorb:0,percentAfterAbsorption:t.sizePercentAtStart,pixelRemain:0};if(0===t.sizePixelAtStart&&i<0)return{areaSnapshot:t,pixelAbsorb:0,percentAfterAbsorption:0,pixelRemain:i};if("percent"===e)return function a(e,t,i){var n=(e.sizePixelAtStart+t)/i*100;{if(0<t){if(null!==e.area.maxSize&&n>e.area.maxSize){var r=e.area.maxSize/100*i;return{areaSnapshot:e,pixelAbsorb:r,percentAfterAbsorption:e.area.maxSize,pixelRemain:e.sizePixelAtStart+t-r}}return{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:100<n?100:n,pixelRemain:0}}if(t<0){if(null!==e.area.minSize&&n<e.area.minSize){var s=e.area.minSize/100*i;return{areaSnapshot:e,pixelAbsorb:s,percentAfterAbsorption:e.area.minSize,pixelRemain:e.sizePixelAtStart+t-s}}return n<0?{areaSnapshot:e,pixelAbsorb:-e.sizePixelAtStart,percentAfterAbsorption:0,pixelRemain:t+e.sizePixelAtStart}:{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:n,pixelRemain:0}}}}(t,i,n);if("pixel"===e)return function r(e,t,i){var n=e.sizePixelAtStart+t;{if(0<t)return null!==e.area.maxSize&&n>e.area.maxSize?{areaSnapshot:e,pixelAbsorb:e.area.maxSize-e.sizePixelAtStart,percentAfterAbsorption:-1,pixelRemain:n-e.area.maxSize}:{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:-1,pixelRemain:0};if(t<0)return null!==e.area.minSize&&n<e.area.minSize?{areaSnapshot:e,pixelAbsorb:e.area.minSize+t-n,percentAfterAbsorption:-1,pixelRemain:n-e.area.minSize}:n<0?{areaSnapshot:e,pixelAbsorb:-e.sizePixelAtStart,percentAfterAbsorption:-1,pixelRemain:t+e.sizePixelAtStart}:{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:-1,pixelRemain:0}}}(t,i)}(n,t,e.remain,r);return e.list.push(i),e.remain=i.pixelRemain,e},{remain:t,list:[]})}function g(e,t){"percent"===e?t.areaSnapshot.area.size=t.percentAfterAbsorption:"pixel"===e&&null!==t.areaSnapshot.area.size&&(t.areaSnapshot.area.size=t.areaSnapshot.sizePixelAtStart+t.pixelAbsorb)}var m=function(){function e(e,t,i,n){this.ngZone=e,this.elRef=t,this.cdRef=i,this.renderer=n,this._direction="horizontal",this._unit="percent",this._gutterSize=11,this._gutterStep=1,this._restrictMove=!1,this._useTransition=!1,this._disabled=!1,this._dir="ltr",this._gutterDblClickDuration=0,this.dragStart=new r.EventEmitter(!1),this.dragEnd=new r.EventEmitter(!1),this.gutterClick=new r.EventEmitter(!1),this.gutterDblClick=new r.EventEmitter(!1),this.dragProgressSubject=new s.Subject,this.dragProgress$=this.dragProgressSubject.asObservable(),this.isDragging=!1,this.dragListeners=[],this.snapshot=null,this.startPoint=null,this.endPoint=null,this.displayedAreas=[],this.hidedAreas=[],this._clickTimeout=null,this.direction=this._direction}return Object.defineProperty(e.prototype,"direction",{get:function(){return this._direction},set:function(e){this._direction="vertical"===e?"vertical":"horizontal",this.renderer.addClass(this.elRef.nativeElement,"as-"+this._direction),this.renderer.removeClass(this.elRef.nativeElement,"as-"+("vertical"===this._direction?"horizontal":"vertical")),this.build(!1,!1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"unit",{get:function(){return this._unit},set:function(e){this._unit="pixel"===e?"pixel":"percent",this.renderer.addClass(this.elRef.nativeElement,"as-"+this._unit),this.renderer.removeClass(this.elRef.nativeElement,"as-"+("pixel"===this._unit?"percent":"pixel")),this.build(!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"gutterSize",{get:function(){return this._gutterSize},set:function(e){this._gutterSize=h(e,11),this.build(!1,!1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"gutterStep",{get:function(){return this._gutterStep},set:function(e){this._gutterStep=h(e,1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"restrictMove",{get:function(){return this._restrictMove},set:function(e){this._restrictMove=o(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"useTransition",{get:function(){return this._useTransition},set:function(e){this._useTransition=o(e),this._useTransition?this.renderer.addClass(this.elRef.nativeElement,"as-transition"):this.renderer.removeClass(this.elRef.nativeElement,"as-transition")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"disabled",{get:function(){return this._disabled},set:function(e){this._disabled=o(e),this._disabled?this.renderer.addClass(this.elRef.nativeElement,"as-disabled"):this.renderer.removeClass(this.elRef.nativeElement,"as-disabled")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dir",{get:function(){return this._dir},set:function(e){this._dir="rtl"===e?"rtl":"ltr",this.renderer.setAttribute(this.elRef.nativeElement,"dir",this._dir)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"gutterDblClickDuration",{get:function(){return this._gutterDblClickDuration},set:function(e){this._gutterDblClickDuration=h(e,0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"transitionEnd",{get:function(){var t=this;return new s.Observable(function(e){return t.transitionEndSubscriber=e}).pipe(i.debounceTime(20))},enumerable:!0,configurable:!0}),e.prototype.ngAfterViewInit=function(){var e=this;this.ngZone.runOutsideAngular(function(){setTimeout(function(){return e.renderer.addClass(e.elRef.nativeElement,"as-init")})})},e.prototype.getNbGutters=function(){return 0===this.displayedAreas.length?0:this.displayedAreas.length-1},e.prototype.addArea=function(e){var t={component:e,order:0,size:0,minSize:null,maxSize:null};!0===e.visible?(this.displayedAreas.push(t),this.build(!0,!0)):this.hidedAreas.push(t)},e.prototype.removeArea=function(t){if(this.displayedAreas.some(function(e){return e.component===t})){var e=this.displayedAreas.find(function(e){return e.component===t});this.displayedAreas.splice(this.displayedAreas.indexOf(e),1),this.build(!0,!0)}else if(this.hidedAreas.some(function(e){return e.component===t})){e=this.hidedAreas.find(function(e){return e.component===t});this.hidedAreas.splice(this.hidedAreas.indexOf(e),1)}},e.prototype.updateArea=function(e,t,i){!0===e.visible&&this.build(t,i)},e.prototype.showArea=function(t){var e,i=this.hidedAreas.find(function(e){return e.component===t});if(i!==undefined){var n=this.hidedAreas.splice(this.hidedAreas.indexOf(i),1);(e=this.displayedAreas).push.apply(e,l(n)),this.build(!0,!0)}},e.prototype.hideArea=function(t){var e,i=this.displayedAreas.find(function(e){return e.component===t});if(i!==undefined){var n=this.displayedAreas.splice(this.displayedAreas.indexOf(i),1);n.forEach(function(e){e.order=0,e.size=0}),(e=this.hidedAreas).push.apply(e,l(n)),this.build(!0,!0)}},e.prototype.getVisibleAreaSizes=function(){return this.displayedAreas.map(function(e){return null===e.size?"*":e.size})},e.prototype.setVisibleAreaSizes=function(e){if(e.length!==this.displayedAreas.length)return!1;var i=e.map(function(e){return h(e,null)});return!1!==p(this.unit,i)&&(this.displayedAreas.forEach(function(e,t){return e.component._size=i[t]}),this.build(!1,!0),!0)},e.prototype.build=function(e,t){if(this.stopDragging(),!0===e&&(this.displayedAreas.every(function(e){return null!==e.component.order})&&this.displayedAreas.sort(function(e,t){return e.component.order-t.component.order}),this.displayedAreas.forEach(function(e,t){e.order=2*t,e.component.setStyleOrder(e.order)})),!0===t){var i=p(this.unit,this.displayedAreas.map(function(e){return e.component.size}));switch(this.unit){case"percent":var n=100/this.displayedAreas.length;this.displayedAreas.forEach(function(e){e.size=i?e.component.size:n,e.minSize=c(e),e.maxSize=d(e)});break;case"pixel":if(i)this.displayedAreas.forEach(function(e){e.size=e.component.size,e.minSize=c(e),e.maxSize=d(e)});else{var r=this.displayedAreas.filter(function(e){return null===e.component.size});if(0===r.length&&0<this.displayedAreas.length)this.displayedAreas.forEach(function(e,t){e.size=0===t?null:e.component.size,e.minSize=0===t?null:c(e),e.maxSize=0===t?null:d(e)});else if(1<r.length){var s=!1;this.displayedAreas.forEach(function(e){null===e.component.size?!1===s?(e.size=null,e.minSize=null,e.maxSize=null,s=!0):(e.size=100,e.minSize=null,e.maxSize=null):(e.size=e.component.size,e.minSize=c(e),e.maxSize=d(e))})}}}}this.refreshStyleSizes(),this.cdRef.markForCheck()},e.prototype.refreshStyleSizes=function(){var t=this;if("percent"===this.unit)if(1===this.displayedAreas.length)this.displayedAreas[0].component.setStyleFlex(0,0,"100%",!1,!1);else{var i=this.getNbGutters()*this.gutterSize;this.displayedAreas.forEach(function(e){e.component.setStyleFlex(0,0,"calc( "+e.size+"% - "+e.size/100*i+"px )",null!==e.minSize&&e.minSize===e.size,null!==e.maxSize&&e.maxSize===e.size)})}else"pixel"===this.unit&&this.displayedAreas.forEach(function(e){null===e.size?1===t.displayedAreas.length?e.component.setStyleFlex(1,1,"100%",!1,!1):e.component.setStyleFlex(1,1,"auto",!1,!1):1===t.displayedAreas.length?e.component.setStyleFlex(0,0,"100%",!1,!1):e.component.setStyleFlex(0,0,e.size+"px",null!==e.minSize&&e.minSize===e.size,null!==e.maxSize&&e.maxSize===e.size)})},e.prototype.clickGutter=function(e,t){var i=this,n=u(e);this.startPoint&&this.startPoint.x===n.x&&this.startPoint.y===n.y&&(null!==this._clickTimeout?(window.clearTimeout(this._clickTimeout),this._clickTimeout=null,this.notify("dblclick",t),this.stopDragging()):this._clickTimeout=window.setTimeout(function(){i._clickTimeout=null,i.notify("click",t),i.stopDragging()},this.gutterDblClickDuration))},e.prototype.startDragging=function(e,i,t){var n=this;e.preventDefault(),e.stopPropagation(),this.startPoint=u(e),null!==this.startPoint&&!0!==this.disabled&&(this.snapshot={gutterNum:t,lastSteppedOffset:0,allAreasSizePixel:a(this.elRef,this.direction)-this.getNbGutters()*this.gutterSize,allInvolvedAreasSizePercent:100,areasBeforeGutter:[],areasAfterGutter:[]},this.displayedAreas.forEach(function(e){var t={area:e,sizePixelAtStart:a(e.component.elRef,n.direction),sizePercentAtStart:"percent"===n.unit?e.size:-1};e.order<i?!0===n.restrictMove?n.snapshot.areasBeforeGutter=[t]:n.snapshot.areasBeforeGutter.unshift(t):e.order>i&&(!0===n.restrictMove?0===n.snapshot.areasAfterGutter.length&&(n.snapshot.areasAfterGutter=[t]):n.snapshot.areasAfterGutter.push(t))}),this.snapshot.allInvolvedAreasSizePercent=l(this.snapshot.areasBeforeGutter,this.snapshot.areasAfterGutter).reduce(function(e,t){return e+t.sizePercentAtStart},0),0!==this.snapshot.areasBeforeGutter.length&&0!==this.snapshot.areasAfterGutter.length&&(this.dragListeners.push(this.renderer.listen("document","mouseup",this.stopDragging.bind(this))),this.dragListeners.push(this.renderer.listen("document","touchend",this.stopDragging.bind(this))),this.dragListeners.push(this.renderer.listen("document","touchcancel",this.stopDragging.bind(this))),this.ngZone.runOutsideAngular(function(){n.dragListeners.push(n.renderer.listen("document","mousemove",n.dragEvent.bind(n))),n.dragListeners.push(n.renderer.listen("document","touchmove",n.dragEvent.bind(n)))}),this.displayedAreas.forEach(function(e){return e.component.lockEvents()}),this.isDragging=!0,this.renderer.addClass(this.elRef.nativeElement,"as-dragging"),this.renderer.addClass(this.gutterEls.toArray()[this.snapshot.gutterNum-1].nativeElement,"as-dragged"),this.notify("start",this.snapshot.gutterNum)))},e.prototype.dragEvent=function(e){var t=this;if(e.preventDefault(),e.stopPropagation(),null!==this._clickTimeout&&(window.clearTimeout(this._clickTimeout),this._clickTimeout=null),!1!==this.isDragging&&(this.endPoint=u(e),null!==this.endPoint)){var i="horizontal"===this.direction?this.startPoint.x-this.endPoint.x:this.startPoint.y-this.endPoint.y;"rtl"===this.dir&&(i=-i);var n=Math.round(i/this.gutterStep)*this.gutterStep;if(n!==this.snapshot.lastSteppedOffset){this.snapshot.lastSteppedOffset=n;var r=f(this.unit,this.snapshot.areasBeforeGutter,-n,this.snapshot.allAreasSizePixel),s=f(this.unit,this.snapshot.areasAfterGutter,n,this.snapshot.allAreasSizePixel);if(0!==r.remain&&0!==s.remain?Math.abs(r.remain)===Math.abs(s.remain)||(Math.abs(r.remain)>Math.abs(s.remain)?s=f(this.unit,this.snapshot.areasAfterGutter,n+r.remain,this.snapshot.allAreasSizePixel):r=f(this.unit,this.snapshot.areasBeforeGutter,-(n-s.remain),this.snapshot.allAreasSizePixel)):0!==r.remain?s=f(this.unit,this.snapshot.areasAfterGutter,n+r.remain,this.snapshot.allAreasSizePixel):0!==s.remain&&(r=f(this.unit,this.snapshot.areasBeforeGutter,-(n-s.remain),this.snapshot.allAreasSizePixel)),"percent"===this.unit){var a=l(r.list,s.list),o=a.find(function(e){return 0!==e.percentAfterAbsorption&&e.percentAfterAbsorption!==e.areaSnapshot.area.minSize&&e.percentAfterAbsorption!==e.areaSnapshot.area.maxSize});o&&(o.percentAfterAbsorption=this.snapshot.allInvolvedAreasSizePercent-a.filter(function(e){return e!==o}).reduce(function(e,t){return e+t.percentAfterAbsorption},0))}r.list.forEach(function(e){return g(t.unit,e)}),s.list.forEach(function(e){return g(t.unit,e)}),this.refreshStyleSizes(),this.notify("progress",this.snapshot.gutterNum)}}},e.prototype.stopDragging=function(e){var t=this;if(e&&(e.preventDefault(),e.stopPropagation()),!1!==this.isDragging){for(this.displayedAreas.forEach(function(e){return e.component.unlockEvents()});0<this.dragListeners.length;){var i=this.dragListeners.pop();i&&i()}this.isDragging=!1,!this.endPoint||this.startPoint.x===this.endPoint.x&&this.startPoint.y===this.endPoint.y||this.notify("end",this.snapshot.gutterNum),this.renderer.removeClass(this.elRef.nativeElement,"as-dragging"),this.renderer.removeClass(this.gutterEls.toArray()[this.snapshot.gutterNum-1].nativeElement,"as-dragged"),this.snapshot=null,this.ngZone.runOutsideAngular(function(){setTimeout(function(){t.startPoint=null,t.endPoint=null})})}},e.prototype.notify=function(e,t){var i=this,n=this.getVisibleAreaSizes();"start"===e?this.dragStart.emit({gutterNum:t,sizes:n}):"end"===e?this.dragEnd.emit({gutterNum:t,sizes:n}):"click"===e?this.gutterClick.emit({gutterNum:t,sizes:n}):"dblclick"===e?this.gutterDblClick.emit({gutterNum:t,sizes:n}):"transitionEnd"===e?this.transitionEndSubscriber&&this.ngZone.run(function(){return i.transitionEndSubscriber.next(n)}):"progress"===e&&this.dragProgressSubject.next({gutterNum:t,sizes:n})},e.prototype.ngOnDestroy=function(){this.stopDragging()},e.decorators=[{type:r.Component,args:[{selector:"as-split",exportAs:"asSplit",changeDetection:r.ChangeDetectionStrategy.OnPush,template:'\n <ng-content></ng-content>\n <ng-template ngFor [ngForOf]="displayedAreas" let-index="index" let-last="last">\n <div *ngIf="last === false" \n #gutterEls\n class="as-split-gutter"\n [style.flex-basis.px]="gutterSize"\n [style.order]="index*2+1"\n (mousedown)="startDragging($event, index*2+1, index+1)"\n (touchstart)="startDragging($event, index*2+1, index+1)"\n (mouseup)="clickGutter($event, index+1)"\n (touchend)="clickGutter($event, index+1)">\n <div class="as-split-gutter-icon"></div>\n </div>\n </ng-template>',styles:[':host{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:stretch;overflow:hidden;width:100%;height:100%}:host>.as-split-gutter{flex-grow:0;flex-shrink:0;background-color:#eee;display:flex;align-items:center;justify-content:center}:host>.as-split-gutter>.as-split-gutter-icon{width:100%;height:100%;background-position:center center;background-repeat:no-repeat}:host ::ng-deep>.as-split-area{flex-grow:0;flex-shrink:0;overflow-x:hidden;overflow-y:auto}:host ::ng-deep>.as-split-area.as-hidden{flex:0 1 0!important;overflow-x:hidden;overflow-y:hidden}:host.as-horizontal{flex-direction:row}:host.as-horizontal>.as-split-gutter{flex-direction:row;cursor:col-resize;height:100%}:host.as-horizontal>.as-split-gutter>.as-split-gutter-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAeCAYAAADkftS9AAAAIklEQVQoU2M4c+bMfxAGAgYYmwGrIIiDjrELjpo5aiZeMwF+yNnOs5KSvgAAAABJRU5ErkJggg==)}:host.as-horizontal ::ng-deep>.as-split-area{height:100%}:host.as-vertical{flex-direction:column}:host.as-vertical>.as-split-gutter{flex-direction:column;cursor:row-resize;width:100%}:host.as-vertical>.as-split-gutter .as-split-gutter-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAFCAMAAABl/6zIAAAABlBMVEUAAADMzMzIT8AyAAAAAXRSTlMAQObYZgAAABRJREFUeAFjYGRkwIMJSeMHlBkOABP7AEGzSuPKAAAAAElFTkSuQmCC)}:host.as-vertical ::ng-deep>.as-split-area{width:100%}:host.as-vertical ::ng-deep>.as-split-area.as-hidden{max-width:0}:host.as-disabled>.as-split-gutter{cursor:default}:host.as-disabled>.as-split-gutter .as-split-gutter-icon{background-image:url("")}:host.as-transition.as-init:not(.as-dragging) ::ng-deep>.as-split-area,:host.as-transition.as-init:not(.as-dragging)>.as-split-gutter{transition:flex-basis .3s}']}]}],e.ctorParameters=function(){return[{type:r.NgZone},{type:r.ElementRef},{type:r.ChangeDetectorRef},{type:r.Renderer2}]},e.propDecorators={direction:[{type:r.Input}],unit:[{type:r.Input}],gutterSize:[{type:r.Input}],gutterStep:[{type:r.Input}],restrictMove:[{type:r.Input}],useTransition:[{type:r.Input}],disabled:[{type:r.Input}],dir:[{type:r.Input}],gutterDblClickDuration:[{type:r.Input}],dragStart:[{type:r.Output}],dragEnd:[{type:r.Output}],gutterClick:[{type:r.Output}],gutterDblClick:[{type:r.Output}],transitionEnd:[{type:r.Output}],gutterEls:[{type:r.ViewChildren,args:["gutterEls"]}]},e}(),A=function(){function e(e,t,i,n){this.ngZone=e,this.elRef=t,this.renderer=i,this.split=n,this._order=null,this._size=null,this._minSize=null,this._maxSize=null,this._lockSize=!1,this._visible=!0,this.lockListeners=[],this.renderer.addClass(this.elRef.nativeElement,"as-split-area")}return Object.defineProperty(e.prototype,"order",{get:function(){return this._order},set:function(e){this._order=h(e,null),this.split.updateArea(this,!0,!1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"size",{get:function(){return this._size},set:function(e){this._size=h(e,null),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"minSize",{get:function(){return this._minSize},set:function(e){this._minSize=h(e,null),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"maxSize",{get:function(){return this._maxSize},set:function(e){this._maxSize=h(e,null),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lockSize",{get:function(){return this._lockSize},set:function(e){this._lockSize=o(e),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"visible",{get:function(){return this._visible},set:function(e){this._visible=o(e),this._visible?(this.split.showArea(this),this.renderer.removeClass(this.elRef.nativeElement,"as-hidden")):(this.split.hideArea(this),this.renderer.addClass(this.elRef.nativeElement,"as-hidden"))},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){var t=this;this.split.addArea(this),this.ngZone.runOutsideAngular(function(){t.transitionListener=t.renderer.listen(t.elRef.nativeElement,"transitionend",function(e){"flex-basis"===e.propertyName&&t.split.notify("transitionEnd",-1)})})},e.prototype.setStyleOrder=function(e){this.renderer.setStyle(this.elRef.nativeElement,"order",e)},e.prototype.setStyleFlex=function(e,t,i,n,r){this.renderer.setStyle(this.elRef.nativeElement,"flex-grow",e),this.renderer.setStyle(this.elRef.nativeElement,"flex-shrink",t),this.renderer.setStyle(this.elRef.nativeElement,"flex-basis",i),!0===n?this.renderer.addClass(this.elRef.nativeElement,"as-min"):this.renderer.removeClass(this.elRef.nativeElement,"as-min"),!0===r?this.renderer.addClass(this.elRef.nativeElement,"as-max"):this.renderer.removeClass(this.elRef.nativeElement,"as-max")},e.prototype.lockEvents=function(){var e=this;this.ngZone.runOutsideAngular(function(){e.lockListeners.push(e.renderer.listen(e.elRef.nativeElement,"selectstart",function(e){return!1})),e.lockListeners.push(e.renderer.listen(e.elRef.nativeElement,"dragstart",function(e){return!1}))})},e.prototype.unlockEvents=function(){for(;0<this.lockListeners.length;){var e=this.lockListeners.pop();e&&e()}},e.prototype.ngOnDestroy=function(){this.unlockEvents(),this.transitionListener&&this.transitionListener(),this.split.removeArea(this)},e.decorators=[{type:r.Directive,args:[{selector:"as-split-area, [as-split-area]",exportAs:"asSplitArea"}]}],e.ctorParameters=function(){return[{type:r.NgZone},{type:r.ElementRef},{type:r.Renderer2},{type:m}]},e.propDecorators={order:[{type:r.Input}],size:[{type:r.Input}],minSize:[{type:r.Input}],maxSize:[{type:r.Input}],lockSize:[{type:r.Input}],visible:[{type:r.Input}]},e}(),y=function(){function e(){}return e.forRoot=function(){return{ngModule:e,providers:[]}},e.forChild=function(){return{ngModule:e,providers:[]}},e.decorators=[{type:r.NgModule,args:[{imports:[t.CommonModule],declarations:[m,A],exports:[m,A]}]}],e}();e.AngularSplitModule=y,e.SplitComponent=m,e.SplitAreaDirective=A,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("angular-split",["exports","@angular/core","@angular/common","rxjs","rxjs/operators"],t):t((e=e||self)["angular-split"]={},e.ng.core,e.ng.common,e.rxjs,e.rxjs.operators)}(this,function(e,t,i,n,r){"use strict";function s(e,t){var i="function"==typeof Symbol&&e[Symbol.iterator];if(!i)return e;var n,r,s=i.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(n=s.next()).done;)a.push(n.value)}catch(o){r={error:o}}finally{try{n&&!n.done&&(i=s["return"])&&i.call(s)}finally{if(r)throw r.error}}return a}function a(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(s(arguments[t]));return e}function o(e){return e.changedTouches!==undefined&&e.changedTouches.length>0?{x:e.changedTouches[0].clientX,y:e.changedTouches[0].clientY}:e.clientX!==undefined&&e.clientY!==undefined?{x:e.clientX,y:e.clientY}:null}function l(e,t){var i=e.nativeElement.getBoundingClientRect();return"horizontal"===t?i.width:i.height}function u(e){return"boolean"==typeof e?e:"false"!==e}function h(e,t){return null===e||e===undefined?t:(e=Number(e),!isNaN(e)&&e>=0?e:t)}function p(e,t){if("percent"===e){var i=t.reduce(function(e,t){return null!==t?e+t:e},0);return t.every(function(e){return null!==e})&&i>99.9&&i<100.1}if("pixel"===e)return 1===t.filter(function(e){return null===e}).length}function c(e){return null===e.size?null:!0===e.component.lockSize?e.size:null===e.component.minSize?null:e.component.minSize>e.size?e.size:e.component.minSize}function d(e){return null===e.size?null:!0===e.component.lockSize?e.size:null===e.component.maxSize?null:e.component.maxSize<e.size?e.size:e.component.maxSize}function f(e,t,i,n){return t.reduce(function(t,i){var r=function(e,t,i,n){if(0===i)return{areaSnapshot:t,pixelAbsorb:0,percentAfterAbsorption:t.sizePercentAtStart,pixelRemain:0};if(0===t.sizePixelAtStart&&i<0)return{areaSnapshot:t,pixelAbsorb:0,percentAfterAbsorption:0,pixelRemain:i};if("percent"===e)return function(e,t,i){var n=(e.sizePixelAtStart+t)/i*100;if(t>0){if(null!==e.area.maxSize&&n>e.area.maxSize){var r=e.area.maxSize/100*i;return{areaSnapshot:e,pixelAbsorb:r,percentAfterAbsorption:e.area.maxSize,pixelRemain:e.sizePixelAtStart+t-r}}return{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:n>100?100:n,pixelRemain:0}}if(t<0){if(null!==e.area.minSize&&n<e.area.minSize){var s=e.area.minSize/100*i;return{areaSnapshot:e,pixelAbsorb:s,percentAfterAbsorption:e.area.minSize,pixelRemain:e.sizePixelAtStart+t-s}}return n<0?{areaSnapshot:e,pixelAbsorb:-e.sizePixelAtStart,percentAfterAbsorption:0,pixelRemain:t+e.sizePixelAtStart}:{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:n,pixelRemain:0}}}(t,i,n);if("pixel"===e)return function(e,t,i){var n=e.sizePixelAtStart+t;if(t>0)return null!==e.area.maxSize&&n>e.area.maxSize?{areaSnapshot:e,pixelAbsorb:e.area.maxSize-e.sizePixelAtStart,percentAfterAbsorption:-1,pixelRemain:n-e.area.maxSize}:{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:-1,pixelRemain:0};if(t<0)return null!==e.area.minSize&&n<e.area.minSize?{areaSnapshot:e,pixelAbsorb:e.area.minSize+t-n,percentAfterAbsorption:-1,pixelRemain:n-e.area.minSize}:n<0?{areaSnapshot:e,pixelAbsorb:-e.sizePixelAtStart,percentAfterAbsorption:-1,pixelRemain:t+e.sizePixelAtStart}:{areaSnapshot:e,pixelAbsorb:t,percentAfterAbsorption:-1,pixelRemain:0}}(t,i)}(e,i,t.remain,n);return t.list.push(r),t.remain=r.pixelRemain,t},{remain:i,list:[]})}function g(e,t){"percent"===e?t.areaSnapshot.area.size=t.percentAfterAbsorption:"pixel"===e&&null!==t.areaSnapshot.area.size&&(t.areaSnapshot.area.size=t.areaSnapshot.sizePixelAtStart+t.pixelAbsorb)}var m=function(){function e(e,i,r,s){this.ngZone=e,this.elRef=i,this.cdRef=r,this.renderer=s,this._direction="horizontal",this._unit="percent",this._gutterSize=11,this._gutterStep=1,this._restrictMove=!1,this._useTransition=!1,this._disabled=!1,this._dir="ltr",this._gutterDblClickDuration=0,this.dragStart=new t.EventEmitter(!1),this.dragEnd=new t.EventEmitter(!1),this.gutterClick=new t.EventEmitter(!1),this.gutterDblClick=new t.EventEmitter(!1),this.dragProgressSubject=new n.Subject,this.dragProgress$=this.dragProgressSubject.asObservable(),this.isDragging=!1,this.dragListeners=[],this.snapshot=null,this.startPoint=null,this.endPoint=null,this.displayedAreas=[],this.hidedAreas=[],this._clickTimeout=null,this.direction=this._direction}return Object.defineProperty(e.prototype,"direction",{get:function(){return this._direction},set:function(e){this._direction="vertical"===e?"vertical":"horizontal",this.renderer.addClass(this.elRef.nativeElement,"as-"+this._direction),this.renderer.removeClass(this.elRef.nativeElement,"as-"+("vertical"===this._direction?"horizontal":"vertical")),this.build(!1,!1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"unit",{get:function(){return this._unit},set:function(e){this._unit="pixel"===e?"pixel":"percent",this.renderer.addClass(this.elRef.nativeElement,"as-"+this._unit),this.renderer.removeClass(this.elRef.nativeElement,"as-"+("pixel"===this._unit?"percent":"pixel")),this.build(!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"gutterSize",{get:function(){return this._gutterSize},set:function(e){this._gutterSize=h(e,11),this.build(!1,!1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"gutterStep",{get:function(){return this._gutterStep},set:function(e){this._gutterStep=h(e,1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"restrictMove",{get:function(){return this._restrictMove},set:function(e){this._restrictMove=u(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"useTransition",{get:function(){return this._useTransition},set:function(e){this._useTransition=u(e),this._useTransition?this.renderer.addClass(this.elRef.nativeElement,"as-transition"):this.renderer.removeClass(this.elRef.nativeElement,"as-transition")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"disabled",{get:function(){return this._disabled},set:function(e){this._disabled=u(e),this._disabled?this.renderer.addClass(this.elRef.nativeElement,"as-disabled"):this.renderer.removeClass(this.elRef.nativeElement,"as-disabled")},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"dir",{get:function(){return this._dir},set:function(e){this._dir="rtl"===e?"rtl":"ltr",this.renderer.setAttribute(this.elRef.nativeElement,"dir",this._dir)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"gutterDblClickDuration",{get:function(){return this._gutterDblClickDuration},set:function(e){this._gutterDblClickDuration=h(e,0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"transitionEnd",{get:function(){var e=this;return new n.Observable(function(t){return e.transitionEndSubscriber=t}).pipe(r.debounceTime(20))},enumerable:!0,configurable:!0}),e.prototype.ngAfterViewInit=function(){var e=this;this.ngZone.runOutsideAngular(function(){setTimeout(function(){return e.renderer.addClass(e.elRef.nativeElement,"as-init")})})},e.prototype.getNbGutters=function(){return 0===this.displayedAreas.length?0:this.displayedAreas.length-1},e.prototype.addArea=function(e){var t={component:e,order:0,size:0,minSize:null,maxSize:null};!0===e.visible?(this.displayedAreas.push(t),this.build(!0,!0)):this.hidedAreas.push(t)},e.prototype.removeArea=function(e){if(this.displayedAreas.some(function(t){return t.component===e})){var t=this.displayedAreas.find(function(t){return t.component===e});this.displayedAreas.splice(this.displayedAreas.indexOf(t),1),this.build(!0,!0)}else if(this.hidedAreas.some(function(t){return t.component===e})){t=this.hidedAreas.find(function(t){return t.component===e});this.hidedAreas.splice(this.hidedAreas.indexOf(t),1)}},e.prototype.updateArea=function(e,t,i){!0===e.visible&&this.build(t,i)},e.prototype.showArea=function(e){var t,i=this.hidedAreas.find(function(t){return t.component===e});if(i!==undefined){var n=this.hidedAreas.splice(this.hidedAreas.indexOf(i),1);(t=this.displayedAreas).push.apply(t,a(n)),this.build(!0,!0)}},e.prototype.hideArea=function(e){var t,i=this.displayedAreas.find(function(t){return t.component===e});if(i!==undefined){var n=this.displayedAreas.splice(this.displayedAreas.indexOf(i),1);n.forEach(function(e){e.order=0,e.size=0}),(t=this.hidedAreas).push.apply(t,a(n)),this.build(!0,!0)}},e.prototype.getVisibleAreaSizes=function(){return this.displayedAreas.map(function(e){return null===e.size?"*":e.size})},e.prototype.setVisibleAreaSizes=function(e){if(e.length!==this.displayedAreas.length)return!1;var t=e.map(function(e){return h(e,null)});return!1!==p(this.unit,t)&&(this.displayedAreas.forEach(function(e,i){return e.component._size=t[i]}),this.build(!1,!0),!0)},e.prototype.build=function(e,t){if(this.stopDragging(),!0===e&&(this.displayedAreas.every(function(e){return null!==e.component.order})&&this.displayedAreas.sort(function(e,t){return e.component.order-t.component.order}),this.displayedAreas.forEach(function(e,t){e.order=2*t,e.component.setStyleOrder(e.order)})),!0===t){var i=p(this.unit,this.displayedAreas.map(function(e){return e.component.size}));switch(this.unit){case"percent":var n=100/this.displayedAreas.length;this.displayedAreas.forEach(function(e){e.size=i?e.component.size:n,e.minSize=c(e),e.maxSize=d(e)});break;case"pixel":if(i)this.displayedAreas.forEach(function(e){e.size=e.component.size,e.minSize=c(e),e.maxSize=d(e)});else{var r=this.displayedAreas.filter(function(e){return null===e.component.size});if(0===r.length&&this.displayedAreas.length>0)this.displayedAreas.forEach(function(e,t){e.size=0===t?null:e.component.size,e.minSize=0===t?null:c(e),e.maxSize=0===t?null:d(e)});else if(r.length>1){var s=!1;this.displayedAreas.forEach(function(e){null===e.component.size?!1===s?(e.size=null,e.minSize=null,e.maxSize=null,s=!0):(e.size=100,e.minSize=null,e.maxSize=null):(e.size=e.component.size,e.minSize=c(e),e.maxSize=d(e))})}}}}this.refreshStyleSizes(),this.cdRef.markForCheck()},e.prototype.refreshStyleSizes=function(){var e=this;if("percent"===this.unit)if(1===this.displayedAreas.length)this.displayedAreas[0].component.setStyleFlex(0,0,"100%",!1,!1);else{var t=this.getNbGutters()*this.gutterSize;this.displayedAreas.forEach(function(e){e.component.setStyleFlex(0,0,"calc( "+e.size+"% - "+e.size/100*t+"px )",null!==e.minSize&&e.minSize===e.size,null!==e.maxSize&&e.maxSize===e.size)})}else"pixel"===this.unit&&this.displayedAreas.forEach(function(t){null===t.size?1===e.displayedAreas.length?t.component.setStyleFlex(1,1,"100%",!1,!1):t.component.setStyleFlex(1,1,"auto",!1,!1):1===e.displayedAreas.length?t.component.setStyleFlex(0,0,"100%",!1,!1):t.component.setStyleFlex(0,0,t.size+"px",null!==t.minSize&&t.minSize===t.size,null!==t.maxSize&&t.maxSize===t.size)})},e.prototype.clickGutter=function(e,t){var i=this,n=o(e);this.startPoint&&this.startPoint.x===n.x&&this.startPoint.y===n.y&&(null!==this._clickTimeout?(window.clearTimeout(this._clickTimeout),this._clickTimeout=null,this.notify("dblclick",t),this.stopDragging()):this._clickTimeout=window.setTimeout(function(){i._clickTimeout=null,i.notify("click",t),i.stopDragging()},this.gutterDblClickDuration))},e.prototype.startDragging=function(e,t,i){var n=this;e.preventDefault(),e.stopPropagation(),this.startPoint=o(e),null!==this.startPoint&&!0!==this.disabled&&(this.snapshot={gutterNum:i,lastSteppedOffset:0,allAreasSizePixel:l(this.elRef,this.direction)-this.getNbGutters()*this.gutterSize,allInvolvedAreasSizePercent:100,areasBeforeGutter:[],areasAfterGutter:[]},this.displayedAreas.forEach(function(e){var i={area:e,sizePixelAtStart:l(e.component.elRef,n.direction),sizePercentAtStart:"percent"===n.unit?e.size:-1};e.order<t?!0===n.restrictMove?n.snapshot.areasBeforeGutter=[i]:n.snapshot.areasBeforeGutter.unshift(i):e.order>t&&(!0===n.restrictMove?0===n.snapshot.areasAfterGutter.length&&(n.snapshot.areasAfterGutter=[i]):n.snapshot.areasAfterGutter.push(i))}),this.snapshot.allInvolvedAreasSizePercent=a(this.snapshot.areasBeforeGutter,this.snapshot.areasAfterGutter).reduce(function(e,t){return e+t.sizePercentAtStart},0),0!==this.snapshot.areasBeforeGutter.length&&0!==this.snapshot.areasAfterGutter.length&&(this.dragListeners.push(this.renderer.listen("document","mouseup",this.stopDragging.bind(this))),this.dragListeners.push(this.renderer.listen("document","touchend",this.stopDragging.bind(this))),this.dragListeners.push(this.renderer.listen("document","touchcancel",this.stopDragging.bind(this))),this.ngZone.runOutsideAngular(function(){n.dragListeners.push(n.renderer.listen("document","mousemove",n.dragEvent.bind(n))),n.dragListeners.push(n.renderer.listen("document","touchmove",n.dragEvent.bind(n)))}),this.displayedAreas.forEach(function(e){return e.component.lockEvents()}),this.isDragging=!0,this.renderer.addClass(this.elRef.nativeElement,"as-dragging"),this.renderer.addClass(this.gutterEls.toArray()[this.snapshot.gutterNum-1].nativeElement,"as-dragged"),this.notify("start",this.snapshot.gutterNum)))},e.prototype.dragEvent=function(e){var t=this;if(e.preventDefault(),e.stopPropagation(),null!==this._clickTimeout&&(window.clearTimeout(this._clickTimeout),this._clickTimeout=null),!1!==this.isDragging&&(this.endPoint=o(e),null!==this.endPoint)){var i="horizontal"===this.direction?this.startPoint.x-this.endPoint.x:this.startPoint.y-this.endPoint.y;"rtl"===this.dir&&(i=-i);var n=Math.round(i/this.gutterStep)*this.gutterStep;if(n!==this.snapshot.lastSteppedOffset){this.snapshot.lastSteppedOffset=n;var r=f(this.unit,this.snapshot.areasBeforeGutter,-n,this.snapshot.allAreasSizePixel),s=f(this.unit,this.snapshot.areasAfterGutter,n,this.snapshot.allAreasSizePixel);if(0!==r.remain&&0!==s.remain?Math.abs(r.remain)===Math.abs(s.remain)||(Math.abs(r.remain)>Math.abs(s.remain)?s=f(this.unit,this.snapshot.areasAfterGutter,n+r.remain,this.snapshot.allAreasSizePixel):r=f(this.unit,this.snapshot.areasBeforeGutter,-(n-s.remain),this.snapshot.allAreasSizePixel)):0!==r.remain?s=f(this.unit,this.snapshot.areasAfterGutter,n+r.remain,this.snapshot.allAreasSizePixel):0!==s.remain&&(r=f(this.unit,this.snapshot.areasBeforeGutter,-(n-s.remain),this.snapshot.allAreasSizePixel)),"percent"===this.unit){var l=a(r.list,s.list),u=l.find(function(e){return 0!==e.percentAfterAbsorption&&e.percentAfterAbsorption!==e.areaSnapshot.area.minSize&&e.percentAfterAbsorption!==e.areaSnapshot.area.maxSize});u&&(u.percentAfterAbsorption=this.snapshot.allInvolvedAreasSizePercent-l.filter(function(e){return e!==u}).reduce(function(e,t){return e+t.percentAfterAbsorption},0))}r.list.forEach(function(e){return g(t.unit,e)}),s.list.forEach(function(e){return g(t.unit,e)}),this.refreshStyleSizes(),this.notify("progress",this.snapshot.gutterNum)}}},e.prototype.stopDragging=function(e){var t=this;if(e&&(e.preventDefault(),e.stopPropagation()),!1!==this.isDragging){for(this.displayedAreas.forEach(function(e){return e.component.unlockEvents()});this.dragListeners.length>0;){var i=this.dragListeners.pop();i&&i()}this.isDragging=!1,!this.endPoint||this.startPoint.x===this.endPoint.x&&this.startPoint.y===this.endPoint.y||this.notify("end",this.snapshot.gutterNum),this.renderer.removeClass(this.elRef.nativeElement,"as-dragging"),this.renderer.removeClass(this.gutterEls.toArray()[this.snapshot.gutterNum-1].nativeElement,"as-dragged"),this.snapshot=null,this.ngZone.runOutsideAngular(function(){setTimeout(function(){t.startPoint=null,t.endPoint=null})})}},e.prototype.notify=function(e,t){var i=this,n=this.getVisibleAreaSizes();"start"===e?this.dragStart.emit({gutterNum:t,sizes:n}):"end"===e?this.dragEnd.emit({gutterNum:t,sizes:n}):"click"===e?this.gutterClick.emit({gutterNum:t,sizes:n}):"dblclick"===e?this.gutterDblClick.emit({gutterNum:t,sizes:n}):"transitionEnd"===e?this.transitionEndSubscriber&&this.ngZone.run(function(){return i.transitionEndSubscriber.next(n)}):"progress"===e&&this.dragProgressSubject.next({gutterNum:t,sizes:n})},e.prototype.ngOnDestroy=function(){this.stopDragging()},e.decorators=[{type:t.Component,args:[{selector:"as-split",exportAs:"asSplit",changeDetection:t.ChangeDetectionStrategy.OnPush,template:'\n <ng-content></ng-content>\n <ng-template ngFor [ngForOf]="displayedAreas" let-index="index" let-last="last">\n <div *ngIf="last === false" \n #gutterEls\n class="as-split-gutter"\n [style.flex-basis.px]="gutterSize"\n [style.order]="index*2+1"\n (mousedown)="startDragging($event, index*2+1, index+1)"\n (touchstart)="startDragging($event, index*2+1, index+1)"\n (mouseup)="clickGutter($event, index+1)"\n (touchend)="clickGutter($event, index+1)">\n <div class="as-split-gutter-icon"></div>\n </div>\n </ng-template>',styles:[':host{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:stretch;overflow:hidden;width:100%;height:100%}:host>.as-split-gutter{flex-grow:0;flex-shrink:0;background-color:#eee;display:flex;align-items:center;justify-content:center}:host>.as-split-gutter>.as-split-gutter-icon{width:100%;height:100%;background-position:center center;background-repeat:no-repeat}:host ::ng-deep>.as-split-area{flex-grow:0;flex-shrink:0;overflow-x:hidden;overflow-y:auto}:host ::ng-deep>.as-split-area.as-hidden{flex:0 1 0!important;overflow-x:hidden;overflow-y:hidden}:host.as-horizontal{flex-direction:row}:host.as-horizontal>.as-split-gutter{flex-direction:row;cursor:col-resize;height:100%}:host.as-horizontal>.as-split-gutter>.as-split-gutter-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAeCAYAAADkftS9AAAAIklEQVQoU2M4c+bMfxAGAgYYmwGrIIiDjrELjpo5aiZeMwF+yNnOs5KSvgAAAABJRU5ErkJggg==)}:host.as-horizontal ::ng-deep>.as-split-area{height:100%}:host.as-vertical{flex-direction:column}:host.as-vertical>.as-split-gutter{flex-direction:column;cursor:row-resize;width:100%}:host.as-vertical>.as-split-gutter .as-split-gutter-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAFCAMAAABl/6zIAAAABlBMVEUAAADMzMzIT8AyAAAAAXRSTlMAQObYZgAAABRJREFUeAFjYGRkwIMJSeMHlBkOABP7AEGzSuPKAAAAAElFTkSuQmCC)}:host.as-vertical ::ng-deep>.as-split-area{width:100%}:host.as-vertical ::ng-deep>.as-split-area.as-hidden{max-width:0}:host.as-disabled>.as-split-gutter{cursor:default}:host.as-disabled>.as-split-gutter .as-split-gutter-icon{background-image:url("")}:host.as-transition.as-init:not(.as-dragging) ::ng-deep>.as-split-area,:host.as-transition.as-init:not(.as-dragging)>.as-split-gutter{transition:flex-basis .3s}']}]}],e.ctorParameters=function(){return[{type:t.NgZone},{type:t.ElementRef},{type:t.ChangeDetectorRef},{type:t.Renderer2}]},e.propDecorators={direction:[{type:t.Input}],unit:[{type:t.Input}],gutterSize:[{type:t.Input}],gutterStep:[{type:t.Input}],restrictMove:[{type:t.Input}],useTransition:[{type:t.Input}],disabled:[{type:t.Input}],dir:[{type:t.Input}],gutterDblClickDuration:[{type:t.Input}],dragStart:[{type:t.Output}],dragEnd:[{type:t.Output}],gutterClick:[{type:t.Output}],gutterDblClick:[{type:t.Output}],transitionEnd:[{type:t.Output}],gutterEls:[{type:t.ViewChildren,args:["gutterEls"]}]},e}(),A=function(){function e(e,t,i,n){this.ngZone=e,this.elRef=t,this.renderer=i,this.split=n,this._order=null,this._size=null,this._minSize=null,this._maxSize=null,this._lockSize=!1,this._visible=!0,this.lockListeners=[],this.renderer.addClass(this.elRef.nativeElement,"as-split-area")}return Object.defineProperty(e.prototype,"order",{get:function(){return this._order},set:function(e){this._order=h(e,null),this.split.updateArea(this,!0,!1)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"size",{get:function(){return this._size},set:function(e){this._size=h(e,null),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"minSize",{get:function(){return this._minSize},set:function(e){this._minSize=h(e,null),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"maxSize",{get:function(){return this._maxSize},set:function(e){this._maxSize=h(e,null),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"lockSize",{get:function(){return this._lockSize},set:function(e){this._lockSize=u(e),this.split.updateArea(this,!1,!0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"visible",{get:function(){return this._visible},set:function(e){this._visible=u(e),this._visible?(this.split.showArea(this),this.renderer.removeClass(this.elRef.nativeElement,"as-hidden")):(this.split.hideArea(this),this.renderer.addClass(this.elRef.nativeElement,"as-hidden"))},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){var e=this;this.split.addArea(this),this.ngZone.runOutsideAngular(function(){e.transitionListener=e.renderer.listen(e.elRef.nativeElement,"transitionend",function(t){"flex-basis"===t.propertyName&&e.split.notify("transitionEnd",-1)})})},e.prototype.setStyleOrder=function(e){this.renderer.setStyle(this.elRef.nativeElement,"order",e)},e.prototype.setStyleFlex=function(e,t,i,n,r){this.renderer.setStyle(this.elRef.nativeElement,"flex-grow",e),this.renderer.setStyle(this.elRef.nativeElement,"flex-shrink",t),this.renderer.setStyle(this.elRef.nativeElement,"flex-basis",i),!0===n?this.renderer.addClass(this.elRef.nativeElement,"as-min"):this.renderer.removeClass(this.elRef.nativeElement,"as-min"),!0===r?this.renderer.addClass(this.elRef.nativeElement,"as-max"):this.renderer.removeClass(this.elRef.nativeElement,"as-max")},e.prototype.lockEvents=function(){var e=this;this.ngZone.runOutsideAngular(function(){e.lockListeners.push(e.renderer.listen(e.elRef.nativeElement,"selectstart",function(e){return!1})),e.lockListeners.push(e.renderer.listen(e.elRef.nativeElement,"dragstart",function(e){return!1}))})},e.prototype.unlockEvents=function(){for(;this.lockListeners.length>0;){var e=this.lockListeners.pop();e&&e()}},e.prototype.ngOnDestroy=function(){this.unlockEvents(),this.transitionListener&&this.transitionListener(),this.split.removeArea(this)},e.decorators=[{type:t.Directive,args:[{selector:"as-split-area, [as-split-area]",exportAs:"asSplitArea"}]}],e.ctorParameters=function(){return[{type:t.NgZone},{type:t.ElementRef},{type:t.Renderer2},{type:m}]},e.propDecorators={order:[{type:t.Input}],size:[{type:t.Input}],minSize:[{type:t.Input}],maxSize:[{type:t.Input}],lockSize:[{type:t.Input}],visible:[{type:t.Input}]},e}(),y=function(){function e(){}return e.forRoot=function(){return{ngModule:e,providers:[]}},e.forChild=function(){return{ngModule:e,providers:[]}},e.decorators=[{type:t.NgModule,args:[{imports:[i.CommonModule],declarations:[m,A],exports:[m,A]}]}],e}();e.AngularSplitModule=y,e.SplitAreaDirective=A,e.SplitComponent=m,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=angular-split.umd.min.js.map
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /**

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -130,4 +130,11 @@ import { Directive, Input, ElementRef, Renderer2, NgZone } from '@angular/core';

this.split.addArea(this);
this.ngZone.runOutsideAngular(() => {
this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event) => {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (/**
* @param {?} event
* @return {?}
*/
(event) => {
// Limit only flex-basis transition to trigger the event

@@ -137,4 +144,4 @@ if (event.propertyName === 'flex-basis') {

}
});
});
}));
}));
}

@@ -174,6 +181,17 @@ /**

lockEvents() {
this.ngZone.runOutsideAngular(() => {
this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e) => false));
this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e) => false));
});
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => {
this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (/**
* @param {?} e
* @return {?}
*/
(e) => false)));
this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (/**
* @param {?} e
* @return {?}
*/
(e) => false)));
}));
}

@@ -224,27 +242,60 @@ /**

if (false) {
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._order;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._size;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._minSize;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._maxSize;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._lockSize;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._visible;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.transitionListener;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.lockListeners;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.ngZone;
/** @type {?} */
SplitAreaDirective.prototype.elRef;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.renderer;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.split;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitArea.directive.js","sourceRoot":"ng://angular-split/","sources":["lib/directive/splitArea.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core';\r\n\r\nimport { SplitComponent } from '../component/split.component';\r\nimport { getInputPositiveNumber, getInputBoolean } from '../utils';\r\n\r\n@Directive({\r\n    selector: 'as-split-area, [as-split-area]',\r\n    exportAs: 'asSplitArea'\r\n})\r\nexport class SplitAreaDirective implements OnInit, OnDestroy {\r\n\r\n    private _order: number | null = null;\r\n\r\n    @Input() set order(v: number | null) {\r\n        this._order = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, true, false);\r\n    }\r\n    \r\n    get order(): number | null {\r\n        return this._order;\r\n    }\r\n\r\n    ////\r\n\r\n    private _size: number | null = null;\r\n\r\n    @Input() set size(v: number | null) {\r\n        this._size = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get size(): number | null {\r\n        return this._size;\r\n    }\r\n\r\n    ////\r\n\r\n    private _minSize: number | null = null;\r\n\r\n    @Input() set minSize(v: number | null) {\r\n        this._minSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get minSize(): number | null {\r\n        return this._minSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _maxSize: number | null = null;\r\n\r\n    @Input() set maxSize(v: number | null) {\r\n        this._maxSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get maxSize(): number | null {\r\n        return this._maxSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _lockSize: boolean = false;\r\n\r\n    @Input() set lockSize(v: boolean) {\r\n        this._lockSize = getInputBoolean(v);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get lockSize(): boolean {\r\n        return this._lockSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _visible: boolean = true;\r\n\r\n    @Input() set visible(v: boolean) {\r\n        this._visible = getInputBoolean(v);\r\n\r\n        if(this._visible) { \r\n            this.split.showArea(this);\r\n            this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n        else {\r\n            this.split.hideArea(this);\r\n            this.renderer.addClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n    }\r\n\r\n    get visible(): boolean {\r\n        return this._visible;\r\n    }\r\n\r\n    ////\r\n\r\n    private transitionListener: Function;\r\n    private readonly lockListeners: Array<Function> = [];\r\n\r\n    constructor(private ngZone: NgZone,\r\n                public elRef: ElementRef,\r\n                private renderer: Renderer2,\r\n                private split: SplitComponent) {\r\n        this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.split.addArea(this);\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event: TransitionEvent) => {\r\n                // Limit only flex-basis transition to trigger the event\r\n                if(event.propertyName === 'flex-basis') {\r\n                    this.split.notify('transitionEnd', -1);\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    public setStyleOrder(value: number): void {\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'order', value);\r\n    }\r\n    \r\n    public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\r\n        // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis);\r\n        \r\n        if(isMin === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-min');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-min');\r\n        \r\n        if(isMax === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-max');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-max');\r\n    }\r\n    \r\n    public lockEvents(): void {\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false) );\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false) );\r\n        });\r\n    }\r\n\r\n    public unlockEvents(): void {\r\n        while(this.lockListeners.length > 0) {\r\n            const fct = this.lockListeners.pop();\r\n            if(fct) fct();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.unlockEvents();\r\n\r\n        if(this.transitionListener) {\r\n            this.transitionListener();\r\n        }\r\n\r\n        this.split.removeArea(this);\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitArea.directive.js","sourceRoot":"ng://angular-split/","sources":["lib/directive/splitArea.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core';\r\n\r\nimport { SplitComponent } from '../component/split.component';\r\nimport { getInputPositiveNumber, getInputBoolean } from '../utils';\r\n\r\n@Directive({\r\n    selector: 'as-split-area, [as-split-area]',\r\n    exportAs: 'asSplitArea'\r\n})\r\nexport class SplitAreaDirective implements OnInit, OnDestroy {\r\n\r\n    private _order: number | null = null;\r\n\r\n    @Input() set order(v: number | null) {\r\n        this._order = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, true, false);\r\n    }\r\n    \r\n    get order(): number | null {\r\n        return this._order;\r\n    }\r\n\r\n    ////\r\n\r\n    private _size: number | null = null;\r\n\r\n    @Input() set size(v: number | null) {\r\n        this._size = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get size(): number | null {\r\n        return this._size;\r\n    }\r\n\r\n    ////\r\n\r\n    private _minSize: number | null = null;\r\n\r\n    @Input() set minSize(v: number | null) {\r\n        this._minSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get minSize(): number | null {\r\n        return this._minSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _maxSize: number | null = null;\r\n\r\n    @Input() set maxSize(v: number | null) {\r\n        this._maxSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get maxSize(): number | null {\r\n        return this._maxSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _lockSize: boolean = false;\r\n\r\n    @Input() set lockSize(v: boolean) {\r\n        this._lockSize = getInputBoolean(v);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get lockSize(): boolean {\r\n        return this._lockSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _visible: boolean = true;\r\n\r\n    @Input() set visible(v: boolean) {\r\n        this._visible = getInputBoolean(v);\r\n\r\n        if(this._visible) { \r\n            this.split.showArea(this);\r\n            this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n        else {\r\n            this.split.hideArea(this);\r\n            this.renderer.addClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n    }\r\n\r\n    get visible(): boolean {\r\n        return this._visible;\r\n    }\r\n\r\n    ////\r\n\r\n    private transitionListener: Function;\r\n    private readonly lockListeners: Array<Function> = [];\r\n\r\n    constructor(private ngZone: NgZone,\r\n                public elRef: ElementRef,\r\n                private renderer: Renderer2,\r\n                private split: SplitComponent) {\r\n        this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.split.addArea(this);\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event: TransitionEvent) => {\r\n                // Limit only flex-basis transition to trigger the event\r\n                if(event.propertyName === 'flex-basis') {\r\n                    this.split.notify('transitionEnd', -1);\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    public setStyleOrder(value: number): void {\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'order', value);\r\n    }\r\n    \r\n    public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\r\n        // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis);\r\n        \r\n        if(isMin === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-min');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-min');\r\n        \r\n        if(isMax === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-max');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-max');\r\n    }\r\n    \r\n    public lockEvents(): void {\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false) );\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false) );\r\n        });\r\n    }\r\n\r\n    public unlockEvents(): void {\r\n        while(this.lockListeners.length > 0) {\r\n            const fct = this.lockListeners.pop();\r\n            if(fct) fct();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.unlockEvents();\r\n\r\n        if(this.transitionListener) {\r\n            this.transitionListener();\r\n        }\r\n\r\n        this.split.removeArea(this);\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /**

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core';

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -64,8 +64,21 @@ /**

/** @type {?} */
const total = sizes.reduce((total, s) => s !== null ? total + s : total, 0);
return sizes.every(s => s !== null) && total > 99.9 && total < 100.1;
const total = sizes.reduce((/**
* @param {?} total
* @param {?} s
* @return {?}
*/
(total, s) => s !== null ? total + s : total), 0);
return sizes.every((/**
* @param {?} s
* @return {?}
*/
s => s !== null)) && total > 99.9 && total < 100.1;
}
// A size at null is mandatory but only one.
if (unit === 'pixel') {
return sizes.filter(s => s === null).length === 1;
return sizes.filter((/**
* @param {?} s
* @return {?}
*/
s => s === null)).length === 1;
}

@@ -119,3 +132,8 @@ }

export function getGutterSideAbsorptionCapacity(unit, sideAreas, pixels, allAreasSizePixel) {
return sideAreas.reduce((acc, area) => {
return sideAreas.reduce((/**
* @param {?} acc
* @param {?} area
* @return {?}
*/
(acc, area) => {
/** @type {?} */

@@ -126,3 +144,3 @@ const res = getAreaAbsorptionCapacity(unit, area, acc.remain, allAreasSizePixel);

return acc;
}, { remain: pixels, list: [] });
}), { remain: pixels, list: [] });
}

@@ -297,2 +315,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://angular-split/","sources":["lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\r\n\r\nimport { IArea, IPoint, IAreaSnapshot, ISplitSideAbsorptionCapacity, IAreaAbsorptionCapacity } from './interface';\r\n\r\nexport function getPointFromEvent(event: MouseEvent | TouchEvent): IPoint {\r\n    // TouchEvent\r\n    if((<TouchEvent> event).changedTouches !== undefined && (<TouchEvent> event).changedTouches.length > 0) {\r\n        return {\r\n            x: (<TouchEvent> event).changedTouches[0].clientX,\r\n            y: (<TouchEvent> event).changedTouches[0].clientY,\r\n        };\r\n    }\r\n    // MouseEvent\r\n    else if((<MouseEvent> event).clientX !== undefined && (<MouseEvent> event).clientY !== undefined) {\r\n        return {\r\n            x: (<MouseEvent> event).clientX,\r\n            y: (<MouseEvent> event).clientY,\r\n        };\r\n    }\r\n    return null;\r\n}\r\n\r\nexport function getElementPixelSize(elRef: ElementRef, direction: 'horizontal' | 'vertical'): number {\r\n    const rect = (<HTMLElement> elRef.nativeElement).getBoundingClientRect();\r\n\r\n    return (direction === 'horizontal') ? rect.width : rect.height;\r\n}\r\n\r\nexport function getInputBoolean(v: any): boolean {\r\n    return (typeof(v) === 'boolean') ? v : (v === 'false' ? false : true);\r\n}\r\n\r\nexport function getInputPositiveNumber<T>(v: any, defaultValue: T): number | T {\r\n    if(v === null || v === undefined) return defaultValue;\r\n\r\n    v = Number(v);\r\n    return !isNaN(v) && v >= 0 ? v : defaultValue;\r\n}\r\n\r\nexport function isUserSizesValid(unit: 'percent' | 'pixel', sizes: Array<number | null>): boolean {\r\n    // All sizes have to be not null and total should be 100\r\n    if(unit === 'percent') {\r\n        const total = sizes.reduce((total, s) => s !== null ? total + s : total, 0);\r\n        return sizes.every(s => s !== null) && total > 99.9 && total < 100.1;\r\n    }\r\n    \r\n    // A size at null is mandatory but only one.\r\n    if(unit === 'pixel') {\r\n        return sizes.filter(s => s === null).length === 1;\r\n    }\r\n}\r\n\r\nexport function getAreaMinSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.minSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.minSize > a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.minSize;\r\n}\r\n\r\nexport function getAreaMaxSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.maxSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.maxSize < a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.maxSize;\r\n}\r\n\r\nexport function getGutterSideAbsorptionCapacity(unit: 'percent' | 'pixel', sideAreas: Array<IAreaSnapshot>, pixels: number, allAreasSizePixel: number): ISplitSideAbsorptionCapacity {\r\n    return sideAreas.reduce((acc, area) => {\r\n        const res = getAreaAbsorptionCapacity(unit, area, acc.remain, allAreasSizePixel);\r\n        acc.list.push(res);\r\n        acc.remain  = res.pixelRemain;\r\n        return acc;\r\n    }, {remain: pixels, list: []});\r\n}\r\n\r\nfunction getAreaAbsorptionCapacity(unit: 'percent' | 'pixel', areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    // No pain no gain\r\n    if(pixels === 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: areaSnapshot.sizePercentAtStart,\r\n            pixelRemain: 0,\r\n        };\r\n    }\r\n    \r\n    // Area start at zero and need to be reduced, not possible\r\n    if(areaSnapshot.sizePixelAtStart === 0 && pixels < 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: 0,\r\n            pixelRemain: pixels,\r\n        };\r\n    }\r\n    \r\n    if(unit === 'percent') {\r\n        return getAreaAbsorptionCapacityPercent(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n    \r\n\tif(unit === 'pixel') {\r\n        return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPercent(areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n    const tempPercentSize = tempPixelSize / allAreasSizePixel * 100;\r\n    \r\n    // ENLARGE AREA\r\n    \r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {\r\n            // Use area.area.maxSize as newPercentSize and return calculate pixels remaining\r\n            const maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: maxSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.maxSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {\r\n            // Use area.area.minSize as newPercentSize and return calculate pixels remaining\r\n            const minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: minSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.minSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPercentSize < 0) {\r\n            // Use 0 as newPercentSize and return calculate pixels remaining\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: 0,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPixel(areaSnapshot: IAreaSnapshot, pixels: number, containerSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n            \r\n    // ENLARGE AREA\r\n\r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.maxSize - areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.maxSize\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.minSize + pixels - tempPixelSize,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.minSize\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPixelSize < 0) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nexport function updateAreaSize(unit: 'percent' | 'pixel', item: IAreaAbsorptionCapacity) {\r\n    \r\n    if(unit === 'percent') {\r\n        item.areaSnapshot.area.size = item.percentAfterAbsorption;\r\n    }\r\n    else if(unit === 'pixel') {\r\n        // Update size except for the wildcard size area\r\n        if(item.areaSnapshot.area.size !== null) {\r\n            item.areaSnapshot.area.size = item.areaSnapshot.sizePixelAtStart + item.pixelAbsorb;\r\n        }\r\n    }\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://angular-split/","sources":["lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\r\n\r\nimport { IArea, IPoint, IAreaSnapshot, ISplitSideAbsorptionCapacity, IAreaAbsorptionCapacity } from './interface';\r\n\r\nexport function getPointFromEvent(event: MouseEvent | TouchEvent): IPoint {\r\n    // TouchEvent\r\n    if((<TouchEvent> event).changedTouches !== undefined && (<TouchEvent> event).changedTouches.length > 0) {\r\n        return {\r\n            x: (<TouchEvent> event).changedTouches[0].clientX,\r\n            y: (<TouchEvent> event).changedTouches[0].clientY,\r\n        };\r\n    }\r\n    // MouseEvent\r\n    else if((<MouseEvent> event).clientX !== undefined && (<MouseEvent> event).clientY !== undefined) {\r\n        return {\r\n            x: (<MouseEvent> event).clientX,\r\n            y: (<MouseEvent> event).clientY,\r\n        };\r\n    }\r\n    return null;\r\n}\r\n\r\nexport function getElementPixelSize(elRef: ElementRef, direction: 'horizontal' | 'vertical'): number {\r\n    const rect = (<HTMLElement> elRef.nativeElement).getBoundingClientRect();\r\n\r\n    return (direction === 'horizontal') ? rect.width : rect.height;\r\n}\r\n\r\nexport function getInputBoolean(v: any): boolean {\r\n    return (typeof(v) === 'boolean') ? v : (v === 'false' ? false : true);\r\n}\r\n\r\nexport function getInputPositiveNumber<T>(v: any, defaultValue: T): number | T {\r\n    if(v === null || v === undefined) return defaultValue;\r\n\r\n    v = Number(v);\r\n    return !isNaN(v) && v >= 0 ? v : defaultValue;\r\n}\r\n\r\nexport function isUserSizesValid(unit: 'percent' | 'pixel', sizes: Array<number | null>): boolean {\r\n    // All sizes have to be not null and total should be 100\r\n    if(unit === 'percent') {\r\n        const total = sizes.reduce((total, s) => s !== null ? total + s : total, 0);\r\n        return sizes.every(s => s !== null) && total > 99.9 && total < 100.1;\r\n    }\r\n    \r\n    // A size at null is mandatory but only one.\r\n    if(unit === 'pixel') {\r\n        return sizes.filter(s => s === null).length === 1;\r\n    }\r\n}\r\n\r\nexport function getAreaMinSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.minSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.minSize > a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.minSize;\r\n}\r\n\r\nexport function getAreaMaxSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.maxSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.maxSize < a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.maxSize;\r\n}\r\n\r\nexport function getGutterSideAbsorptionCapacity(unit: 'percent' | 'pixel', sideAreas: Array<IAreaSnapshot>, pixels: number, allAreasSizePixel: number): ISplitSideAbsorptionCapacity {\r\n    return sideAreas.reduce((acc, area) => {\r\n        const res = getAreaAbsorptionCapacity(unit, area, acc.remain, allAreasSizePixel);\r\n        acc.list.push(res);\r\n        acc.remain  = res.pixelRemain;\r\n        return acc;\r\n    }, {remain: pixels, list: []});\r\n}\r\n\r\nfunction getAreaAbsorptionCapacity(unit: 'percent' | 'pixel', areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    // No pain no gain\r\n    if(pixels === 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: areaSnapshot.sizePercentAtStart,\r\n            pixelRemain: 0,\r\n        };\r\n    }\r\n    \r\n    // Area start at zero and need to be reduced, not possible\r\n    if(areaSnapshot.sizePixelAtStart === 0 && pixels < 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: 0,\r\n            pixelRemain: pixels,\r\n        };\r\n    }\r\n    \r\n    if(unit === 'percent') {\r\n        return getAreaAbsorptionCapacityPercent(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n    \r\n\tif(unit === 'pixel') {\r\n        return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPercent(areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n    const tempPercentSize = tempPixelSize / allAreasSizePixel * 100;\r\n    \r\n    // ENLARGE AREA\r\n    \r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {\r\n            // Use area.area.maxSize as newPercentSize and return calculate pixels remaining\r\n            const maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: maxSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.maxSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {\r\n            // Use area.area.minSize as newPercentSize and return calculate pixels remaining\r\n            const minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: minSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.minSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPercentSize < 0) {\r\n            // Use 0 as newPercentSize and return calculate pixels remaining\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: 0,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPixel(areaSnapshot: IAreaSnapshot, pixels: number, containerSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n            \r\n    // ENLARGE AREA\r\n\r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.maxSize - areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.maxSize\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.minSize + pixels - tempPixelSize,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.minSize\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPixelSize < 0) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nexport function updateAreaSize(unit: 'percent' | 'pixel', item: IAreaAbsorptionCapacity) {\r\n    \r\n    if(unit === 'percent') {\r\n        item.areaSnapshot.area.size = item.percentAfterAbsorption;\r\n    }\r\n    else if(unit === 'pixel') {\r\n        // Update size except for the wildcard size area\r\n        if(item.areaSnapshot.area.size !== null) {\r\n            item.areaSnapshot.area.size = item.areaSnapshot.sizePixelAtStart + item.pixelAbsorb;\r\n        }\r\n    }\r\n}"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -11,2 +11,2 @@ /*

export { SplitAreaDirective } from './lib/directive/splitArea.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItc3BsaXQvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGFuZ3VsYXItc3BsaXRcclxuICovXHJcblxyXG5leHBvcnQgeyBBbmd1bGFyU3BsaXRNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGUnO1xyXG5leHBvcnQgeyBTcGxpdENvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudC9zcGxpdC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBTcGxpdEFyZWFEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmUvc3BsaXRBcmVhLmRpcmVjdGl2ZSc7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItc3BsaXQvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhbmd1bGFyLXNwbGl0XG4gKi9cblxuZXhwb3J0IHsgQW5ndWxhclNwbGl0TW9kdWxlIH0gZnJvbSAnLi9saWIvbW9kdWxlJztcbmV4cG9ydCB7IFNwbGl0Q29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50L3NwbGl0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBTcGxpdEFyZWFEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmUvc3BsaXRBcmVhLmRpcmVjdGl2ZSc7XG4iXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /**

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -152,4 +152,11 @@ import { Directive, Input, ElementRef, Renderer2, NgZone } from '@angular/core';

this.split.addArea(this);
this.ngZone.runOutsideAngular(function () {
_this.transitionListener = _this.renderer.listen(_this.elRef.nativeElement, 'transitionend', function (event) {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () {
_this.transitionListener = _this.renderer.listen(_this.elRef.nativeElement, 'transitionend', (/**
* @param {?} event
* @return {?}
*/
function (event) {
// Limit only flex-basis transition to trigger the event

@@ -159,4 +166,4 @@ if (event.propertyName === 'flex-basis') {

}
});
});
}));
}));
};

@@ -212,6 +219,17 @@ /**

var _this = this;
this.ngZone.runOutsideAngular(function () {
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'selectstart', function (e) { return false; }));
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'dragstart', function (e) { return false; }));
});
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () {
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'selectstart', (/**
* @param {?} e
* @return {?}
*/
function (e) { return false; })));
_this.lockListeners.push(_this.renderer.listen(_this.elRef.nativeElement, 'dragstart', (/**
* @param {?} e
* @return {?}
*/
function (e) { return false; })));
}));
};

@@ -270,27 +288,60 @@ /**

if (false) {
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._order;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._size;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._minSize;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._maxSize;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._lockSize;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._visible;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.transitionListener;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.lockListeners;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.ngZone;
/** @type {?} */
SplitAreaDirective.prototype.elRef;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.renderer;
/** @type {?} */
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.split;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitArea.directive.js","sourceRoot":"ng://angular-split/","sources":["lib/directive/splitArea.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,SAAS,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAC;AAEnG,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAEnE;IAoGI,4BAAoB,MAAc,EACf,KAAiB,EAChB,QAAmB,EACnB,KAAqB;QAHrB,WAAM,GAAN,MAAM,CAAQ;QACf,UAAK,GAAL,KAAK,CAAY;QAChB,aAAQ,GAAR,QAAQ,CAAW;QACnB,UAAK,GAAL,KAAK,CAAgB;QAjGjC,WAAM,GAAkB,IAAI,CAAC;;QAc7B,UAAK,GAAkB,IAAI,CAAC;;QAc5B,aAAQ,GAAkB,IAAI,CAAC;;QAc/B,aAAQ,GAAkB,IAAI,CAAC;;QAc/B,cAAS,GAAY,KAAK,CAAC;;QAc3B,aAAQ,GAAY,IAAI,CAAC;QAsBhB,kBAAa,GAAoB,EAAE,CAAC;QAMjD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,eAAe,CAAC,CAAC;IACtE,CAAC;IAjGD,sBAAa,qCAAK;;;;QAMlB;YACI,OAAO,IAAI,CAAC,MAAM,CAAC;QACvB,CAAC;;;;;QARD,UAAmB,CAAgB;YAC/B,IAAI,CAAC,MAAM,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAE9C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QAC7C,CAAC;;;OAAA;IAUD,sBAAa,oCAAI;;;;QAMjB;YACI,OAAO,IAAI,CAAC,KAAK,CAAC;QACtB,CAAC;;;;;QARD,UAAkB,CAAgB;YAC9B,IAAI,CAAC,KAAK,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAE7C,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAC7C,CAAC;;;OAAA;IAUD,sBAAa,uCAAO;;;;QAMpB;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;;;QARD,UAAqB,CAAgB;YACjC,IAAI,CAAC,QAAQ,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAEhD,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAC7C,CAAC;;;OAAA;IAUD,sBAAa,uCAAO;;;;QAMpB;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;;;QARD,UAAqB,CAAgB;YACjC,IAAI,CAAC,QAAQ,GAAG,sBAAsB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YAEhD,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAC7C,CAAC;;;OAAA;IAUD,sBAAa,wCAAQ;;;;QAMrB;YACI,OAAO,IAAI,CAAC,SAAS,CAAC;QAC1B,CAAC;;;;;QARD,UAAsB,CAAU;YAC5B,IAAI,CAAC,SAAS,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;YAEpC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAC7C,CAAC;;;OAAA;IAUD,sBAAa,uCAAO;;;;QAapB;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;;;QAfD,UAAqB,CAAU;YAC3B,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;YAEnC,IAAG,IAAI,CAAC,QAAQ,EAAE;gBACd,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;gBAC1B,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;aACpE;iBACI;gBACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;gBAC1B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;aACjE;QACL,CAAC;;;OAAA;;;;IAkBM,qCAAQ;;;IAAf;QAAA,iBAWC;QAVG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEzB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC;YAC1B,KAAI,CAAC,kBAAkB,GAAG,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,EAAE,eAAe,EAAE,UAAC,KAAsB;gBAC7G,wDAAwD;gBACxD,IAAG,KAAK,CAAC,YAAY,KAAK,YAAY,EAAE;oBACpC,KAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,CAAC;iBAC1C;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;;;;;IAEM,0CAAa;;;;IAApB,UAAqB,KAAa;QAC9B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IACrE,CAAC;;;;;;;;;IAEM,yCAAY;;;;;;;;IAAnB,UAAoB,IAAY,EAAE,MAAc,EAAE,KAAa,EAAE,KAAc,EAAE,KAAc;QAC3F,kGAAkG;QAClG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;QACxE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;QAEtE,IAAG,KAAK,KAAK,IAAI;YAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;;YAC3D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QAElF,IAAG,KAAK,KAAK,IAAI;YAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;;YAC3D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACtF,CAAC;;;;IAEM,uCAAU;;;IAAjB;QAAA,iBAKC;QAJG,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC;YAC1B,KAAI,CAAC,aAAa,CAAC,IAAI,CAAE,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,EAAE,UAAC,CAAQ,IAAK,OAAA,KAAK,EAAL,CAAK,CAAC,CAAE,CAAC;YAC9G,KAAI,CAAC,aAAa,CAAC,IAAI,CAAE,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,KAAK,CAAC,aAAa,EAAE,WAAW,EAAE,UAAC,CAAQ,IAAK,OAAA,KAAK,EAAL,CAAK,CAAC,CAAE,CAAC;QAChH,CAAC,CAAC,CAAC;IACP,CAAC;;;;IAEM,yCAAY;;;IAAnB;QACI,OAAM,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;;gBAC3B,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE;YACpC,IAAG,GAAG;gBAAE,GAAG,EAAE,CAAC;SACjB;IACL,CAAC;;;;IAEM,wCAAW;;;IAAlB;QACI,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,IAAG,IAAI,CAAC,kBAAkB,EAAE;YACxB,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC7B;QAED,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;;gBA/JJ,SAAS,SAAC;oBACP,QAAQ,EAAE,gCAAgC;oBAC1C,QAAQ,EAAE,aAAa;iBAC1B;;;;gBARoE,MAAM;gBAAhD,UAAU;gBAAE,SAAS;gBAEvC,cAAc;;;wBAWlB,KAAK;uBAcL,KAAK;0BAcL,KAAK;0BAcL,KAAK;2BAcL,KAAK;0BAcL,KAAK;;IAkFV,yBAAC;CAAA,AAhKD,IAgKC;SA5JY,kBAAkB;;;IAE3B,oCAAqC;;IAcrC,mCAAoC;;IAcpC,sCAAuC;;IAcvC,sCAAuC;;IAcvC,uCAAmC;;IAcnC,sCAAiC;;IAqBjC,gDAAqC;;IACrC,2CAAqD;;IAEzC,oCAAsB;;IACtB,mCAAwB;;IACxB,sCAA2B;;IAC3B,mCAA6B","sourcesContent":["import { Directive, Input, ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core';\r\n\r\nimport { SplitComponent } from '../component/split.component';\r\nimport { getInputPositiveNumber, getInputBoolean } from '../utils';\r\n\r\n@Directive({\r\n    selector: 'as-split-area, [as-split-area]',\r\n    exportAs: 'asSplitArea'\r\n})\r\nexport class SplitAreaDirective implements OnInit, OnDestroy {\r\n\r\n    private _order: number | null = null;\r\n\r\n    @Input() set order(v: number | null) {\r\n        this._order = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, true, false);\r\n    }\r\n    \r\n    get order(): number | null {\r\n        return this._order;\r\n    }\r\n\r\n    ////\r\n\r\n    private _size: number | null = null;\r\n\r\n    @Input() set size(v: number | null) {\r\n        this._size = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get size(): number | null {\r\n        return this._size;\r\n    }\r\n\r\n    ////\r\n\r\n    private _minSize: number | null = null;\r\n\r\n    @Input() set minSize(v: number | null) {\r\n        this._minSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get minSize(): number | null {\r\n        return this._minSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _maxSize: number | null = null;\r\n\r\n    @Input() set maxSize(v: number | null) {\r\n        this._maxSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get maxSize(): number | null {\r\n        return this._maxSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _lockSize: boolean = false;\r\n\r\n    @Input() set lockSize(v: boolean) {\r\n        this._lockSize = getInputBoolean(v);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get lockSize(): boolean {\r\n        return this._lockSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _visible: boolean = true;\r\n\r\n    @Input() set visible(v: boolean) {\r\n        this._visible = getInputBoolean(v);\r\n\r\n        if(this._visible) { \r\n            this.split.showArea(this);\r\n            this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n        else {\r\n            this.split.hideArea(this);\r\n            this.renderer.addClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n    }\r\n\r\n    get visible(): boolean {\r\n        return this._visible;\r\n    }\r\n\r\n    ////\r\n\r\n    private transitionListener: Function;\r\n    private readonly lockListeners: Array<Function> = [];\r\n\r\n    constructor(private ngZone: NgZone,\r\n                public elRef: ElementRef,\r\n                private renderer: Renderer2,\r\n                private split: SplitComponent) {\r\n        this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.split.addArea(this);\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event: TransitionEvent) => {\r\n                // Limit only flex-basis transition to trigger the event\r\n                if(event.propertyName === 'flex-basis') {\r\n                    this.split.notify('transitionEnd', -1);\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    public setStyleOrder(value: number): void {\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'order', value);\r\n    }\r\n    \r\n    public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\r\n        // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis);\r\n        \r\n        if(isMin === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-min');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-min');\r\n        \r\n        if(isMax === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-max');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-max');\r\n    }\r\n    \r\n    public lockEvents(): void {\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false) );\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false) );\r\n        });\r\n    }\r\n\r\n    public unlockEvents(): void {\r\n        while(this.lockListeners.length > 0) {\r\n            const fct = this.lockListeners.pop();\r\n            if(fct) fct();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.unlockEvents();\r\n\r\n        if(this.transitionListener) {\r\n            this.transitionListener();\r\n        }\r\n\r\n        this.split.removeArea(this);\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitArea.directive.js","sourceRoot":"ng://angular-split/","sources":["lib/directive/splitArea.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core';\r\n\r\nimport { SplitComponent } from '../component/split.component';\r\nimport { getInputPositiveNumber, getInputBoolean } from '../utils';\r\n\r\n@Directive({\r\n    selector: 'as-split-area, [as-split-area]',\r\n    exportAs: 'asSplitArea'\r\n})\r\nexport class SplitAreaDirective implements OnInit, OnDestroy {\r\n\r\n    private _order: number | null = null;\r\n\r\n    @Input() set order(v: number | null) {\r\n        this._order = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, true, false);\r\n    }\r\n    \r\n    get order(): number | null {\r\n        return this._order;\r\n    }\r\n\r\n    ////\r\n\r\n    private _size: number | null = null;\r\n\r\n    @Input() set size(v: number | null) {\r\n        this._size = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get size(): number | null {\r\n        return this._size;\r\n    }\r\n\r\n    ////\r\n\r\n    private _minSize: number | null = null;\r\n\r\n    @Input() set minSize(v: number | null) {\r\n        this._minSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get minSize(): number | null {\r\n        return this._minSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _maxSize: number | null = null;\r\n\r\n    @Input() set maxSize(v: number | null) {\r\n        this._maxSize = getInputPositiveNumber(v, null);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get maxSize(): number | null {\r\n        return this._maxSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _lockSize: boolean = false;\r\n\r\n    @Input() set lockSize(v: boolean) {\r\n        this._lockSize = getInputBoolean(v);\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get lockSize(): boolean {\r\n        return this._lockSize;\r\n    }\r\n\r\n    ////\r\n\r\n    private _visible: boolean = true;\r\n\r\n    @Input() set visible(v: boolean) {\r\n        this._visible = getInputBoolean(v);\r\n\r\n        if(this._visible) { \r\n            this.split.showArea(this);\r\n            this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n        else {\r\n            this.split.hideArea(this);\r\n            this.renderer.addClass(this.elRef.nativeElement, 'as-hidden');\r\n        }\r\n    }\r\n\r\n    get visible(): boolean {\r\n        return this._visible;\r\n    }\r\n\r\n    ////\r\n\r\n    private transitionListener: Function;\r\n    private readonly lockListeners: Array<Function> = [];\r\n\r\n    constructor(private ngZone: NgZone,\r\n                public elRef: ElementRef,\r\n                private renderer: Renderer2,\r\n                private split: SplitComponent) {\r\n        this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.split.addArea(this);\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event: TransitionEvent) => {\r\n                // Limit only flex-basis transition to trigger the event\r\n                if(event.propertyName === 'flex-basis') {\r\n                    this.split.notify('transitionEnd', -1);\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    public setStyleOrder(value: number): void {\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'order', value);\r\n    }\r\n    \r\n    public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\r\n        // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink);\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis);\r\n        \r\n        if(isMin === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-min');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-min');\r\n        \r\n        if(isMax === true)  this.renderer.addClass(this.elRef.nativeElement, 'as-max');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'as-max');\r\n    }\r\n    \r\n    public lockEvents(): void {\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false) );\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false) );\r\n        });\r\n    }\r\n\r\n    public unlockEvents(): void {\r\n        while(this.lockListeners.length > 0) {\r\n            const fct = this.lockListeners.pop();\r\n            if(fct) fct();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.unlockEvents();\r\n\r\n        if(this.transitionListener) {\r\n            this.transitionListener();\r\n        }\r\n\r\n        this.split.removeArea(this);\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ /**

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core';

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -64,8 +64,21 @@ /**

/** @type {?} */
var total = sizes.reduce(function (total, s) { return s !== null ? total + s : total; }, 0);
return sizes.every(function (s) { return s !== null; }) && total > 99.9 && total < 100.1;
var total = sizes.reduce((/**
* @param {?} total
* @param {?} s
* @return {?}
*/
function (total, s) { return s !== null ? total + s : total; }), 0);
return sizes.every((/**
* @param {?} s
* @return {?}
*/
function (s) { return s !== null; })) && total > 99.9 && total < 100.1;
}
// A size at null is mandatory but only one.
if (unit === 'pixel') {
return sizes.filter(function (s) { return s === null; }).length === 1;
return sizes.filter((/**
* @param {?} s
* @return {?}
*/
function (s) { return s === null; })).length === 1;
}

@@ -119,3 +132,8 @@ }

export function getGutterSideAbsorptionCapacity(unit, sideAreas, pixels, allAreasSizePixel) {
return sideAreas.reduce(function (acc, area) {
return sideAreas.reduce((/**
* @param {?} acc
* @param {?} area
* @return {?}
*/
function (acc, area) {
/** @type {?} */

@@ -126,3 +144,3 @@ var res = getAreaAbsorptionCapacity(unit, area, acc.remain, allAreasSizePixel);

return acc;
}, { remain: pixels, list: [] });
}), { remain: pixels, list: [] });
}

@@ -297,2 +315,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://angular-split/","sources":["lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef } from '@angular/core';\r\n\r\nimport { IArea, IPoint, IAreaSnapshot, ISplitSideAbsorptionCapacity, IAreaAbsorptionCapacity } from './interface';\r\n\r\nexport function getPointFromEvent(event: MouseEvent | TouchEvent): IPoint {\r\n    // TouchEvent\r\n    if((<TouchEvent> event).changedTouches !== undefined && (<TouchEvent> event).changedTouches.length > 0) {\r\n        return {\r\n            x: (<TouchEvent> event).changedTouches[0].clientX,\r\n            y: (<TouchEvent> event).changedTouches[0].clientY,\r\n        };\r\n    }\r\n    // MouseEvent\r\n    else if((<MouseEvent> event).clientX !== undefined && (<MouseEvent> event).clientY !== undefined) {\r\n        return {\r\n            x: (<MouseEvent> event).clientX,\r\n            y: (<MouseEvent> event).clientY,\r\n        };\r\n    }\r\n    return null;\r\n}\r\n\r\nexport function getElementPixelSize(elRef: ElementRef, direction: 'horizontal' | 'vertical'): number {\r\n    const rect = (<HTMLElement> elRef.nativeElement).getBoundingClientRect();\r\n\r\n    return (direction === 'horizontal') ? rect.width : rect.height;\r\n}\r\n\r\nexport function getInputBoolean(v: any): boolean {\r\n    return (typeof(v) === 'boolean') ? v : (v === 'false' ? false : true);\r\n}\r\n\r\nexport function getInputPositiveNumber<T>(v: any, defaultValue: T): number | T {\r\n    if(v === null || v === undefined) return defaultValue;\r\n\r\n    v = Number(v);\r\n    return !isNaN(v) && v >= 0 ? v : defaultValue;\r\n}\r\n\r\nexport function isUserSizesValid(unit: 'percent' | 'pixel', sizes: Array<number | null>): boolean {\r\n    // All sizes have to be not null and total should be 100\r\n    if(unit === 'percent') {\r\n        const total = sizes.reduce((total, s) => s !== null ? total + s : total, 0);\r\n        return sizes.every(s => s !== null) && total > 99.9 && total < 100.1;\r\n    }\r\n    \r\n    // A size at null is mandatory but only one.\r\n    if(unit === 'pixel') {\r\n        return sizes.filter(s => s === null).length === 1;\r\n    }\r\n}\r\n\r\nexport function getAreaMinSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.minSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.minSize > a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.minSize;\r\n}\r\n\r\nexport function getAreaMaxSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.maxSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.maxSize < a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.maxSize;\r\n}\r\n\r\nexport function getGutterSideAbsorptionCapacity(unit: 'percent' | 'pixel', sideAreas: Array<IAreaSnapshot>, pixels: number, allAreasSizePixel: number): ISplitSideAbsorptionCapacity {\r\n    return sideAreas.reduce((acc, area) => {\r\n        const res = getAreaAbsorptionCapacity(unit, area, acc.remain, allAreasSizePixel);\r\n        acc.list.push(res);\r\n        acc.remain  = res.pixelRemain;\r\n        return acc;\r\n    }, {remain: pixels, list: []});\r\n}\r\n\r\nfunction getAreaAbsorptionCapacity(unit: 'percent' | 'pixel', areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    // No pain no gain\r\n    if(pixels === 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: areaSnapshot.sizePercentAtStart,\r\n            pixelRemain: 0,\r\n        };\r\n    }\r\n    \r\n    // Area start at zero and need to be reduced, not possible\r\n    if(areaSnapshot.sizePixelAtStart === 0 && pixels < 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: 0,\r\n            pixelRemain: pixels,\r\n        };\r\n    }\r\n    \r\n    if(unit === 'percent') {\r\n        return getAreaAbsorptionCapacityPercent(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n    \r\n\tif(unit === 'pixel') {\r\n        return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPercent(areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n    const tempPercentSize = tempPixelSize / allAreasSizePixel * 100;\r\n    \r\n    // ENLARGE AREA\r\n    \r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {\r\n            // Use area.area.maxSize as newPercentSize and return calculate pixels remaining\r\n            const maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: maxSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.maxSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {\r\n            // Use area.area.minSize as newPercentSize and return calculate pixels remaining\r\n            const minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: minSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.minSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPercentSize < 0) {\r\n            // Use 0 as newPercentSize and return calculate pixels remaining\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: 0,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPixel(areaSnapshot: IAreaSnapshot, pixels: number, containerSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n            \r\n    // ENLARGE AREA\r\n\r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.maxSize - areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.maxSize\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.minSize + pixels - tempPixelSize,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.minSize\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPixelSize < 0) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nexport function updateAreaSize(unit: 'percent' | 'pixel', item: IAreaAbsorptionCapacity) {\r\n    \r\n    if(unit === 'percent') {\r\n        item.areaSnapshot.area.size = item.percentAfterAbsorption;\r\n    }\r\n    else if(unit === 'pixel') {\r\n        // Update size except for the wildcard size area\r\n        if(item.areaSnapshot.area.size !== null) {\r\n            item.areaSnapshot.area.size = item.areaSnapshot.sizePixelAtStart + item.pixelAbsorb;\r\n        }\r\n    }\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://angular-split/","sources":["lib/utils.ts"],"names":[],"mappings":";;;;;;;;AAIA,MAAM,UAAU,iBAAiB,CAAC,KAA8B;IAC5D,aAAa;IACb,IAAG,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,cAAc,KAAK,SAAS,IAAI,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;QACpG,OAAO;YACH,CAAC,EAAE,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO;YACjD,CAAC,EAAE,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO;SACpD,CAAC;KACL;IACD,aAAa;SACR,IAAG,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,OAAO,KAAK,SAAS,IAAI,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,OAAO,KAAK,SAAS,EAAE;QAC9F,OAAO;YACH,CAAC,EAAE,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,OAAO;YAC/B,CAAC,EAAE,CAAC,mBAAa,KAAK,EAAA,CAAC,CAAC,OAAO;SAClC,CAAC;KACL;IACD,OAAO,IAAI,CAAC;AAChB,CAAC;;;;;;AAED,MAAM,UAAU,mBAAmB,CAAC,KAAiB,EAAE,SAAoC;;QACjF,IAAI,GAAG,CAAC,mBAAc,KAAK,CAAC,aAAa,EAAA,CAAC,CAAC,qBAAqB,EAAE;IAExE,OAAO,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;AACnE,CAAC;;;;;AAED,MAAM,UAAU,eAAe,CAAC,CAAM;IAClC,OAAO,CAAC,OAAM,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AAC1E,CAAC;;;;;;;AAED,MAAM,UAAU,sBAAsB,CAAI,CAAM,EAAE,YAAe;IAC7D,IAAG,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,SAAS;QAAE,OAAO,YAAY,CAAC;IAEtD,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IACd,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;AAClD,CAAC;;;;;;AAED,MAAM,UAAU,gBAAgB,CAAC,IAAyB,EAAE,KAA2B;IACnF,wDAAwD;IACxD,IAAG,IAAI,KAAK,SAAS,EAAE;;YACb,KAAK,GAAG,KAAK,CAAC,MAAM;;;;;QAAC,UAAC,KAAK,EAAE,CAAC,IAAK,OAAA,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,EAA9B,CAA8B,GAAE,CAAC,CAAC;QAC3E,OAAO,KAAK,CAAC,KAAK;;;;QAAC,UAAA,CAAC,IAAI,OAAA,CAAC,KAAK,IAAI,EAAV,CAAU,EAAC,IAAI,KAAK,GAAG,IAAI,IAAI,KAAK,GAAG,KAAK,CAAC;KACxE;IAED,4CAA4C;IAC5C,IAAG,IAAI,KAAK,OAAO,EAAE;QACjB,OAAO,KAAK,CAAC,MAAM;;;;QAAC,UAAA,CAAC,IAAI,OAAA,CAAC,KAAK,IAAI,EAAV,CAAU,EAAC,CAAC,MAAM,KAAK,CAAC,CAAC;KACrD;AACL,CAAC;;;;;AAED,MAAM,UAAU,cAAc,CAAC,CAAQ;IACnC,IAAG,CAAC,CAAC,IAAI,KAAK,IAAI,EAAE;QAChB,OAAO,IAAI,CAAC;KACf;IAED,IAAG,CAAC,CAAC,SAAS,CAAC,QAAQ,KAAK,IAAI,EAAE;QAC9B,OAAO,CAAC,CAAC,IAAI,CAAC;KACjB;IAED,IAAG,CAAC,CAAC,SAAS,CAAC,OAAO,KAAK,IAAI,EAAE;QAC7B,OAAO,IAAI,CAAC;KACf;IAED,IAAG,CAAC,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,EAAE;QAC7B,OAAO,CAAC,CAAC,IAAI,CAAC;KACjB;IAED,OAAO,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC;AAC/B,CAAC;;;;;AAED,MAAM,UAAU,cAAc,CAAC,CAAQ;IACnC,IAAG,CAAC,CAAC,IAAI,KAAK,IAAI,EAAE;QAChB,OAAO,IAAI,CAAC;KACf;IAED,IAAG,CAAC,CAAC,SAAS,CAAC,QAAQ,KAAK,IAAI,EAAE;QAC9B,OAAO,CAAC,CAAC,IAAI,CAAC;KACjB;IAED,IAAG,CAAC,CAAC,SAAS,CAAC,OAAO,KAAK,IAAI,EAAE;QAC7B,OAAO,IAAI,CAAC;KACf;IAED,IAAG,CAAC,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,EAAE;QAC7B,OAAO,CAAC,CAAC,IAAI,CAAC;KACjB;IAED,OAAO,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC;AAC/B,CAAC;;;;;;;;AAED,MAAM,UAAU,+BAA+B,CAAC,IAAyB,EAAE,SAA+B,EAAE,MAAc,EAAE,iBAAyB;IACjJ,OAAO,SAAS,CAAC,MAAM;;;;;IAAC,UAAC,GAAG,EAAE,IAAI;;YACxB,GAAG,GAAG,yBAAyB,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC;QAChF,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnB,GAAG,CAAC,MAAM,GAAI,GAAG,CAAC,WAAW,CAAC;QAC9B,OAAO,GAAG,CAAC;IACf,CAAC,GAAE,EAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAC,CAAC,CAAC;AACnC,CAAC;;;;;;;;AAED,SAAS,yBAAyB,CAAC,IAAyB,EAAE,YAA2B,EAAE,MAAc,EAAE,iBAAyB;IAChI,kBAAkB;IAClB,IAAG,MAAM,KAAK,CAAC,EAAE;QACb,OAAO;YACH,YAAY,cAAA;YACZ,WAAW,EAAE,CAAC;YACd,sBAAsB,EAAE,YAAY,CAAC,kBAAkB;YACvD,WAAW,EAAE,CAAC;SACjB,CAAC;KACL;IAED,0DAA0D;IAC1D,IAAG,YAAY,CAAC,gBAAgB,KAAK,CAAC,IAAI,MAAM,GAAG,CAAC,EAAE;QAClD,OAAO;YACH,YAAY,cAAA;YACZ,WAAW,EAAE,CAAC;YACd,sBAAsB,EAAE,CAAC;YACzB,WAAW,EAAE,MAAM;SACtB,CAAC;KACL;IAED,IAAG,IAAI,KAAK,SAAS,EAAE;QACnB,OAAO,gCAAgC,CAAC,YAAY,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;KACpF;IAEJ,IAAG,IAAI,KAAK,OAAO,EAAE;QACd,OAAO,8BAA8B,CAAC,YAAY,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;KAClF;AACL,CAAC;;;;;;;AAED,SAAS,gCAAgC,CAAC,YAA2B,EAAE,MAAc,EAAE,iBAAyB;;QACtG,aAAa,GAAG,YAAY,CAAC,gBAAgB,GAAG,MAAM;;QACtD,eAAe,GAAG,aAAa,GAAG,iBAAiB,GAAG,GAAG;IAE/D,eAAe;IAEf,IAAG,MAAM,GAAG,CAAC,EAAE;QACX,mFAAmF;QACnF,IAAG,YAAY,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,eAAe,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE;;;gBAE5E,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,GAAG,GAAG,GAAG,iBAAiB;YACxE,OAAO;gBACH,YAAY,cAAA;gBACZ,WAAW,EAAE,YAAY;gBACzB,sBAAsB,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO;gBACjD,WAAW,EAAE,YAAY,CAAC,gBAAgB,GAAG,MAAM,GAAG,YAAY;aACrE,CAAC;SACL;QACD,OAAO;YACH,YAAY,cAAA;YACZ,WAAW,EAAE,MAAM;YACnB,sBAAsB,EAAE,eAAe,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,eAAe;YACrE,WAAW,EAAE,CAAC;SACjB,CAAC;KACL;IAED,cAAc;SAET,IAAG,MAAM,GAAG,CAAC,EAAE;QAChB,oFAAoF;QACpF,IAAG,YAAY,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,eAAe,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE;;;gBAE5E,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,GAAG,GAAG,GAAG,iBAAiB;YACxE,OAAO;gBACH,YAAY,cAAA;gBACZ,WAAW,EAAE,YAAY;gBACzB,sBAAsB,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO;gBACjD,WAAW,EAAE,YAAY,CAAC,gBAAgB,GAAG,MAAM,GAAG,YAAY;aACrE,CAAC;SACL;QACD,kDAAkD;aAC7C,IAAG,eAAe,GAAG,CAAC,EAAE;YACzB,gEAAgE;YAChE,OAAO;gBACH,YAAY,cAAA;gBACZ,WAAW,EAAE,CAAC,YAAY,CAAC,gBAAgB;gBAC3C,sBAAsB,EAAE,CAAC;gBACzB,WAAW,EAAE,MAAM,GAAG,YAAY,CAAC,gBAAgB;aACtD,CAAC;SACL;QACD,OAAO;YACH,YAAY,cAAA;YACZ,WAAW,EAAE,MAAM;YACnB,sBAAsB,EAAE,eAAe;YACvC,WAAW,EAAE,CAAC;SACjB,CAAC;KACL;AACL,CAAC;;;;;;;AAED,SAAS,8BAA8B,CAAC,YAA2B,EAAE,MAAc,EAAE,kBAA0B;;QACrG,aAAa,GAAG,YAAY,CAAC,gBAAgB,GAAG,MAAM;IAE5D,eAAe;IAEf,IAAG,MAAM,GAAG,CAAC,EAAE;QACX,mFAAmF;QACnF,IAAG,YAAY,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE;YAChF,OAAO;gBACH,YAAY,cAAA;gBACZ,WAAW,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,gBAAgB;gBACtE,sBAAsB,EAAE,CAAC,CAAC;gBAC1B,WAAW,EAAE,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO;aACzD,CAAC;SACL;QACD,OAAO;YACH,YAAY,cAAA;YACZ,WAAW,EAAE,MAAM;YACnB,sBAAsB,EAAE,CAAC,CAAC;YAC1B,WAAW,EAAE,CAAC;SACjB,CAAC;KACL;IAED,cAAc;SAET,IAAG,MAAM,GAAG,CAAC,EAAE;QAChB,oFAAoF;QACpF,IAAG,YAAY,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE;YAChF,OAAO;gBACH,YAAY,cAAA;gBACZ,WAAW,EAAE,YAAY,CAAC,IAAI,CAAC,OAAO,GAAG,MAAM,GAAG,aAAa;gBAC/D,sBAAsB,EAAE,CAAC,CAAC;gBAC1B,WAAW,EAAE,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO;aACzD,CAAC;SACL;QACD,kDAAkD;aAC7C,IAAG,aAAa,GAAG,CAAC,EAAE;YACvB,OAAO;gBACH,YAAY,cAAA;gBACZ,WAAW,EAAE,CAAC,YAAY,CAAC,gBAAgB;gBAC3C,sBAAsB,EAAE,CAAC,CAAC;gBAC1B,WAAW,EAAE,MAAM,GAAG,YAAY,CAAC,gBAAgB;aACtD,CAAC;SACL;QACD,OAAO;YACH,YAAY,cAAA;YACZ,WAAW,EAAE,MAAM;YACnB,sBAAsB,EAAE,CAAC,CAAC;YAC1B,WAAW,EAAE,CAAC;SACjB,CAAC;KACL;AACL,CAAC;;;;;;AAED,MAAM,UAAU,cAAc,CAAC,IAAyB,EAAE,IAA6B;IAEnF,IAAG,IAAI,KAAK,SAAS,EAAE;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,sBAAsB,CAAC;KAC7D;SACI,IAAG,IAAI,KAAK,OAAO,EAAE;QACtB,gDAAgD;QAChD,IAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE;YACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC;SACvF;KACJ;AACL,CAAC","sourcesContent":["import { ElementRef } from '@angular/core';\r\n\r\nimport { IArea, IPoint, IAreaSnapshot, ISplitSideAbsorptionCapacity, IAreaAbsorptionCapacity } from './interface';\r\n\r\nexport function getPointFromEvent(event: MouseEvent | TouchEvent): IPoint {\r\n    // TouchEvent\r\n    if((<TouchEvent> event).changedTouches !== undefined && (<TouchEvent> event).changedTouches.length > 0) {\r\n        return {\r\n            x: (<TouchEvent> event).changedTouches[0].clientX,\r\n            y: (<TouchEvent> event).changedTouches[0].clientY,\r\n        };\r\n    }\r\n    // MouseEvent\r\n    else if((<MouseEvent> event).clientX !== undefined && (<MouseEvent> event).clientY !== undefined) {\r\n        return {\r\n            x: (<MouseEvent> event).clientX,\r\n            y: (<MouseEvent> event).clientY,\r\n        };\r\n    }\r\n    return null;\r\n}\r\n\r\nexport function getElementPixelSize(elRef: ElementRef, direction: 'horizontal' | 'vertical'): number {\r\n    const rect = (<HTMLElement> elRef.nativeElement).getBoundingClientRect();\r\n\r\n    return (direction === 'horizontal') ? rect.width : rect.height;\r\n}\r\n\r\nexport function getInputBoolean(v: any): boolean {\r\n    return (typeof(v) === 'boolean') ? v : (v === 'false' ? false : true);\r\n}\r\n\r\nexport function getInputPositiveNumber<T>(v: any, defaultValue: T): number | T {\r\n    if(v === null || v === undefined) return defaultValue;\r\n\r\n    v = Number(v);\r\n    return !isNaN(v) && v >= 0 ? v : defaultValue;\r\n}\r\n\r\nexport function isUserSizesValid(unit: 'percent' | 'pixel', sizes: Array<number | null>): boolean {\r\n    // All sizes have to be not null and total should be 100\r\n    if(unit === 'percent') {\r\n        const total = sizes.reduce((total, s) => s !== null ? total + s : total, 0);\r\n        return sizes.every(s => s !== null) && total > 99.9 && total < 100.1;\r\n    }\r\n    \r\n    // A size at null is mandatory but only one.\r\n    if(unit === 'pixel') {\r\n        return sizes.filter(s => s === null).length === 1;\r\n    }\r\n}\r\n\r\nexport function getAreaMinSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.minSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.minSize > a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.minSize;\r\n}\r\n\r\nexport function getAreaMaxSize(a: IArea): null | number {\r\n    if(a.size === null) {\r\n        return null;\r\n    }\r\n    \r\n    if(a.component.lockSize === true) {\r\n        return a.size;\r\n    }\r\n\r\n    if(a.component.maxSize === null) {\r\n        return null;\r\n    }\r\n\r\n    if(a.component.maxSize < a.size) {\r\n        return a.size;\r\n    }\r\n\r\n    return a.component.maxSize;\r\n}\r\n\r\nexport function getGutterSideAbsorptionCapacity(unit: 'percent' | 'pixel', sideAreas: Array<IAreaSnapshot>, pixels: number, allAreasSizePixel: number): ISplitSideAbsorptionCapacity {\r\n    return sideAreas.reduce((acc, area) => {\r\n        const res = getAreaAbsorptionCapacity(unit, area, acc.remain, allAreasSizePixel);\r\n        acc.list.push(res);\r\n        acc.remain  = res.pixelRemain;\r\n        return acc;\r\n    }, {remain: pixels, list: []});\r\n}\r\n\r\nfunction getAreaAbsorptionCapacity(unit: 'percent' | 'pixel', areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    // No pain no gain\r\n    if(pixels === 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: areaSnapshot.sizePercentAtStart,\r\n            pixelRemain: 0,\r\n        };\r\n    }\r\n    \r\n    // Area start at zero and need to be reduced, not possible\r\n    if(areaSnapshot.sizePixelAtStart === 0 && pixels < 0) {\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: 0,\r\n            percentAfterAbsorption: 0,\r\n            pixelRemain: pixels,\r\n        };\r\n    }\r\n    \r\n    if(unit === 'percent') {\r\n        return getAreaAbsorptionCapacityPercent(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n    \r\n\tif(unit === 'pixel') {\r\n        return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels, allAreasSizePixel);\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPercent(areaSnapshot: IAreaSnapshot, pixels: number, allAreasSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n    const tempPercentSize = tempPixelSize / allAreasSizePixel * 100;\r\n    \r\n    // ENLARGE AREA\r\n    \r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {\r\n            // Use area.area.maxSize as newPercentSize and return calculate pixels remaining\r\n            const maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: maxSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.maxSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {\r\n            // Use area.area.minSize as newPercentSize and return calculate pixels remaining\r\n            const minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: minSizePixel,\r\n                percentAfterAbsorption: areaSnapshot.area.minSize,\r\n                pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPercentSize < 0) {\r\n            // Use 0 as newPercentSize and return calculate pixels remaining\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: 0,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: tempPercentSize,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nfunction getAreaAbsorptionCapacityPixel(areaSnapshot: IAreaSnapshot, pixels: number, containerSizePixel: number): IAreaAbsorptionCapacity {\r\n    const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;\r\n            \r\n    // ENLARGE AREA\r\n\r\n    if(pixels > 0) {\r\n        // If maxSize & newSize bigger than it > absorb to max and return remaining pixels \r\n        if(areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.maxSize - areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.maxSize\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n\r\n    // REDUCE AREA\r\n    \r\n    else if(pixels < 0) {\r\n        // If minSize & newSize smaller than it > absorb to min and return remaining pixels \r\n        if(areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: areaSnapshot.area.minSize + pixels - tempPixelSize,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: tempPixelSize - areaSnapshot.area.minSize\r\n            };\r\n        }\r\n        // If reduced under zero > return remaining pixels\r\n        else if(tempPixelSize < 0) {\r\n            return {\r\n                areaSnapshot,\r\n                pixelAbsorb: -areaSnapshot.sizePixelAtStart,\r\n                percentAfterAbsorption: -1,\r\n                pixelRemain: pixels + areaSnapshot.sizePixelAtStart\r\n            };\r\n        }\r\n        return {\r\n            areaSnapshot,\r\n            pixelAbsorb: pixels,\r\n            percentAfterAbsorption: -1,\r\n            pixelRemain: 0\r\n        };\r\n    }\r\n}\r\n\r\nexport function updateAreaSize(unit: 'percent' | 'pixel', item: IAreaAbsorptionCapacity) {\r\n    \r\n    if(unit === 'percent') {\r\n        item.areaSnapshot.area.size = item.percentAfterAbsorption;\r\n    }\r\n    else if(unit === 'pixel') {\r\n        // Update size except for the wildcard size area\r\n        if(item.areaSnapshot.area.size !== null) {\r\n            item.areaSnapshot.area.size = item.areaSnapshot.sizePixelAtStart + item.pixelAbsorb;\r\n        }\r\n    }\r\n}"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/

@@ -11,2 +11,2 @@ /*

export { SplitAreaDirective } from './lib/directive/splitArea.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItc3BsaXQvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGFuZ3VsYXItc3BsaXRcclxuICovXHJcblxyXG5leHBvcnQgeyBBbmd1bGFyU3BsaXRNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGUnO1xyXG5leHBvcnQgeyBTcGxpdENvbXBvbmVudCB9IGZyb20gJy4vbGliL2NvbXBvbmVudC9zcGxpdC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBTcGxpdEFyZWFEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmUvc3BsaXRBcmVhLmRpcmVjdGl2ZSc7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FuZ3VsYXItc3BsaXQvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhbmd1bGFyLXNwbGl0XG4gKi9cblxuZXhwb3J0IHsgQW5ndWxhclNwbGl0TW9kdWxlIH0gZnJvbSAnLi9saWIvbW9kdWxlJztcbmV4cG9ydCB7IFNwbGl0Q29tcG9uZW50IH0gZnJvbSAnLi9saWIvY29tcG9uZW50L3NwbGl0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBTcGxpdEFyZWFEaXJlY3RpdmUgfSBmcm9tICcuL2xpYi9kaXJlY3RpdmUvc3BsaXRBcmVhLmRpcmVjdGl2ZSc7XG4iXX0=

@@ -0,0 +0,0 @@ import { ChangeDetectorRef, Renderer2, AfterViewInit, OnDestroy, ElementRef, NgZone, EventEmitter } from '@angular/core';

@@ -0,0 +0,0 @@ import { ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core';

@@ -0,0 +0,0 @@ import { SplitAreaDirective } from "./directive/splitArea.directive";

@@ -0,0 +0,0 @@ import { ModuleWithProviders } from '@angular/core';

@@ -0,0 +0,0 @@ import { ElementRef } from '@angular/core';

{
"name": "angular-split",
"version": "3.0.1",
"version": "3.0.2",
"description": "Angular UI library to split views and allow dragging to resize areas using CSS flexbox layout.",

@@ -23,4 +23,4 @@ "author": "bertrandg",

"peerDependencies": {
"@angular/common": "^7.0.0",
"@angular/core": "^7.0.0",
"@angular/common": "^8.0.0",
"@angular/core": "^8.0.0",
"rxjs": "^6.0.0"

@@ -27,0 +27,0 @@ },

export { AngularSplitModule } from './lib/module';
export { SplitComponent } from './lib/component/split.component';
export { SplitAreaDirective } from './lib/directive/splitArea.directive';

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 too big to display

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

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 too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc