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
2
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.3 to 4.0.0-beta.0

2

angular-split.metadata.json

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

{"__symbolic":"module","version":4,"metadata":{"AngularSplitModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":8,"character":8}],"declarations":[{"__symbolic":"reference","name":"SplitComponent"},{"__symbolic":"reference","name":"SplitAreaDirective"}],"exports":[{"__symbolic":"reference","name":"SplitComponent"},{"__symbolic":"reference","name":"SplitAreaDirective"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"AngularSplitModule"},"providers":[]}},"forChild":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"AngularSplitModule"},"providers":[]}}}},"SplitComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":38,"character":1},"arguments":[{"selector":"as-split","exportAs":"asSplit","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":41,"character":21},"member":"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}"]}]}],"members":{"direction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":63,"character":5}}]}],"unit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":80,"character":5}}]}],"gutterSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":97,"character":5}}]}],"gutterStep":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":111,"character":5}}]}],"restrictMove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":123,"character":5}}]}],"useTransition":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":135,"character":5}}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":150,"character":5}}]}],"dir":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":165,"character":5}}]}],"gutterDblClickDuration":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":179,"character":5}}]}],"dragStart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":189,"character":5}}]}],"dragEnd":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":190,"character":5}}]}],"gutterClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":191,"character":5}}]}],"gutterDblClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":192,"character":5}}]}],"transitionEnd":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":195,"character":5}}]}],"gutterEls":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":215,"character":5},"arguments":["gutterEls"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":217,"character":32},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":218,"character":31},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":219,"character":31},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":220,"character":34}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"getNbGutters":[{"__symbolic":"method"}],"addArea":[{"__symbolic":"method"}],"removeArea":[{"__symbolic":"method"}],"updateArea":[{"__symbolic":"method"}],"showArea":[{"__symbolic":"method"}],"hideArea":[{"__symbolic":"method"}],"getVisibleAreaSizes":[{"__symbolic":"method"}],"setVisibleAreaSizes":[{"__symbolic":"method"}],"build":[{"__symbolic":"method"}],"refreshStyleSizes":[{"__symbolic":"method"}],"clickGutter":[{"__symbolic":"method"}],"startDragging":[{"__symbolic":"method"}],"dragEvent":[{"__symbolic":"method"}],"stopDragging":[{"__symbolic":"method"}],"notify":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"SplitAreaDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"as-split-area, [as-split-area]","exportAs":"asSplitArea"}]}],"members":{"order":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":5}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":5}}]}],"minSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":5}}]}],"maxSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":55,"character":5}}]}],"lockSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":69,"character":5}}]}],"visible":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":5}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":105,"character":32},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":106,"character":30},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":107,"character":34},{"__symbolic":"reference","name":"SplitComponent"}]}],"ngOnInit":[{"__symbolic":"method"}],"setStyleOrder":[{"__symbolic":"method"}],"setStyleFlex":[{"__symbolic":"method"}],"lockEvents":[{"__symbolic":"method"}],"unlockEvents":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}}},"origins":{"AngularSplitModule":"./lib/module","SplitComponent":"./lib/component/split.component","SplitAreaDirective":"./lib/directive/splitArea.directive"},"importAs":"angular-split"}
{"__symbolic":"module","version":4,"metadata":{"AngularSplitModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":7,"character":12}],"declarations":[{"__symbolic":"reference","name":"SplitComponent"},{"__symbolic":"reference","name":"SplitAreaDirective"}],"exports":[{"__symbolic":"reference","name":"SplitComponent"},{"__symbolic":"reference","name":"SplitAreaDirective"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"AngularSplitModule"},"providers":[]}},"forChild":{"__symbolic":"function","parameters":[],"value":{"ngModule":{"__symbolic":"reference","name":"AngularSplitModule"},"providers":[]}}}},"SplitComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":63,"character":1},"arguments":[{"selector":"as-split","exportAs":"asSplit","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":66,"character":19},"member":"OnPush"},"template":" <ng-content></ng-content>\n <ng-template ngFor [ngForOf]=\"displayedAreas\" let-index=\"index\" let-last=\"last\">\n <div\n *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 >\n <div class=\"as-split-gutter-icon\"></div>\n </div>\n </ng-template>","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":84,"character":17},"member":"Emulated"},"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 0px!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}"]}]}],"members":{"direction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"unit":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":109,"character":3}}]}],"gutterSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":126,"character":3}}]}],"gutterStep":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":140,"character":3}}]}],"restrictMove":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":152,"character":3}}]}],"useTransition":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":164,"character":3}}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":179,"character":3}}]}],"dir":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":194,"character":3}}]}],"gutterDblClickDuration":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":208,"character":3}}]}],"dragStart":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":218,"character":3}}]}],"dragEnd":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":219,"character":3}}]}],"gutterClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":220,"character":3}}]}],"gutterDblClick":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":221,"character":3}}]}],"transitionEnd":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":224,"character":3}}]}],"gutterEls":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":245,"character":3},"arguments":["gutterEls"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":248,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":249,"character":19},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":250,"character":19},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":251,"character":22}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"getNbGutters":[{"__symbolic":"method"}],"addArea":[{"__symbolic":"method"}],"removeArea":[{"__symbolic":"method"}],"updateArea":[{"__symbolic":"method"}],"showArea":[{"__symbolic":"method"}],"hideArea":[{"__symbolic":"method"}],"getVisibleAreaSizes":[{"__symbolic":"method"}],"setVisibleAreaSizes":[{"__symbolic":"method"}],"build":[{"__symbolic":"method"}],"refreshStyleSizes":[{"__symbolic":"method"}],"clickGutter":[{"__symbolic":"method"}],"startDragging":[{"__symbolic":"method"}],"dragEvent":[{"__symbolic":"method"}],"stopDragging":[{"__symbolic":"method"}],"notify":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"SplitAreaDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"as-split-area, [as-split-area]","exportAs":"asSplitArea"}]}],"members":{"order":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":26,"character":3}}]}],"minSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"maxSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":3}}]}],"lockSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"visible":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":82,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":104,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":105,"character":18},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":106,"character":22},{"__symbolic":"reference","name":"SplitComponent"}]}],"ngOnInit":[{"__symbolic":"method"}],"setStyleOrder":[{"__symbolic":"method"}],"setStyleFlex":[{"__symbolic":"method"}],"lockEvents":[{"__symbolic":"method"}],"unlockEvents":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}]}},"IOutputData":{"__symbolic":"interface"},"IOutputAreaSizes":{"__symbolic":"interface"}},"origins":{"AngularSplitModule":"./lib/module","SplitComponent":"./lib/component/split.component","SplitAreaDirective":"./lib/directive/splitArea.directive","IOutputData":"./lib/interface","IOutputAreaSizes":"./lib/interface"},"importAs":"angular-split"}

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

!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})});
!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";
/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */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(e){r={error:e}}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 void 0!==e.changedTouches&&e.changedTouches.length>0?{x:e.changedTouches[0].clientX,y:e.changedTouches[0].clientY}:void 0!==e.clientX&&void 0!==e.clientY?{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?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.isWaitingClear=!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(void 0!==i){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(void 0!==i){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&&!0!==this.isWaitingClear&&(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.isWaitingClear=!0,this.ngZone.runOutsideAngular((function(){setTimeout((function(){t.startPoint=null,t.endPoint=null,t.isWaitingClear=!1}))}))}},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:' <ng-content></ng-content>\n <ng-template ngFor [ngForOf]="displayedAreas" let-index="index" let-last="last">\n <div\n *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 >\n <div class="as-split-gutter-icon"></div>\n </div>\n </ng-template>',encapsulation:t.ViewEncapsulation.Emulated,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 0px!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}();var 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}();var 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

@@ -220,3 +220,3 @@ /**

selector: 'as-split-area, [as-split-area]',
exportAs: 'asSplitArea'
exportAs: 'asSplitArea',
},] }

@@ -298,2 +298,2 @@ ];

}
//# 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'\n\nimport { SplitComponent } from '../component/split.component'\nimport { getInputPositiveNumber, getInputBoolean } from '../utils'\n\n@Directive({\n  selector: 'as-split-area, [as-split-area]',\n  exportAs: 'asSplitArea',\n})\nexport class SplitAreaDirective implements OnInit, OnDestroy {\n  private _order: number | null = null\n\n  @Input() set order(v: number | null) {\n    this._order = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, true, false)\n  }\n\n  get order(): number | null {\n    return this._order\n  }\n\n  ////\n\n  private _size: number | null = null\n\n  @Input() set size(v: number | null) {\n    this._size = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get size(): number | null {\n    return this._size\n  }\n\n  ////\n\n  private _minSize: number | null = null\n\n  @Input() set minSize(v: number | null) {\n    this._minSize = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get minSize(): number | null {\n    return this._minSize\n  }\n\n  ////\n\n  private _maxSize: number | null = null\n\n  @Input() set maxSize(v: number | null) {\n    this._maxSize = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get maxSize(): number | null {\n    return this._maxSize\n  }\n\n  ////\n\n  private _lockSize: boolean = false\n\n  @Input() set lockSize(v: boolean) {\n    this._lockSize = getInputBoolean(v)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get lockSize(): boolean {\n    return this._lockSize\n  }\n\n  ////\n\n  private _visible: boolean = true\n\n  @Input() set visible(v: boolean) {\n    this._visible = getInputBoolean(v)\n\n    if (this._visible) {\n      this.split.showArea(this)\n      this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden')\n    } else {\n      this.split.hideArea(this)\n      this.renderer.addClass(this.elRef.nativeElement, 'as-hidden')\n    }\n  }\n\n  get visible(): boolean {\n    return this._visible\n  }\n\n  ////\n\n  private transitionListener: Function\n  private readonly lockListeners: Array<Function> = []\n\n  constructor(\n    private ngZone: NgZone,\n    public elRef: ElementRef,\n    private renderer: Renderer2,\n    private split: SplitComponent,\n  ) {\n    this.renderer.addClass(this.elRef.nativeElement, 'as-split-area')\n  }\n\n  public ngOnInit(): void {\n    this.split.addArea(this)\n\n    this.ngZone.runOutsideAngular(() => {\n      this.transitionListener = this.renderer.listen(\n        this.elRef.nativeElement,\n        'transitionend',\n        (event: TransitionEvent) => {\n          // Limit only flex-basis transition to trigger the event\n          if (event.propertyName === 'flex-basis') {\n            this.split.notify('transitionEnd', -1)\n          }\n        },\n      )\n    })\n  }\n\n  public setStyleOrder(value: number): void {\n    this.renderer.setStyle(this.elRef.nativeElement, 'order', value)\n  }\n\n  public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\n    // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis)\n\n    if (isMin === true) this.renderer.addClass(this.elRef.nativeElement, 'as-min')\n    else this.renderer.removeClass(this.elRef.nativeElement, 'as-min')\n\n    if (isMax === true) this.renderer.addClass(this.elRef.nativeElement, 'as-max')\n    else this.renderer.removeClass(this.elRef.nativeElement, 'as-max')\n  }\n\n  public lockEvents(): void {\n    this.ngZone.runOutsideAngular(() => {\n      this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false))\n      this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false))\n    })\n  }\n\n  public unlockEvents(): void {\n    while (this.lockListeners.length > 0) {\n      const fct = this.lockListeners.pop()\n      if (fct) fct()\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.unlockEvents()\n\n    if (this.transitionListener) {\n      this.transitionListener()\n    }\n\n    this.split.removeArea(this)\n  }\n}\n"]}

@@ -99,2 +99,2 @@ /**

export function IOutputAreaSizes() { }
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUVBLDRCQUdDOzs7SUFGRyxtQkFBVTs7SUFDVixtQkFBVTs7Ozs7QUFHZCwyQkFNQzs7O0lBTEcsMEJBQThCOztJQUM5QixzQkFBYzs7SUFDZCxxQkFBb0I7O0lBQ3BCLHdCQUF1Qjs7SUFDdkIsd0JBQXVCOzs7OztBQUszQixvQ0FPQzs7O0lBTkcsbUNBQWlCOztJQUNqQiwyQ0FBeUI7O0lBQ3pCLHFEQUFtQzs7SUFDbkMsMkNBQXlCOztJQUN6QiwyQ0FBdUM7O0lBQ3ZDLDBDQUFzQzs7Ozs7QUFHMUMsbUNBSUM7OztJQUhHLDZCQUFXOztJQUNYLHlDQUF3Qjs7SUFDeEIsMkNBQTBCOzs7OztBQUs5QixrREFHQzs7O0lBRkcsOENBQWM7O0lBQ2QsNENBQW9DOzs7OztBQUd4Qyw2Q0FLQzs7O0lBSkcsK0NBQTJCOztJQUMzQiw4Q0FBbUI7O0lBQ25CLHlEQUE4Qjs7SUFDOUIsOENBQW1COzs7OztBQUt2QixpQ0FHQzs7O0lBRkcsZ0NBQWlCOztJQUNqQiw0QkFBdUI7Ozs7O0FBRzNCLHNDQUFnRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNwbGl0QXJlYURpcmVjdGl2ZSB9IGZyb20gXCIuL2RpcmVjdGl2ZS9zcGxpdEFyZWEuZGlyZWN0aXZlXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElQb2ludCB7XHJcbiAgICB4OiBudW1iZXI7XHJcbiAgICB5OiBudW1iZXI7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUFyZWEge1xyXG4gICAgY29tcG9uZW50OiBTcGxpdEFyZWFEaXJlY3RpdmU7XHJcbiAgICBvcmRlcjogbnVtYmVyO1xyXG4gICAgc2l6ZTogbnVtYmVyIHwgbnVsbDtcclxuICAgIG1pblNpemU6IG51bWJlciB8IG51bGw7XHJcbiAgICBtYXhTaXplOiBudW1iZXIgfCBudWxsO1xyXG59XHJcblxyXG4vLyBDUkVBVEVEIE9OIERSQUcgU1RBUlRcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVNwbGl0U25hcHNob3Qge1xyXG4gICAgZ3V0dGVyTnVtOiBudW1iZXJcclxuICAgIGFsbEFyZWFzU2l6ZVBpeGVsOiBudW1iZXJcclxuICAgIGFsbEludm9sdmVkQXJlYXNTaXplUGVyY2VudDogbnVtYmVyXHJcbiAgICBsYXN0U3RlcHBlZE9mZnNldDogbnVtYmVyXHJcbiAgICBhcmVhc0JlZm9yZUd1dHRlcjogQXJyYXk8SUFyZWFTbmFwc2hvdD5cclxuICAgIGFyZWFzQWZ0ZXJHdXR0ZXI6IEFycmF5PElBcmVhU25hcHNob3Q+XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUFyZWFTbmFwc2hvdCB7XHJcbiAgICBhcmVhOiBJQXJlYVxyXG4gICAgc2l6ZVBpeGVsQXRTdGFydDogbnVtYmVyXHJcbiAgICBzaXplUGVyY2VudEF0U3RhcnQ6IG51bWJlclxyXG59XHJcblxyXG4vLyBDUkVBVEVEIE9OIERSQUcgUFJPR1JFU1NcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVNwbGl0U2lkZUFic29ycHRpb25DYXBhY2l0eSB7XHJcbiAgICByZW1haW46IG51bWJlclxyXG4gICAgbGlzdDogQXJyYXk8SUFyZWFBYnNvcnB0aW9uQ2FwYWNpdHk+XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUFyZWFBYnNvcnB0aW9uQ2FwYWNpdHkge1xyXG4gICAgYXJlYVNuYXBzaG90OiBJQXJlYVNuYXBzaG90XHJcbiAgICBwaXhlbEFic29yYjogbnVtYmVyXHJcbiAgICBwZXJjZW50QWZ0ZXJBYnNvcnB0aW9uOiBudW1iZXJcclxuICAgIHBpeGVsUmVtYWluOiBudW1iZXJcclxufVxyXG5cclxuLy8gQ1JFQVRFRCBUTyBTRU5EIE9VVFNJREVcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSU91dHB1dERhdGEge1xyXG4gICAgZ3V0dGVyTnVtOiBudW1iZXJcclxuICAgIHNpemVzOiBJT3V0cHV0QXJlYVNpemVzXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSU91dHB1dEFyZWFTaXplcyBleHRlbmRzIEFycmF5PG51bWJlciB8ICcqJz4ge30iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUVBLDRCQUdDOzs7SUFGQyxtQkFBUzs7SUFDVCxtQkFBUzs7Ozs7QUFHWCwyQkFNQzs7O0lBTEMsMEJBQTZCOztJQUM3QixzQkFBYTs7SUFDYixxQkFBbUI7O0lBQ25CLHdCQUFzQjs7SUFDdEIsd0JBQXNCOzs7OztBQUt4QixvQ0FPQzs7O0lBTkMsbUNBQWlCOztJQUNqQiwyQ0FBeUI7O0lBQ3pCLHFEQUFtQzs7SUFDbkMsMkNBQXlCOztJQUN6QiwyQ0FBdUM7O0lBQ3ZDLDBDQUFzQzs7Ozs7QUFHeEMsbUNBSUM7OztJQUhDLDZCQUFXOztJQUNYLHlDQUF3Qjs7SUFDeEIsMkNBQTBCOzs7OztBQUs1QixrREFHQzs7O0lBRkMsOENBQWM7O0lBQ2QsNENBQW9DOzs7OztBQUd0Qyw2Q0FLQzs7O0lBSkMsK0NBQTJCOztJQUMzQiw4Q0FBbUI7O0lBQ25CLHlEQUE4Qjs7SUFDOUIsOENBQW1COzs7OztBQUtyQixpQ0FHQzs7O0lBRkMsZ0NBQWlCOztJQUNqQiw0QkFBdUI7Ozs7O0FBR3pCLHNDQUFnRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNwbGl0QXJlYURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlL3NwbGl0QXJlYS5kaXJlY3RpdmUnXG5cbmV4cG9ydCBpbnRlcmZhY2UgSVBvaW50IHtcbiAgeDogbnVtYmVyXG4gIHk6IG51bWJlclxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBcmVhIHtcbiAgY29tcG9uZW50OiBTcGxpdEFyZWFEaXJlY3RpdmVcbiAgb3JkZXI6IG51bWJlclxuICBzaXplOiBudW1iZXIgfCBudWxsXG4gIG1pblNpemU6IG51bWJlciB8IG51bGxcbiAgbWF4U2l6ZTogbnVtYmVyIHwgbnVsbFxufVxuXG4vLyBDUkVBVEVEIE9OIERSQUcgU1RBUlRcblxuZXhwb3J0IGludGVyZmFjZSBJU3BsaXRTbmFwc2hvdCB7XG4gIGd1dHRlck51bTogbnVtYmVyXG4gIGFsbEFyZWFzU2l6ZVBpeGVsOiBudW1iZXJcbiAgYWxsSW52b2x2ZWRBcmVhc1NpemVQZXJjZW50OiBudW1iZXJcbiAgbGFzdFN0ZXBwZWRPZmZzZXQ6IG51bWJlclxuICBhcmVhc0JlZm9yZUd1dHRlcjogQXJyYXk8SUFyZWFTbmFwc2hvdD5cbiAgYXJlYXNBZnRlckd1dHRlcjogQXJyYXk8SUFyZWFTbmFwc2hvdD5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQXJlYVNuYXBzaG90IHtcbiAgYXJlYTogSUFyZWFcbiAgc2l6ZVBpeGVsQXRTdGFydDogbnVtYmVyXG4gIHNpemVQZXJjZW50QXRTdGFydDogbnVtYmVyXG59XG5cbi8vIENSRUFURUQgT04gRFJBRyBQUk9HUkVTU1xuXG5leHBvcnQgaW50ZXJmYWNlIElTcGxpdFNpZGVBYnNvcnB0aW9uQ2FwYWNpdHkge1xuICByZW1haW46IG51bWJlclxuICBsaXN0OiBBcnJheTxJQXJlYUFic29ycHRpb25DYXBhY2l0eT5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQXJlYUFic29ycHRpb25DYXBhY2l0eSB7XG4gIGFyZWFTbmFwc2hvdDogSUFyZWFTbmFwc2hvdFxuICBwaXhlbEFic29yYjogbnVtYmVyXG4gIHBlcmNlbnRBZnRlckFic29ycHRpb246IG51bWJlclxuICBwaXhlbFJlbWFpbjogbnVtYmVyXG59XG5cbi8vIENSRUFURUQgVE8gU0VORCBPVVRTSURFXG5cbmV4cG9ydCBpbnRlcmZhY2UgSU91dHB1dERhdGEge1xuICBndXR0ZXJOdW06IG51bWJlclxuICBzaXplczogSU91dHB1dEFyZWFTaXplc1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElPdXRwdXRBcmVhU2l6ZXMgZXh0ZW5kcyBBcnJheTxudW1iZXIgfCAnKic+IHt9XG4iXX0=

@@ -16,3 +16,3 @@ /**

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -26,3 +26,3 @@ }

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -33,15 +33,7 @@ }

{ type: NgModule, args: [{
imports: [
CommonModule
],
declarations: [
SplitComponent,
SplitAreaDirective,
],
exports: [
SplitComponent,
SplitAreaDirective,
]
imports: [CommonModule],
declarations: [SplitComponent, SplitAreaDirective],
exports: [SplitComponent, SplitAreaDirective],
},] }
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFlckUsTUFBTSxPQUFPLGtCQUFrQjs7OztJQUVwQixNQUFNLENBQUMsT0FBTztRQUNqQixPQUFPO1lBQ0gsUUFBUSxFQUFFLGtCQUFrQjtZQUM1QixTQUFTLEVBQUUsRUFBRTtTQUNoQixDQUFDO0lBQ04sQ0FBQzs7OztJQUVNLE1BQU0sQ0FBQyxRQUFRO1FBQ2xCLE9BQU87WUFDSCxRQUFRLEVBQUUsa0JBQWtCO1lBQzVCLFNBQVMsRUFBRSxFQUFFO1NBQ2hCLENBQUM7SUFDTixDQUFDOzs7WUEzQkosUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO2lCQUNmO2dCQUNELFlBQVksRUFBRTtvQkFDVixjQUFjO29CQUNkLGtCQUFrQjtpQkFDckI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLGNBQWM7b0JBQ2Qsa0JBQWtCO2lCQUNyQjthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbmltcG9ydCB7IFNwbGl0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnQvc3BsaXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU3BsaXRBcmVhRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmUvc3BsaXRBcmVhLmRpcmVjdGl2ZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIFNwbGl0Q29tcG9uZW50LFxyXG4gICAgICAgIFNwbGl0QXJlYURpcmVjdGl2ZSxcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgU3BsaXRDb21wb25lbnQsXHJcbiAgICAgICAgU3BsaXRBcmVhRGlyZWN0aXZlLFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQW5ndWxhclNwbGl0TW9kdWxlIHtcclxuXHJcbiAgICBwdWJsaWMgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgbmdNb2R1bGU6IEFuZ3VsYXJTcGxpdE1vZHVsZSxcclxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbXVxyXG4gICAgICAgIH07XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHN0YXRpYyBmb3JDaGlsZCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzIHtcclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBuZ01vZHVsZTogQW5ndWxhclNwbGl0TW9kdWxlLFxyXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtdXHJcbiAgICAgICAgfTtcclxuICAgIH1cclxuXHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFBO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUU5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUE7QUFPcEUsTUFBTSxPQUFPLGtCQUFrQjs7OztJQUN0QixNQUFNLENBQUMsT0FBTztRQUNuQixPQUFPO1lBQ0wsUUFBUSxFQUFFLGtCQUFrQjtZQUM1QixTQUFTLEVBQUUsRUFBRTtTQUNkLENBQUE7SUFDSCxDQUFDOzs7O0lBRU0sTUFBTSxDQUFDLFFBQVE7UUFDcEIsT0FBTztZQUNMLFFBQVEsRUFBRSxrQkFBa0I7WUFDNUIsU0FBUyxFQUFFLEVBQUU7U0FDZCxDQUFBO0lBQ0gsQ0FBQzs7O1lBbEJGLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7Z0JBQ3ZCLFlBQVksRUFBRSxDQUFDLGNBQWMsRUFBRSxrQkFBa0IsQ0FBQztnQkFDbEQsT0FBTyxFQUFFLENBQUMsY0FBYyxFQUFFLGtCQUFrQixDQUFDO2FBQzlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuXG5pbXBvcnQgeyBTcGxpdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50L3NwbGl0LmNvbXBvbmVudCdcbmltcG9ydCB7IFNwbGl0QXJlYURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlL3NwbGl0QXJlYS5kaXJlY3RpdmUnXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtTcGxpdENvbXBvbmVudCwgU3BsaXRBcmVhRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW1NwbGl0Q29tcG9uZW50LCBTcGxpdEFyZWFEaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBBbmd1bGFyU3BsaXRNb2R1bGUge1xuICBwdWJsaWMgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxBbmd1bGFyU3BsaXRNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEFuZ3VsYXJTcGxpdE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW10sXG4gICAgfVxuICB9XG5cbiAgcHVibGljIHN0YXRpYyBmb3JDaGlsZCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEFuZ3VsYXJTcGxpdE1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogQW5ndWxhclNwbGl0TW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXSxcbiAgICB9XG4gIH1cbn1cbiJdfQ==

@@ -34,3 +34,3 @@ /**

const rect = ((/** @type {?} */ (elRef.nativeElement))).getBoundingClientRect();
return (direction === 'horizontal') ? rect.width : rect.height;
return direction === 'horizontal' ? rect.width : rect.height;
}

@@ -42,3 +42,3 @@ /**

export function getInputBoolean(v) {
return (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
return typeof v === 'boolean' ? v : v === 'false' ? false : true;
}

@@ -71,3 +71,3 @@ /**

*/
(total, s) => s !== null ? total + s : total), 0);
(total, s) => (s !== null ? total + s : total)), 0);
return sizes.every((/**

@@ -77,3 +77,3 @@ * @param {?} s

*/
s => s !== null)) && total > 99.9 && total < 100.1;
(s) => s !== null)) && total > 99.9 && total < 100.1;
}

@@ -86,3 +86,3 @@ // A size at null is mandatory but only one.

*/
s => s === null)).length === 1;
(s) => s === null)).length === 1;
}

@@ -192,10 +192,12 @@ }

/** @type {?} */
const tempPercentSize = tempPixelSize / allAreasSizePixel * 100;
const tempPercentSize = (tempPixelSize / allAreasSizePixel) * 100
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {
// Use area.area.maxSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
const maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;
const maxSizePixel = (areaSnapshot.area.maxSize / 100) * allAreasSizePixel;
return {

@@ -205,3 +207,3 @@ areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.maxSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel,
};

@@ -213,3 +215,3 @@ }

percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -219,7 +221,7 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {
// Use area.area.minSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
const minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;
const minSizePixel = (areaSnapshot.area.minSize / 100) * allAreasSizePixel;
return {

@@ -229,3 +231,3 @@ areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.minSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel,
};

@@ -240,3 +242,3 @@ }

percentAfterAbsorption: 0,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -248,3 +250,3 @@ }

percentAfterAbsorption: tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -261,6 +263,8 @@ }

/** @type {?} */
const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;
const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {

@@ -271,3 +275,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize,
};

@@ -279,3 +283,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

@@ -285,3 +289,3 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {

@@ -292,3 +296,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.minSize
pixelRemain: tempPixelSize - areaSnapshot.area.minSize,
};

@@ -302,3 +306,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -310,3 +314,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

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

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

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

@@ -263,3 +263,3 @@ /**

selector: 'as-split-area, [as-split-area]',
exportAs: 'asSplitArea'
exportAs: 'asSplitArea',
},] }

@@ -344,2 +344,2 @@ ];

}
//# 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'\n\nimport { SplitComponent } from '../component/split.component'\nimport { getInputPositiveNumber, getInputBoolean } from '../utils'\n\n@Directive({\n  selector: 'as-split-area, [as-split-area]',\n  exportAs: 'asSplitArea',\n})\nexport class SplitAreaDirective implements OnInit, OnDestroy {\n  private _order: number | null = null\n\n  @Input() set order(v: number | null) {\n    this._order = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, true, false)\n  }\n\n  get order(): number | null {\n    return this._order\n  }\n\n  ////\n\n  private _size: number | null = null\n\n  @Input() set size(v: number | null) {\n    this._size = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get size(): number | null {\n    return this._size\n  }\n\n  ////\n\n  private _minSize: number | null = null\n\n  @Input() set minSize(v: number | null) {\n    this._minSize = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get minSize(): number | null {\n    return this._minSize\n  }\n\n  ////\n\n  private _maxSize: number | null = null\n\n  @Input() set maxSize(v: number | null) {\n    this._maxSize = getInputPositiveNumber(v, null)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get maxSize(): number | null {\n    return this._maxSize\n  }\n\n  ////\n\n  private _lockSize: boolean = false\n\n  @Input() set lockSize(v: boolean) {\n    this._lockSize = getInputBoolean(v)\n\n    this.split.updateArea(this, false, true)\n  }\n\n  get lockSize(): boolean {\n    return this._lockSize\n  }\n\n  ////\n\n  private _visible: boolean = true\n\n  @Input() set visible(v: boolean) {\n    this._visible = getInputBoolean(v)\n\n    if (this._visible) {\n      this.split.showArea(this)\n      this.renderer.removeClass(this.elRef.nativeElement, 'as-hidden')\n    } else {\n      this.split.hideArea(this)\n      this.renderer.addClass(this.elRef.nativeElement, 'as-hidden')\n    }\n  }\n\n  get visible(): boolean {\n    return this._visible\n  }\n\n  ////\n\n  private transitionListener: Function\n  private readonly lockListeners: Array<Function> = []\n\n  constructor(\n    private ngZone: NgZone,\n    public elRef: ElementRef,\n    private renderer: Renderer2,\n    private split: SplitComponent,\n  ) {\n    this.renderer.addClass(this.elRef.nativeElement, 'as-split-area')\n  }\n\n  public ngOnInit(): void {\n    this.split.addArea(this)\n\n    this.ngZone.runOutsideAngular(() => {\n      this.transitionListener = this.renderer.listen(\n        this.elRef.nativeElement,\n        'transitionend',\n        (event: TransitionEvent) => {\n          // Limit only flex-basis transition to trigger the event\n          if (event.propertyName === 'flex-basis') {\n            this.split.notify('transitionEnd', -1)\n          }\n        },\n      )\n    })\n  }\n\n  public setStyleOrder(value: number): void {\n    this.renderer.setStyle(this.elRef.nativeElement, 'order', value)\n  }\n\n  public setStyleFlex(grow: number, shrink: number, basis: string, isMin: boolean, isMax: boolean): void {\n    // Need 3 separated properties to work on IE11 (https://github.com/angular/flex-layout/issues/323)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-grow', grow)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-shrink', shrink)\n    this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', basis)\n\n    if (isMin === true) this.renderer.addClass(this.elRef.nativeElement, 'as-min')\n    else this.renderer.removeClass(this.elRef.nativeElement, 'as-min')\n\n    if (isMax === true) this.renderer.addClass(this.elRef.nativeElement, 'as-max')\n    else this.renderer.removeClass(this.elRef.nativeElement, 'as-max')\n  }\n\n  public lockEvents(): void {\n    this.ngZone.runOutsideAngular(() => {\n      this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false))\n      this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false))\n    })\n  }\n\n  public unlockEvents(): void {\n    while (this.lockListeners.length > 0) {\n      const fct = this.lockListeners.pop()\n      if (fct) fct()\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.unlockEvents()\n\n    if (this.transitionListener) {\n      this.transitionListener()\n    }\n\n    this.split.removeArea(this)\n  }\n}\n"]}

@@ -99,2 +99,2 @@ /**

export function IOutputAreaSizes() { }
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUVBLDRCQUdDOzs7SUFGRyxtQkFBVTs7SUFDVixtQkFBVTs7Ozs7QUFHZCwyQkFNQzs7O0lBTEcsMEJBQThCOztJQUM5QixzQkFBYzs7SUFDZCxxQkFBb0I7O0lBQ3BCLHdCQUF1Qjs7SUFDdkIsd0JBQXVCOzs7OztBQUszQixvQ0FPQzs7O0lBTkcsbUNBQWlCOztJQUNqQiwyQ0FBeUI7O0lBQ3pCLHFEQUFtQzs7SUFDbkMsMkNBQXlCOztJQUN6QiwyQ0FBdUM7O0lBQ3ZDLDBDQUFzQzs7Ozs7QUFHMUMsbUNBSUM7OztJQUhHLDZCQUFXOztJQUNYLHlDQUF3Qjs7SUFDeEIsMkNBQTBCOzs7OztBQUs5QixrREFHQzs7O0lBRkcsOENBQWM7O0lBQ2QsNENBQW9DOzs7OztBQUd4Qyw2Q0FLQzs7O0lBSkcsK0NBQTJCOztJQUMzQiw4Q0FBbUI7O0lBQ25CLHlEQUE4Qjs7SUFDOUIsOENBQW1COzs7OztBQUt2QixpQ0FHQzs7O0lBRkcsZ0NBQWlCOztJQUNqQiw0QkFBdUI7Ozs7O0FBRzNCLHNDQUFnRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNwbGl0QXJlYURpcmVjdGl2ZSB9IGZyb20gXCIuL2RpcmVjdGl2ZS9zcGxpdEFyZWEuZGlyZWN0aXZlXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElQb2ludCB7XHJcbiAgICB4OiBudW1iZXI7XHJcbiAgICB5OiBudW1iZXI7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUFyZWEge1xyXG4gICAgY29tcG9uZW50OiBTcGxpdEFyZWFEaXJlY3RpdmU7XHJcbiAgICBvcmRlcjogbnVtYmVyO1xyXG4gICAgc2l6ZTogbnVtYmVyIHwgbnVsbDtcclxuICAgIG1pblNpemU6IG51bWJlciB8IG51bGw7XHJcbiAgICBtYXhTaXplOiBudW1iZXIgfCBudWxsO1xyXG59XHJcblxyXG4vLyBDUkVBVEVEIE9OIERSQUcgU1RBUlRcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVNwbGl0U25hcHNob3Qge1xyXG4gICAgZ3V0dGVyTnVtOiBudW1iZXJcclxuICAgIGFsbEFyZWFzU2l6ZVBpeGVsOiBudW1iZXJcclxuICAgIGFsbEludm9sdmVkQXJlYXNTaXplUGVyY2VudDogbnVtYmVyXHJcbiAgICBsYXN0U3RlcHBlZE9mZnNldDogbnVtYmVyXHJcbiAgICBhcmVhc0JlZm9yZUd1dHRlcjogQXJyYXk8SUFyZWFTbmFwc2hvdD5cclxuICAgIGFyZWFzQWZ0ZXJHdXR0ZXI6IEFycmF5PElBcmVhU25hcHNob3Q+XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUFyZWFTbmFwc2hvdCB7XHJcbiAgICBhcmVhOiBJQXJlYVxyXG4gICAgc2l6ZVBpeGVsQXRTdGFydDogbnVtYmVyXHJcbiAgICBzaXplUGVyY2VudEF0U3RhcnQ6IG51bWJlclxyXG59XHJcblxyXG4vLyBDUkVBVEVEIE9OIERSQUcgUFJPR1JFU1NcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSVNwbGl0U2lkZUFic29ycHRpb25DYXBhY2l0eSB7XHJcbiAgICByZW1haW46IG51bWJlclxyXG4gICAgbGlzdDogQXJyYXk8SUFyZWFBYnNvcnB0aW9uQ2FwYWNpdHk+XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUFyZWFBYnNvcnB0aW9uQ2FwYWNpdHkge1xyXG4gICAgYXJlYVNuYXBzaG90OiBJQXJlYVNuYXBzaG90XHJcbiAgICBwaXhlbEFic29yYjogbnVtYmVyXHJcbiAgICBwZXJjZW50QWZ0ZXJBYnNvcnB0aW9uOiBudW1iZXJcclxuICAgIHBpeGVsUmVtYWluOiBudW1iZXJcclxufVxyXG5cclxuLy8gQ1JFQVRFRCBUTyBTRU5EIE9VVFNJREVcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSU91dHB1dERhdGEge1xyXG4gICAgZ3V0dGVyTnVtOiBudW1iZXJcclxuICAgIHNpemVzOiBJT3V0cHV0QXJlYVNpemVzXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSU91dHB1dEFyZWFTaXplcyBleHRlbmRzIEFycmF5PG51bWJlciB8ICcqJz4ge30iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUVBLDRCQUdDOzs7SUFGQyxtQkFBUzs7SUFDVCxtQkFBUzs7Ozs7QUFHWCwyQkFNQzs7O0lBTEMsMEJBQTZCOztJQUM3QixzQkFBYTs7SUFDYixxQkFBbUI7O0lBQ25CLHdCQUFzQjs7SUFDdEIsd0JBQXNCOzs7OztBQUt4QixvQ0FPQzs7O0lBTkMsbUNBQWlCOztJQUNqQiwyQ0FBeUI7O0lBQ3pCLHFEQUFtQzs7SUFDbkMsMkNBQXlCOztJQUN6QiwyQ0FBdUM7O0lBQ3ZDLDBDQUFzQzs7Ozs7QUFHeEMsbUNBSUM7OztJQUhDLDZCQUFXOztJQUNYLHlDQUF3Qjs7SUFDeEIsMkNBQTBCOzs7OztBQUs1QixrREFHQzs7O0lBRkMsOENBQWM7O0lBQ2QsNENBQW9DOzs7OztBQUd0Qyw2Q0FLQzs7O0lBSkMsK0NBQTJCOztJQUMzQiw4Q0FBbUI7O0lBQ25CLHlEQUE4Qjs7SUFDOUIsOENBQW1COzs7OztBQUtyQixpQ0FHQzs7O0lBRkMsZ0NBQWlCOztJQUNqQiw0QkFBdUI7Ozs7O0FBR3pCLHNDQUFnRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNwbGl0QXJlYURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlL3NwbGl0QXJlYS5kaXJlY3RpdmUnXG5cbmV4cG9ydCBpbnRlcmZhY2UgSVBvaW50IHtcbiAgeDogbnVtYmVyXG4gIHk6IG51bWJlclxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBcmVhIHtcbiAgY29tcG9uZW50OiBTcGxpdEFyZWFEaXJlY3RpdmVcbiAgb3JkZXI6IG51bWJlclxuICBzaXplOiBudW1iZXIgfCBudWxsXG4gIG1pblNpemU6IG51bWJlciB8IG51bGxcbiAgbWF4U2l6ZTogbnVtYmVyIHwgbnVsbFxufVxuXG4vLyBDUkVBVEVEIE9OIERSQUcgU1RBUlRcblxuZXhwb3J0IGludGVyZmFjZSBJU3BsaXRTbmFwc2hvdCB7XG4gIGd1dHRlck51bTogbnVtYmVyXG4gIGFsbEFyZWFzU2l6ZVBpeGVsOiBudW1iZXJcbiAgYWxsSW52b2x2ZWRBcmVhc1NpemVQZXJjZW50OiBudW1iZXJcbiAgbGFzdFN0ZXBwZWRPZmZzZXQ6IG51bWJlclxuICBhcmVhc0JlZm9yZUd1dHRlcjogQXJyYXk8SUFyZWFTbmFwc2hvdD5cbiAgYXJlYXNBZnRlckd1dHRlcjogQXJyYXk8SUFyZWFTbmFwc2hvdD5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQXJlYVNuYXBzaG90IHtcbiAgYXJlYTogSUFyZWFcbiAgc2l6ZVBpeGVsQXRTdGFydDogbnVtYmVyXG4gIHNpemVQZXJjZW50QXRTdGFydDogbnVtYmVyXG59XG5cbi8vIENSRUFURUQgT04gRFJBRyBQUk9HUkVTU1xuXG5leHBvcnQgaW50ZXJmYWNlIElTcGxpdFNpZGVBYnNvcnB0aW9uQ2FwYWNpdHkge1xuICByZW1haW46IG51bWJlclxuICBsaXN0OiBBcnJheTxJQXJlYUFic29ycHRpb25DYXBhY2l0eT5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQXJlYUFic29ycHRpb25DYXBhY2l0eSB7XG4gIGFyZWFTbmFwc2hvdDogSUFyZWFTbmFwc2hvdFxuICBwaXhlbEFic29yYjogbnVtYmVyXG4gIHBlcmNlbnRBZnRlckFic29ycHRpb246IG51bWJlclxuICBwaXhlbFJlbWFpbjogbnVtYmVyXG59XG5cbi8vIENSRUFURUQgVE8gU0VORCBPVVRTSURFXG5cbmV4cG9ydCBpbnRlcmZhY2UgSU91dHB1dERhdGEge1xuICBndXR0ZXJOdW06IG51bWJlclxuICBzaXplczogSU91dHB1dEFyZWFTaXplc1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElPdXRwdXRBcmVhU2l6ZXMgZXh0ZW5kcyBBcnJheTxudW1iZXIgfCAnKic+IHt9XG4iXX0=

@@ -21,3 +21,3 @@ /**

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -34,3 +34,3 @@ };

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -40,13 +40,5 @@ };

{ type: NgModule, args: [{
imports: [
CommonModule
],
declarations: [
SplitComponent,
SplitAreaDirective,
],
exports: [
SplitComponent,
SplitAreaDirective,
]
imports: [CommonModule],
declarations: [SplitComponent, SplitAreaDirective],
exports: [SplitComponent, SplitAreaDirective],
},] }

@@ -57,2 +49,2 @@ ];

export { AngularSplitModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFckU7SUFBQTtJQTZCQSxDQUFDOzs7O0lBZGlCLDBCQUFPOzs7SUFBckI7UUFDSSxPQUFPO1lBQ0gsUUFBUSxFQUFFLGtCQUFrQjtZQUM1QixTQUFTLEVBQUUsRUFBRTtTQUNoQixDQUFDO0lBQ04sQ0FBQzs7OztJQUVhLDJCQUFROzs7SUFBdEI7UUFDSSxPQUFPO1lBQ0gsUUFBUSxFQUFFLGtCQUFrQjtZQUM1QixTQUFTLEVBQUUsRUFBRTtTQUNoQixDQUFDO0lBQ04sQ0FBQzs7Z0JBM0JKLFFBQVEsU0FBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTtxQkFDZjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1YsY0FBYzt3QkFDZCxrQkFBa0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxjQUFjO3dCQUNkLGtCQUFrQjtxQkFDckI7aUJBQ0o7O0lBaUJELHlCQUFDO0NBQUEsQUE3QkQsSUE2QkM7U0FoQlksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbmltcG9ydCB7IFNwbGl0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnQvc3BsaXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU3BsaXRBcmVhRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmUvc3BsaXRBcmVhLmRpcmVjdGl2ZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIFNwbGl0Q29tcG9uZW50LFxyXG4gICAgICAgIFNwbGl0QXJlYURpcmVjdGl2ZSxcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgU3BsaXRDb21wb25lbnQsXHJcbiAgICAgICAgU3BsaXRBcmVhRGlyZWN0aXZlLFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQW5ndWxhclNwbGl0TW9kdWxlIHtcclxuXHJcbiAgICBwdWJsaWMgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgbmdNb2R1bGU6IEFuZ3VsYXJTcGxpdE1vZHVsZSxcclxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbXVxyXG4gICAgICAgIH07XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHN0YXRpYyBmb3JDaGlsZCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzIHtcclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBuZ01vZHVsZTogQW5ndWxhclNwbGl0TW9kdWxlLFxyXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtdXHJcbiAgICAgICAgfTtcclxuICAgIH1cclxuXHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vYW5ndWxhci1zcGxpdC8iLCJzb3VyY2VzIjpbImxpYi9tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFBO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUU5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUE7QUFFcEU7SUFBQTtJQW1CQSxDQUFDOzs7O0lBYmUsMEJBQU87OztJQUFyQjtRQUNFLE9BQU87WUFDTCxRQUFRLEVBQUUsa0JBQWtCO1lBQzVCLFNBQVMsRUFBRSxFQUFFO1NBQ2QsQ0FBQTtJQUNILENBQUM7Ozs7SUFFYSwyQkFBUTs7O0lBQXRCO1FBQ0UsT0FBTztZQUNMLFFBQVEsRUFBRSxrQkFBa0I7WUFDNUIsU0FBUyxFQUFFLEVBQUU7U0FDZCxDQUFBO0lBQ0gsQ0FBQzs7Z0JBbEJGLFFBQVEsU0FBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLFlBQVksRUFBRSxDQUFDLGNBQWMsRUFBRSxrQkFBa0IsQ0FBQztvQkFDbEQsT0FBTyxFQUFFLENBQUMsY0FBYyxFQUFFLGtCQUFrQixDQUFDO2lCQUM5Qzs7SUFlRCx5QkFBQztDQUFBLEFBbkJELElBbUJDO1NBZFksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuXG5pbXBvcnQgeyBTcGxpdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50L3NwbGl0LmNvbXBvbmVudCdcbmltcG9ydCB7IFNwbGl0QXJlYURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlL3NwbGl0QXJlYS5kaXJlY3RpdmUnXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtTcGxpdENvbXBvbmVudCwgU3BsaXRBcmVhRGlyZWN0aXZlXSxcbiAgZXhwb3J0czogW1NwbGl0Q29tcG9uZW50LCBTcGxpdEFyZWFEaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBBbmd1bGFyU3BsaXRNb2R1bGUge1xuICBwdWJsaWMgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxBbmd1bGFyU3BsaXRNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEFuZ3VsYXJTcGxpdE1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW10sXG4gICAgfVxuICB9XG5cbiAgcHVibGljIHN0YXRpYyBmb3JDaGlsZCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEFuZ3VsYXJTcGxpdE1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogQW5ndWxhclNwbGl0TW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXSxcbiAgICB9XG4gIH1cbn1cbiJdfQ==

@@ -34,3 +34,3 @@ /**

var rect = ((/** @type {?} */ (elRef.nativeElement))).getBoundingClientRect();
return (direction === 'horizontal') ? rect.width : rect.height;
return direction === 'horizontal' ? rect.width : rect.height;
}

@@ -42,3 +42,3 @@ /**

export function getInputBoolean(v) {
return (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
return typeof v === 'boolean' ? v : v === 'false' ? false : true;
}

@@ -71,3 +71,3 @@ /**

*/
function (total, s) { return s !== null ? total + s : total; }), 0);
function (total, s) { return (s !== null ? total + s : total); }), 0);
return sizes.every((/**

@@ -190,10 +190,12 @@ * @param {?} s

/** @type {?} */
var tempPercentSize = tempPixelSize / allAreasSizePixel * 100;
var tempPercentSize = (tempPixelSize / allAreasSizePixel) * 100
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {
// Use area.area.maxSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
var maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;
var maxSizePixel = (areaSnapshot.area.maxSize / 100) * allAreasSizePixel;
return {

@@ -203,3 +205,3 @@ areaSnapshot: areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.maxSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel,
};

@@ -211,3 +213,3 @@ }

percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -217,7 +219,7 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {
// Use area.area.minSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
var minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;
var minSizePixel = (areaSnapshot.area.minSize / 100) * allAreasSizePixel;
return {

@@ -227,3 +229,3 @@ areaSnapshot: areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.minSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel,
};

@@ -238,3 +240,3 @@ }

percentAfterAbsorption: 0,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -246,3 +248,3 @@ }

percentAfterAbsorption: tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -259,6 +261,8 @@ }

/** @type {?} */
var tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;
var tempPixelSize = areaSnapshot.sizePixelAtStart + pixels
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {

@@ -269,3 +273,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize,
};

@@ -277,3 +281,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

@@ -283,3 +287,3 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {

@@ -290,3 +294,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.minSize
pixelRemain: tempPixelSize - areaSnapshot.area.minSize,
};

@@ -300,3 +304,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -308,3 +312,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

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

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

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

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

import { EventEmitter, Component, ChangeDetectionStrategy, NgZone, ElementRef, ChangeDetectorRef, Renderer2, Input, Output, ViewChildren, Directive, NgModule } from '@angular/core';
import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, NgZone, ElementRef, ChangeDetectorRef, Renderer2, Input, Output, ViewChildren, Directive, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';

@@ -39,3 +39,3 @@ import { Subject, Observable } from 'rxjs';

const rect = ((/** @type {?} */ (elRef.nativeElement))).getBoundingClientRect();
return (direction === 'horizontal') ? rect.width : rect.height;
return direction === 'horizontal' ? rect.width : rect.height;
}

@@ -47,3 +47,3 @@ /**

function getInputBoolean(v) {
return (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
return typeof v === 'boolean' ? v : v === 'false' ? false : true;
}

@@ -76,3 +76,3 @@ /**

*/
(total, s) => s !== null ? total + s : total), 0);
(total, s) => (s !== null ? total + s : total)), 0);
return sizes.every((/**

@@ -82,3 +82,3 @@ * @param {?} s

*/
s => s !== null)) && total > 99.9 && total < 100.1;
(s) => s !== null)) && total > 99.9 && total < 100.1;
}

@@ -91,3 +91,3 @@ // A size at null is mandatory but only one.

*/
s => s === null)).length === 1;
(s) => s === null)).length === 1;
}

@@ -184,3 +184,3 @@ }

if (unit === 'pixel') {
return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels);
return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels, allAreasSizePixel);
}

@@ -198,10 +198,12 @@ }

/** @type {?} */
const tempPercentSize = tempPixelSize / allAreasSizePixel * 100;
const tempPercentSize = (tempPixelSize / allAreasSizePixel) * 100
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {
// Use area.area.maxSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
const maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;
const maxSizePixel = (areaSnapshot.area.maxSize / 100) * allAreasSizePixel;
return {

@@ -211,3 +213,3 @@ areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.maxSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel,
};

@@ -219,3 +221,3 @@ }

percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -225,7 +227,7 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {
// Use area.area.minSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
const minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;
const minSizePixel = (areaSnapshot.area.minSize / 100) * allAreasSizePixel;
return {

@@ -235,3 +237,3 @@ areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.minSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel,
};

@@ -246,3 +248,3 @@ }

percentAfterAbsorption: 0,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -254,3 +256,3 @@ }

percentAfterAbsorption: tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -267,6 +269,8 @@ }

/** @type {?} */
const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;
const tempPixelSize = areaSnapshot.sizePixelAtStart + pixels
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {

@@ -277,3 +281,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize,
};

@@ -285,3 +289,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

@@ -291,3 +295,3 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {

@@ -298,3 +302,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.minSize
pixelRemain: tempPixelSize - areaSnapshot.area.minSize,
};

@@ -308,3 +312,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -316,3 +320,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

@@ -409,2 +413,3 @@ }

this.isDragging = false;
this.isWaitingClear = false;
this.dragListeners = [];

@@ -425,5 +430,5 @@ this.snapshot = null;

set direction(v) {
this._direction = (v === 'vertical') ? 'vertical' : 'horizontal';
this._direction = v === 'vertical' ? 'vertical' : 'horizontal';
this.renderer.addClass(this.elRef.nativeElement, `as-${this._direction}`);
this.renderer.removeClass(this.elRef.nativeElement, `as-${(this._direction === 'vertical') ? 'horizontal' : 'vertical'}`);
this.renderer.removeClass(this.elRef.nativeElement, `as-${this._direction === 'vertical' ? 'horizontal' : 'vertical'}`);
this.build(false, false);

@@ -442,5 +447,5 @@ }

set unit(v) {
this._unit = (v === 'pixel') ? 'pixel' : 'percent';
this._unit = v === 'pixel' ? 'pixel' : 'percent';
this.renderer.addClass(this.elRef.nativeElement, `as-${this._unit}`);
this.renderer.removeClass(this.elRef.nativeElement, `as-${(this._unit === 'pixel') ? 'percent' : 'pixel'}`);
this.renderer.removeClass(this.elRef.nativeElement, `as-${this._unit === 'pixel' ? 'percent' : 'pixel'}`);
this.build(false, true);

@@ -533,3 +538,3 @@ }

set dir(v) {
this._dir = (v === 'rtl') ? 'rtl' : 'ltr';
this._dir = v === 'rtl' ? 'rtl' : 'ltr';
this.renderer.setAttribute(this.elRef.nativeElement, 'dir', this._dir);

@@ -564,3 +569,3 @@ }

*/
subscriber => this.transitionEndSubscriber = subscriber)).pipe(debounceTime(20));
(subscriber) => (this.transitionEndSubscriber = subscriber))).pipe(debounceTime(20));
}

@@ -587,3 +592,3 @@ /**

getNbGutters() {
return (this.displayedAreas.length === 0) ? 0 : this.displayedAreas.length - 1;
return this.displayedAreas.length === 0 ? 0 : this.displayedAreas.length - 1;
}

@@ -620,3 +625,3 @@ /**

*/
a => a.component === component))) {
(a) => a.component === component))) {
/** @type {?} */

@@ -627,3 +632,3 @@ const area = this.displayedAreas.find((/**

*/
a => a.component === component));
(a) => a.component === component));
this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);

@@ -636,3 +641,3 @@ this.build(true, true);

*/
a => a.component === component))) {
(a) => a.component === component))) {
/** @type {?} */

@@ -643,3 +648,3 @@ const area = this.hidedAreas.find((/**

*/
a => a.component === component));
(a) => a.component === component));
this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);

@@ -669,3 +674,3 @@ }

*/
a => a.component === component));
(a) => a.component === component));
if (area === undefined) {

@@ -689,3 +694,3 @@ return;

*/
a => a.component === comp));
(a) => a.component === comp));
if (area === undefined) {

@@ -700,3 +705,3 @@ return;

*/
area => {
(area) => {
area.order = 0;

@@ -716,3 +721,3 @@ area.size = 0;

*/
a => a.size === null ? '*' : a.size));
(a) => (a.size === null ? '*' : a.size)));
}

@@ -732,3 +737,3 @@ /**

*/
s => getInputPositiveNumber(s, null)));
(s) => getInputPositiveNumber(s, null)));
/** @type {?} */

@@ -745,3 +750,3 @@ const isValid = isUserSizesValid(this.unit, formatedSizes);

*/
(area, i) => area.component._size = formatedSizes[i]));
(area, i) => (area.component._size = formatedSizes[i])));
this.build(false, true);

@@ -765,3 +770,3 @@ return true;

*/
a => a.component.order !== null))) {
(a) => a.component.order !== null))) {
this.displayedAreas.sort((/**

@@ -772,3 +777,3 @@ * @param {?} a

*/
(a, b) => ((/** @type {?} */ (a.component.order))) - ((/** @type {?} */ (b.component.order)))));
(a, b) => (/** @type {?} */ (a.component.order)) - (/** @type {?} */ (b.component.order))));
}

@@ -793,3 +798,3 @@ // Then set real order with multiples of 2, numbers between will be used by gutters.

*/
a => a.component.size)));
(a) => a.component.size)));
switch (this.unit) {

@@ -803,3 +808,3 @@ case 'percent': {

*/
area => {
(area) => {
area.size = useUserSizes ? (/** @type {?} */ (area.component.size)) : defaultSize;

@@ -817,3 +822,3 @@ area.minSize = getAreaMinSize(area);

*/
area => {
(area) => {
area.size = area.component.size;

@@ -830,4 +835,6 @@ area.minSize = getAreaMinSize(area);

*/
a => a.component.size === null));
(a) => a.component.size === null))
// No wildcard area > Need to select one arbitrarily > first
;
// No wildcard area > Need to select one arbitrarily > first
if (wildcardSizeAreas.length === 0 && this.displayedAreas.length > 0) {

@@ -840,5 +847,5 @@ this.displayedAreas.forEach((/**

(area, i) => {
area.size = (i === 0) ? null : area.component.size;
area.minSize = (i === 0) ? null : getAreaMinSize(area);
area.maxSize = (i === 0) ? null : getAreaMaxSize(area);
area.size = i === 0 ? null : area.component.size;
area.minSize = i === 0 ? null : getAreaMinSize(area);
area.maxSize = i === 0 ? null : getAreaMaxSize(area);
}));

@@ -854,3 +861,3 @@ }

*/
area => {
(area) => {
if (area.component.size === null) {

@@ -904,4 +911,4 @@ if (alreadyGotOne === false) {

*/
area => {
area.component.setStyleFlex(0, 0, `calc( ${area.size}% - ${(/** @type {?} */ (area.size)) / 100 * sumGutterSize}px )`, (area.minSize !== null && area.minSize === area.size) ? true : false, (area.maxSize !== null && area.maxSize === area.size) ? true : false);
(area) => {
area.component.setStyleFlex(0, 0, `calc( ${area.size}% - ${((/** @type {?} */ (area.size)) / 100) * sumGutterSize}px )`, area.minSize !== null && area.minSize === area.size ? true : false, area.maxSize !== null && area.maxSize === area.size ? true : false);
}));

@@ -917,3 +924,3 @@ }

*/
area => {
(area) => {
// Area with wildcard size

@@ -936,3 +943,3 @@ if (area.size === null) {

else {
area.component.setStyleFlex(0, 0, `${area.size}px`, (area.minSize !== null && area.minSize === area.size) ? true : false, (area.maxSize !== null && area.maxSize === area.size) ? true : false);
area.component.setStyleFlex(0, 0, `${area.size}px`, area.minSize !== null && area.minSize === area.size ? true : false, area.maxSize !== null && area.maxSize === area.size ? true : false);
}

@@ -950,4 +957,6 @@ }

/** @type {?} */
const tempPoint = getPointFromEvent(event);
const tempPoint = getPointFromEvent(event)
// Be sure mouseup/touchend happened at same point as mousedown/touchstart to trigger click/dblclick
;
// Be sure mouseup/touchend happened at same point as mousedown/touchstart to trigger click/dblclick
if (this.startPoint && this.startPoint.x === tempPoint.x && this.startPoint.y === tempPoint.y) {

@@ -984,3 +993,3 @@ // If timeout in progress and new click > clearTimeout & dblClickEvent

this.startPoint = getPointFromEvent(event);
if (this.startPoint === null || this.disabled === true) {
if (this.startPoint === null || this.disabled === true || this.isWaitingClear === true) {
return;

@@ -1000,3 +1009,3 @@ }

*/
area => {
(area) => {
/** @type {?} */

@@ -1006,3 +1015,3 @@ const areaSnapshot = {

sizePixelAtStart: getElementPixelSize(area.component.elRef, this.direction),
sizePercentAtStart: (this.unit === 'percent') ? area.size : -1 // If pixel mode, anyway, will not be used.
sizePercentAtStart: this.unit === 'percent' ? area.size : -1,
};

@@ -1027,3 +1036,6 @@ if (area.order < gutterOrder) {

}));
this.snapshot.allInvolvedAreasSizePercent = [...this.snapshot.areasBeforeGutter, ...this.snapshot.areasAfterGutter].reduce((/**
this.snapshot.allInvolvedAreasSizePercent = [
...this.snapshot.areasBeforeGutter,
...this.snapshot.areasAfterGutter,
].reduce((/**
* @param {?} t

@@ -1051,3 +1063,3 @@ * @param {?} a

*/
area => area.component.lockEvents()));
(area) => area.component.lockEvents()));
this.isDragging = true;

@@ -1079,3 +1091,3 @@ this.renderer.addClass(this.elRef.nativeElement, 'as-dragging');

/** @type {?} */
let offset = (this.direction === 'horizontal') ? (this.startPoint.x - this.endPoint.x) : (this.startPoint.y - this.endPoint.y);
let offset = this.direction === 'horizontal' ? this.startPoint.x - this.endPoint.x : this.startPoint.y - this.endPoint.y;
if (this.dir === 'rtl') {

@@ -1094,6 +1106,9 @@ offset = -offset;

/** @type {?} */
let areasAfter = getGutterSideAbsorptionCapacity(this.unit, this.snapshot.areasAfterGutter, steppedOffset, this.snapshot.allAreasSizePixel);
// Each gutter side areas can't absorb all offset
let areasAfter = getGutterSideAbsorptionCapacity(this.unit, this.snapshot.areasAfterGutter, steppedOffset, this.snapshot.allAreasSizePixel)
// Each gutter side areas can't absorb all offset
;
// Each gutter side areas can't absorb all offset
if (areasBefore.remain !== 0 && areasAfter.remain !== 0) {
if (Math.abs(areasBefore.remain) === Math.abs(areasAfter.remain)) ;
if (Math.abs(areasBefore.remain) === Math.abs(areasAfter.remain)) {
}
else if (Math.abs(areasBefore.remain) > Math.abs(areasAfter.remain)) {

@@ -1124,14 +1139,18 @@ areasAfter = getGutterSideAbsorptionCapacity(this.unit, this.snapshot.areasAfterGutter, steppedOffset + areasBefore.remain, this.snapshot.allAreasSizePixel);

*/
a => a.percentAfterAbsorption !== 0 && a.percentAfterAbsorption !== a.areaSnapshot.area.minSize && a.percentAfterAbsorption !== a.areaSnapshot.area.maxSize));
(a) => a.percentAfterAbsorption !== 0 &&
a.percentAfterAbsorption !== a.areaSnapshot.area.minSize &&
a.percentAfterAbsorption !== a.areaSnapshot.area.maxSize));
if (areaToReset) {
areaToReset.percentAfterAbsorption = this.snapshot.allInvolvedAreasSizePercent - all.filter((/**
* @param {?} a
* @return {?}
*/
a => a !== areaToReset)).reduce((/**
* @param {?} total
* @param {?} a
* @return {?}
*/
(total, a) => total + a.percentAfterAbsorption), 0);
areaToReset.percentAfterAbsorption =
this.snapshot.allInvolvedAreasSizePercent -
all.filter((/**
* @param {?} a
* @return {?}
*/
(a) => a !== areaToReset)).reduce((/**
* @param {?} total
* @param {?} a
* @return {?}
*/
(total, a) => total + a.percentAfterAbsorption), 0);
}

@@ -1144,3 +1163,3 @@ }

*/
item => updateAreaSize(this.unit, item)));
(item) => updateAreaSize(this.unit, item)));
areasAfter.list.forEach((/**

@@ -1150,3 +1169,3 @@ * @param {?} item

*/
item => updateAreaSize(this.unit, item)));
(item) => updateAreaSize(this.unit, item)));
this.refreshStyleSizes();

@@ -1172,3 +1191,3 @@ this.notify('progress', this.snapshot.gutterNum);

*/
area => area.component.unlockEvents()));
(area) => area.component.unlockEvents()));
while (this.dragListeners.length > 0) {

@@ -1180,3 +1199,3 @@ /** @type {?} */

}
// Warning: Have to be before "notify('end')"
// Warning: Have to be before "notify('end')"
// because "notify('end')"" can be linked to "[size]='x'" > "build()" > "stopDragging()"

@@ -1191,2 +1210,3 @@ this.isDragging = false;

this.snapshot = null;
this.isWaitingClear = true;
// Needed to let (click)="clickGutter(...)" event run and verify if mouse moved or not

@@ -1203,2 +1223,3 @@ this.ngZone.runOutsideAngular((/**

this.endPoint = null;
this.isWaitingClear = false;
}));

@@ -1252,18 +1273,20 @@ }));

changeDetection: ChangeDetectionStrategy.OnPush,
template: `
<ng-content></ng-content>
<ng-template ngFor [ngForOf]="displayedAreas" let-index="index" let-last="last">
<div *ngIf="last === false"
#gutterEls
class="as-split-gutter"
[style.flex-basis.px]="gutterSize"
[style.order]="index*2+1"
(mousedown)="startDragging($event, index*2+1, index+1)"
(touchstart)="startDragging($event, index*2+1, index+1)"
(mouseup)="clickGutter($event, index+1)"
(touchend)="clickGutter($event, index+1)">
<div class="as-split-gutter-icon"></div>
</div>
</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}"]
template: ` <ng-content></ng-content>
<ng-template ngFor [ngForOf]="displayedAreas" let-index="index" let-last="last">
<div
*ngIf="last === false"
#gutterEls
class="as-split-gutter"
[style.flex-basis.px]="gutterSize"
[style.order]="index * 2 + 1"
(mousedown)="startDragging($event, index * 2 + 1, index + 1)"
(touchstart)="startDragging($event, index * 2 + 1, index + 1)"
(mouseup)="clickGutter($event, index + 1)"
(touchend)="clickGutter($event, index + 1)"
>
<div class="as-split-gutter-icon"></div>
</div>
</ng-template>`,
encapsulation: ViewEncapsulation.Emulated,
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 0px!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}"]
}] }

@@ -1295,2 +1318,133 @@ ];

};
if (false) {
/**
* @type {?}
* @private
*/
SplitComponent.prototype._direction;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._unit;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._gutterSize;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._gutterStep;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._restrictMove;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._useTransition;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._dir;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._gutterDblClickDuration;
/** @type {?} */
SplitComponent.prototype.dragStart;
/** @type {?} */
SplitComponent.prototype.dragEnd;
/** @type {?} */
SplitComponent.prototype.gutterClick;
/** @type {?} */
SplitComponent.prototype.gutterDblClick;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.transitionEndSubscriber;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.dragProgressSubject;
/** @type {?} */
SplitComponent.prototype.dragProgress$;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.isDragging;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.isWaitingClear;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.dragListeners;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.snapshot;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.startPoint;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.endPoint;
/** @type {?} */
SplitComponent.prototype.displayedAreas;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.hidedAreas;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.gutterEls;
/** @type {?} */
SplitComponent.prototype._clickTimeout;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.ngZone;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.elRef;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.cdRef;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.renderer;
}

@@ -1513,3 +1667,3 @@ /**

selector: 'as-split-area, [as-split-area]',
exportAs: 'asSplitArea'
exportAs: 'asSplitArea',
},] }

@@ -1532,2 +1686,61 @@ ];

};
if (false) {
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._order;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._size;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._minSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._maxSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._lockSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._visible;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.transitionListener;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.lockListeners;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.ngZone;
/** @type {?} */
SplitAreaDirective.prototype.elRef;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.renderer;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.split;
}

@@ -1545,3 +1758,3 @@ /**

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -1555,3 +1768,3 @@ }

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -1562,17 +1775,19 @@ }

{ type: NgModule, args: [{
imports: [
CommonModule
],
declarations: [
SplitComponent,
SplitAreaDirective,
],
exports: [
SplitComponent,
SplitAreaDirective,
]
imports: [CommonModule],
declarations: [SplitComponent, SplitAreaDirective],
exports: [SplitComponent, SplitAreaDirective],
},] }
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { AngularSplitModule, SplitAreaDirective, SplitComponent };
//# sourceMappingURL=angular-split.js.map

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

import { Component, ChangeDetectionStrategy, NgZone, ElementRef, ChangeDetectorRef, Renderer2, Input, Output, ViewChildren, EventEmitter, Directive, NgModule } from '@angular/core';
import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, NgZone, ElementRef, ChangeDetectorRef, Renderer2, Input, Output, ViewChildren, Directive, NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { __spread } from 'tslib';
import { Observable, Subject } from 'rxjs';
import { Subject, Observable } from 'rxjs';
import { debounceTime } from 'rxjs/operators';

@@ -40,3 +40,3 @@

var rect = ((/** @type {?} */ (elRef.nativeElement))).getBoundingClientRect();
return (direction === 'horizontal') ? rect.width : rect.height;
return direction === 'horizontal' ? rect.width : rect.height;
}

@@ -48,3 +48,3 @@ /**

function getInputBoolean(v) {
return (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
return typeof v === 'boolean' ? v : v === 'false' ? false : true;
}

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

*/
function (total, s) { return s !== null ? total + s : total; }), 0);
function (total, s) { return (s !== null ? total + s : total); }), 0);
return sizes.every((/**

@@ -183,3 +183,3 @@ * @param {?} s

if (unit === 'pixel') {
return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels);
return getAreaAbsorptionCapacityPixel(areaSnapshot, pixels, allAreasSizePixel);
}

@@ -197,10 +197,12 @@ }

/** @type {?} */
var tempPercentSize = tempPixelSize / allAreasSizePixel * 100;
var tempPercentSize = (tempPixelSize / allAreasSizePixel) * 100
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPercentSize > areaSnapshot.area.maxSize) {
// Use area.area.maxSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
var maxSizePixel = areaSnapshot.area.maxSize / 100 * allAreasSizePixel;
var maxSizePixel = (areaSnapshot.area.maxSize / 100) * allAreasSizePixel;
return {

@@ -210,3 +212,3 @@ areaSnapshot: areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.maxSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - maxSizePixel,
};

@@ -218,3 +220,3 @@ }

percentAfterAbsorption: tempPercentSize > 100 ? 100 : tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -224,7 +226,7 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPercentSize < areaSnapshot.area.minSize) {
// Use area.area.minSize as newPercentSize and return calculate pixels remaining
/** @type {?} */
var minSizePixel = areaSnapshot.area.minSize / 100 * allAreasSizePixel;
var minSizePixel = (areaSnapshot.area.minSize / 100) * allAreasSizePixel;
return {

@@ -234,3 +236,3 @@ areaSnapshot: areaSnapshot,

percentAfterAbsorption: areaSnapshot.area.minSize,
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel
pixelRemain: areaSnapshot.sizePixelAtStart + pixels - minSizePixel,
};

@@ -245,3 +247,3 @@ }

percentAfterAbsorption: 0,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -253,3 +255,3 @@ }

percentAfterAbsorption: tempPercentSize,
pixelRemain: 0
pixelRemain: 0,
};

@@ -266,6 +268,8 @@ }

/** @type {?} */
var tempPixelSize = areaSnapshot.sizePixelAtStart + pixels;
var tempPixelSize = areaSnapshot.sizePixelAtStart + pixels
// ENLARGE AREA
;
// ENLARGE AREA
if (pixels > 0) {
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
// If maxSize & newSize bigger than it > absorb to max and return remaining pixels
if (areaSnapshot.area.maxSize !== null && tempPixelSize > areaSnapshot.area.maxSize) {

@@ -276,3 +280,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize
pixelRemain: tempPixelSize - areaSnapshot.area.maxSize,
};

@@ -284,3 +288,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

@@ -290,3 +294,3 @@ }

else if (pixels < 0) {
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
// If minSize & newSize smaller than it > absorb to min and return remaining pixels
if (areaSnapshot.area.minSize !== null && tempPixelSize < areaSnapshot.area.minSize) {

@@ -297,3 +301,3 @@ return {

percentAfterAbsorption: -1,
pixelRemain: tempPixelSize - areaSnapshot.area.minSize
pixelRemain: tempPixelSize - areaSnapshot.area.minSize,
};

@@ -307,3 +311,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: pixels + areaSnapshot.sizePixelAtStart
pixelRemain: pixels + areaSnapshot.sizePixelAtStart,
};

@@ -315,3 +319,3 @@ }

percentAfterAbsorption: -1,
pixelRemain: 0
pixelRemain: 0,
};

@@ -402,2 +406,3 @@ }

this.isDragging = false;
this.isWaitingClear = false;
this.dragListeners = [];

@@ -425,5 +430,5 @@ this.snapshot = null;

function (v) {
this._direction = (v === 'vertical') ? 'vertical' : 'horizontal';
this._direction = v === 'vertical' ? 'vertical' : 'horizontal';
this.renderer.addClass(this.elRef.nativeElement, "as-" + this._direction);
this.renderer.removeClass(this.elRef.nativeElement, "as-" + ((this._direction === 'vertical') ? 'horizontal' : 'vertical'));
this.renderer.removeClass(this.elRef.nativeElement, "as-" + (this._direction === 'vertical' ? 'horizontal' : 'vertical'));
this.build(false, false);

@@ -446,5 +451,5 @@ },

function (v) {
this._unit = (v === 'pixel') ? 'pixel' : 'percent';
this._unit = v === 'pixel' ? 'pixel' : 'percent';
this.renderer.addClass(this.elRef.nativeElement, "as-" + this._unit);
this.renderer.removeClass(this.elRef.nativeElement, "as-" + ((this._unit === 'pixel') ? 'percent' : 'pixel'));
this.renderer.removeClass(this.elRef.nativeElement, "as-" + (this._unit === 'pixel' ? 'percent' : 'pixel'));
this.build(false, true);

@@ -561,3 +566,3 @@ },

function (v) {
this._dir = (v === 'rtl') ? 'rtl' : 'ltr';
this._dir = v === 'rtl' ? 'rtl' : 'ltr';
this.renderer.setAttribute(this.elRef.nativeElement, 'dir', this._dir);

@@ -595,3 +600,3 @@ },

*/
function (subscriber) { return _this.transitionEndSubscriber = subscriber; })).pipe(debounceTime(20));
function (subscriber) { return (_this.transitionEndSubscriber = subscriber); })).pipe(debounceTime(20));
},

@@ -629,3 +634,3 @@ enumerable: true,

function () {
return (this.displayedAreas.length === 0) ? 0 : this.displayedAreas.length - 1;
return this.displayedAreas.length === 0 ? 0 : this.displayedAreas.length - 1;
};

@@ -778,3 +783,3 @@ /**

*/
function (a) { return a.size === null ? '*' : a.size; }));
function (a) { return (a.size === null ? '*' : a.size); }));
};

@@ -810,3 +815,3 @@ /**

*/
function (area, i) { return area.component._size = formatedSizes[i]; }));
function (area, i) { return (area.component._size = formatedSizes[i]); }));
this.build(false, true);

@@ -842,3 +847,3 @@ return true;

*/
function (a, b) { return ((/** @type {?} */ (a.component.order))) - ((/** @type {?} */ (b.component.order))); }));
function (a, b) { return (/** @type {?} */ (a.component.order)) - (/** @type {?} */ (b.component.order)); }));
}

@@ -897,4 +902,6 @@ // Then set real order with multiples of 2, numbers between will be used by gutters.

*/
function (a) { return a.component.size === null; }));
function (a) { return a.component.size === null; }))
// No wildcard area > Need to select one arbitrarily > first
;
// No wildcard area > Need to select one arbitrarily > first
if (wildcardSizeAreas.length === 0 && this.displayedAreas.length > 0) {

@@ -907,5 +914,5 @@ this.displayedAreas.forEach((/**

function (area, i) {
area.size = (i === 0) ? null : area.component.size;
area.minSize = (i === 0) ? null : getAreaMinSize(area);
area.maxSize = (i === 0) ? null : getAreaMaxSize(area);
area.size = i === 0 ? null : area.component.size;
area.minSize = i === 0 ? null : getAreaMinSize(area);
area.maxSize = i === 0 ? null : getAreaMaxSize(area);
}));

@@ -976,3 +983,3 @@ }

function (area) {
area.component.setStyleFlex(0, 0, "calc( " + area.size + "% - " + (/** @type {?} */ (area.size)) / 100 * sumGutterSize_1 + "px )", (area.minSize !== null && area.minSize === area.size) ? true : false, (area.maxSize !== null && area.maxSize === area.size) ? true : false);
area.component.setStyleFlex(0, 0, "calc( " + area.size + "% - " + ((/** @type {?} */ (area.size)) / 100) * sumGutterSize_1 + "px )", area.minSize !== null && area.minSize === area.size ? true : false, area.maxSize !== null && area.maxSize === area.size ? true : false);
}));

@@ -1006,3 +1013,3 @@ }

else {
area.component.setStyleFlex(0, 0, area.size + "px", (area.minSize !== null && area.minSize === area.size) ? true : false, (area.maxSize !== null && area.maxSize === area.size) ? true : false);
area.component.setStyleFlex(0, 0, area.size + "px", area.minSize !== null && area.minSize === area.size ? true : false, area.maxSize !== null && area.maxSize === area.size ? true : false);
}

@@ -1026,4 +1033,6 @@ }

/** @type {?} */
var tempPoint = getPointFromEvent(event);
var tempPoint = getPointFromEvent(event)
// Be sure mouseup/touchend happened at same point as mousedown/touchstart to trigger click/dblclick
;
// Be sure mouseup/touchend happened at same point as mousedown/touchstart to trigger click/dblclick
if (this.startPoint && this.startPoint.x === tempPoint.x && this.startPoint.y === tempPoint.y) {

@@ -1067,3 +1076,3 @@ // If timeout in progress and new click > clearTimeout & dblClickEvent

this.startPoint = getPointFromEvent(event);
if (this.startPoint === null || this.disabled === true) {
if (this.startPoint === null || this.disabled === true || this.isWaitingClear === true) {
return;

@@ -1088,3 +1097,3 @@ }

sizePixelAtStart: getElementPixelSize(area.component.elRef, _this.direction),
sizePercentAtStart: (_this.unit === 'percent') ? area.size : -1 // If pixel mode, anyway, will not be used.
sizePercentAtStart: _this.unit === 'percent' ? area.size : -1,
};

@@ -1165,3 +1174,3 @@ if (area.order < gutterOrder) {

/** @type {?} */
var offset = (this.direction === 'horizontal') ? (this.startPoint.x - this.endPoint.x) : (this.startPoint.y - this.endPoint.y);
var offset = this.direction === 'horizontal' ? this.startPoint.x - this.endPoint.x : this.startPoint.y - this.endPoint.y;
if (this.dir === 'rtl') {

@@ -1180,6 +1189,9 @@ offset = -offset;

/** @type {?} */
var areasAfter = getGutterSideAbsorptionCapacity(this.unit, this.snapshot.areasAfterGutter, steppedOffset, this.snapshot.allAreasSizePixel);
// Each gutter side areas can't absorb all offset
var areasAfter = getGutterSideAbsorptionCapacity(this.unit, this.snapshot.areasAfterGutter, steppedOffset, this.snapshot.allAreasSizePixel)
// Each gutter side areas can't absorb all offset
;
// Each gutter side areas can't absorb all offset
if (areasBefore.remain !== 0 && areasAfter.remain !== 0) {
if (Math.abs(areasBefore.remain) === Math.abs(areasAfter.remain)) ;
if (Math.abs(areasBefore.remain) === Math.abs(areasAfter.remain)) {
}
else if (Math.abs(areasBefore.remain) > Math.abs(areasAfter.remain)) {

@@ -1210,14 +1222,20 @@ areasAfter = getGutterSideAbsorptionCapacity(this.unit, this.snapshot.areasAfterGutter, steppedOffset + areasBefore.remain, this.snapshot.allAreasSizePixel);

*/
function (a) { return a.percentAfterAbsorption !== 0 && a.percentAfterAbsorption !== a.areaSnapshot.area.minSize && a.percentAfterAbsorption !== a.areaSnapshot.area.maxSize; }));
function (a) {
return a.percentAfterAbsorption !== 0 &&
a.percentAfterAbsorption !== a.areaSnapshot.area.minSize &&
a.percentAfterAbsorption !== a.areaSnapshot.area.maxSize;
}));
if (areaToReset_1) {
areaToReset_1.percentAfterAbsorption = this.snapshot.allInvolvedAreasSizePercent - all.filter((/**
* @param {?} a
* @return {?}
*/
function (a) { return a !== areaToReset_1; })).reduce((/**
* @param {?} total
* @param {?} a
* @return {?}
*/
function (total, a) { return total + a.percentAfterAbsorption; }), 0);
areaToReset_1.percentAfterAbsorption =
this.snapshot.allInvolvedAreasSizePercent -
all.filter((/**
* @param {?} a
* @return {?}
*/
function (a) { return a !== areaToReset_1; })).reduce((/**
* @param {?} total
* @param {?} a
* @return {?}
*/
function (total, a) { return total + a.percentAfterAbsorption; }), 0);
}

@@ -1269,3 +1287,3 @@ }

}
// Warning: Have to be before "notify('end')"
// Warning: Have to be before "notify('end')"
// because "notify('end')"" can be linked to "[size]='x'" > "build()" > "stopDragging()"

@@ -1280,2 +1298,3 @@ this.isDragging = false;

this.snapshot = null;
this.isWaitingClear = true;
// Needed to let (click)="clickGutter(...)" event run and verify if mouse moved or not

@@ -1292,2 +1311,3 @@ this.ngZone.runOutsideAngular((/**

_this.endPoint = null;
_this.isWaitingClear = false;
}));

@@ -1349,4 +1369,5 @@ }));

changeDetection: 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}"]
template: " <ng-content></ng-content>\n <ng-template ngFor [ngForOf]=\"displayedAreas\" let-index=\"index\" let-last=\"last\">\n <div\n *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 >\n <div class=\"as-split-gutter-icon\"></div>\n </div>\n </ng-template>",
encapsulation: ViewEncapsulation.Emulated,
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 0px!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}"]
}] }

@@ -1380,2 +1401,133 @@ ];

}());
if (false) {
/**
* @type {?}
* @private
*/
SplitComponent.prototype._direction;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._unit;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._gutterSize;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._gutterStep;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._restrictMove;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._useTransition;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._dir;
/**
* @type {?}
* @private
*/
SplitComponent.prototype._gutterDblClickDuration;
/** @type {?} */
SplitComponent.prototype.dragStart;
/** @type {?} */
SplitComponent.prototype.dragEnd;
/** @type {?} */
SplitComponent.prototype.gutterClick;
/** @type {?} */
SplitComponent.prototype.gutterDblClick;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.transitionEndSubscriber;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.dragProgressSubject;
/** @type {?} */
SplitComponent.prototype.dragProgress$;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.isDragging;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.isWaitingClear;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.dragListeners;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.snapshot;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.startPoint;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.endPoint;
/** @type {?} */
SplitComponent.prototype.displayedAreas;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.hidedAreas;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.gutterEls;
/** @type {?} */
SplitComponent.prototype._clickTimeout;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.ngZone;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.elRef;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.cdRef;
/**
* @type {?}
* @private
*/
SplitComponent.prototype.renderer;
}

@@ -1641,3 +1793,3 @@ /**

selector: 'as-split-area, [as-split-area]',
exportAs: 'asSplitArea'
exportAs: 'asSplitArea',
},] }

@@ -1662,2 +1814,61 @@ ];

}());
if (false) {
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._order;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._size;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._minSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._maxSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._lockSize;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype._visible;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.transitionListener;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.lockListeners;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.ngZone;
/** @type {?} */
SplitAreaDirective.prototype.elRef;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.renderer;
/**
* @type {?}
* @private
*/
SplitAreaDirective.prototype.split;
}

@@ -1680,3 +1891,3 @@ /**

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -1693,3 +1904,3 @@ };

ngModule: AngularSplitModule,
providers: []
providers: [],
};

@@ -1699,13 +1910,5 @@ };

{ type: NgModule, args: [{
imports: [
CommonModule
],
declarations: [
SplitComponent,
SplitAreaDirective,
],
exports: [
SplitComponent,
SplitAreaDirective,
]
imports: [CommonModule],
declarations: [SplitComponent, SplitAreaDirective],
exports: [SplitComponent, SplitAreaDirective],
},] }

@@ -1716,3 +1919,13 @@ ];

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
export { AngularSplitModule, SplitAreaDirective, SplitComponent };
//# sourceMappingURL=angular-split.js.map

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

private isDragging;
private isWaitingClear;
private dragListeners;

@@ -68,0 +69,0 @@ private snapshot;

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

import { SplitAreaDirective } from "./directive/splitArea.directive";
import { SplitAreaDirective } from './directive/splitArea.directive';
export interface IPoint {

@@ -3,0 +3,0 @@ x: number;

import { ModuleWithProviders } from '@angular/core';
export declare class AngularSplitModule {
static forRoot(): ModuleWithProviders;
static forChild(): ModuleWithProviders;
static forRoot(): ModuleWithProviders<AngularSplitModule>;
static forChild(): ModuleWithProviders<AngularSplitModule>;
}
{
"name": "angular-split",
"version": "3.0.3",
"version": "4.0.0-beta.0",
"description": "Angular UI library to split views and allow dragging to resize areas using CSS flexbox layout.",

@@ -13,2 +13,9 @@ "author": "bertrandg",

},
"maintainers": [
{
"email": "beeman@beeman.nl",
"name": "Bram Borggreve",
"url": "https://github.com/beeman"
}
],
"homepage": "https://bertrandg.github.io/angular-split/",

@@ -15,0 +22,0 @@ "keywords": [

export { AngularSplitModule } from './lib/module';
export { SplitComponent } from './lib/component/split.component';
export { SplitAreaDirective } from './lib/directive/splitArea.directive';
export { IOutputData, IOutputAreaSizes } from './lib/interface';
# angular-split [![npm latest version](https://img.shields.io/npm/v/angular-split/latest.svg?style=flat-square)](https://www.npmjs.com/package/angular-split) [![NPM next version](https://img.shields.io/npm/v/angular-split/next.svg?style=flat-square)](https://www.npmjs.com/package/angular-split) [![Travis build](https://img.shields.io/travis/com/bertrandg/angular-split/master.svg?style=flat-square&label=Cypress+E2E+tests)](https://travis-ci.com/bertrandg/angular-split)
Angular UI library to split views and allow dragging to resize areas using CSS flexbox layout.

@@ -8,2 +9,3 @@

### Credits
Crossbrowser testing sponsored by [Browser Stack](https://www.browserstack.com)

@@ -10,0 +12,0 @@ [<img src="https://camo.githubusercontent.com/a7b268f2785656ab3ca7b1cbb1633ee5affceb8f/68747470733a2f2f64677a6f7139623561736a67312e636c6f756466726f6e742e6e65742f70726f64756374696f6e2f696d616765732f6c61796f75742f6c6f676f2d6865616465722e706e67" alt="Browser Stack" height="31px" style="background: cornflowerblue;">](https://www.browserstack.com)

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 not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc