Socket
Socket
Sign inDemoInstall

npn-slider

Package Overview
Dependencies
7
Maintainers
1
Versions
17
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.1.3 to 1.2.0

esm2015/lib/slider-handler.enum.js

2

bundles/npn-slider.umd.min.js

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

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/platform-browser")):"function"==typeof define&&define.amd?define("npn-slider",["exports","@angular/core","@angular/platform-browser"],t):t(e["npn-slider"]={},e.ng.core,e.ng.platformBrowser)}(this,function(e,s,t){"use strict";var n=function(e,t){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)t.hasOwnProperty(i)&&(e[i]=t[i])})(e,t)};var i=function(){function e(){}return e.prototype.isNumberArray=function(e){return e.filter(function(e){return!isNaN(e)}).length===e.length},e.prototype.isNullOrEmpty=function(e){return e===undefined||null===e||""===e},e.prototype.findNextValidStepValue=function(e,t){for(var i=[],s=Math.sqrt(e),n=0;n<s;n++)e%n==0&&(e/n===n?i.push(n):(i.push(n),i.push(e/n)));i.sort(function(e,t){return(e=Number(e))<(t=Number(t))?-1:t<e?1:0});for(n=i.length-1;0<=n;n--)if(t>i[n]){t=i[n];break}return t},e}(),a=function(i){function e(e){var t=i.call(this)||this;return t.el=e,t.sliderModel=[0,0,0],t.step=1,t.sliderWidth=0,t.totalDiff=0,t.startClientX=0,t.startPleft=0,t.startPRight=0,t.sliderInitiated=!1,t.initValues=[],t.currentValues=[0,0],t.handlerX=[0,0],t.isHandlerActive=!1,t.isTouchEventStart=!1,t.isMouseEventStart=!1,t.currentHandlerIndex=0,t.stepIndicatorPositions=[],t.isDisabled=!1,t.showStepIndicator=!1,t.onChange=new s.EventEmitter,t}return function(e,t){function i(){this.constructor=e}n(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}(e,i),Object.defineProperty(e.prototype,"setMinValues",{set:function(e){isNaN(e)||(this.minValue=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setMaxValues",{set:function(e){isNaN(e)||(this.maxValue=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setMinSelectedValues",{set:function(e){!isNaN(e)&&this.isNullOrEmpty(this.minSelected)&&(this.minSelected=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setMaxSelectedValues",{set:function(e){!isNaN(e)&&this.isNullOrEmpty(this.maxSelected)&&(this.maxSelected=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"stepValue",{set:function(e){isNaN(e)||(this.step=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setDisabled",{set:function(e){this.isDisabled="true"===e||"disabled"===e},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.initializeSlider()},e.prototype.ngOnChanges=function(e){e.setMinSelectedValues||e.setMaxSelectedValues||!this.sliderInitiated||this.resetModel()},e.prototype.initializeSlider=function(){try{this.sliderWidth=this.el.nativeElement.children[0].children[0].offsetWidth,this.resetModel(),this.sliderInitiated=!0}catch(e){console.error(e)}},e.prototype.resetModel=function(){if(this.validateSliderValues(),this.sliderModel=[this.currentValues[0]-this.initValues[0],this.currentValues[1]-this.currentValues[0],this.initValues[1]-this.currentValues[1]],this.totalDiff=this.sliderModel.reduce(function(e,t){return e+t},0),this.totalDiff%this.step!=0){var e=this.findNextValidStepValue(this.totalDiff,this.step);console.warn('Invalid step value "'+this.step+'" : and took "'+e+'" as default step'),this.step=e}this.sliderWidth/(this.totalDiff/this.step)<10&&console.error("'step' value is too small compared to min & max value difference and slider width.\n Slider might not work properly!. Provide slight large value for 'step'"),this.initializeStepIndicator(),this.setHandlerPosition()},e.prototype.validateSliderValues=function(){this.isNullOrEmpty(this.minValue)||this.isNullOrEmpty(this.maxValue)?(this.updateInitValues([0,0]),this.updateCurrentValue([0,0],!0)):this.minValue>this.maxValue?(this.updateInitValues([0,0]),this.updateCurrentValue([0,0],!0)):(this.initValues=[this.minValue,this.maxValue],this.minSelected=this.isNullOrEmpty(this.minSelected)?0:this.minSelected,this.maxSelected=this.isNullOrEmpty(this.maxSelected)?0:this.maxSelected,(this.minSelected<this.minValue||this.minSelected>this.maxValue)&&(this.minSelected=this.minValue),(this.maxSelected<this.minValue||this.maxSelected>this.maxValue)&&(this.maxSelected=this.maxValue),this.minSelected>this.maxSelected&&(this.minSelected=this.minValue,this.maxSelected=this.maxValue),this.updateCurrentValue([this.minSelected,this.maxSelected],!0))},e.prototype.initializeStepIndicator=function(){if(this.showStepIndicator){this.stepIndicatorPositions=[];var e=this.totalDiff/this.step;if(10<=this.sliderWidth/e)for(var t=this.sliderWidth/e,i=t;this.stepIndicatorPositions.length<e-1;)this.stepIndicatorPositions.push(+i.toFixed(2)),i+=t}},e.prototype.updateCurrentValue=function(e,t){void 0===t&&(t=!1),this.minSelected=this.currentValues[0]=e[0],this.maxSelected=this.currentValues[1]=e[1],t||this.onChange.emit(this.currentValues)},e.prototype.updateInitValues=function(e){this.minValue=this.initValues[0]=e[0],this.maxValue=this.initValues[1]=e[1]},e.prototype.setHandlerPosition=function(){var e=0;this.updateCurrentValue([this.initValues[0]+this.sliderModel[0],this.initValues[1]-this.sliderModel[2]]);for(var t=0,i=this.sliderModel.length-1;t<i;t++)e+=this.sliderModel[t],this.handlerX[t]=e/this.totalDiff*100},e.prototype.setModelValue=function(e,t){1<this.step&&(t=Math.round(t/this.step)*this.step),this.sliderModel[e]=t},e.prototype.setHandlerActiveOff=function(){this.isMouseEventStart=!1,this.isTouchEventStart=!1,this.isHandlerActive=!1},e.prototype.setHandlerActive=function(e,t){e.preventDefault(),this.isDisabled||(e.clientX?(this.startClientX=e.clientX,this.isMouseEventStart=!0,this.isTouchEventStart=!1):e.deltaX&&(this.startClientX=e.deltaX,this.isTouchEventStart=!0,this.isMouseEventStart=!1),(this.isMouseEventStart||this.isTouchEventStart)&&(this.currentHandlerIndex=t,this.startPleft=this.sliderModel[t],this.startPRight=this.sliderModel[t+1],this.isHandlerActive=!0))},e.prototype.handlerSliding=function(e){if(this.isMouseEventStart&&e.clientX||this.isTouchEventStart&&e.deltaX){var t=Math.round(((e.clientX||e.deltaX)-this.startClientX)/this.sliderWidth*this.totalDiff),i=this.startPleft+t,s=this.startPRight-t;0<=i&&0<=s&&(this.setModelValue(this.currentHandlerIndex,i),this.setModelValue(this.currentHandlerIndex+1,s),this.setHandlerPosition())}},e.decorators=[{type:s.Component,args:[{selector:"npn-slider",template:'\x3c!--npn-slider template--\x3e\n<div class="slider" [class.disabled]="isDisabled">\n <div class="bar" (mousemove)="handlerSliding($event)"\n (panmove)="handlerSliding($event)">\n <span class="left-handle"\n [ngClass]="{\'active\':isHandlerActive&&currentHandlerIndex==0,\'last-active\':currentHandlerIndex==0}"\n [style.left.%]="handlerX[0]"\n (mousedown)="setHandlerActive($event,0)"\n (panstart)="setHandlerActive($event,0)">\n <span class="handle-tooltip">{{currentValues[0]}}</span>\n </span>\n <div class="filler">\n <div class="step-indicators">\n <span *ngFor="let stepPos of stepIndicatorPositions" [style.left.px]="stepPos"></span>\n </div>\n <span [style.left.%]="handlerX[0]" [style.width.%]="handlerX[1] - handlerX[0]"></span>\n </div>\n <span class="right-handle"\n [ngClass]="{\'active\':isHandlerActive&&currentHandlerIndex==1, \'last-active\':currentHandlerIndex==1}"\n [style.left.%]="handlerX[1]"\n (mousedown)="setHandlerActive($event,1)"\n (panstart)="setHandlerActive($event,1)">\n <span class="handle-tooltip">{{currentValues[1]}}</span>\n </span>\n </div>\n <div class="values">\n <span>{{initValues[0]}}</span>\n <span>{{initValues[1]}}</span>\n </div>\n</div>\n',styles:['.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:"";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:"";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}']}]}],e.ctorParameters=function(){return[{type:s.ElementRef}]},e.propDecorators={setMinValues:[{type:s.Input,args:["min"]}],setMaxValues:[{type:s.Input,args:["max"]}],setMinSelectedValues:[{type:s.Input,args:["minSelected"]}],setMaxSelectedValues:[{type:s.Input,args:["maxSelected"]}],stepValue:[{type:s.Input,args:["step"]}],showStepIndicator:[{type:s.Input}],setDisabled:[{type:s.Input,args:["disabled"]}],onChange:[{type:s.Output}],setHandlerActiveOff:[{type:s.HostListener,args:["document:mouseup"]},{type:s.HostListener,args:["document:panend"]}]},e}(i),l=function(){function e(){}return e.decorators=[{type:s.NgModule,args:[{imports:[t.BrowserModule],declarations:[a],exports:[a]}]}],e}();e.NpnSliderComponent=a,e.NpnSliderModule=l,e.ɵa=i,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/platform-browser")):"function"==typeof define&&define.amd?define("npn-slider",["exports","@angular/core","@angular/platform-browser"],t):t(e["npn-slider"]={},e.ng.core,e.ng.platformBrowser)}(this,function(e,s,t){"use strict";var n=function(e,t){return(n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)t.hasOwnProperty(i)&&(e[i]=t[i])})(e,t)};var i=function(){function e(){}return e.prototype.isNumberArray=function(e){return!(!e||!e.length||e.filter(function(e){return!isNaN(e)}).length!==e.length)},e.prototype.isNullOrEmpty=function(e){return e===undefined||null===e||""===e},e.prototype.toBoolean=function(e){for(var t=[],i=1;i<arguments.length;i++)t[i-1]=arguments[i];return""===e||"true"===e||-1!==t.indexOf(e)},e.prototype.findNextValidStepValue=function(e,t){for(var i=[],s=[],n=Math.sqrt(e),l=-1,a=0;a<n;a++)e%a==0&&(e/a===a?i.push(a):(i.push(a),s.push(e/a)));for(a=0;a<s.length;a++)if(t>s[a]){l=s[a];break}if(-1===l)for(a=i.length-1;0<=a;a--)if(t>i[a]){l=i[a];break}return-1===l?1:l},e}(),l={left:0,right:1};l[l.left]="left",l[l.right]="right";var a=function(i){function e(e){var t=i.call(this)||this;return t.el=e,t.sliderModel=[0,0,0],t.step=1,t.sliderWidth=0,t.totalDiff=0,t.startClientX=0,t.startPleft=0,t.startPRight=0,t.sliderInitiated=!1,t.initValues=[],t.currentValues=[0,0],t.handlerX=[0,0],t.isHandlerActive=!1,t.isTouchEventStart=!1,t.isMouseEventStart=!1,t.currentHandlerIndex=0,t.stepIndicatorPositions=[],t.isDisabled=!1,t.hideTooltip=!1,t.hideValues=!1,t.handlerIndex=l,t.showStepIndicator=!1,t.multiRange=!0,t.onChange=new s.EventEmitter,t}return function(e,t){function i(){this.constructor=e}n(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}(e,i),Object.defineProperty(e.prototype,"setMinValues",{set:function(e){isNaN(e)||(this.minValue=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setMaxValues",{set:function(e){isNaN(e)||(this.maxValue=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setMinSelectedValues",{set:function(e){isNaN(e)||this.minSelected===Number(e)||(this.minSelected=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setMaxSelectedValues",{set:function(e){isNaN(e)||this.maxSelected===Number(e)||(this.maxSelected=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"stepValue",{set:function(e){isNaN(e)||(this.step=Number(e))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setHideTooltip",{set:function(e){this.hideTooltip=this.toBoolean(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setHideValues",{set:function(e){this.hideValues=this.toBoolean(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setDisabled",{set:function(e){this.isDisabled=this.toBoolean(e,"disabled")},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.initializeSlider()},e.prototype.ngOnChanges=function(e){if(this.sliderInitiated){if(!this.isNullOrEmpty(e.setMinSelectedValues)&&e.setMinSelectedValues.previousValue===e.setMinSelectedValues.currentValue)return;if(!this.isNullOrEmpty(e.setMaxSelectedValues)&&e.setMaxSelectedValues.previousValue===e.setMaxSelectedValues.currentValue)return;this.resetModel()}},e.prototype.initializeSlider=function(){try{this.sliderWidth=this.el.nativeElement.children[0].children[0].offsetWidth,this.resetModel(),this.sliderInitiated=!0}catch(e){console.error(e)}},e.prototype.resetModel=function(){if(this.validateSliderValues(),this.sliderModel=[this.currentValues[0]-this.initValues[0],this.currentValues[1]-this.currentValues[0],this.initValues[1]-this.currentValues[1]],this.totalDiff=this.sliderModel.reduce(function(e,t){return e+t},0),this.totalDiff%this.step!=0){var e=this.findNextValidStepValue(this.totalDiff,this.step);console.warn('Invalid step value "'+this.step+'" : and took "'+e+'" as default step'),this.step=e}this.initializeStepIndicator(),this.setHandlerPosition()},e.prototype.validateSliderValues=function(){this.isNullOrEmpty(this.minValue)||this.isNullOrEmpty(this.maxValue)?(this.updateInitValues([0,0]),this.updateCurrentValue([0,0],!0)):this.minValue>this.maxValue?(this.updateInitValues([0,0]),this.updateCurrentValue([0,0],!0)):(this.initValues=[this.minValue,this.maxValue],this.minSelected=this.isNullOrEmpty(this.minSelected)?0:this.minSelected,this.maxSelected=this.isNullOrEmpty(this.maxSelected)?0:this.maxSelected,(this.minSelected<this.minValue||this.minSelected>this.maxValue)&&(this.minSelected=this.minValue),(this.maxSelected<this.minValue||this.maxSelected>this.maxValue)&&(this.maxSelected=this.maxValue),this.minSelected>this.maxSelected&&(this.minSelected=this.minValue,this.maxSelected=this.maxValue),this.updateCurrentValue([this.minSelected,this.maxSelected],!0))},e.prototype.initializeStepIndicator=function(){if(this.showStepIndicator){this.stepIndicatorPositions.length=0;var e=this.totalDiff/this.step;if(10<=this.sliderWidth/e)for(var t=this.sliderWidth/e,i=t;this.stepIndicatorPositions.length<e-1;)this.stepIndicatorPositions.push(+i.toFixed(2)),i+=t;else console.warn("As 'step' value is too small compared to min & max value difference and slider width,\n Step Indicator can't be displayed!. Provide slight large value for 'step'")}else this.stepIndicatorPositions.length=0},e.prototype.updateCurrentValue=function(e,t){void 0===t&&(t=!1),this.minSelected=this.currentValues[0]=e[0],this.maxSelected=this.currentValues[1]=e[1],t||this.onChange.emit(this.multiRange?this.currentValues:[this.currentValues[0]])},e.prototype.updateInitValues=function(e){this.minValue=this.initValues[0]=e[0],this.maxValue=this.initValues[1]=e[1]},e.prototype.setHandlerPosition=function(){var e=0;this.updateCurrentValue([this.initValues[0]+this.sliderModel[0],this.initValues[1]-this.sliderModel[2]]);for(var t=0,i=this.sliderModel.length-1;t<i;t++)e+=this.sliderModel[t],this.handlerX[t]=e/this.totalDiff*100},e.prototype.setModelValue=function(e,t){1<this.step&&(t=Math.round(t/this.step)*this.step),this.sliderModel[e]=t},e.prototype.setHandlerActiveOff=function(){this.isMouseEventStart=!1,this.isTouchEventStart=!1,this.isHandlerActive=!1},e.prototype.setHandlerActive=function(e,t){e.preventDefault(),this.isDisabled||(this.isNullOrEmpty(e.clientX)?this.isNullOrEmpty(e.deltaX)||(this.startClientX=e.deltaX,this.isTouchEventStart=!0,this.isMouseEventStart=!1):(this.startClientX=e.clientX,this.isMouseEventStart=!0,this.isTouchEventStart=!1),(this.isMouseEventStart||this.isTouchEventStart)&&(this.currentHandlerIndex=t,this.startPleft=this.sliderModel[t],this.startPRight=this.sliderModel[t+1],this.isHandlerActive=!0))},e.prototype.handlerSliding=function(e){if(this.isMouseEventStart&&e.clientX||this.isTouchEventStart&&e.deltaX){var t=Math.round(((e.clientX||e.deltaX)-this.startClientX)/this.sliderWidth*this.totalDiff),i=this.startPleft+t,s=this.startPRight-t;0<=i&&0<=s&&(this.setModelValue(this.currentHandlerIndex,i),this.setModelValue(this.currentHandlerIndex+1,s),this.setHandlerPosition())}},e.decorators=[{type:s.Component,args:[{selector:"npn-slider",template:'\x3c!--npn-slider template--\x3e\n<div class="slider" [class.disabled]="isDisabled">\n <div class="bar" (mousemove)="handlerSliding($event)" (panmove)="handlerSliding($event)">\n <span class="left-handle" [ngClass]="{\'active\': isHandlerActive && currentHandlerIndex === handlerIndex.left,\n \'last-active\': currentHandlerIndex === handlerIndex.left\n }"\n [style.left.%]="handlerX[handlerIndex.left]" (mousedown)="setHandlerActive($event, handlerIndex.left)" (panstart)="setHandlerActive($event, handlerIndex.left)">\n <span *ngIf="!hideTooltip" class="handle-tooltip">{{currentValues[handlerIndex.left]}}</span>\n </span>\n <div class="filler">\n <div class="step-indicators">\n <span *ngFor="let stepPos of stepIndicatorPositions" [style.left.px]="stepPos"></span>\n </div>\n <span *ngIf="multiRange" [style.left.%]="handlerX[0]" [style.width.%]="handlerX[handlerIndex.right] - handlerX[handlerIndex.left]"></span>\n <span *ngIf="!multiRange" [style.left.%]="0" [style.width.%]="handlerX[0]"></span>\n </div>\n <span *ngIf="multiRange" class="right-handle" [ngClass]="{\'active\': isHandlerActive && currentHandlerIndex === handlerIndex.right,\n \'last-active\': currentHandlerIndex === handlerIndex.right\n }"\n [style.left.%]="handlerX[handlerIndex.right]" (mousedown)="setHandlerActive($event, handlerIndex.right)"\n (panstart)="setHandlerActive($event, handlerIndex.right)">\n <span *ngIf="!hideTooltip" class="handle-tooltip">{{currentValues[handlerIndex.right]}}</span>\n </span>\n </div>\n <div class="values" *ngIf="!hideValues">\n <span>{{initValues[handlerIndex.left]}}</span>\n <span>{{initValues[handlerIndex.right]}}</span>\n </div>\n</div>\n',styles:['.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:"";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:"";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}']}]}],e.ctorParameters=function(){return[{type:s.ElementRef}]},e.propDecorators={setMinValues:[{type:s.Input,args:["min"]}],setMaxValues:[{type:s.Input,args:["max"]}],setMinSelectedValues:[{type:s.Input,args:["minSelected"]}],setMaxSelectedValues:[{type:s.Input,args:["maxSelected"]}],stepValue:[{type:s.Input,args:["step"]}],showStepIndicator:[{type:s.Input}],multiRange:[{type:s.Input}],setHideTooltip:[{type:s.Input,args:["hide-tooltip"]}],setHideValues:[{type:s.Input,args:["hide-values"]}],setDisabled:[{type:s.Input,args:["disabled"]}],onChange:[{type:s.Output}],setHandlerActiveOff:[{type:s.HostListener,args:["document:mouseup"]},{type:s.HostListener,args:["document:panend"]}]},e}(i),r=function(){function e(){}return e.decorators=[{type:s.NgModule,args:[{imports:[t.BrowserModule],declarations:[a],exports:[a]}]}],e}();e.NpnSliderComponent=a,e.NpnSliderModule=r,e.ɵa=i,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=npn-slider.umd.min.js.map

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

import { Utilities } from './utilities';
import { SliderHandlerEnum } from './slider-handler.enum';
export class NpnSliderComponent extends Utilities {

@@ -32,3 +33,7 @@ /**

this.isDisabled = false;
this.hideTooltip = false;
this.hideValues = false;
this.handlerIndex = SliderHandlerEnum;
this.showStepIndicator = false;
this.multiRange = true;
this.onChange = new EventEmitter();

@@ -59,3 +64,3 @@ }

set setMinSelectedValues(value) {
if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {
if (!isNaN(value) && this.minSelected !== Number(value)) {
this.minSelected = Number(value);

@@ -69,3 +74,3 @@ }

set setMaxSelectedValues(value) {
if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {
if (!isNaN(value) && this.maxSelected !== Number(value)) {
this.maxSelected = Number(value);

@@ -87,4 +92,18 @@ }

*/
set setHideTooltip(value) {
this.hideTooltip = this.toBoolean(value);
}
/**
* @param {?} value
* @return {?}
*/
set setHideValues(value) {
this.hideValues = this.toBoolean(value);
}
/**
* @param {?} value
* @return {?}
*/
set setDisabled(value) {
this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;
this.isDisabled = this.toBoolean(value, 'disabled');
}

@@ -102,3 +121,11 @@ /**

ngOnChanges(changes) {
if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {
if (this.sliderInitiated) {
if (!this.isNullOrEmpty(changes["setMinSelectedValues"])
&& changes["setMinSelectedValues"].previousValue === changes["setMinSelectedValues"].currentValue) {
return;
}
if (!this.isNullOrEmpty(changes["setMaxSelectedValues"])
&& changes["setMaxSelectedValues"].previousValue === changes["setMaxSelectedValues"].currentValue) {
return;
}
this.resetModel();

@@ -139,6 +166,2 @@ }

}
if (this.sliderWidth / (this.totalDiff / this.step) < 10) {
console.error(`'step' value is too small compared to min & max value difference and slider width.
Slider might not work properly!. Provide slight large value for 'step'`);
}
this.initializeStepIndicator();

@@ -184,3 +207,3 @@ this.setHandlerPosition();

if (this.showStepIndicator) {
this.stepIndicatorPositions = [];
this.stepIndicatorPositions.length = 0;
const /** @type {?} */ numOfStepIndicators = this.totalDiff / this.step;

@@ -195,3 +218,10 @@ if (this.sliderWidth / numOfStepIndicators >= 10) {

}
else {
console.warn(`As 'step' value is too small compared to min & max value difference and slider width,
Step Indicator can't be displayed!. Provide slight large value for 'step'`);
}
}
else {
this.stepIndicatorPositions.length = 0;
}
}

@@ -207,3 +237,3 @@ /**

if (!privateChange) {
this.onChange.emit(this.currentValues);
this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);
}

@@ -262,3 +292,3 @@ }

if (!this.isDisabled) {
if (event.clientX) {
if (!this.isNullOrEmpty(event.clientX)) {
this.startClientX = event.clientX;

@@ -268,3 +298,3 @@ this.isMouseEventStart = true;

}
else if (event.deltaX) {
else if (!this.isNullOrEmpty(event.deltaX)) {
this.startClientX = event.deltaX;

@@ -304,32 +334,31 @@ this.isTouchEventStart = true;

<div class="slider" [class.disabled]="isDisabled">
<div class="bar" (mousemove)="handlerSliding($event)"
(panmove)="handlerSliding($event)">
<span class="left-handle"
[ngClass]="{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}"
[style.left.%]="handlerX[0]"
(mousedown)="setHandlerActive($event,0)"
(panstart)="setHandlerActive($event,0)">
<span class="handle-tooltip">{{currentValues[0]}}</span>
<div class="bar" (mousemove)="handlerSliding($event)" (panmove)="handlerSliding($event)">
<span class="left-handle" [ngClass]="{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,
'last-active': currentHandlerIndex === handlerIndex.left
}"
[style.left.%]="handlerX[handlerIndex.left]" (mousedown)="setHandlerActive($event, handlerIndex.left)" (panstart)="setHandlerActive($event, handlerIndex.left)">
<span *ngIf="!hideTooltip" class="handle-tooltip">{{currentValues[handlerIndex.left]}}</span>
</span>
<div class="filler">
<div class="step-indicators">
<span *ngFor="let stepPos of stepIndicatorPositions" [style.left.px]="stepPos"></span>
<span *ngFor="let stepPos of stepIndicatorPositions" [style.left.px]="stepPos"></span>
</div>
<span [style.left.%]="handlerX[0]" [style.width.%]="handlerX[1] - handlerX[0]"></span>
<span *ngIf="multiRange" [style.left.%]="handlerX[0]" [style.width.%]="handlerX[handlerIndex.right] - handlerX[handlerIndex.left]"></span>
<span *ngIf="!multiRange" [style.left.%]="0" [style.width.%]="handlerX[0]"></span>
</div>
<span class="right-handle"
[ngClass]="{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}"
[style.left.%]="handlerX[1]"
(mousedown)="setHandlerActive($event,1)"
(panstart)="setHandlerActive($event,1)">
<span class="handle-tooltip">{{currentValues[1]}}</span>
<span *ngIf="multiRange" class="right-handle" [ngClass]="{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,
'last-active': currentHandlerIndex === handlerIndex.right
}"
[style.left.%]="handlerX[handlerIndex.right]" (mousedown)="setHandlerActive($event, handlerIndex.right)"
(panstart)="setHandlerActive($event, handlerIndex.right)">
<span *ngIf="!hideTooltip" class="handle-tooltip">{{currentValues[handlerIndex.right]}}</span>
</span>
</div>
<div class="values">
<span>{{initValues[0]}}</span>
<span>{{initValues[1]}}</span>
<div class="values" *ngIf="!hideValues">
<span>{{initValues[handlerIndex.left]}}</span>
<span>{{initValues[handlerIndex.right]}}</span>
</div>
</div>
`,
styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:"";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:"";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]
styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:"";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:"";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]
},] },

@@ -348,2 +377,5 @@ ];

showStepIndicator: [{ type: Input }],
multiRange: [{ type: Input }],
setHideTooltip: [{ type: Input, args: ['hide-tooltip',] }],
setHideValues: [{ type: Input, args: ['hide-values',] }],
setDisabled: [{ type: Input, args: ['disabled',] }],

@@ -397,4 +429,12 @@ onChange: [{ type: Output }],

/** @type {?} */
NpnSliderComponent.prototype.hideTooltip;
/** @type {?} */
NpnSliderComponent.prototype.hideValues;
/** @type {?} */
NpnSliderComponent.prototype.handlerIndex;
/** @type {?} */
NpnSliderComponent.prototype.showStepIndicator;
/** @type {?} */
NpnSliderComponent.prototype.multiRange;
/** @type {?} */
NpnSliderComponent.prototype.onChange;

@@ -405,2 +445,2 @@ /** @type {?} */

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npn-slider.component.js","sourceRoot":"ng://npn-slider/","sources":["lib/npn-slider.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EACrC,UAAU,EAAU,YAAY,EAA4B,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAqCxC,MAAM,yBAA0B,SAAQ,SAAS;;;;IAwB/C,YAAoB,EAAc;QAChC,KAAK,EAAE,CAAC;QADU,OAAE,GAAF,EAAE,CAAY;2BAvBZ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;oBAChB,CAAC;2BACM,CAAC;yBACH,CAAC;4BACE,CAAC;0BACH,CAAC;2BACA,CAAC;+BAKG,KAAK;0BAED,EAAE;6BACC,CAAC,CAAC,EAAE,CAAC,CAAC;wBACX,CAAC,CAAC,EAAE,CAAC,CAAC;+BACT,KAAK;iCACH,KAAK;iCACL,KAAK;mCACH,CAAC;sCACE,EAAE;0BACd,KAAK;iCAwCI,KAAK;wBAOb,IAAI,YAAY,EAAY;KA3ChD;;;;;IAED,IACI,YAAY,CAAC,KAAa;QAC5B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAC/B;KACF;;;;;IAED,IACI,YAAY,CAAC,KAAa;QAC5B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAC/B;KACF;;;;;IAED,IACI,oBAAoB,CAAC,KAAa;QACpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YAC1D,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAClC;KACF;;;;;IAED,IACI,oBAAoB,CAAC,KAAa;QACpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YAC1D,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAClC;KACF;;;;;IACD,IACI,SAAS,CAAC,KAAa;QACzB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAC3B;KACF;;;;;IAID,IACI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,UAAU,GAAG,CAAC,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;KAC7E;;;;IAID,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;;;IAED,WAAW,CAAC,OAAsB;QAChC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;YACjG,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;KACF;;;;IAGM,gBAAgB;QACrB,IAAI,CAAC;;YAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YAC7E,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;QAAC,KAAK,CAAC,CAAC,iBAAA,CAAC,EAAE,CAAC;YACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SAClB;;;;;IAIK,UAAU;QAChB,IAAI,CAAC,oBAAoB,EAAE,CAAC;;QAE5B,IAAI,CAAC,WAAW,GAAG;YACjB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;SAC3C,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,QAAQ,EAAE,EAAE,CAAC,SAAS,GAAG,QAAQ,EAAE,CAAC,CAAC,CAAC;;QAG3F,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;YACrC,uBAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACvE,OAAO,CAAC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,IAAI,GAAG,gBAAgB,GAAG,OAAO,GAAG,mBAAmB,CAAC,CAAC;YACpG,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;SACrB;QACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;YACzD,OAAO,CAAC,KAAK,CAAC;+EAC2D,CAAC,CAAC;SAC5E;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;;;;;IAIpB,oBAAoB;QAC1B,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC3E,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;QAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YACzC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;QAAC,IAAI,CAAC,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;;;;YAIjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;YAC/E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;YAE/E,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;gBACxC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAAC;SACrE;;;;;IAIK,uBAAuB;QAC7B,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;YAC3B,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;YACjC,uBAAM,mBAAmB,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;YACvD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,mBAAmB,IAAI,EAAE,CAAC,CAAC,CAAC;gBACjD,uBAAM,SAAS,GAAG,IAAI,CAAC,WAAW,GAAG,mBAAmB,CAAC;gBACzD,qBAAI,YAAY,GAAG,SAAS,CAAC;gBAC7B,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,mBAAmB,GAAG,CAAC,EAAE,CAAC;oBACpE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3D,YAAY,IAAI,SAAS,CAAC;iBAC3B;aACF;SACF;;;;;;;IAIK,kBAAkB,CAAC,UAAoB,EAAE,gBAAyB,KAAK;QAC7E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACxC;;;;;;IAIK,gBAAgB,CAAC,UAAoB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;;;;;IAI7C,kBAAkB;QACxB,qBAAI,YAAY,GAAG,CAAC,CAAC;;QAErB,IAAI,CAAC,kBAAkB,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;SACzC,CAAC,CAAC;;QAEH,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,mBAAE,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;YAChE,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,GAAG,CAAC;SAC1D;;;;;;;IAIK,aAAa,CAAC,KAAa,EAAE,KAAa;QAChD,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;YAClB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;SACnD;QACD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;;;;;IAUlC,mBAAmB;QACjB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;KAC9B;;;;;;IAOM,gBAAgB,CAAC,KAAU,EAAE,YAAoB;QACtD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACrB,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC;gBAClC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;gBACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC;gBACjC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBACrD,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;gBACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;gBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;gBACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;SACF;;;;;;IASI,cAAc,CAAC,KAAU;QAC9B,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC1F,uBAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;YACrH,uBAAM,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3C,uBAAM,UAAU,GAAG,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC7C,EAAE,CAAC,CAAC,SAAS,IAAI,CAAC,IAAI,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,EAAE,SAAS,CAAC,CAAC;gBACxD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;gBAC7D,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;SACF;;;;YArSJ,SAAS,SAAC;gBACT,QAAQ,EAAE,YAAY;gBACtB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8BX;gBACC,MAAM,EAAE,CAAC,4/EAA4/E,CAAC;aACvgF;;;;YArCS,UAAU;;;2BAkEjB,KAAK,SAAC,KAAK;2BAOX,KAAK,SAAC,KAAK;mCAOX,KAAK,SAAC,aAAa;mCAOnB,KAAK,SAAC,aAAa;wBAMnB,KAAK,SAAC,MAAM;gCAOZ,KAAK;0BAEL,KAAK,SAAC,UAAU;uBAKhB,MAAM;kCA2IN,YAAY,SAAC,kBAAkB,cAC/B,YAAY,SAAC,iBAAiB","sourcesContent":["import { Component, Input, Output, EventEmitter,\n          ElementRef, OnInit, HostListener, SimpleChanges, OnChanges } from '@angular/core';\nimport { Utilities } from './utilities';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\r\n                   (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\r\n          [style.left.%]=\"handlerX[0]\"\r\n          (mousedown)=\"setHandlerActive($event,0)\"\r\n          (panstart)=\"setHandlerActive($event,0)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n            <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\r\n    </div>\r\n    <span class=\"right-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\r\n          [style.left.%]=\"handlerX[1]\"\r\n          (mousedown)=\"setHandlerActive($event,1)\"\r\n          (panstart)=\"setHandlerActive($event,1)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\">\r\n    <span>{{initValues[0]}}</span>\r\n    <span>{{initValues[1]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    if (this.sliderWidth / (this.totalDiff / this.step) < 10) {\n      console.error(`'step' value is too small compared to min & max value difference and slider width.\n        Slider might not work properly!. Provide slight large value for 'step'`);\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions = [];\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      }\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit(this.currentValues);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n      if (event.clientX) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (event.deltaX) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npn-slider.component.js","sourceRoot":"ng://npn-slider/","sources":["lib/npn-slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Input, Output, EventEmitter,\n  ElementRef, OnInit, HostListener, SimpleChanges, OnChanges\n} from '@angular/core';\nimport { Utilities } from './utilities';\nimport { SliderHandlerEnum } from './slider-handler.enum';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\r\n                      'last-active': currentHandlerIndex === handlerIndex.left\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n        <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\r\n      <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\r\n    </div>\r\n    <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\r\n                      'last-active': currentHandlerIndex === handlerIndex.right\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\r\n      (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\" *ngIf=\"!hideValues\">\r\n    <span>{{initValues[handlerIndex.left]}}</span>\r\n    <span>{{initValues[handlerIndex.right]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n  public hideTooltip = false;\n  public hideValues = false;\n\n  public handlerIndex = SliderHandlerEnum;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.minSelected !== Number(value)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.maxSelected !== Number(value)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n  @Input() multiRange = true;\n  @Input('hide-tooltip')\n  set setHideTooltip(value: boolean) {\n    this.hideTooltip = this.toBoolean(value);\n  }\n  @Input('hide-values')\n  set setHideValues(value: boolean) {\n    this.hideValues = this.toBoolean(value);\n  }\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = this.toBoolean(value, 'disabled');\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.sliderInitiated) {\n      if (!this.isNullOrEmpty(changes.setMinSelectedValues)\n        && changes.setMinSelectedValues.previousValue === changes.setMinSelectedValues.currentValue) {\n        return;\n      }\n      if (!this.isNullOrEmpty(changes.setMaxSelectedValues)\n        && changes.setMaxSelectedValues.previousValue === changes.setMaxSelectedValues.currentValue) {\n        return;\n      }\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions.length = 0;\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      } else {\n        console.warn(`As 'step' value is too small compared to min & max value difference and slider width,\n          Step Indicator can't be displayed!. Provide slight large value for 'step'`);\n      }\n    } else {\n      this.stepIndicatorPositions.length = 0;\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n\n      if (!this.isNullOrEmpty(event.clientX)) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (!this.isNullOrEmpty(event.deltaX)) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n"]}

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

isNumberArray(arr) {
return arr.filter((value) => !isNaN(value)).length === arr.length;
return (arr && arr.length && arr.filter((value) => !isNaN(value)).length === arr.length) ? true : false;
}

@@ -22,2 +22,10 @@ /**

/**
* @param {?} obj
* @param {...?} allowedValues
* @return {?}
*/
toBoolean(obj, ...allowedValues) {
return (obj === '' || obj === 'true' || allowedValues.indexOf(obj) !== -1) ? true : false;
}
/**
* @param {?} n

@@ -28,36 +36,37 @@ * @param {?} step

findNextValidStepValue(n, step) {
const /** @type {?} */ divisors = [];
const /** @type {?} */ divisorsSet1 = [];
const /** @type {?} */ divisorsSet2 = [];
const /** @type {?} */ sqrtNum = Math.sqrt(n);
let /** @type {?} */ newStep = -1;
for (let /** @type {?} */ i = 0; i < sqrtNum; i++) {
if (n % i === 0) {
if ((n / i) === i) {
divisors.push(i);
divisorsSet1.push(i);
}
else {
divisors.push(i);
divisors.push(n / i);
divisorsSet1.push(i);
divisorsSet2.push(n / i);
}
}
}
divisors.sort((a, b) => {
a = Number(a);
b = Number(b);
if (a < b) {
return -1;
}
if (a > b) {
return 1;
}
return 0;
});
for (let /** @type {?} */ i = divisors.length - 1; i >= 0; i--) {
if (step > divisors[i]) {
step = divisors[i];
// Picking newStep by checking large set of divisors first
for (let /** @type {?} */ i = 0; i < divisorsSet2.length; i++) {
if (step > divisorsSet2[i]) {
newStep = divisorsSet2[i];
break;
}
}
return step;
if (newStep === -1) {
// checking set of small divisors if newStep didn't find out till.
for (let /** @type {?} */ i = divisorsSet1.length - 1; i >= 0; i--) {
if (step > divisorsSet1[i]) {
newStep = divisorsSet1[i];
break;
}
}
}
return (newStep === -1) ? 1 : newStep;
}
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbnBuLXNsaWRlci8iLCJzb3VyY2VzIjpbImxpYi91dGlsaXRpZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUdBLE1BQU07Ozs7O0lBRUcsYUFBYSxDQUFDLEdBQWE7UUFDaEMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxNQUFNLENBQUM7Ozs7OztJQUU3RCxhQUFhLENBQUMsR0FBUTtRQUMzQixNQUFNLENBQUMsR0FBRyxLQUFLLFNBQVMsSUFBSSxHQUFHLEtBQUssSUFBSSxJQUFJLEdBQUcsS0FBSyxFQUFFLENBQUM7Ozs7Ozs7SUFFbEQsc0JBQXNCLENBQUMsQ0FBUyxFQUFFLElBQVk7UUFDbkQsdUJBQU0sUUFBUSxHQUFhLEVBQUUsQ0FBQztRQUM5Qix1QkFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM3QixHQUFHLENBQUMsQ0FBQyxxQkFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxPQUFPLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNqQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2hCLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ2xCLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7aUJBQ2xCO2dCQUFDLElBQUksQ0FBQyxDQUFDO29CQUNOLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ2pCLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2lCQUN0QjthQUNGO1NBQ0Y7UUFDRCxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQ3JCLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDZCxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2QsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ1YsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ1g7WUFDRCxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDVixNQUFNLENBQUMsQ0FBQyxDQUFDO2FBQ1Y7WUFDRCxNQUFNLENBQUMsQ0FBQyxDQUFDO1NBQ1YsQ0FBQyxDQUFDO1FBQ0gsR0FBRyxDQUFDLENBQUMscUJBQUksQ0FBQyxHQUFHLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUM5QyxFQUFFLENBQUMsQ0FBQyxJQUFJLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDdkIsSUFBSSxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDbkIsS0FBSyxDQUFDO2FBQ1A7U0FDRjtRQUNELE1BQU0sQ0FBQyxJQUFJLENBQUM7O0NBRWYiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuXHJcbi8qVXRpbGl0aWVzICovXHJcbmV4cG9ydCBjbGFzcyBVdGlsaXRpZXMge1xyXG5cclxuICBwdWJsaWMgaXNOdW1iZXJBcnJheShhcnI6IG51bWJlcltdKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gYXJyLmZpbHRlcigodmFsdWUpID0+ICFpc05hTih2YWx1ZSkpLmxlbmd0aCA9PT0gYXJyLmxlbmd0aDtcclxuICB9XHJcbiAgcHVibGljIGlzTnVsbE9yRW1wdHkob2JqOiBhbnkpIHtcclxuICAgIHJldHVybiBvYmogPT09IHVuZGVmaW5lZCB8fCBvYmogPT09IG51bGwgfHwgb2JqID09PSAnJztcclxuICB9XHJcbiAgcHVibGljIGZpbmROZXh0VmFsaWRTdGVwVmFsdWUobjogbnVtYmVyLCBzdGVwOiBudW1iZXIpOiBudW1iZXIge1xyXG4gICAgY29uc3QgZGl2aXNvcnM6IG51bWJlcltdID0gW107XHJcbiAgICBjb25zdCBzcXJ0TnVtID0gTWF0aC5zcXJ0KG4pO1xyXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBzcXJ0TnVtOyBpKyspIHtcclxuICAgICAgaWYgKG4gJSBpID09PSAwKSB7XHJcbiAgICAgICAgaWYgKChuIC8gaSkgPT09IGkpIHtcclxuICAgICAgICAgIGRpdmlzb3JzLnB1c2goaSk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGRpdmlzb3JzLnB1c2goaSk7XHJcbiAgICAgICAgICBkaXZpc29ycy5wdXNoKG4gLyBpKTtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIGRpdmlzb3JzLnNvcnQoKGEsIGIpID0+IHtcclxuICAgICAgYSA9IE51bWJlcihhKTtcclxuICAgICAgYiA9IE51bWJlcihiKTtcclxuICAgICAgaWYgKGEgPCBiKSB7XHJcbiAgICAgICAgcmV0dXJuIC0xO1xyXG4gICAgICB9XHJcbiAgICAgIGlmIChhID4gYikge1xyXG4gICAgICAgIHJldHVybiAxO1xyXG4gICAgICB9XHJcbiAgICAgIHJldHVybiAwO1xyXG4gICAgfSk7XHJcbiAgICBmb3IgKGxldCBpID0gZGl2aXNvcnMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcclxuICAgICAgaWYgKHN0ZXAgPiBkaXZpc29yc1tpXSkge1xyXG4gICAgICAgIHN0ZXAgPSBkaXZpc29yc1tpXTtcclxuICAgICAgICBicmVhaztcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHN0ZXA7XHJcbiAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbnBuLXNsaWRlci8iLCJzb3VyY2VzIjpbImxpYi91dGlsaXRpZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUdBLE1BQU07Ozs7O0lBRUcsYUFBYSxDQUFDLEdBQWE7UUFDaEMsTUFBTSxDQUFDLENBQUMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxNQUFNLElBQUksR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQzs7Ozs7O0lBRW5HLGFBQWEsQ0FBQyxHQUFRO1FBQzNCLE1BQU0sQ0FBQyxHQUFHLEtBQUssU0FBUyxJQUFJLEdBQUcsS0FBSyxJQUFJLElBQUksR0FBRyxLQUFLLEVBQUUsQ0FBQzs7Ozs7OztJQUVsRCxTQUFTLENBQUMsR0FBUSxFQUFFLEdBQUcsYUFBYTtRQUN6QyxNQUFNLENBQUMsQ0FBQyxHQUFHLEtBQUssRUFBRSxJQUFJLEdBQUcsS0FBSyxNQUFNLElBQUksYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQzs7Ozs7OztJQUVyRixzQkFBc0IsQ0FBQyxDQUFTLEVBQUUsSUFBWTtRQUNuRCx1QkFBTSxZQUFZLEdBQWEsRUFBRSxDQUFDO1FBQ2xDLHVCQUFNLFlBQVksR0FBYSxFQUFFLENBQUM7UUFDbEMsdUJBQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0IscUJBQUksT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2pCLEdBQUcsQ0FBQyxDQUFDLHFCQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE9BQU8sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ2pDLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDaEIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDbEIsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztpQkFDdEI7Z0JBQUMsSUFBSSxDQUFDLENBQUM7b0JBQ04sWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDckIsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7aUJBQzFCO2FBQ0Y7U0FDRjs7UUFFRCxHQUFHLENBQUMsQ0FBQyxxQkFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDN0MsRUFBRSxDQUFDLENBQUMsSUFBSSxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzNCLE9BQU8sR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzFCLEtBQUssQ0FBQzthQUNQO1NBQ0Y7UUFDRCxFQUFFLENBQUMsQ0FBQyxPQUFPLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDOztZQUNuQixHQUFHLENBQUMsQ0FBQyxxQkFBSSxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO2dCQUNsRCxFQUFFLENBQUMsQ0FBQyxJQUFJLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDM0IsT0FBTyxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDMUIsS0FBSyxDQUFDO2lCQUNQO2FBQ0Y7U0FDRjtRQUNELE1BQU0sQ0FBQyxDQUFDLE9BQU8sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQzs7Q0FFekMiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuXHJcbi8qVXRpbGl0aWVzICovXHJcbmV4cG9ydCBjbGFzcyBVdGlsaXRpZXMge1xyXG5cclxuICBwdWJsaWMgaXNOdW1iZXJBcnJheShhcnI6IG51bWJlcltdKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gKGFyciAmJiBhcnIubGVuZ3RoICYmIGFyci5maWx0ZXIoKHZhbHVlKSA9PiAhaXNOYU4odmFsdWUpKS5sZW5ndGggPT09IGFyci5sZW5ndGgpID8gdHJ1ZSA6IGZhbHNlO1xyXG4gIH1cclxuICBwdWJsaWMgaXNOdWxsT3JFbXB0eShvYmo6IGFueSk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIG9iaiA9PT0gdW5kZWZpbmVkIHx8IG9iaiA9PT0gbnVsbCB8fCBvYmogPT09ICcnO1xyXG4gIH1cclxuICBwdWJsaWMgdG9Cb29sZWFuKG9iajogYW55LCAuLi5hbGxvd2VkVmFsdWVzKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gKG9iaiA9PT0gJycgfHwgb2JqID09PSAndHJ1ZScgfHwgYWxsb3dlZFZhbHVlcy5pbmRleE9mKG9iaikgIT09IC0xKSA/IHRydWUgOiBmYWxzZTtcclxuICB9XHJcbiAgcHVibGljIGZpbmROZXh0VmFsaWRTdGVwVmFsdWUobjogbnVtYmVyLCBzdGVwOiBudW1iZXIpOiBudW1iZXIge1xyXG4gICAgY29uc3QgZGl2aXNvcnNTZXQxOiBudW1iZXJbXSA9IFtdO1xyXG4gICAgY29uc3QgZGl2aXNvcnNTZXQyOiBudW1iZXJbXSA9IFtdO1xyXG4gICAgY29uc3Qgc3FydE51bSA9IE1hdGguc3FydChuKTtcclxuICAgIGxldCBuZXdTdGVwID0gLTE7XHJcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHNxcnROdW07IGkrKykge1xyXG4gICAgICBpZiAobiAlIGkgPT09IDApIHtcclxuICAgICAgICBpZiAoKG4gLyBpKSA9PT0gaSkge1xyXG4gICAgICAgICAgZGl2aXNvcnNTZXQxLnB1c2goaSk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGRpdmlzb3JzU2V0MS5wdXNoKGkpO1xyXG4gICAgICAgICAgZGl2aXNvcnNTZXQyLnB1c2gobiAvIGkpO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgLy8gUGlja2luZyBuZXdTdGVwIGJ5IGNoZWNraW5nIGxhcmdlIHNldCBvZiBkaXZpc29ycyBmaXJzdFxyXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBkaXZpc29yc1NldDIubGVuZ3RoOyBpKyspIHtcclxuICAgICAgaWYgKHN0ZXAgPiBkaXZpc29yc1NldDJbaV0pIHtcclxuICAgICAgICBuZXdTdGVwID0gZGl2aXNvcnNTZXQyW2ldO1xyXG4gICAgICAgIGJyZWFrO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICBpZiAobmV3U3RlcCA9PT0gLTEpIHsgLy8gY2hlY2tpbmcgc2V0IG9mIHNtYWxsIGRpdmlzb3JzIGlmIG5ld1N0ZXAgZGlkbid0IGZpbmQgb3V0IHRpbGwuXHJcbiAgICAgIGZvciAobGV0IGkgPSBkaXZpc29yc1NldDEubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcclxuICAgICAgICBpZiAoc3RlcCA+IGRpdmlzb3JzU2V0MVtpXSkge1xyXG4gICAgICAgICAgbmV3U3RlcCA9IGRpdmlzb3JzU2V0MVtpXTtcclxuICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIChuZXdTdGVwID09PSAtMSkgPyAxIDogbmV3U3RlcDtcclxuICB9XHJcbn1cclxuIl19

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

import { Utilities } from './utilities';
import { SliderHandlerEnum } from './slider-handler.enum';
var NpnSliderComponent = /** @class */ (function (_super) {

@@ -31,3 +32,7 @@ tslib_1.__extends(NpnSliderComponent, _super);

_this.isDisabled = false;
_this.hideTooltip = false;
_this.hideValues = false;
_this.handlerIndex = SliderHandlerEnum;
_this.showStepIndicator = false;
_this.multiRange = true;
_this.onChange = new EventEmitter();

@@ -68,3 +73,3 @@ return _this;

function (value) {
if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {
if (!isNaN(value) && this.minSelected !== Number(value)) {
this.minSelected = Number(value);

@@ -82,3 +87,3 @@ }

function (value) {
if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {
if (!isNaN(value) && this.maxSelected !== Number(value)) {
this.maxSelected = Number(value);

@@ -103,2 +108,24 @@ }

});
Object.defineProperty(NpnSliderComponent.prototype, "setHideTooltip", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.hideTooltip = this.toBoolean(value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(NpnSliderComponent.prototype, "setHideValues", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.hideValues = this.toBoolean(value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(NpnSliderComponent.prototype, "setDisabled", {

@@ -110,3 +137,3 @@ set: /**

function (value) {
this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;
this.isDisabled = this.toBoolean(value, 'disabled');
},

@@ -134,3 +161,11 @@ enumerable: true,

function (changes) {
if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {
if (this.sliderInitiated) {
if (!this.isNullOrEmpty(changes["setMinSelectedValues"])
&& changes["setMinSelectedValues"].previousValue === changes["setMinSelectedValues"].currentValue) {
return;
}
if (!this.isNullOrEmpty(changes["setMaxSelectedValues"])
&& changes["setMaxSelectedValues"].previousValue === changes["setMaxSelectedValues"].currentValue) {
return;
}
this.resetModel();

@@ -177,5 +212,2 @@ }

}
if (this.sliderWidth / (this.totalDiff / this.step) < 10) {
console.error("'step' value is too small compared to min & max value difference and slider width.\n Slider might not work properly!. Provide slight large value for 'step'");
}
this.initializeStepIndicator();

@@ -227,3 +259,3 @@ this.setHandlerPosition();

if (this.showStepIndicator) {
this.stepIndicatorPositions = [];
this.stepIndicatorPositions.length = 0;
var /** @type {?} */ numOfStepIndicators = this.totalDiff / this.step;

@@ -238,3 +270,9 @@ if (this.sliderWidth / numOfStepIndicators >= 10) {

}
else {
console.warn("As 'step' value is too small compared to min & max value difference and slider width,\n Step Indicator can't be displayed!. Provide slight large value for 'step'");
}
}
else {
this.stepIndicatorPositions.length = 0;
}
};

@@ -256,3 +294,3 @@ /**

if (!privateChange) {
this.onChange.emit(this.currentValues);
this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);
}

@@ -336,3 +374,3 @@ };

if (!this.isDisabled) {
if (event.clientX) {
if (!this.isNullOrEmpty(event.clientX)) {
this.startClientX = event.clientX;

@@ -342,3 +380,3 @@ this.isMouseEventStart = true;

}
else if (event.deltaX) {
else if (!this.isNullOrEmpty(event.deltaX)) {
this.startClientX = event.deltaX;

@@ -379,4 +417,4 @@ this.isTouchEventStart = true;

selector: 'npn-slider',
template: "<!--npn-slider template-->\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\n <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\n (panmove)=\"handlerSliding($event)\">\n <span class=\"left-handle\"\n [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\n [style.left.%]=\"handlerX[0]\"\n (mousedown)=\"setHandlerActive($event,0)\"\n (panstart)=\"setHandlerActive($event,0)\">\n <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\n </span>\n <div class=\"filler\">\n <div class=\"step-indicators\">\n <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\n </div>\n <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\n </div>\n <span class=\"right-handle\"\n [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\n [style.left.%]=\"handlerX[1]\"\n (mousedown)=\"setHandlerActive($event,1)\"\n (panstart)=\"setHandlerActive($event,1)\">\n <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\n </span>\n </div>\n <div class=\"values\">\n <span>{{initValues[0]}}</span>\n <span>{{initValues[1]}}</span>\n </div>\n</div>\n",
styles: [".slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}"]
template: "<!--npn-slider template-->\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\n <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\n <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\n 'last-active': currentHandlerIndex === handlerIndex.left\n }\"\n [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\n <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\n </span>\n <div class=\"filler\">\n <div class=\"step-indicators\">\n <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\n </div>\n <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\n <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\n </div>\n <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\n 'last-active': currentHandlerIndex === handlerIndex.right\n }\"\n [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\n (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\n <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\n </span>\n </div>\n <div class=\"values\" *ngIf=\"!hideValues\">\n <span>{{initValues[handlerIndex.left]}}</span>\n <span>{{initValues[handlerIndex.right]}}</span>\n </div>\n</div>\n",
styles: [".slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}"]
},] },

@@ -395,2 +433,5 @@ ];

showStepIndicator: [{ type: Input }],
multiRange: [{ type: Input }],
setHideTooltip: [{ type: Input, args: ['hide-tooltip',] }],
setHideValues: [{ type: Input, args: ['hide-values',] }],
setDisabled: [{ type: Input, args: ['disabled',] }],

@@ -447,4 +488,12 @@ onChange: [{ type: Output }],

/** @type {?} */
NpnSliderComponent.prototype.hideTooltip;
/** @type {?} */
NpnSliderComponent.prototype.hideValues;
/** @type {?} */
NpnSliderComponent.prototype.handlerIndex;
/** @type {?} */
NpnSliderComponent.prototype.showStepIndicator;
/** @type {?} */
NpnSliderComponent.prototype.multiRange;
/** @type {?} */
NpnSliderComponent.prototype.onChange;

@@ -455,2 +504,2 @@ /** @type {?} */

//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npn-slider.component.js","sourceRoot":"ng://npn-slider/","sources":["lib/npn-slider.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EACrC,UAAU,EAAU,YAAY,EAA4B,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;;IAqCA,8CAAS;IAwB/C,4BAAoB,EAAc;QAAlC,YACE,iBAAO,SACR;QAFmB,QAAE,GAAF,EAAE,CAAY;4BAvBZ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;qBAChB,CAAC;4BACM,CAAC;0BACH,CAAC;6BACE,CAAC;2BACH,CAAC;4BACA,CAAC;gCAKG,KAAK;2BAED,EAAE;8BACC,CAAC,CAAC,EAAE,CAAC,CAAC;yBACX,CAAC,CAAC,EAAE,CAAC,CAAC;gCACT,KAAK;kCACH,KAAK;kCACL,KAAK;oCACH,CAAC;uCACE,EAAE;2BACd,KAAK;kCAwCI,KAAK;yBAOb,IAAI,YAAY,EAAY;;KA3ChD;IAED,sBACI,4CAAY;;;;;QADhB,UACiB,KAAa;YAC5B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAC/B;SACF;;;OAAA;IAED,sBACI,4CAAY;;;;;QADhB,UACiB,KAAa;YAC5B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAC/B;SACF;;;OAAA;IAED,sBACI,oDAAoB;;;;;QADxB,UACyB,KAAa;YACpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBAC1D,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAClC;SACF;;;OAAA;IAED,sBACI,oDAAoB;;;;;QADxB,UACyB,KAAa;YACpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBAC1D,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAClC;SACF;;;OAAA;IACD,sBACI,yCAAS;;;;;QADb,UACc,KAAa;YACzB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAC3B;SACF;;;OAAA;IAID,sBACI,2CAAW;;;;;QADf,UACgB,KAAa;YAC3B,IAAI,CAAC,UAAU,GAAG,CAAC,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;SAC7E;;;OAAA;;;;IAID,qCAAQ;;;IAAR;QACE,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;;;IAED,wCAAW;;;;IAAX,UAAY,OAAsB;QAChC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;YACjG,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;KACF;;;;IAGM,6CAAgB;;;;QACrB,IAAI,CAAC;;YAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YAC7E,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;QAAC,KAAK,CAAC,CAAC,iBAAA,CAAC,EAAE,CAAC;YACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SAClB;;;;;IAIK,uCAAU;;;;QAChB,IAAI,CAAC,oBAAoB,EAAE,CAAC;;QAE5B,IAAI,CAAC,WAAW,GAAG;YACjB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;SAC3C,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,UAAC,SAAS,EAAE,QAAQ,IAAK,OAAA,SAAS,GAAG,QAAQ,EAApB,CAAoB,EAAE,CAAC,CAAC,CAAC;;QAG3F,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;YACrC,qBAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACvE,OAAO,CAAC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,IAAI,GAAG,gBAAgB,GAAG,OAAO,GAAG,mBAAmB,CAAC,CAAC;YACpG,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;SACrB;QACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;YACzD,OAAO,CAAC,KAAK,CAAC,oKAC2D,CAAC,CAAC;SAC5E;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;;;;;IAIpB,iDAAoB;;;;QAC1B,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC3E,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;QAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YACzC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;QAAC,IAAI,CAAC,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;;;;YAIjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;YAC/E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;YAE/E,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;gBACxC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAAC;SACrE;;;;;IAIK,oDAAuB;;;;QAC7B,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;YAC3B,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;YACjC,qBAAM,mBAAmB,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;YACvD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,mBAAmB,IAAI,EAAE,CAAC,CAAC,CAAC;gBACjD,qBAAM,SAAS,GAAG,IAAI,CAAC,WAAW,GAAG,mBAAmB,CAAC;gBACzD,qBAAI,YAAY,GAAG,SAAS,CAAC;gBAC7B,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,mBAAmB,GAAG,CAAC,EAAE,CAAC;oBACpE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3D,YAAY,IAAI,SAAS,CAAC;iBAC3B;aACF;SACF;;;;;;;IAIK,+CAAkB;;;;;cAAC,UAAoB,EAAE,aAA8B;QAA9B,8BAAA,EAAA,qBAA8B;QAC7E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACxC;;;;;;IAIK,6CAAgB;;;;cAAC,UAAoB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;;;;;IAI7C,+CAAkB;;;;QACxB,qBAAI,YAAY,GAAG,CAAC,CAAC;;QAErB,IAAI,CAAC,kBAAkB,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;SACzC,CAAC,CAAC;;QAEH,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,mBAAE,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;YAChE,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,GAAG,CAAC;SAC1D;;;;;;;IAIK,0CAAa;;;;;cAAC,KAAa,EAAE,KAAa;QAChD,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;YAClB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;SACnD;QACD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;;IAGlC,sCAAsC;IACtC;;;MAGE;;;;IAGF,gDAAmB;;;IAFnB;QAGE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;KAC9B;;;;;;IAOM,6CAAgB;;;;;cAAC,KAAU,EAAE,YAAoB;QACtD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACrB,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC;gBAClC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;gBACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC;gBACjC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBACrD,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;gBACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;gBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;gBACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;SACF;;;;;;IASI,2CAAc;;;;cAAC,KAAU;QAC9B,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC1F,qBAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;YACrH,qBAAM,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3C,qBAAM,UAAU,GAAG,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC7C,EAAE,CAAC,CAAC,SAAS,IAAI,CAAC,IAAI,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,EAAE,SAAS,CAAC,CAAC;gBACxD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;gBAC7D,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;SACF;;;gBArSJ,SAAS,SAAC;oBACT,QAAQ,EAAE,YAAY;oBACtB,QAAQ,EAAE,k2CA8BX;oBACC,MAAM,EAAE,CAAC,ggFAA4/E,CAAC;iBACvgF;;;;gBArCS,UAAU;;;+BAkEjB,KAAK,SAAC,KAAK;+BAOX,KAAK,SAAC,KAAK;uCAOX,KAAK,SAAC,aAAa;uCAOnB,KAAK,SAAC,aAAa;4BAMnB,KAAK,SAAC,MAAM;oCAOZ,KAAK;8BAEL,KAAK,SAAC,UAAU;2BAKhB,MAAM;sCA2IN,YAAY,SAAC,kBAAkB,cAC/B,YAAY,SAAC,iBAAiB;;6BAxPjC;EAuCwC,SAAS;SAApC,kBAAkB","sourcesContent":["import { Component, Input, Output, EventEmitter,\n          ElementRef, OnInit, HostListener, SimpleChanges, OnChanges } from '@angular/core';\nimport { Utilities } from './utilities';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\r\n                   (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\r\n          [style.left.%]=\"handlerX[0]\"\r\n          (mousedown)=\"setHandlerActive($event,0)\"\r\n          (panstart)=\"setHandlerActive($event,0)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n            <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\r\n    </div>\r\n    <span class=\"right-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\r\n          [style.left.%]=\"handlerX[1]\"\r\n          (mousedown)=\"setHandlerActive($event,1)\"\r\n          (panstart)=\"setHandlerActive($event,1)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\">\r\n    <span>{{initValues[0]}}</span>\r\n    <span>{{initValues[1]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    if (this.sliderWidth / (this.totalDiff / this.step) < 10) {\n      console.error(`'step' value is too small compared to min & max value difference and slider width.\n        Slider might not work properly!. Provide slight large value for 'step'`);\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions = [];\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      }\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit(this.currentValues);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n      if (event.clientX) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (event.deltaX) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npn-slider.component.js","sourceRoot":"ng://npn-slider/","sources":["lib/npn-slider.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACL,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EACtC,UAAU,EAAU,YAAY,EACjC,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;;IAoClB,8CAAS;IA4B/C,4BAAoB,EAAc;QAAlC,YACE,iBAAO,SACR;QAFmB,QAAE,GAAF,EAAE,CAAY;4BA3BZ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;qBAChB,CAAC;4BACM,CAAC;0BACH,CAAC;6BACE,CAAC;2BACH,CAAC;4BACA,CAAC;gCAKG,KAAK;2BAED,EAAE;8BACC,CAAC,CAAC,EAAE,CAAC,CAAC;yBACX,CAAC,CAAC,EAAE,CAAC,CAAC;gCACT,KAAK;kCACH,KAAK;kCACL,KAAK;oCACH,CAAC;uCACE,EAAE;2BACd,KAAK;4BACJ,KAAK;2BACN,KAAK;6BAEH,iBAAiB;kCAwCV,KAAK;2BACZ,IAAI;yBAeL,IAAI,YAAY,EAAY;;KApDhD;IAED,sBACI,4CAAY;;;;;QADhB,UACiB,KAAa;YAC5B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAC/B;SACF;;;OAAA;IAED,sBACI,4CAAY;;;;;QADhB,UACiB,KAAa;YAC5B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAC/B;SACF;;;OAAA;IAED,sBACI,oDAAoB;;;;;QADxB,UACyB,KAAa;YACpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,WAAW,KAAK,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACxD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAClC;SACF;;;OAAA;IAED,sBACI,oDAAoB;;;;;QADxB,UACyB,KAAa;YACpC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,WAAW,KAAK,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACxD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAClC;SACF;;;OAAA;IACD,sBACI,yCAAS;;;;;QADb,UACc,KAAa;YACzB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;aAC3B;SACF;;;OAAA;IAID,sBACI,8CAAc;;;;;QADlB,UACmB,KAAc;YAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAC1C;;;OAAA;IACD,sBACI,6CAAa;;;;;QADjB,UACkB,KAAc;YAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SACzC;;;OAAA;IAED,sBACI,2CAAW;;;;;QADf,UACgB,KAAa;YAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;SACrD;;;OAAA;;;;IAID,qCAAQ;;;IAAR;QACE,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;;;IAED,wCAAW;;;;IAAX,UAAY,OAAsB;QAChC,EAAE,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;YACzB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,yBAAsB;mBAChD,OAAO,yBAAsB,aAAa,KAAK,OAAO,yBAAsB,YAAY,CAAC,CAAC,CAAC;gBAC9F,MAAM,CAAC;aACR;YACD,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,yBAAsB;mBAChD,OAAO,yBAAsB,aAAa,KAAK,OAAO,yBAAsB,YAAY,CAAC,CAAC,CAAC;gBAC9F,MAAM,CAAC;aACR;YACD,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;KACF;;;;IAGM,6CAAgB;;;;QACrB,IAAI,CAAC;;YAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YAC7E,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;QAAC,KAAK,CAAC,CAAC,iBAAA,CAAC,EAAE,CAAC;YACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SAClB;;;;;IAIK,uCAAU;;;;QAChB,IAAI,CAAC,oBAAoB,EAAE,CAAC;;QAE5B,IAAI,CAAC,WAAW,GAAG;YACjB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;SAC3C,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,UAAC,SAAS,EAAE,QAAQ,IAAK,OAAA,SAAS,GAAG,QAAQ,EAApB,CAAoB,EAAE,CAAC,CAAC,CAAC;;QAG3F,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;YACrC,qBAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACvE,OAAO,CAAC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,IAAI,GAAG,gBAAgB,GAAG,OAAO,GAAG,mBAAmB,CAAC,CAAC;YACpG,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;SACrB;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;;;;;IAIpB,iDAAoB;;;;QAC1B,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC3E,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;QAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YACzC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;QAAC,IAAI,CAAC,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;;;;YAIjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;YAC/E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;YAE/E,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;gBACxC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAAC;SACrE;;;;;IAIK,oDAAuB;;;;QAC7B,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;YAC3B,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,CAAC,CAAC;YACvC,qBAAM,mBAAmB,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;YACvD,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,mBAAmB,IAAI,EAAE,CAAC,CAAC,CAAC;gBACjD,qBAAM,SAAS,GAAG,IAAI,CAAC,WAAW,GAAG,mBAAmB,CAAC;gBACzD,qBAAI,YAAY,GAAG,SAAS,CAAC;gBAC7B,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,mBAAmB,GAAG,CAAC,EAAE,CAAC;oBACpE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3D,YAAY,IAAI,SAAS,CAAC;iBAC3B;aACF;YAAC,IAAI,CAAC,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,4KAC+D,CAAC,CAAC;aAC/E;SACF;QAAC,IAAI,CAAC,CAAC;YACN,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,CAAC,CAAC;SACxC;;;;;;;IAIK,+CAAkB;;;;;cAAC,UAAoB,EAAE,aAA8B;QAA9B,8BAAA,EAAA,qBAA8B;QAC7E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACtF;;;;;;IAIK,6CAAgB;;;;cAAC,UAAoB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;;;;;IAI7C,+CAAkB;;;;QACxB,qBAAI,YAAY,GAAG,CAAC,CAAC;;QAErB,IAAI,CAAC,kBAAkB,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;SACzC,CAAC,CAAC;;QAEH,GAAG,CAAC,CAAC,qBAAI,CAAC,GAAG,CAAC,mBAAE,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;YAChE,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,GAAG,CAAC;SAC1D;;;;;;;IAIK,0CAAa;;;;;cAAC,KAAa,EAAE,KAAa;QAChD,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;YAClB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;SACnD;QACD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;;IAGlC,sCAAsC;IACtC;;;MAGE;;;;IAGF,gDAAmB;;;IAFnB;QAGE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;KAC9B;;;;;;IAOM,6CAAgB;;;;;cAAC,KAAU,EAAE,YAAoB;QACtD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YAErB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBACvC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC;gBAClC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAC7C,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC;gBACjC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YACD,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBACrD,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;gBACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;gBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;gBACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;SACF;;;;;;IASI,2CAAc;;;;cAAC,KAAU;QAC9B,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC1F,qBAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;YACrH,qBAAM,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3C,qBAAM,UAAU,GAAG,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC7C,EAAE,CAAC,CAAC,SAAS,IAAI,CAAC,IAAI,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,EAAE,SAAS,CAAC,CAAC;gBACxD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;gBAC7D,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;SACF;;;gBA3TJ,SAAS,SAAC;oBACT,QAAQ,EAAE,YAAY;oBACtB,QAAQ,EAAE,g1DA6BX;oBACC,MAAM,EAAE,CAAC,ggFAA4/E,CAAC;iBACvgF;;;;gBAtCC,UAAU;;;+BAuET,KAAK,SAAC,KAAK;+BAOX,KAAK,SAAC,KAAK;uCAOX,KAAK,SAAC,aAAa;uCAOnB,KAAK,SAAC,aAAa;4BAMnB,KAAK,SAAC,MAAM;oCAOZ,KAAK;6BACL,KAAK;iCACL,KAAK,SAAC,cAAc;gCAIpB,KAAK,SAAC,aAAa;8BAKnB,KAAK,SAAC,UAAU;2BAKhB,MAAM;sCAoJN,YAAY,SAAC,kBAAkB,cAC/B,YAAY,SAAC,iBAAiB;;6BAhRjC;EAyCwC,SAAS;SAApC,kBAAkB","sourcesContent":["import {\n  Component, Input, Output, EventEmitter,\n  ElementRef, OnInit, HostListener, SimpleChanges, OnChanges\n} from '@angular/core';\nimport { Utilities } from './utilities';\nimport { SliderHandlerEnum } from './slider-handler.enum';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\r\n                      'last-active': currentHandlerIndex === handlerIndex.left\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n        <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\r\n      <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\r\n    </div>\r\n    <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\r\n                      'last-active': currentHandlerIndex === handlerIndex.right\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\r\n      (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\" *ngIf=\"!hideValues\">\r\n    <span>{{initValues[handlerIndex.left]}}</span>\r\n    <span>{{initValues[handlerIndex.right]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n  public hideTooltip = false;\n  public hideValues = false;\n\n  public handlerIndex = SliderHandlerEnum;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.minSelected !== Number(value)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.maxSelected !== Number(value)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n  @Input() multiRange = true;\n  @Input('hide-tooltip')\n  set setHideTooltip(value: boolean) {\n    this.hideTooltip = this.toBoolean(value);\n  }\n  @Input('hide-values')\n  set setHideValues(value: boolean) {\n    this.hideValues = this.toBoolean(value);\n  }\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = this.toBoolean(value, 'disabled');\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.sliderInitiated) {\n      if (!this.isNullOrEmpty(changes.setMinSelectedValues)\n        && changes.setMinSelectedValues.previousValue === changes.setMinSelectedValues.currentValue) {\n        return;\n      }\n      if (!this.isNullOrEmpty(changes.setMaxSelectedValues)\n        && changes.setMaxSelectedValues.previousValue === changes.setMaxSelectedValues.currentValue) {\n        return;\n      }\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions.length = 0;\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      } else {\n        console.warn(`As 'step' value is too small compared to min & max value difference and slider width,\n          Step Indicator can't be displayed!. Provide slight large value for 'step'`);\n      }\n    } else {\n      this.stepIndicatorPositions.length = 0;\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n\n      if (!this.isNullOrEmpty(event.clientX)) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (!this.isNullOrEmpty(event.deltaX)) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n"]}

@@ -17,3 +17,3 @@ /**

function (arr) {
return arr.filter(function (value) { return !isNaN(value); }).length === arr.length;
return (arr && arr.length && arr.filter(function (value) { return !isNaN(value); }).length === arr.length) ? true : false;
};

@@ -32,2 +32,19 @@ /**

/**
* @param {?} obj
* @param {...?} allowedValues
* @return {?}
*/
Utilities.prototype.toBoolean = /**
* @param {?} obj
* @param {...?} allowedValues
* @return {?}
*/
function (obj) {
var allowedValues = [];
for (var _i = 1; _i < arguments.length; _i++) {
allowedValues[_i - 1] = arguments[_i];
}
return (obj === '' || obj === 'true' || allowedValues.indexOf(obj) !== -1) ? true : false;
};
/**
* @param {?} n

@@ -43,33 +60,34 @@ * @param {?} step

function (n, step) {
var /** @type {?} */ divisors = [];
var /** @type {?} */ divisorsSet1 = [];
var /** @type {?} */ divisorsSet2 = [];
var /** @type {?} */ sqrtNum = Math.sqrt(n);
var /** @type {?} */ newStep = -1;
for (var /** @type {?} */ i = 0; i < sqrtNum; i++) {
if (n % i === 0) {
if ((n / i) === i) {
divisors.push(i);
divisorsSet1.push(i);
}
else {
divisors.push(i);
divisors.push(n / i);
divisorsSet1.push(i);
divisorsSet2.push(n / i);
}
}
}
divisors.sort(function (a, b) {
a = Number(a);
b = Number(b);
if (a < b) {
return -1;
}
if (a > b) {
return 1;
}
return 0;
});
for (var /** @type {?} */ i = divisors.length - 1; i >= 0; i--) {
if (step > divisors[i]) {
step = divisors[i];
// Picking newStep by checking large set of divisors first
for (var /** @type {?} */ i = 0; i < divisorsSet2.length; i++) {
if (step > divisorsSet2[i]) {
newStep = divisorsSet2[i];
break;
}
}
return step;
if (newStep === -1) {
// checking set of small divisors if newStep didn't find out till.
for (var /** @type {?} */ i = divisorsSet1.length - 1; i >= 0; i--) {
if (step > divisorsSet1[i]) {
newStep = divisorsSet1[i];
break;
}
}
}
return (newStep === -1) ? 1 : newStep;
};

@@ -80,2 +98,2 @@ return Utilities;

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbnBuLXNsaWRlci8iLCJzb3VyY2VzIjpbImxpYi91dGlsaXRpZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUdBLElBQUE7Ozs7Ozs7SUFFUyxpQ0FBYTs7OztjQUFDLEdBQWE7UUFDaEMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsVUFBQyxLQUFLLElBQUssT0FBQSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBYixDQUFhLENBQUMsQ0FBQyxNQUFNLEtBQUssR0FBRyxDQUFDLE1BQU0sQ0FBQzs7Ozs7O0lBRTdELGlDQUFhOzs7O2NBQUMsR0FBUTtRQUMzQixNQUFNLENBQUMsR0FBRyxLQUFLLFNBQVMsSUFBSSxHQUFHLEtBQUssSUFBSSxJQUFJLEdBQUcsS0FBSyxFQUFFLENBQUM7Ozs7Ozs7SUFFbEQsMENBQXNCOzs7OztjQUFDLENBQVMsRUFBRSxJQUFZO1FBQ25ELHFCQUFNLFFBQVEsR0FBYSxFQUFFLENBQUM7UUFDOUIscUJBQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0IsR0FBRyxDQUFDLENBQUMscUJBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsT0FBTyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNoQixFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO29CQUNsQixRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2lCQUNsQjtnQkFBQyxJQUFJLENBQUMsQ0FBQztvQkFDTixRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO29CQUNqQixRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztpQkFDdEI7YUFDRjtTQUNGO1FBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFDLENBQUMsRUFBRSxDQUFDO1lBQ2pCLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDZCxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2QsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ1YsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ1g7WUFDRCxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDVixNQUFNLENBQUMsQ0FBQyxDQUFDO2FBQ1Y7WUFDRCxNQUFNLENBQUMsQ0FBQyxDQUFDO1NBQ1YsQ0FBQyxDQUFDO1FBQ0gsR0FBRyxDQUFDLENBQUMscUJBQUksQ0FBQyxHQUFHLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUM5QyxFQUFFLENBQUMsQ0FBQyxJQUFJLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDdkIsSUFBSSxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDbkIsS0FBSyxDQUFDO2FBQ1A7U0FDRjtRQUNELE1BQU0sQ0FBQyxJQUFJLENBQUM7O29CQXpDaEI7SUEyQ0MsQ0FBQTtBQXhDRCxxQkF3Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuXHJcbi8qVXRpbGl0aWVzICovXHJcbmV4cG9ydCBjbGFzcyBVdGlsaXRpZXMge1xyXG5cclxuICBwdWJsaWMgaXNOdW1iZXJBcnJheShhcnI6IG51bWJlcltdKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gYXJyLmZpbHRlcigodmFsdWUpID0+ICFpc05hTih2YWx1ZSkpLmxlbmd0aCA9PT0gYXJyLmxlbmd0aDtcclxuICB9XHJcbiAgcHVibGljIGlzTnVsbE9yRW1wdHkob2JqOiBhbnkpIHtcclxuICAgIHJldHVybiBvYmogPT09IHVuZGVmaW5lZCB8fCBvYmogPT09IG51bGwgfHwgb2JqID09PSAnJztcclxuICB9XHJcbiAgcHVibGljIGZpbmROZXh0VmFsaWRTdGVwVmFsdWUobjogbnVtYmVyLCBzdGVwOiBudW1iZXIpOiBudW1iZXIge1xyXG4gICAgY29uc3QgZGl2aXNvcnM6IG51bWJlcltdID0gW107XHJcbiAgICBjb25zdCBzcXJ0TnVtID0gTWF0aC5zcXJ0KG4pO1xyXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBzcXJ0TnVtOyBpKyspIHtcclxuICAgICAgaWYgKG4gJSBpID09PSAwKSB7XHJcbiAgICAgICAgaWYgKChuIC8gaSkgPT09IGkpIHtcclxuICAgICAgICAgIGRpdmlzb3JzLnB1c2goaSk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIGRpdmlzb3JzLnB1c2goaSk7XHJcbiAgICAgICAgICBkaXZpc29ycy5wdXNoKG4gLyBpKTtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIGRpdmlzb3JzLnNvcnQoKGEsIGIpID0+IHtcclxuICAgICAgYSA9IE51bWJlcihhKTtcclxuICAgICAgYiA9IE51bWJlcihiKTtcclxuICAgICAgaWYgKGEgPCBiKSB7XHJcbiAgICAgICAgcmV0dXJuIC0xO1xyXG4gICAgICB9XHJcbiAgICAgIGlmIChhID4gYikge1xyXG4gICAgICAgIHJldHVybiAxO1xyXG4gICAgICB9XHJcbiAgICAgIHJldHVybiAwO1xyXG4gICAgfSk7XHJcbiAgICBmb3IgKGxldCBpID0gZGl2aXNvcnMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcclxuICAgICAgaWYgKHN0ZXAgPiBkaXZpc29yc1tpXSkge1xyXG4gICAgICAgIHN0ZXAgPSBkaXZpc29yc1tpXTtcclxuICAgICAgICBicmVhaztcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHN0ZXA7XHJcbiAgfVxyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0aWVzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vbnBuLXNsaWRlci8iLCJzb3VyY2VzIjpbImxpYi91dGlsaXRpZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUdBLElBQUE7Ozs7Ozs7SUFFUyxpQ0FBYTs7OztjQUFDLEdBQWE7UUFDaEMsTUFBTSxDQUFDLENBQUMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxNQUFNLElBQUksR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFDLEtBQUssSUFBSyxPQUFBLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFiLENBQWEsQ0FBQyxDQUFDLE1BQU0sS0FBSyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDOzs7Ozs7SUFFbkcsaUNBQWE7Ozs7Y0FBQyxHQUFRO1FBQzNCLE1BQU0sQ0FBQyxHQUFHLEtBQUssU0FBUyxJQUFJLEdBQUcsS0FBSyxJQUFJLElBQUksR0FBRyxLQUFLLEVBQUUsQ0FBQzs7Ozs7OztJQUVsRCw2QkFBUzs7Ozs7Y0FBQyxHQUFRO1FBQUUsdUJBQWdCO2FBQWhCLFVBQWdCLEVBQWhCLHFCQUFnQixFQUFoQixJQUFnQjtZQUFoQixzQ0FBZ0I7O1FBQ3pDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsS0FBSyxFQUFFLElBQUksR0FBRyxLQUFLLE1BQU0sSUFBSSxhQUFhLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDOzs7Ozs7O0lBRXJGLDBDQUFzQjs7Ozs7Y0FBQyxDQUFTLEVBQUUsSUFBWTtRQUNuRCxxQkFBTSxZQUFZLEdBQWEsRUFBRSxDQUFDO1FBQ2xDLHFCQUFNLFlBQVksR0FBYSxFQUFFLENBQUM7UUFDbEMscUJBQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0IscUJBQUksT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2pCLEdBQUcsQ0FBQyxDQUFDLHFCQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE9BQU8sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ2pDLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDaEIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDbEIsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztpQkFDdEI7Z0JBQUMsSUFBSSxDQUFDLENBQUM7b0JBQ04sWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDckIsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7aUJBQzFCO2FBQ0Y7U0FDRjs7UUFFRCxHQUFHLENBQUMsQ0FBQyxxQkFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDN0MsRUFBRSxDQUFDLENBQUMsSUFBSSxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzNCLE9BQU8sR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzFCLEtBQUssQ0FBQzthQUNQO1NBQ0Y7UUFDRCxFQUFFLENBQUMsQ0FBQyxPQUFPLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDOztZQUNuQixHQUFHLENBQUMsQ0FBQyxxQkFBSSxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO2dCQUNsRCxFQUFFLENBQUMsQ0FBQyxJQUFJLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDM0IsT0FBTyxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDMUIsS0FBSyxDQUFDO2lCQUNQO2FBQ0Y7U0FDRjtRQUNELE1BQU0sQ0FBQyxDQUFDLE9BQU8sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQzs7b0JBNUMxQztJQThDQyxDQUFBO0FBM0NELHFCQTJDQyIsInNvdXJjZXNDb250ZW50IjpbIlxyXG5cclxuLypVdGlsaXRpZXMgKi9cclxuZXhwb3J0IGNsYXNzIFV0aWxpdGllcyB7XHJcblxyXG4gIHB1YmxpYyBpc051bWJlckFycmF5KGFycjogbnVtYmVyW10pOiBib29sZWFuIHtcclxuICAgIHJldHVybiAoYXJyICYmIGFyci5sZW5ndGggJiYgYXJyLmZpbHRlcigodmFsdWUpID0+ICFpc05hTih2YWx1ZSkpLmxlbmd0aCA9PT0gYXJyLmxlbmd0aCkgPyB0cnVlIDogZmFsc2U7XHJcbiAgfVxyXG4gIHB1YmxpYyBpc051bGxPckVtcHR5KG9iajogYW55KTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gb2JqID09PSB1bmRlZmluZWQgfHwgb2JqID09PSBudWxsIHx8IG9iaiA9PT0gJyc7XHJcbiAgfVxyXG4gIHB1YmxpYyB0b0Jvb2xlYW4ob2JqOiBhbnksIC4uLmFsbG93ZWRWYWx1ZXMpOiBib29sZWFuIHtcclxuICAgIHJldHVybiAob2JqID09PSAnJyB8fCBvYmogPT09ICd0cnVlJyB8fCBhbGxvd2VkVmFsdWVzLmluZGV4T2Yob2JqKSAhPT0gLTEpID8gdHJ1ZSA6IGZhbHNlO1xyXG4gIH1cclxuICBwdWJsaWMgZmluZE5leHRWYWxpZFN0ZXBWYWx1ZShuOiBudW1iZXIsIHN0ZXA6IG51bWJlcik6IG51bWJlciB7XHJcbiAgICBjb25zdCBkaXZpc29yc1NldDE6IG51bWJlcltdID0gW107XHJcbiAgICBjb25zdCBkaXZpc29yc1NldDI6IG51bWJlcltdID0gW107XHJcbiAgICBjb25zdCBzcXJ0TnVtID0gTWF0aC5zcXJ0KG4pO1xyXG4gICAgbGV0IG5ld1N0ZXAgPSAtMTtcclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgc3FydE51bTsgaSsrKSB7XHJcbiAgICAgIGlmIChuICUgaSA9PT0gMCkge1xyXG4gICAgICAgIGlmICgobiAvIGkpID09PSBpKSB7XHJcbiAgICAgICAgICBkaXZpc29yc1NldDEucHVzaChpKTtcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgZGl2aXNvcnNTZXQxLnB1c2goaSk7XHJcbiAgICAgICAgICBkaXZpc29yc1NldDIucHVzaChuIC8gaSk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICAvLyBQaWNraW5nIG5ld1N0ZXAgYnkgY2hlY2tpbmcgbGFyZ2Ugc2V0IG9mIGRpdmlzb3JzIGZpcnN0XHJcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGRpdmlzb3JzU2V0Mi5sZW5ndGg7IGkrKykge1xyXG4gICAgICBpZiAoc3RlcCA+IGRpdmlzb3JzU2V0MltpXSkge1xyXG4gICAgICAgIG5ld1N0ZXAgPSBkaXZpc29yc1NldDJbaV07XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIGlmIChuZXdTdGVwID09PSAtMSkgeyAvLyBjaGVja2luZyBzZXQgb2Ygc21hbGwgZGl2aXNvcnMgaWYgbmV3U3RlcCBkaWRuJ3QgZmluZCBvdXQgdGlsbC5cclxuICAgICAgZm9yIChsZXQgaSA9IGRpdmlzb3JzU2V0MS5sZW5ndGggLSAxOyBpID49IDA7IGktLSkge1xyXG4gICAgICAgIGlmIChzdGVwID4gZGl2aXNvcnNTZXQxW2ldKSB7XHJcbiAgICAgICAgICBuZXdTdGVwID0gZGl2aXNvcnNTZXQxW2ldO1xyXG4gICAgICAgICAgYnJlYWs7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKG5ld1N0ZXAgPT09IC0xKSA/IDEgOiBuZXdTdGVwO1xyXG4gIH1cclxufVxyXG4iXX0=

@@ -14,3 +14,3 @@ import { Component, Input, Output, EventEmitter, ElementRef, HostListener, NgModule } from '@angular/core';

isNumberArray(arr) {
return arr.filter((value) => !isNaN(value)).length === arr.length;
return (arr && arr.length && arr.filter((value) => !isNaN(value)).length === arr.length) ? true : false;
}

@@ -25,2 +25,10 @@ /**

/**
* @param {?} obj
* @param {...?} allowedValues
* @return {?}
*/
toBoolean(obj, ...allowedValues) {
return (obj === '' || obj === 'true' || allowedValues.indexOf(obj) !== -1) ? true : false;
}
/**
* @param {?} n

@@ -31,33 +39,34 @@ * @param {?} step

findNextValidStepValue(n, step) {
const /** @type {?} */ divisors = [];
const /** @type {?} */ divisorsSet1 = [];
const /** @type {?} */ divisorsSet2 = [];
const /** @type {?} */ sqrtNum = Math.sqrt(n);
let /** @type {?} */ newStep = -1;
for (let /** @type {?} */ i = 0; i < sqrtNum; i++) {
if (n % i === 0) {
if ((n / i) === i) {
divisors.push(i);
divisorsSet1.push(i);
}
else {
divisors.push(i);
divisors.push(n / i);
divisorsSet1.push(i);
divisorsSet2.push(n / i);
}
}
}
divisors.sort((a, b) => {
a = Number(a);
b = Number(b);
if (a < b) {
return -1;
}
if (a > b) {
return 1;
}
return 0;
});
for (let /** @type {?} */ i = divisors.length - 1; i >= 0; i--) {
if (step > divisors[i]) {
step = divisors[i];
// Picking newStep by checking large set of divisors first
for (let /** @type {?} */ i = 0; i < divisorsSet2.length; i++) {
if (step > divisorsSet2[i]) {
newStep = divisorsSet2[i];
break;
}
}
return step;
if (newStep === -1) {
// checking set of small divisors if newStep didn't find out till.
for (let /** @type {?} */ i = divisorsSet1.length - 1; i >= 0; i--) {
if (step > divisorsSet1[i]) {
newStep = divisorsSet1[i];
break;
}
}
}
return (newStep === -1) ? 1 : newStep;
}

@@ -70,2 +79,14 @@ }

*/
/** @enum {number} */
const SliderHandlerEnum = {
left: 0,
right: 1,
};
SliderHandlerEnum[SliderHandlerEnum.left] = "left";
SliderHandlerEnum[SliderHandlerEnum.right] = "right";
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class NpnSliderComponent extends Utilities {

@@ -95,3 +116,7 @@ /**

this.isDisabled = false;
this.hideTooltip = false;
this.hideValues = false;
this.handlerIndex = SliderHandlerEnum;
this.showStepIndicator = false;
this.multiRange = true;
this.onChange = new EventEmitter();

@@ -122,3 +147,3 @@ }

set setMinSelectedValues(value) {
if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {
if (!isNaN(value) && this.minSelected !== Number(value)) {
this.minSelected = Number(value);

@@ -132,3 +157,3 @@ }

set setMaxSelectedValues(value) {
if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {
if (!isNaN(value) && this.maxSelected !== Number(value)) {
this.maxSelected = Number(value);

@@ -150,4 +175,18 @@ }

*/
set setHideTooltip(value) {
this.hideTooltip = this.toBoolean(value);
}
/**
* @param {?} value
* @return {?}
*/
set setHideValues(value) {
this.hideValues = this.toBoolean(value);
}
/**
* @param {?} value
* @return {?}
*/
set setDisabled(value) {
this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;
this.isDisabled = this.toBoolean(value, 'disabled');
}

@@ -165,3 +204,11 @@ /**

ngOnChanges(changes) {
if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {
if (this.sliderInitiated) {
if (!this.isNullOrEmpty(changes["setMinSelectedValues"])
&& changes["setMinSelectedValues"].previousValue === changes["setMinSelectedValues"].currentValue) {
return;
}
if (!this.isNullOrEmpty(changes["setMaxSelectedValues"])
&& changes["setMaxSelectedValues"].previousValue === changes["setMaxSelectedValues"].currentValue) {
return;
}
this.resetModel();

@@ -202,6 +249,2 @@ }

}
if (this.sliderWidth / (this.totalDiff / this.step) < 10) {
console.error(`'step' value is too small compared to min & max value difference and slider width.
Slider might not work properly!. Provide slight large value for 'step'`);
}
this.initializeStepIndicator();

@@ -247,3 +290,3 @@ this.setHandlerPosition();

if (this.showStepIndicator) {
this.stepIndicatorPositions = [];
this.stepIndicatorPositions.length = 0;
const /** @type {?} */ numOfStepIndicators = this.totalDiff / this.step;

@@ -258,3 +301,10 @@ if (this.sliderWidth / numOfStepIndicators >= 10) {

}
else {
console.warn(`As 'step' value is too small compared to min & max value difference and slider width,
Step Indicator can't be displayed!. Provide slight large value for 'step'`);
}
}
else {
this.stepIndicatorPositions.length = 0;
}
}

@@ -270,3 +320,3 @@ /**

if (!privateChange) {
this.onChange.emit(this.currentValues);
this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);
}

@@ -325,3 +375,3 @@ }

if (!this.isDisabled) {
if (event.clientX) {
if (!this.isNullOrEmpty(event.clientX)) {
this.startClientX = event.clientX;

@@ -331,3 +381,3 @@ this.isMouseEventStart = true;

}
else if (event.deltaX) {
else if (!this.isNullOrEmpty(event.deltaX)) {
this.startClientX = event.deltaX;

@@ -367,32 +417,31 @@ this.isTouchEventStart = true;

<div class="slider" [class.disabled]="isDisabled">
<div class="bar" (mousemove)="handlerSliding($event)"
(panmove)="handlerSliding($event)">
<span class="left-handle"
[ngClass]="{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}"
[style.left.%]="handlerX[0]"
(mousedown)="setHandlerActive($event,0)"
(panstart)="setHandlerActive($event,0)">
<span class="handle-tooltip">{{currentValues[0]}}</span>
<div class="bar" (mousemove)="handlerSliding($event)" (panmove)="handlerSliding($event)">
<span class="left-handle" [ngClass]="{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,
'last-active': currentHandlerIndex === handlerIndex.left
}"
[style.left.%]="handlerX[handlerIndex.left]" (mousedown)="setHandlerActive($event, handlerIndex.left)" (panstart)="setHandlerActive($event, handlerIndex.left)">
<span *ngIf="!hideTooltip" class="handle-tooltip">{{currentValues[handlerIndex.left]}}</span>
</span>
<div class="filler">
<div class="step-indicators">
<span *ngFor="let stepPos of stepIndicatorPositions" [style.left.px]="stepPos"></span>
<span *ngFor="let stepPos of stepIndicatorPositions" [style.left.px]="stepPos"></span>
</div>
<span [style.left.%]="handlerX[0]" [style.width.%]="handlerX[1] - handlerX[0]"></span>
<span *ngIf="multiRange" [style.left.%]="handlerX[0]" [style.width.%]="handlerX[handlerIndex.right] - handlerX[handlerIndex.left]"></span>
<span *ngIf="!multiRange" [style.left.%]="0" [style.width.%]="handlerX[0]"></span>
</div>
<span class="right-handle"
[ngClass]="{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}"
[style.left.%]="handlerX[1]"
(mousedown)="setHandlerActive($event,1)"
(panstart)="setHandlerActive($event,1)">
<span class="handle-tooltip">{{currentValues[1]}}</span>
<span *ngIf="multiRange" class="right-handle" [ngClass]="{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,
'last-active': currentHandlerIndex === handlerIndex.right
}"
[style.left.%]="handlerX[handlerIndex.right]" (mousedown)="setHandlerActive($event, handlerIndex.right)"
(panstart)="setHandlerActive($event, handlerIndex.right)">
<span *ngIf="!hideTooltip" class="handle-tooltip">{{currentValues[handlerIndex.right]}}</span>
</span>
</div>
<div class="values">
<span>{{initValues[0]}}</span>
<span>{{initValues[1]}}</span>
<div class="values" *ngIf="!hideValues">
<span>{{initValues[handlerIndex.left]}}</span>
<span>{{initValues[handlerIndex.right]}}</span>
</div>
</div>
`,
styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:"";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:"";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]
styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:"";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:"";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]
},] },

@@ -411,2 +460,5 @@ ];

showStepIndicator: [{ type: Input }],
multiRange: [{ type: Input }],
setHideTooltip: [{ type: Input, args: ['hide-tooltip',] }],
setHideValues: [{ type: Input, args: ['hide-values',] }],
setDisabled: [{ type: Input, args: ['disabled',] }],

@@ -445,2 +497,2 @@ onChange: [{ type: Output }],

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"npn-slider.js.map","sources":["ng://npn-slider/lib/utilities.ts","ng://npn-slider/lib/npn-slider.component.ts","ng://npn-slider/lib/npn-slider.module.ts"],"sourcesContent":["\r\n\r\n/*Utilities */\r\nexport class Utilities {\r\n\r\n  public isNumberArray(arr: number[]): boolean {\r\n    return arr.filter((value) => !isNaN(value)).length === arr.length;\r\n  }\r\n  public isNullOrEmpty(obj: any) {\r\n    return obj === undefined || obj === null || obj === '';\r\n  }\r\n  public findNextValidStepValue(n: number, step: number): number {\r\n    const divisors: number[] = [];\r\n    const sqrtNum = Math.sqrt(n);\r\n    for (let i = 0; i < sqrtNum; i++) {\r\n      if (n % i === 0) {\r\n        if ((n / i) === i) {\r\n          divisors.push(i);\r\n        } else {\r\n          divisors.push(i);\r\n          divisors.push(n / i);\r\n        }\r\n      }\r\n    }\r\n    divisors.sort((a, b) => {\r\n      a = Number(a);\r\n      b = Number(b);\r\n      if (a < b) {\r\n        return -1;\r\n      }\r\n      if (a > b) {\r\n        return 1;\r\n      }\r\n      return 0;\r\n    });\r\n    for (let i = divisors.length - 1; i >= 0; i--) {\r\n      if (step > divisors[i]) {\r\n        step = divisors[i];\r\n        break;\r\n      }\r\n    }\r\n    return step;\r\n  }\r\n}\r\n","import { Component, Input, Output, EventEmitter,\n          ElementRef, OnInit, HostListener, SimpleChanges, OnChanges } from '@angular/core';\nimport { Utilities } from './utilities';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\r\n                   (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\r\n          [style.left.%]=\"handlerX[0]\"\r\n          (mousedown)=\"setHandlerActive($event,0)\"\r\n          (panstart)=\"setHandlerActive($event,0)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n            <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\r\n    </div>\r\n    <span class=\"right-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\r\n          [style.left.%]=\"handlerX[1]\"\r\n          (mousedown)=\"setHandlerActive($event,1)\"\r\n          (panstart)=\"setHandlerActive($event,1)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\">\r\n    <span>{{initValues[0]}}</span>\r\n    <span>{{initValues[1]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    if (this.sliderWidth / (this.totalDiff / this.step) < 10) {\n      console.error(`'step' value is too small compared to min & max value difference and slider width.\n        Slider might not work properly!. Provide slight large value for 'step'`);\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions = [];\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      }\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit(this.currentValues);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n      if (event.clientX) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (event.deltaX) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n","import { BrowserModule } from '@angular/platform-browser';\nimport { NgModule } from '@angular/core';\nimport { NpnSliderComponent } from './npn-slider.component';\n\n@NgModule({\n  imports: [\n    BrowserModule\n  ],\n  declarations: [NpnSliderComponent],\n  exports: [NpnSliderComponent]\n})\nexport class NpnSliderModule { }\n"],"names":[],"mappings":";;;;;;;AAGA;;;;;IAES,aAAa,CAAC,GAAa;QAChC,OAAO,GAAG,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,CAAC;;;;;;IAE7D,aAAa,CAAC,GAAQ;QAC3B,OAAO,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,EAAE,CAAC;;;;;;;IAElD,sBAAsB,CAAC,CAAS,EAAE,IAAY;QACnD,uBAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,uBAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,KAAK,qBAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE;YAChC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBACf,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;oBACjB,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBAClB;qBAAM;oBACL,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBACjB,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;iBACtB;aACF;SACF;QACD,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YACjB,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACd,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACd,IAAI,CAAC,GAAG,CAAC,EAAE;gBACT,OAAO,CAAC,CAAC,CAAC;aACX;YACD,IAAI,CAAC,GAAG,CAAC,EAAE;gBACT,OAAO,CAAC,CAAC;aACV;YACD,OAAO,CAAC,CAAC;SACV,CAAC,CAAC;QACH,KAAK,qBAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YAC7C,IAAI,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE;gBACtB,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;gBACnB,MAAM;aACP;SACF;QACD,OAAO,IAAI,CAAC;;CAEf;;;;;;AC3CD,wBAuCgC,SAAQ,SAAS;;;;IAwB/C,YAAoB,EAAc;QAChC,KAAK,EAAE,CAAC;QADU,OAAE,GAAF,EAAE,CAAY;2BAvBZ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;oBAChB,CAAC;2BACM,CAAC;yBACH,CAAC;4BACE,CAAC;0BACH,CAAC;2BACA,CAAC;+BAKG,KAAK;0BAED,EAAE;6BACC,CAAC,CAAC,EAAE,CAAC,CAAC;wBACX,CAAC,CAAC,EAAE,CAAC,CAAC;+BACT,KAAK;iCACH,KAAK;iCACL,KAAK;mCACH,CAAC;sCACE,EAAE;0BACd,KAAK;iCAwCI,KAAK;wBAOb,IAAI,YAAY,EAAY;KA3ChD;;;;;IAED,IACI,YAAY,CAAC,KAAa;QAC5B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAC/B;KACF;;;;;IAED,IACI,YAAY,CAAC,KAAa;QAC5B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAC/B;KACF;;;;;IAED,IACI,oBAAoB,CAAC,KAAa;QACpC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACzD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAClC;KACF;;;;;IAED,IACI,oBAAoB,CAAC,KAAa;QACpC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACzD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAClC;KACF;;;;;IACD,IACI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;SAC3B;KACF;;;;;IAID,IACI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,UAAU,GAAG,CAAC,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,UAAU,IAAI,IAAI,GAAG,KAAK,CAAC;KAC7E;;;;IAID,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;;;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE;YAChG,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;KACF;;;;IAGM,gBAAgB;QACrB,IAAI;;YAEF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YAC7E,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;QAAC,wBAAO,CAAC,EAAE;YACV,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SAClB;;;;;IAIK,UAAU;QAChB,IAAI,CAAC,oBAAoB,EAAE,CAAC;;QAE5B,IAAI,CAAC,WAAW,GAAG;YACjB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;SAC3C,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,QAAQ,KAAK,SAAS,GAAG,QAAQ,EAAE,CAAC,CAAC,CAAC;;QAG3F,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE;YACpC,uBAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACvE,OAAO,CAAC,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,IAAI,GAAG,gBAAgB,GAAG,OAAO,GAAG,mBAAmB,CAAC,CAAC;YACpG,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;SACrB;QACD,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE;YACxD,OAAO,CAAC,KAAK,CAAC;+EAC2D,CAAC,CAAC;SAC5E;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;;;;;IAIpB,oBAAoB;QAC1B,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YAC1E,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;aAAM,IAAI,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE;YACxC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SACvC;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;;;;YAIjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC;YAC/E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC;YAE/E,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE;gBACxE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE;gBACxE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE;gBACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;aAClC;YACD,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAAC;SACrE;;;;;IAIK,uBAAuB;QAC7B,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;YACjC,uBAAM,mBAAmB,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;YACvD,IAAI,IAAI,CAAC,WAAW,GAAG,mBAAmB,IAAI,EAAE,EAAE;gBAChD,uBAAM,SAAS,GAAG,IAAI,CAAC,WAAW,GAAG,mBAAmB,CAAC;gBACzD,qBAAI,YAAY,GAAG,SAAS,CAAC;gBAC7B,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,mBAAmB,GAAG,CAAC,EAAE;oBACnE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3D,YAAY,IAAI,SAAS,CAAC;iBAC3B;aACF;SACF;;;;;;;IAIK,kBAAkB,CAAC,UAAoB,EAAE,gBAAyB,KAAK;QAC7E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,aAAa,EAAE;YAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACxC;;;;;;IAIK,gBAAgB,CAAC,UAAoB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;;;;;IAI7C,kBAAkB;QACxB,qBAAI,YAAY,GAAG,CAAC,CAAC;;QAErB,IAAI,CAAC,kBAAkB,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;SACzC,CAAC,CAAC;;QAEH,KAAK,qBAAI,CAAC,GAAG,CAAC,mBAAE,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;YAC/D,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,IAAI,GAAG,CAAC;SAC1D;;;;;;;IAIK,aAAa,CAAC,KAAa,EAAE,KAAa;QAChD,IAAI,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE;YACjB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;SACnD;QACD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;;;;;IAUlC,mBAAmB;QACjB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;KAC9B;;;;;;IAOM,gBAAgB,CAAC,KAAU,EAAE,YAAoB;QACtD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB,IAAI,KAAK,CAAC,OAAO,EAAE;gBACjB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC;gBAClC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;iBAAM,IAAI,KAAK,CAAC,MAAM,EAAE;gBACvB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC;gBACjC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;aAChC;YACD,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBACpD,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;gBACxC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;gBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;gBACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;SACF;;;;;;IASI,cAAc,CAAC,KAAU;QAC9B,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,OAAO,MAAM,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,MAAM,CAAC,EAAE;YACzF,uBAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;YACrH,uBAAM,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3C,uBAAM,UAAU,GAAG,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC7C,IAAI,SAAS,IAAI,CAAC,IAAI,UAAU,IAAI,CAAC,EAAE;gBACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,EAAE,SAAS,CAAC,CAAC;gBACxD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;gBAC7D,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC3B;SACF;;;;YArSJ,SAAS,SAAC;gBACT,QAAQ,EAAE,YAAY;gBACtB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8BX;gBACC,MAAM,EAAE,CAAC,4/EAA4/E,CAAC;aACvgF;;;;YArCS,UAAU;;;2BAkEjB,KAAK,SAAC,KAAK;2BAOX,KAAK,SAAC,KAAK;mCAOX,KAAK,SAAC,aAAa;mCAOnB,KAAK,SAAC,aAAa;wBAMnB,KAAK,SAAC,MAAM;gCAOZ,KAAK;0BAEL,KAAK,SAAC,UAAU;uBAKhB,MAAM;kCA2IN,YAAY,SAAC,kBAAkB,cAC/B,YAAY,SAAC,iBAAiB;;;;;;;ACxPjC;;;YAIC,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,aAAa;iBACd;gBACD,YAAY,EAAE,CAAC,kBAAkB,CAAC;gBAClC,OAAO,EAAE,CAAC,kBAAkB,CAAC;aAC9B;;;;;;;;;;;;;;;"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"npn-slider.js.map","sources":["ng://npn-slider/lib/utilities.ts","ng://npn-slider/lib/npn-slider.component.ts","ng://npn-slider/lib/npn-slider.module.ts"],"sourcesContent":["\r\n\r\n/*Utilities */\r\nexport class Utilities {\r\n\r\n  public isNumberArray(arr: number[]): boolean {\r\n    return (arr && arr.length && arr.filter((value) => !isNaN(value)).length === arr.length) ? true : false;\r\n  }\r\n  public isNullOrEmpty(obj: any): boolean {\r\n    return obj === undefined || obj === null || obj === '';\r\n  }\r\n  public toBoolean(obj: any, ...allowedValues): boolean {\r\n    return (obj === '' || obj === 'true' || allowedValues.indexOf(obj) !== -1) ? true : false;\r\n  }\r\n  public findNextValidStepValue(n: number, step: number): number {\r\n    const divisorsSet1: number[] = [];\r\n    const divisorsSet2: number[] = [];\r\n    const sqrtNum = Math.sqrt(n);\r\n    let newStep = -1;\r\n    for (let i = 0; i < sqrtNum; i++) {\r\n      if (n % i === 0) {\r\n        if ((n / i) === i) {\r\n          divisorsSet1.push(i);\r\n        } else {\r\n          divisorsSet1.push(i);\r\n          divisorsSet2.push(n / i);\r\n        }\r\n      }\r\n    }\r\n    // Picking newStep by checking large set of divisors first\r\n    for (let i = 0; i < divisorsSet2.length; i++) {\r\n      if (step > divisorsSet2[i]) {\r\n        newStep = divisorsSet2[i];\r\n        break;\r\n      }\r\n    }\r\n    if (newStep === -1) { // checking set of small divisors if newStep didn't find out till.\r\n      for (let i = divisorsSet1.length - 1; i >= 0; i--) {\r\n        if (step > divisorsSet1[i]) {\r\n          newStep = divisorsSet1[i];\r\n          break;\r\n        }\r\n      }\r\n    }\r\n    return (newStep === -1) ? 1 : newStep;\r\n  }\r\n}\r\n","import {\n  Component, Input, Output, EventEmitter,\n  ElementRef, OnInit, HostListener, SimpleChanges, OnChanges\n} from '@angular/core';\nimport { Utilities } from './utilities';\nimport { SliderHandlerEnum } from './slider-handler.enum';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\r\n                      'last-active': currentHandlerIndex === handlerIndex.left\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n        <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\r\n      <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\r\n    </div>\r\n    <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\r\n                      'last-active': currentHandlerIndex === handlerIndex.right\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\r\n      (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\" *ngIf=\"!hideValues\">\r\n    <span>{{initValues[handlerIndex.left]}}</span>\r\n    <span>{{initValues[handlerIndex.right]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n  public hideTooltip = false;\n  public hideValues = false;\n\n  public handlerIndex = SliderHandlerEnum;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.minSelected !== Number(value)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.maxSelected !== Number(value)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n  @Input() multiRange = true;\n  @Input('hide-tooltip')\n  set setHideTooltip(value: boolean) {\n    this.hideTooltip = this.toBoolean(value);\n  }\n  @Input('hide-values')\n  set setHideValues(value: boolean) {\n    this.hideValues = this.toBoolean(value);\n  }\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = this.toBoolean(value, 'disabled');\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.sliderInitiated) {\n      if (!this.isNullOrEmpty(changes.setMinSelectedValues)\n        && changes.setMinSelectedValues.previousValue === changes.setMinSelectedValues.currentValue) {\n        return;\n      }\n      if (!this.isNullOrEmpty(changes.setMaxSelectedValues)\n        && changes.setMaxSelectedValues.previousValue === changes.setMaxSelectedValues.currentValue) {\n        return;\n      }\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions.length = 0;\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      } else {\n        console.warn(`As 'step' value is too small compared to min & max value difference and slider width,\n          Step Indicator can't be displayed!. Provide slight large value for 'step'`);\n      }\n    } else {\n      this.stepIndicatorPositions.length = 0;\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n\n      if (!this.isNullOrEmpty(event.clientX)) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (!this.isNullOrEmpty(event.deltaX)) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n","import { BrowserModule } from '@angular/platform-browser';\nimport { NgModule } from '@angular/core';\nimport { NpnSliderComponent } from './npn-slider.component';\n\n@NgModule({\n  imports: [\n    BrowserModule\n  ],\n  declarations: [NpnSliderComponent],\n  exports: [NpnSliderComponent]\n})\nexport class NpnSliderModule { }\n"],"names":[],"mappings":"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"}

@@ -21,3 +21,3 @@ import { __extends } from 'tslib';

function (arr) {
return arr.filter(function (value) { return !isNaN(value); }).length === arr.length;
return (arr && arr.length && arr.filter(function (value) { return !isNaN(value); }).length === arr.length) ? true : false;
};

@@ -36,2 +36,19 @@ /**

/**
* @param {?} obj
* @param {...?} allowedValues
* @return {?}
*/
Utilities.prototype.toBoolean = /**
* @param {?} obj
* @param {...?} allowedValues
* @return {?}
*/
function (obj) {
var allowedValues = [];
for (var _i = 1; _i < arguments.length; _i++) {
allowedValues[_i - 1] = arguments[_i];
}
return (obj === '' || obj === 'true' || allowedValues.indexOf(obj) !== -1) ? true : false;
};
/**
* @param {?} n

@@ -47,33 +64,34 @@ * @param {?} step

function (n, step) {
var /** @type {?} */ divisors = [];
var /** @type {?} */ divisorsSet1 = [];
var /** @type {?} */ divisorsSet2 = [];
var /** @type {?} */ sqrtNum = Math.sqrt(n);
var /** @type {?} */ newStep = -1;
for (var /** @type {?} */ i = 0; i < sqrtNum; i++) {
if (n % i === 0) {
if ((n / i) === i) {
divisors.push(i);
divisorsSet1.push(i);
}
else {
divisors.push(i);
divisors.push(n / i);
divisorsSet1.push(i);
divisorsSet2.push(n / i);
}
}
}
divisors.sort(function (a, b) {
a = Number(a);
b = Number(b);
if (a < b) {
return -1;
}
if (a > b) {
return 1;
}
return 0;
});
for (var /** @type {?} */ i = divisors.length - 1; i >= 0; i--) {
if (step > divisors[i]) {
step = divisors[i];
// Picking newStep by checking large set of divisors first
for (var /** @type {?} */ i = 0; i < divisorsSet2.length; i++) {
if (step > divisorsSet2[i]) {
newStep = divisorsSet2[i];
break;
}
}
return step;
if (newStep === -1) {
// checking set of small divisors if newStep didn't find out till.
for (var /** @type {?} */ i = divisorsSet1.length - 1; i >= 0; i--) {
if (step > divisorsSet1[i]) {
newStep = divisorsSet1[i];
break;
}
}
}
return (newStep === -1) ? 1 : newStep;
};

@@ -87,2 +105,14 @@ return Utilities;

*/
/** @enum {number} */
var SliderHandlerEnum = {
left: 0,
right: 1,
};
SliderHandlerEnum[SliderHandlerEnum.left] = "left";
SliderHandlerEnum[SliderHandlerEnum.right] = "right";
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
var NpnSliderComponent = /** @class */ (function (_super) {

@@ -110,3 +140,7 @@ __extends(NpnSliderComponent, _super);

_this.isDisabled = false;
_this.hideTooltip = false;
_this.hideValues = false;
_this.handlerIndex = SliderHandlerEnum;
_this.showStepIndicator = false;
_this.multiRange = true;
_this.onChange = new EventEmitter();

@@ -147,3 +181,3 @@ return _this;

function (value) {
if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {
if (!isNaN(value) && this.minSelected !== Number(value)) {
this.minSelected = Number(value);

@@ -161,3 +195,3 @@ }

function (value) {
if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {
if (!isNaN(value) && this.maxSelected !== Number(value)) {
this.maxSelected = Number(value);

@@ -182,2 +216,24 @@ }

});
Object.defineProperty(NpnSliderComponent.prototype, "setHideTooltip", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.hideTooltip = this.toBoolean(value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(NpnSliderComponent.prototype, "setHideValues", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.hideValues = this.toBoolean(value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(NpnSliderComponent.prototype, "setDisabled", {

@@ -189,3 +245,3 @@ set: /**

function (value) {
this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;
this.isDisabled = this.toBoolean(value, 'disabled');
},

@@ -213,3 +269,11 @@ enumerable: true,

function (changes) {
if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {
if (this.sliderInitiated) {
if (!this.isNullOrEmpty(changes["setMinSelectedValues"])
&& changes["setMinSelectedValues"].previousValue === changes["setMinSelectedValues"].currentValue) {
return;
}
if (!this.isNullOrEmpty(changes["setMaxSelectedValues"])
&& changes["setMaxSelectedValues"].previousValue === changes["setMaxSelectedValues"].currentValue) {
return;
}
this.resetModel();

@@ -256,5 +320,2 @@ }

}
if (this.sliderWidth / (this.totalDiff / this.step) < 10) {
console.error("'step' value is too small compared to min & max value difference and slider width.\n Slider might not work properly!. Provide slight large value for 'step'");
}
this.initializeStepIndicator();

@@ -306,3 +367,3 @@ this.setHandlerPosition();

if (this.showStepIndicator) {
this.stepIndicatorPositions = [];
this.stepIndicatorPositions.length = 0;
var /** @type {?} */ numOfStepIndicators = this.totalDiff / this.step;

@@ -317,3 +378,9 @@ if (this.sliderWidth / numOfStepIndicators >= 10) {

}
else {
console.warn("As 'step' value is too small compared to min & max value difference and slider width,\n Step Indicator can't be displayed!. Provide slight large value for 'step'");
}
}
else {
this.stepIndicatorPositions.length = 0;
}
};

@@ -335,3 +402,3 @@ /**

if (!privateChange) {
this.onChange.emit(this.currentValues);
this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);
}

@@ -415,3 +482,3 @@ };

if (!this.isDisabled) {
if (event.clientX) {
if (!this.isNullOrEmpty(event.clientX)) {
this.startClientX = event.clientX;

@@ -421,3 +488,3 @@ this.isMouseEventStart = true;

}
else if (event.deltaX) {
else if (!this.isNullOrEmpty(event.deltaX)) {
this.startClientX = event.deltaX;

@@ -458,4 +525,4 @@ this.isTouchEventStart = true;

selector: 'npn-slider',
template: "<!--npn-slider template-->\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\n <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\n (panmove)=\"handlerSliding($event)\">\n <span class=\"left-handle\"\n [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\n [style.left.%]=\"handlerX[0]\"\n (mousedown)=\"setHandlerActive($event,0)\"\n (panstart)=\"setHandlerActive($event,0)\">\n <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\n </span>\n <div class=\"filler\">\n <div class=\"step-indicators\">\n <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\n </div>\n <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\n </div>\n <span class=\"right-handle\"\n [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\n [style.left.%]=\"handlerX[1]\"\n (mousedown)=\"setHandlerActive($event,1)\"\n (panstart)=\"setHandlerActive($event,1)\">\n <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\n </span>\n </div>\n <div class=\"values\">\n <span>{{initValues[0]}}</span>\n <span>{{initValues[1]}}</span>\n </div>\n</div>\n",
styles: [".slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}"]
template: "<!--npn-slider template-->\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\n <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\n <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\n 'last-active': currentHandlerIndex === handlerIndex.left\n }\"\n [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\n <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\n </span>\n <div class=\"filler\">\n <div class=\"step-indicators\">\n <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\n </div>\n <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\n <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\n </div>\n <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\n 'last-active': currentHandlerIndex === handlerIndex.right\n }\"\n [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\n (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\n <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\n </span>\n </div>\n <div class=\"values\" *ngIf=\"!hideValues\">\n <span>{{initValues[handlerIndex.left]}}</span>\n <span>{{initValues[handlerIndex.right]}}</span>\n </div>\n</div>\n",
styles: [".slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}"]
},] },

@@ -474,2 +541,5 @@ ];

showStepIndicator: [{ type: Input }],
multiRange: [{ type: Input }],
setHideTooltip: [{ type: Input, args: ['hide-tooltip',] }],
setHideValues: [{ type: Input, args: ['hide-values',] }],
setDisabled: [{ type: Input, args: ['disabled',] }],

@@ -513,2 +583,2 @@ onChange: [{ type: Output }],

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"npn-slider.js.map","sources":["ng://npn-slider/lib/utilities.ts","ng://npn-slider/lib/npn-slider.component.ts","ng://npn-slider/lib/npn-slider.module.ts"],"sourcesContent":["\r\n\r\n/*Utilities */\r\nexport class Utilities {\r\n\r\n  public isNumberArray(arr: number[]): boolean {\r\n    return arr.filter((value) => !isNaN(value)).length === arr.length;\r\n  }\r\n  public isNullOrEmpty(obj: any) {\r\n    return obj === undefined || obj === null || obj === '';\r\n  }\r\n  public findNextValidStepValue(n: number, step: number): number {\r\n    const divisors: number[] = [];\r\n    const sqrtNum = Math.sqrt(n);\r\n    for (let i = 0; i < sqrtNum; i++) {\r\n      if (n % i === 0) {\r\n        if ((n / i) === i) {\r\n          divisors.push(i);\r\n        } else {\r\n          divisors.push(i);\r\n          divisors.push(n / i);\r\n        }\r\n      }\r\n    }\r\n    divisors.sort((a, b) => {\r\n      a = Number(a);\r\n      b = Number(b);\r\n      if (a < b) {\r\n        return -1;\r\n      }\r\n      if (a > b) {\r\n        return 1;\r\n      }\r\n      return 0;\r\n    });\r\n    for (let i = divisors.length - 1; i >= 0; i--) {\r\n      if (step > divisors[i]) {\r\n        step = divisors[i];\r\n        break;\r\n      }\r\n    }\r\n    return step;\r\n  }\r\n}\r\n","import { Component, Input, Output, EventEmitter,\n          ElementRef, OnInit, HostListener, SimpleChanges, OnChanges } from '@angular/core';\nimport { Utilities } from './utilities';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\r\n                   (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\r\n          [style.left.%]=\"handlerX[0]\"\r\n          (mousedown)=\"setHandlerActive($event,0)\"\r\n          (panstart)=\"setHandlerActive($event,0)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n            <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\r\n    </div>\r\n    <span class=\"right-handle\"\r\n          [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\r\n          [style.left.%]=\"handlerX[1]\"\r\n          (mousedown)=\"setHandlerActive($event,1)\"\r\n          (panstart)=\"setHandlerActive($event,1)\">\r\n      <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\">\r\n    <span>{{initValues[0]}}</span>\r\n    <span>{{initValues[1]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.minSelected)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.isNullOrEmpty(this.maxSelected)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = (value === 'true' || value === 'disabled') ? true : false;\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes['setMinSelectedValues'] && !changes['setMaxSelectedValues'] && this.sliderInitiated) {\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    if (this.sliderWidth / (this.totalDiff / this.step) < 10) {\n      console.error(`'step' value is too small compared to min & max value difference and slider width.\n        Slider might not work properly!. Provide slight large value for 'step'`);\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions = [];\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      }\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit(this.currentValues);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n      if (event.clientX) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (event.deltaX) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n","import { BrowserModule } from '@angular/platform-browser';\nimport { NgModule } from '@angular/core';\nimport { NpnSliderComponent } from './npn-slider.component';\n\n@NgModule({\n  imports: [\n    BrowserModule\n  ],\n  declarations: [NpnSliderComponent],\n  exports: [NpnSliderComponent]\n})\nexport class NpnSliderModule { }\n"],"names":["tslib_1.__extends"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"npn-slider.js.map","sources":["ng://npn-slider/lib/utilities.ts","ng://npn-slider/lib/npn-slider.component.ts","ng://npn-slider/lib/npn-slider.module.ts"],"sourcesContent":["\r\n\r\n/*Utilities */\r\nexport class Utilities {\r\n\r\n  public isNumberArray(arr: number[]): boolean {\r\n    return (arr && arr.length && arr.filter((value) => !isNaN(value)).length === arr.length) ? true : false;\r\n  }\r\n  public isNullOrEmpty(obj: any): boolean {\r\n    return obj === undefined || obj === null || obj === '';\r\n  }\r\n  public toBoolean(obj: any, ...allowedValues): boolean {\r\n    return (obj === '' || obj === 'true' || allowedValues.indexOf(obj) !== -1) ? true : false;\r\n  }\r\n  public findNextValidStepValue(n: number, step: number): number {\r\n    const divisorsSet1: number[] = [];\r\n    const divisorsSet2: number[] = [];\r\n    const sqrtNum = Math.sqrt(n);\r\n    let newStep = -1;\r\n    for (let i = 0; i < sqrtNum; i++) {\r\n      if (n % i === 0) {\r\n        if ((n / i) === i) {\r\n          divisorsSet1.push(i);\r\n        } else {\r\n          divisorsSet1.push(i);\r\n          divisorsSet2.push(n / i);\r\n        }\r\n      }\r\n    }\r\n    // Picking newStep by checking large set of divisors first\r\n    for (let i = 0; i < divisorsSet2.length; i++) {\r\n      if (step > divisorsSet2[i]) {\r\n        newStep = divisorsSet2[i];\r\n        break;\r\n      }\r\n    }\r\n    if (newStep === -1) { // checking set of small divisors if newStep didn't find out till.\r\n      for (let i = divisorsSet1.length - 1; i >= 0; i--) {\r\n        if (step > divisorsSet1[i]) {\r\n          newStep = divisorsSet1[i];\r\n          break;\r\n        }\r\n      }\r\n    }\r\n    return (newStep === -1) ? 1 : newStep;\r\n  }\r\n}\r\n","import {\n  Component, Input, Output, EventEmitter,\n  ElementRef, OnInit, HostListener, SimpleChanges, OnChanges\n} from '@angular/core';\nimport { Utilities } from './utilities';\nimport { SliderHandlerEnum } from './slider-handler.enum';\n\n@Component({\n  selector: 'npn-slider',\n  template: `<!--npn-slider template-->\r\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\r\n  <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\r\n    <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\r\n                      'last-active': currentHandlerIndex === handlerIndex.left\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\r\n    </span>\r\n    <div class=\"filler\">\r\n      <div class=\"step-indicators\">\r\n        <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\r\n      </div>\r\n      <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\r\n      <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\r\n    </div>\r\n    <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\r\n                      'last-active': currentHandlerIndex === handlerIndex.right\r\n                    }\"\r\n      [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\r\n      (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\r\n      <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\r\n    </span>\r\n  </div>\r\n  <div class=\"values\" *ngIf=\"!hideValues\">\r\n    <span>{{initValues[handlerIndex.left]}}</span>\r\n    <span>{{initValues[handlerIndex.right]}}</span>\r\n  </div>\r\n</div>\r\n`,\n  styles: [`.slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}`]\n})\nexport class NpnSliderComponent extends Utilities implements OnInit, OnChanges {\n  private sliderModel = [0, 0, 0];\n  private step = 1;\n  private sliderWidth = 0;\n  private totalDiff = 0;\n  private startClientX = 0;\n  private startPleft = 0;\n  private startPRight = 0;\n  private minValue: number;\n  private maxValue: number;\n  private minSelected: number;\n  private maxSelected: number;\n  private sliderInitiated = false;\n\n  public initValues: number[] = [];\n  public currentValues: number[] = [0, 0];\n  public handlerX: number[] = [0, 0];\n  public isHandlerActive = false;\n  public isTouchEventStart = false;\n  public isMouseEventStart = false;\n  public currentHandlerIndex = 0;\n  public stepIndicatorPositions = [];\n  public isDisabled = false;\n  public hideTooltip = false;\n  public hideValues = false;\n\n  public handlerIndex = SliderHandlerEnum;\n\n  constructor(private el: ElementRef) {\n    super();\n  }\n\n  @Input('min')\n  set setMinValues(value: number) {\n    if (!isNaN(value)) {\n      this.minValue = Number(value);\n    }\n  }\n\n  @Input('max')\n  set setMaxValues(value: number) {\n    if (!isNaN(value)) {\n      this.maxValue = Number(value);\n    }\n  }\n\n  @Input('minSelected')\n  set setMinSelectedValues(value: number) {\n    if (!isNaN(value) && this.minSelected !== Number(value)) {\n      this.minSelected = Number(value);\n    }\n  }\n\n  @Input('maxSelected')\n  set setMaxSelectedValues(value: number) {\n    if (!isNaN(value) && this.maxSelected !== Number(value)) {\n      this.maxSelected = Number(value);\n    }\n  }\n  @Input('step')\n  set stepValue(value: number) {\n    if (!isNaN(value)) {\n      this.step = Number(value);\n    }\n  }\n\n  @Input() showStepIndicator = false;\n  @Input() multiRange = true;\n  @Input('hide-tooltip')\n  set setHideTooltip(value: boolean) {\n    this.hideTooltip = this.toBoolean(value);\n  }\n  @Input('hide-values')\n  set setHideValues(value: boolean) {\n    this.hideValues = this.toBoolean(value);\n  }\n\n  @Input('disabled')\n  set setDisabled(value: string) {\n    this.isDisabled = this.toBoolean(value, 'disabled');\n  }\n\n  @Output() onChange = new EventEmitter<number[]>();\n\n  ngOnInit() {\n    this.initializeSlider();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.sliderInitiated) {\n      if (!this.isNullOrEmpty(changes.setMinSelectedValues)\n        && changes.setMinSelectedValues.previousValue === changes.setMinSelectedValues.currentValue) {\n        return;\n      }\n      if (!this.isNullOrEmpty(changes.setMaxSelectedValues)\n        && changes.setMaxSelectedValues.previousValue === changes.setMaxSelectedValues.currentValue) {\n        return;\n      }\n      this.resetModel();\n    }\n  }\n\n  /*Method to initailize entire Slider*/\n  public initializeSlider() {\n    try {\n      // Taking width of slider bar element.\n      this.sliderWidth = this.el.nativeElement.children[0].children[0].offsetWidth;\n      this.resetModel();\n      this.sliderInitiated = true;\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  /*Method to initialize variables and model values */\n  private resetModel() {\n    this.validateSliderValues();\n    // Setting the model values\n    this.sliderModel = [\n      this.currentValues[0] - this.initValues[0],\n      this.currentValues[1] - this.currentValues[0],\n      this.initValues[1] - this.currentValues[1]\n    ];\n\n    this.totalDiff = this.sliderModel.reduce((prevValue, curValue) => prevValue + curValue, 0);\n\n    // Validation for slider step\n    if (this.totalDiff % this.step !== 0) {\n      const newStep = this.findNextValidStepValue(this.totalDiff, this.step);\n      console.warn('Invalid step value \"' + this.step + '\" : and took \"' + newStep + '\" as default step');\n      this.step = newStep;\n    }\n    this.initializeStepIndicator();\n    this.setHandlerPosition();\n  }\n\n  /*Method to do validation of init and seleted range values*/\n  private validateSliderValues() {\n    if (this.isNullOrEmpty(this.minValue) || this.isNullOrEmpty(this.maxValue)) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else if (this.minValue > this.maxValue) {\n      this.updateInitValues([0, 0]);\n      this.updateCurrentValue([0, 0], true);\n    } else {\n      this.initValues = [this.minValue, this.maxValue];\n      /*\n      * Validation for Selected range values\n      */\n      this.minSelected = this.isNullOrEmpty(this.minSelected) ? 0 : this.minSelected;\n      this.maxSelected = this.isNullOrEmpty(this.maxSelected) ? 0 : this.maxSelected;\n\n      if (this.minSelected < this.minValue || this.minSelected > this.maxValue) {\n        this.minSelected = this.minValue;\n      }\n      if (this.maxSelected < this.minValue || this.maxSelected > this.maxValue) {\n        this.maxSelected = this.maxValue;\n      }\n      if (this.minSelected > this.maxSelected) {\n        this.minSelected = this.minValue;\n        this.maxSelected = this.maxValue;\n      }\n      this.updateCurrentValue([this.minSelected, this.maxSelected], true);\n    }\n  }\n\n  /*Method to add step inidicator to slider */\n  private initializeStepIndicator() {\n    if (this.showStepIndicator) {\n      this.stepIndicatorPositions.length = 0;\n      const numOfStepIndicators = this.totalDiff / this.step;\n      if (this.sliderWidth / numOfStepIndicators >= 10) {\n        const increment = this.sliderWidth / numOfStepIndicators;\n        let leftPosition = increment;\n        while (this.stepIndicatorPositions.length < numOfStepIndicators - 1) {\n          this.stepIndicatorPositions.push(+leftPosition.toFixed(2));\n          leftPosition += increment;\n        }\n      } else {\n        console.warn(`As 'step' value is too small compared to min & max value difference and slider width,\n          Step Indicator can't be displayed!. Provide slight large value for 'step'`);\n      }\n    } else {\n      this.stepIndicatorPositions.length = 0;\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateCurrentValue(arrayValue: number[], privateChange: boolean = false) {\n    this.minSelected = this.currentValues[0] = arrayValue[0];\n    this.maxSelected = this.currentValues[1] = arrayValue[1];\n    if (!privateChange) {\n      this.onChange.emit((this.multiRange) ? this.currentValues : [this.currentValues[0]]);\n    }\n  }\n\n  /*Method to set current selected values */\n  private updateInitValues(arrayValue: number[]) {\n    this.minValue = this.initValues[0] = arrayValue[0];\n    this.maxValue = this.initValues[1] = arrayValue[1];\n  }\n\n  /*Method to set handler position */\n  private setHandlerPosition() {\n    let runningTotal = 0;\n    // Updating selected values : current values\n    this.updateCurrentValue([\n      this.initValues[0] + this.sliderModel[0],\n      this.initValues[1] - this.sliderModel[2]\n    ]);\n    /*Setting handler position */\n    for (let i = 0, len = this.sliderModel.length - 1; i < len; i++) {\n      runningTotal += this.sliderModel[i];\n      this.handlerX[i] = (runningTotal / this.totalDiff) * 100;\n    }\n  }\n\n  /*Method to set model array values - will try to refine the values using step */\n  private setModelValue(index: number, value: number) {\n    if (this.step > 1) {\n      value = Math.round(value / this.step) * this.step;\n    }\n    this.sliderModel[index] = value;\n  }\n\n  /*Method to disable handler movement*/\n  /*Execute on events:\n  * on-mouseup\n  * on-panend\n  */\n  @HostListener('document:mouseup')\n  @HostListener('document:panend')\n  setHandlerActiveOff() {\n    this.isMouseEventStart = false;\n    this.isTouchEventStart = false;\n    this.isHandlerActive = false;\n  }\n\n  /*Method to detect start draging handler*/\n  /*Execute on events:\n  * on-mousedown\n  * on-panstart\n  */\n  public setHandlerActive(event: any, handlerIndex: number) {\n    event.preventDefault();\n    if (!this.isDisabled) {\n\n      if (!this.isNullOrEmpty(event.clientX)) {\n        this.startClientX = event.clientX;\n        this.isMouseEventStart = true;\n        this.isTouchEventStart = false;\n      } else if (!this.isNullOrEmpty(event.deltaX)) {\n        this.startClientX = event.deltaX;\n        this.isTouchEventStart = true;\n        this.isMouseEventStart = false;\n      }\n      if (this.isMouseEventStart || this.isTouchEventStart) {\n        this.currentHandlerIndex = handlerIndex;\n        this.startPleft = this.sliderModel[handlerIndex];\n        this.startPRight = this.sliderModel[handlerIndex + 1];\n        this.isHandlerActive = true;\n      }\n    }\n  }\n\n\n  /*Method to calculate silder handler movement */\n  /*Execute on events:\n  * on-mousemove\n  * on-panmove\n  */\n  public handlerSliding(event: any) {\n    if ((this.isMouseEventStart && event.clientX) || (this.isTouchEventStart && event.deltaX)) {\n      const movedX = Math.round(((event.clientX || event.deltaX) - this.startClientX) / this.sliderWidth * this.totalDiff);\n      const nextPLeft = this.startPleft + movedX;\n      const nextPRight = this.startPRight - movedX;\n      if (nextPLeft >= 0 && nextPRight >= 0) {\n        this.setModelValue(this.currentHandlerIndex, nextPLeft);\n        this.setModelValue(this.currentHandlerIndex + 1, nextPRight);\n        this.setHandlerPosition();\n      }\n    }\n  }\n}\n","import { BrowserModule } from '@angular/platform-browser';\nimport { NgModule } from '@angular/core';\nimport { NpnSliderComponent } from './npn-slider.component';\n\n@NgModule({\n  imports: [\n    BrowserModule\n  ],\n  declarations: [NpnSliderComponent],\n  exports: [NpnSliderComponent]\n})\nexport class NpnSliderModule { }\n"],"names":["tslib_1.__extends"],"mappings":"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"}
import { EventEmitter, ElementRef, OnInit, SimpleChanges, OnChanges } from '@angular/core';
import { Utilities } from './utilities';
import { SliderHandlerEnum } from './slider-handler.enum';
export declare class NpnSliderComponent extends Utilities implements OnInit, OnChanges {

@@ -26,2 +27,5 @@ private el;

isDisabled: boolean;
hideTooltip: boolean;
hideValues: boolean;
handlerIndex: typeof SliderHandlerEnum;
constructor(el: ElementRef);

@@ -34,2 +38,5 @@ setMinValues: number;

showStepIndicator: boolean;
multiRange: boolean;
setHideTooltip: boolean;
setHideValues: boolean;
setDisabled: string;

@@ -36,0 +43,0 @@ onChange: EventEmitter<number[]>;

export declare class Utilities {
isNumberArray(arr: number[]): boolean;
isNullOrEmpty(obj: any): boolean;
toBoolean(obj: any, ...allowedValues: any[]): boolean;
findNextValidStepValue(n: number, step: number): number;
}

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

{"__symbolic":"module","version":4,"metadata":{"NpnSliderComponent":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵa"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"npn-slider","template":"<!--npn-slider template-->\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\n <div class=\"bar\" (mousemove)=\"handlerSliding($event)\"\n (panmove)=\"handlerSliding($event)\">\n <span class=\"left-handle\"\n [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==0,'last-active':currentHandlerIndex==0}\"\n [style.left.%]=\"handlerX[0]\"\n (mousedown)=\"setHandlerActive($event,0)\"\n (panstart)=\"setHandlerActive($event,0)\">\n <span class=\"handle-tooltip\">{{currentValues[0]}}</span>\n </span>\n <div class=\"filler\">\n <div class=\"step-indicators\">\n <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\n </div>\n <span [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[1] - handlerX[0]\"></span>\n </div>\n <span class=\"right-handle\"\n [ngClass]=\"{'active':isHandlerActive&&currentHandlerIndex==1, 'last-active':currentHandlerIndex==1}\"\n [style.left.%]=\"handlerX[1]\"\n (mousedown)=\"setHandlerActive($event,1)\"\n (panstart)=\"setHandlerActive($event,1)\">\n <span class=\"handle-tooltip\">{{currentValues[1]}}</span>\n </span>\n </div>\n <div class=\"values\">\n <span>{{initValues[0]}}</span>\n <span>{{initValues[1]}}</span>\n </div>\n</div>\n","styles":[".slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:104%;margin-left:-2%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}"]}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":63,"character":26}]}],"setMinValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":3},"arguments":["min"]}]}],"setMaxValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":3},"arguments":["max"]}]}],"setMinSelectedValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":81,"character":3},"arguments":["minSelected"]}]}],"setMaxSelectedValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3},"arguments":["maxSelected"]}]}],"stepValue":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3},"arguments":["step"]}]}],"showStepIndicator":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":101,"character":3}}]}],"setDisabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":103,"character":3},"arguments":["disabled"]}]}],"onChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":108,"character":3}}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"initializeSlider":[{"__symbolic":"method"}],"resetModel":[{"__symbolic":"method"}],"validateSliderValues":[{"__symbolic":"method"}],"initializeStepIndicator":[{"__symbolic":"method"}],"updateCurrentValue":[{"__symbolic":"method"}],"updateInitValues":[{"__symbolic":"method"}],"setHandlerPosition":[{"__symbolic":"method"}],"setModelValue":[{"__symbolic":"method"}],"setHandlerActiveOff":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":247,"character":3},"arguments":["document:mouseup"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":248,"character":3},"arguments":["document:panend"]}]}],"setHandlerActive":[{"__symbolic":"method"}],"handlerSliding":[{"__symbolic":"method"}]}},"NpnSliderModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"BrowserModule","line":6,"character":4}],"declarations":[{"__symbolic":"reference","name":"NpnSliderComponent"}],"exports":[{"__symbolic":"reference","name":"NpnSliderComponent"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","members":{"isNumberArray":[{"__symbolic":"method"}],"isNullOrEmpty":[{"__symbolic":"method"}],"findNextValidStepValue":[{"__symbolic":"method"}]}}},"origins":{"NpnSliderComponent":"./lib/npn-slider.component","NpnSliderModule":"./lib/npn-slider.module","ɵa":"./lib/utilities"},"importAs":"npn-slider"}
{"__symbolic":"module","version":4,"metadata":{"NpnSliderComponent":{"__symbolic":"class","extends":{"__symbolic":"reference","name":"ɵa"},"decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"npn-slider","template":"<!--npn-slider template-->\n<div class=\"slider\" [class.disabled]=\"isDisabled\">\n <div class=\"bar\" (mousemove)=\"handlerSliding($event)\" (panmove)=\"handlerSliding($event)\">\n <span class=\"left-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.left,\n 'last-active': currentHandlerIndex === handlerIndex.left\n }\"\n [style.left.%]=\"handlerX[handlerIndex.left]\" (mousedown)=\"setHandlerActive($event, handlerIndex.left)\" (panstart)=\"setHandlerActive($event, handlerIndex.left)\">\n <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.left]}}</span>\n </span>\n <div class=\"filler\">\n <div class=\"step-indicators\">\n <span *ngFor=\"let stepPos of stepIndicatorPositions\" [style.left.px]=\"stepPos\"></span>\n </div>\n <span *ngIf=\"multiRange\" [style.left.%]=\"handlerX[0]\" [style.width.%]=\"handlerX[handlerIndex.right] - handlerX[handlerIndex.left]\"></span>\n <span *ngIf=\"!multiRange\" [style.left.%]=\"0\" [style.width.%]=\"handlerX[0]\"></span>\n </div>\n <span *ngIf=\"multiRange\" class=\"right-handle\" [ngClass]=\"{'active': isHandlerActive && currentHandlerIndex === handlerIndex.right,\n 'last-active': currentHandlerIndex === handlerIndex.right\n }\"\n [style.left.%]=\"handlerX[handlerIndex.right]\" (mousedown)=\"setHandlerActive($event, handlerIndex.right)\"\n (panstart)=\"setHandlerActive($event, handlerIndex.right)\">\n <span *ngIf=\"!hideTooltip\" class=\"handle-tooltip\">{{currentValues[handlerIndex.right]}}</span>\n </span>\n </div>\n <div class=\"values\" *ngIf=\"!hideValues\">\n <span>{{initValues[handlerIndex.left]}}</span>\n <span>{{initValues[handlerIndex.right]}}</span>\n </div>\n</div>\n","styles":[".slider,.slider *{box-sizing:border-box}.slider{display:block;width:100%;height:30px;padding:4px 10px;cursor:default;font-size:12px}.slider .bar{width:100%;background:#e8e8e8;height:10px;position:relative;border-radius:5px;box-shadow:inset 1px 1px 5px #bababa}.slider .bar>span.left-handle,.slider .bar>span.right-handle{display:inline-block;width:22px;height:22px;background:#bedcb2;border:7px solid #71b357;border-radius:50%;position:absolute;top:-7px;margin-left:-10px;z-index:1;cursor:pointer;transition:left .2s ease}.slider .bar>span.left-handle.last-active,.slider .bar>span.right-handle.last-active{z-index:2}.slider .bar>span.left-handle .handle-tooltip,.slider .bar>span.right-handle .handle-tooltip{display:block;position:absolute;top:-34px;left:-14px;border:1px solid #8fc37a;border-radius:4px;padding:1px 4px;min-width:20px;text-align:center;background:#d9ebd2;color:#71b357;font-weight:700;transition:opacity .2s ease;opacity:0}.slider .bar>span.left-handle .handle-tooltip:before,.slider .bar>span.right-handle .handle-tooltip:before{content:\"\";border:5px solid transparent;border-top-color:#8fc37a;position:absolute;top:104%;left:33%}.slider .bar>span.left-handle .handle-tooltip:after,.slider .bar>span.right-handle .handle-tooltip:after{content:\"\";border:5px solid transparent;border-top-color:#d9ebd2;position:absolute;top:100%;left:33%}.slider .bar>span.left-handle.active>.handle-tooltip,.slider .bar>span.left-handle:hover>.handle-tooltip,.slider .bar>span.right-handle.active>.handle-tooltip,.slider .bar>span.right-handle:hover>.handle-tooltip{opacity:1}.slider .bar div.filler{display:block;width:100%;height:100%;position:relative;overflow:hidden;border-radius:5px;border:1px solid #bedcb2}.slider .bar div.filler>span{display:inline-block;height:100%;position:absolute;top:0;background:#bedcb2;transition:all .2s ease}.slider .bar div.filler>div.step-indicators{width:100%;height:100%;position:relative}.slider .bar div.filler>div.step-indicators>span{width:1px;display:inline-block;height:10px;background:#71b357;position:absolute;left:0}.slider .values{display:block;font-weight:700;margin-top:4px;width:102%;margin-left:-1%;color:#908f90}.slider .values span:first-child{float:left}.slider .values span:last-child{float:right}.slider.disabled{opacity:.4}.slider.disabled .bar{box-shadow:none!important}.slider.disabled .bar>span.left-handle,.slider.disabled .bar>span.right-handle{cursor:not-allowed}.slider.disabled .bar>span.left-handle .handle-tooltip,.slider.disabled .bar>span.right-handle .handle-tooltip{display:none}"]}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":69,"character":26}]}],"setMinValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":73,"character":3},"arguments":["min"]}]}],"setMaxValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":80,"character":3},"arguments":["max"]}]}],"setMinSelectedValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":87,"character":3},"arguments":["minSelected"]}]}],"setMaxSelectedValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":94,"character":3},"arguments":["maxSelected"]}]}],"stepValue":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":100,"character":3},"arguments":["step"]}]}],"showStepIndicator":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":107,"character":3}}]}],"multiRange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":108,"character":3}}]}],"setHideTooltip":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":109,"character":3},"arguments":["hide-tooltip"]}]}],"setHideValues":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":113,"character":3},"arguments":["hide-values"]}]}],"setDisabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":118,"character":3},"arguments":["disabled"]}]}],"onChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":123,"character":3}}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"initializeSlider":[{"__symbolic":"method"}],"resetModel":[{"__symbolic":"method"}],"validateSliderValues":[{"__symbolic":"method"}],"initializeStepIndicator":[{"__symbolic":"method"}],"updateCurrentValue":[{"__symbolic":"method"}],"updateInitValues":[{"__symbolic":"method"}],"setHandlerPosition":[{"__symbolic":"method"}],"setModelValue":[{"__symbolic":"method"}],"setHandlerActiveOff":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":271,"character":3},"arguments":["document:mouseup"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":272,"character":3},"arguments":["document:panend"]}]}],"setHandlerActive":[{"__symbolic":"method"}],"handlerSliding":[{"__symbolic":"method"}]}},"NpnSliderModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"BrowserModule","line":6,"character":4}],"declarations":[{"__symbolic":"reference","name":"NpnSliderComponent"}],"exports":[{"__symbolic":"reference","name":"NpnSliderComponent"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","members":{"isNumberArray":[{"__symbolic":"method"}],"isNullOrEmpty":[{"__symbolic":"method"}],"toBoolean":[{"__symbolic":"method"}],"findNextValidStepValue":[{"__symbolic":"method"}]}}},"origins":{"NpnSliderComponent":"./lib/npn-slider.component","NpnSliderModule":"./lib/npn-slider.module","ɵa":"./lib/utilities"},"importAs":"npn-slider"}
{
"name": "npn-slider",
"description": "A multi range slider component using Angular v6.0",
"version": "1.1.3",
"version": "1.2.0",
"peerDependencies": {

@@ -6,0 +6,0 @@ "@angular/common": "^6.0.3",

# [NpnSlider](https://npnm.github.io/NpnSlider/) (A Multi Range Slider Angular Component)
NpnSlider is reusable multi range slider component using Angular v6.0
NpnSlider is a reusable range slider component using Angular v6.0. It can be used either as a multi range or a single range slider. By default, it is a multi range slider.
_[View on Github](https://github.com/npnm/NpnSlider)_
_[View Release Notes](https://github.com/npnm/NpnSlider/releases/tag/v1.2.0)_

@@ -21,4 +21,7 @@ ## Usage

@Input() <br> **maxSelected**: number | The selected value for slider's right handler
@Input() <br> **disabled**: string | To disable the slider. Valid values: _'true'_ or _'disabled'_
@Output() <br> **onChange**: EventEmitter<number[]>() | The event will be fired on change of selected range of values.<br>_Returns: Selected range of values as an array[]_
@Input() <br> **disabled**: string | To disable the slider. Valid values: _'true'_ or _'disabled'_ or _empty attribute_
@Input() <br> **multiRange**: boolean | To switch between Mutli range and Single range mode. Slider is multi range by default
@Input() <br> **hide-tooltip**: boolean | To hide the tooltip that shows on hover of slider handler. Default value: _'false'_
@Input() <br> **hide-values**: boolean | To hide values displayed at bottom of slider. Default value: _'false'_
@Output() <br> **onChange**: EventEmitter<number[]>() | The event will be fired on change of selected range of values.<br>_Returns: Selected range of values as an array[],_ <br>_On Single range mode, a number array with single value will be returned_

@@ -49,3 +52,2 @@ ### Example and Sample Code

```
d) **You done. Run your app. cheers!**
d) **You done. Run your app. cheers!** _[View Demo](https://npnm.github.io/NpnSlider/)_

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

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc