ngx-color-picker
Advanced tools
Comparing version 5.3.2 to 5.3.3
@@ -1,1 +0,1 @@ | ||
(function(global,factory){typeof exports==="object"&&typeof module!=="undefined"?factory(exports,require("@angular/core"),require("@angular/common")):typeof define==="function"&&define.amd?define(["exports","@angular/core","@angular/common"],factory):factory((global.zef=global.zef||{},global.zef.ngxColorPicker={}),global.ng.core,global.ng.common)})(this,function(exports,core,common){"use strict";var Cmyk=function(){function Cmyk(c,m,y,k){this.c=c;this.m=m;this.y=y;this.k=k}return Cmyk}();var Hsla=function(){function Hsla(h,s,l,a){this.h=h;this.s=s;this.l=l;this.a=a}return Hsla}();var Hsva=function(){function Hsva(h,s,v,a){this.h=h;this.s=s;this.v=v;this.a=a}return Hsva}();var Rgba=function(){function Rgba(r,g,b,a){this.r=r;this.g=g;this.b=b;this.a=a}return Rgba}();function detectIE(){var ua="";if(typeof navigator!=="undefined"){ua=navigator.userAgent.toLowerCase()}var msie=ua.indexOf("msie ");if(msie>0){return parseInt(ua.substring(msie+5,ua.indexOf(".",msie)),10)}return false}var TextDirective=function(){function TextDirective(){this.newValue=new core.EventEmitter}TextDirective.prototype.inputChange=function(event){var value=event.target.value;if(this.rg===undefined){this.newValue.emit(value)}else{var numeric=parseFloat(value);if(!isNaN(numeric)&&numeric>=0&&numeric<=this.rg){this.newValue.emit({v:numeric,rg:this.rg})}}};TextDirective.decorators=[{type:core.Directive,args:[{selector:"[text]"}]}];TextDirective.ctorParameters=function(){return[]};TextDirective.propDecorators={rg:[{type:core.Input}],text:[{type:core.Input}],newValue:[{type:core.Output}],inputChange:[{type:core.HostListener,args:["input",["$event"]]}]};return TextDirective}();var SliderDirective=function(){function SliderDirective(elRef){var _this=this;this.elRef=elRef;this.dragEnd=new core.EventEmitter;this.dragStart=new core.EventEmitter;this.newValue=new core.EventEmitter;this.listenerMove=function(event){return _this.move(event)};this.listenerStop=function(){return _this.stop()}}SliderDirective.prototype.mouseDown=function(event){this.start(event)};SliderDirective.prototype.touchStart=function(event){this.start(event)};SliderDirective.prototype.move=function(event){event.preventDefault();this.setCursor(event)};SliderDirective.prototype.start=function(event){this.setCursor(event);document.addEventListener("mouseup",this.listenerStop);document.addEventListener("touchend",this.listenerStop);document.addEventListener("mousemove",this.listenerMove);document.addEventListener("touchmove",this.listenerMove);this.dragStart.emit()};SliderDirective.prototype.stop=function(){document.removeEventListener("mouseup",this.listenerStop);document.removeEventListener("touchend",this.listenerStop);document.removeEventListener("mousemove",this.listenerMove);document.removeEventListener("touchmove",this.listenerMove);this.dragEnd.emit()};SliderDirective.prototype.getX=function(event){var position=this.elRef.nativeElement.getBoundingClientRect();var pageX=event.pageX!==undefined?event.pageX:event.touches[0].pageX;return pageX-position.left-window.pageXOffset};SliderDirective.prototype.getY=function(event){var position=this.elRef.nativeElement.getBoundingClientRect();var pageY=event.pageY!==undefined?event.pageY:event.touches[0].pageY;return pageY-position.top-window.pageYOffset};SliderDirective.prototype.setCursor=function(event){var width=this.elRef.nativeElement.offsetWidth;var height=this.elRef.nativeElement.offsetHeight;var x=Math.max(0,Math.min(this.getX(event),width));var y=Math.max(0,Math.min(this.getY(event),height));if(this.rgX!==undefined&&this.rgY!==undefined){this.newValue.emit({s:x/width,v:1-y/height,rgX:this.rgX,rgY:this.rgY})}else if(this.rgX===undefined&&this.rgY!==undefined){this.newValue.emit({v:y/height,rgY:this.rgY})}else if(this.rgX!==undefined&&this.rgY===undefined){this.newValue.emit({v:x/width,rgX:this.rgX})}};SliderDirective.decorators=[{type:core.Directive,args:[{selector:"[slider]"}]}];SliderDirective.ctorParameters=function(){return[{type:core.ElementRef}]};SliderDirective.propDecorators={rgX:[{type:core.Input}],rgY:[{type:core.Input}],slider:[{type:core.Input}],dragEnd:[{type:core.Output}],dragStart:[{type:core.Output}],newValue:[{type:core.Output}],mouseDown:[{type:core.HostListener,args:["mousedown",["$event"]]}],touchStart:[{type:core.HostListener,args:["touchstart",["$event"]]}]};return SliderDirective}();var SliderPosition=function(){function SliderPosition(h,s,v,a){this.h=h;this.s=s;this.v=v;this.a=a}return SliderPosition}();var SliderDimension=function(){function SliderDimension(h,s,v,a){this.h=h;this.s=s;this.v=v;this.a=a}return SliderDimension}();var ColorPickerService=function(){function ColorPickerService(){this.active=null}ColorPickerService.prototype.setActive=function(active){if(this.active&&this.active!==active&&this.active.cpDialogDisplay!=="inline"){this.active.closeColorPicker()}this.active=active};ColorPickerService.prototype.hsva2hsla=function(hsva){var h=hsva.h,s=hsva.s,v=hsva.v,a=hsva.a;if(v===0){return new Hsla(h,0,0,a)}else if(s===0&&v===1){return new Hsla(h,1,1,a)}else{var l=v*(2-s)/2;return new Hsla(h,v*s/(1-Math.abs(2*l-1)),l,a)}};ColorPickerService.prototype.hsla2hsva=function(hsla){var h=Math.min(hsla.h,1),s=Math.min(hsla.s,1);var l=Math.min(hsla.l,1),a=Math.min(hsla.a,1);if(l===0){return new Hsva(h,0,0,a)}else{var v=l+s*(1-Math.abs(2*l-1))/2;return new Hsva(h,2*(v-l)/v,v,a)}};ColorPickerService.prototype.hsvaToRgba=function(hsva){var r,g,b;var h=hsva.h,s=hsva.s,v=hsva.v,a=hsva.a;var i=Math.floor(h*6);var f=h*6-i;var p=v*(1-s);var q=v*(1-f*s);var t=v*(1-(1-f)*s);switch(i%6){case 0:r=v,g=t,b=p;break;case 1:r=q,g=v,b=p;break;case 2:r=p,g=v,b=t;break;case 3:r=p,g=q,b=v;break;case 4:r=t,g=p,b=v;break;case 5:r=v,g=p,b=q;break}return new Rgba(r,g,b,a)};ColorPickerService.prototype.rgbaToCmyk=function(rgba){var k=1-Math.max(rgba.r,rgba.g,rgba.b);if(k===1){return new Cmyk(0,0,0,1)}else{var c=(1-rgba.r-k)/(1-k);var m=(1-rgba.g-k)/(1-k);var y=(1-rgba.b-k)/(1-k);return new Cmyk(c,m,y,k)}};ColorPickerService.prototype.rgbaToHsva=function(rgba){var h,s;var r=Math.min(rgba.r,1),g=Math.min(rgba.g,1);var b=Math.min(rgba.b,1),a=Math.min(rgba.a,1);var max=Math.max(r,g,b),min=Math.min(r,g,b);var v=max,d=max-min;s=max===0?0:d/max;if(max===min){h=0}else{switch(max){case r:h=(g-b)/d+(g<b?6:0);break;case g:h=(b-r)/d+2;break;case b:h=(r-g)/d+4;break}h/=6}return new Hsva(h,s,v,a)};ColorPickerService.prototype.rgbaToHex=function(rgba,allowHex8){var hex="#"+(1<<24|rgba.r<<16|rgba.g<<8|rgba.b).toString(16).substr(1);if(allowHex8){hex+=(1<<8|Math.round(rgba.a*255)).toString(16).substr(1)}return hex};ColorPickerService.prototype.denormalizeRGBA=function(rgba){return new Rgba(Math.round(rgba.r*255),Math.round(rgba.g*255),Math.round(rgba.b*255),rgba.a)};ColorPickerService.prototype.stringToHsva=function(colorString,allowHex8){if(colorString===void 0){colorString=""}if(allowHex8===void 0){allowHex8=false}var hsva=null;colorString=(colorString||"").toLowerCase();var stringParsers=[{re:/(rgb)a?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*%?,\s*(\d{1,3})\s*%?(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/,parse:function(execResult){return new Rgba(parseInt(execResult[2],10)/255,parseInt(execResult[3],10)/255,parseInt(execResult[4],10)/255,isNaN(parseFloat(execResult[5]))?1:parseFloat(execResult[5]))}},{re:/(hsl)a?\(\s*(\d{1,3})\s*,\s*(\d{1,3})%\s*,\s*(\d{1,3})%\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/,parse:function(execResult){return new Hsla(parseInt(execResult[2],10)/360,parseInt(execResult[3],10)/100,parseInt(execResult[4],10)/100,isNaN(parseFloat(execResult[5]))?1:parseFloat(execResult[5]))}}];if(allowHex8){stringParsers.push({re:/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})?$/,parse:function(execResult){return new Rgba(parseInt(execResult[1],16)/255,parseInt(execResult[2],16)/255,parseInt(execResult[3],16)/255,parseInt(execResult[4]||"FF",16)/255)}})}else{stringParsers.push({re:/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})$/,parse:function(execResult){return new Rgba(parseInt(execResult[1],16)/255,parseInt(execResult[2],16)/255,parseInt(execResult[3],16)/255,1)}},{re:/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])$/,parse:function(execResult){return new Rgba(parseInt(execResult[1]+execResult[1],16)/255,parseInt(execResult[2]+execResult[2],16)/255,parseInt(execResult[3]+execResult[3],16)/255,1)}})}for(var key in stringParsers){if(stringParsers.hasOwnProperty(key)){var parser=stringParsers[key];var match=parser.re.exec(colorString),color=match&&parser.parse(match);if(color){if(color instanceof Rgba){hsva=this.rgbaToHsva(color)}else if(color instanceof Hsla){hsva=this.hsla2hsva(color)}return hsva}}}return hsva};ColorPickerService.prototype.outputFormat=function(hsva,outputFormat,alphaChannel){switch(outputFormat){case"hsla":var hsla=this.hsva2hsla(hsva);var hslaText=new Hsla(Math.round(hsla.h*360),Math.round(hsla.s*100),Math.round(hsla.l*100),Math.round(hsla.a*100)/100);if(hsva.a<1||alphaChannel==="always"){return"hsla("+hslaText.h+","+hslaText.s+"%,"+hslaText.l+"%,"+hslaText.a+")"}else{return"hsl("+hslaText.h+","+hslaText.s+"%,"+hslaText.l+"%)"}case"rgba":var rgba=this.denormalizeRGBA(this.hsvaToRgba(hsva));if(hsva.a<1||alphaChannel==="always"){return"rgba("+rgba.r+","+rgba.g+","+rgba.b+","+Math.round(rgba.a*100)/100+")"}else{return"rgb("+rgba.r+","+rgba.g+","+rgba.b+")"}default:var allowHex8=alphaChannel==="always"||alphaChannel==="hex8";return this.rgbaToHex(this.denormalizeRGBA(this.hsvaToRgba(hsva)),allowHex8)}};ColorPickerService.decorators=[{type:core.Injectable}];ColorPickerService.ctorParameters=function(){return[]};return ColorPickerService}();var ColorPickerComponent=function(){function ColorPickerComponent(elRef,cdRef,service){this.elRef=elRef;this.cdRef=cdRef;this.service=service;this.isIE10=false;this.dialogArrowSize=10;this.dialogArrowOffset=15;this.useRootViewContainer=false}ColorPickerComponent.prototype.ngOnInit=function(){var _this=this;this.slider=new SliderPosition(0,0,0,0);var hueWidth=this.hueSlider.nativeElement.offsetWidth;var alphaWidth=this.alphaSlider.nativeElement.offsetWidth;this.sliderDimMax=new SliderDimension(hueWidth,this.cpWidth,130,alphaWidth);if(this.cpOutputFormat==="rgba"){this.format=1}else if(this.cpOutputFormat==="hsla"){this.format=2}else{this.format=0}this.listenerMouseDown=function(event){_this.onMouseDown(event)};this.listenerResize=function(){_this.onResize()};this.openDialog(this.initialColor,false)};ColorPickerComponent.prototype.ngOnDestroy=function(){this.closeDialog()};ColorPickerComponent.prototype.ngAfterViewInit=function(){if(this.cpWidth!==230){var hueWidth=this.hueSlider.nativeElement.offsetWidth;var alphaWidth=this.alphaSlider.nativeElement.offsetWidth;this.sliderDimMax=new SliderDimension(hueWidth,this.cpWidth,130,alphaWidth);this.updateColorPicker(false);this.cdRef.detectChanges()}};ColorPickerComponent.prototype.openDialog=function(color,emit){if(emit===void 0){emit=true}this.service.setActive(this);if(!this.width){this.cpWidth=this.directiveElementRef.nativeElement.offsetWidth}this.setInitialColor(color);this.setColorFromString(color,emit);this.openColorPicker()};ColorPickerComponent.prototype.closeDialog=function(){this.closeColorPicker()};ColorPickerComponent.prototype.setupDialog=function(instance,elementRef,color,cpWidth,cpHeight,cpDialogDisplay,cpAlphaChannel,cpOutputFormat,cpDisableInput,cpIgnoredElements,cpSaveClickOutside,cpUseRootViewContainer,cpPosition,cpPositionOffset,cpPositionRelativeToArrow,cpPresetLabel,cpPresetColors,cpMaxPresetColorsLength,cpPresetEmptyMessage,cpPresetEmptyMessageClass,cpOKButton,cpOKButtonClass,cpOKButtonText,cpCancelButton,cpCancelButtonClass,cpCancelButtonText,cpAddColorButton,cpAddColorButtonClass,cpAddColorButtonText,cpRemoveColorButtonClass){this.setInitialColor(color);this.isIE10=detectIE()===10;this.directiveInstance=instance;this.directiveElementRef=elementRef;this.cpDisableInput=cpDisableInput;this.cpAlphaChannel=cpAlphaChannel;this.cpOutputFormat=cpOutputFormat;this.cpDialogDisplay=cpDialogDisplay;this.cpIgnoredElements=cpIgnoredElements;this.cpSaveClickOutside=cpSaveClickOutside;this.useRootViewContainer=cpUseRootViewContainer;this.width=this.cpWidth=parseInt(cpWidth,10);this.height=this.cpHeight=parseInt(cpHeight,10);this.cpPosition=cpPosition;this.cpPositionOffset=parseInt(cpPositionOffset,10);this.cpOKButton=cpOKButton;this.cpOKButtonText=cpOKButtonText;this.cpOKButtonClass=cpOKButtonClass;this.cpCancelButton=cpCancelButton;this.cpCancelButtonText=cpCancelButtonText;this.cpCancelButtonClass=cpCancelButtonClass;this.setPresetConfig(cpPresetLabel,cpPresetColors);this.cpMaxPresetColorsLength=cpMaxPresetColorsLength;this.cpPresetEmptyMessage=cpPresetEmptyMessage;this.cpPresetEmptyMessageClass=cpPresetEmptyMessageClass;this.cpAddColorButton=cpAddColorButton;this.cpAddColorButtonText=cpAddColorButtonText;this.cpAddColorButtonClass=cpAddColorButtonClass;this.cpRemoveColorButtonClass=cpRemoveColorButtonClass;if(!cpPositionRelativeToArrow){this.dialogArrowOffset=0}if(this.cpDialogDisplay==="inline"){this.dialogArrowSize=0;this.dialogArrowOffset=0}if(cpOutputFormat==="hex"&&cpAlphaChannel!=="always"&&cpAlphaChannel!=="hex8"){this.cpAlphaChannel="disabled"}};ColorPickerComponent.prototype.setInitialColor=function(color){this.initialColor=color};ColorPickerComponent.prototype.setPresetConfig=function(cpPresetLabel,cpPresetColors){this.cpPresetLabel=cpPresetLabel;this.cpPresetColors=cpPresetColors};ColorPickerComponent.prototype.setColorFromString=function(value,emit,update){if(emit===void 0){emit=true}if(update===void 0){update=true}var hsva;if(this.cpAlphaChannel==="always"||this.cpAlphaChannel==="hex8"){hsva=this.service.stringToHsva(value,true);if(!hsva&&!this.hsva){hsva=this.service.stringToHsva(value,false)}}else{hsva=this.service.stringToHsva(value,false)}if(hsva){this.hsva=hsva;this.updateColorPicker(emit,update)}};ColorPickerComponent.prototype.onResize=function(){if(this.position==="fixed"){this.setDialogPosition()}else if(this.cpDialogDisplay!=="inline"){this.closeColorPicker()}};ColorPickerComponent.prototype.onDragEnd=function(slider){this.directiveInstance.sliderDragEnd({slider:slider,color:this.outputColor})};ColorPickerComponent.prototype.onDragStart=function(slider){this.directiveInstance.sliderDragStart({slider:slider,color:this.outputColor})};ColorPickerComponent.prototype.onMouseDown=function(event){if(!this.isIE10&&this.cpDialogDisplay==="popup"&&event.target!==this.directiveElementRef.nativeElement&&!this.isDescendant(this.elRef.nativeElement,event.target)&&this.cpIgnoredElements.filter(function(item){return item===event.target}).length===0){if(!this.cpSaveClickOutside){this.setColorFromString(this.initialColor,false);this.directiveInstance.colorChanged(this.initialColor)}this.closeColorPicker()}};ColorPickerComponent.prototype.onAcceptColor=function(event){event.stopPropagation();if(this.cpDialogDisplay==="popup"){this.closeColorPicker()}if(this.outputColor){this.directiveInstance.colorSelected(this.outputColor)}};ColorPickerComponent.prototype.onCancelColor=function(event){event.stopPropagation();this.setColorFromString(this.initialColor,true);if(this.cpDialogDisplay==="popup"){this.directiveInstance.colorChanged(this.initialColor,true);this.closeColorPicker()}this.directiveInstance.colorCanceled()};ColorPickerComponent.prototype.onFormatToggle=function(){this.format=(this.format+1)%3};ColorPickerComponent.prototype.onColorChange=function(value){this.hsva.s=value.s/value.rgX;this.hsva.v=value.v/value.rgY;this.updateColorPicker();this.directiveInstance.sliderChanged({slider:"lightness",value:this.hsva.v,color:this.outputColor});this.directiveInstance.sliderChanged({slider:"saturation",value:this.hsva.s,color:this.outputColor})};ColorPickerComponent.prototype.onHueChange=function(value){this.hsva.h=value.v/value.rgX;this.sliderH=this.hsva.h;this.updateColorPicker();this.directiveInstance.sliderChanged({slider:"hue",value:this.hsva.h,color:this.outputColor})};ColorPickerComponent.prototype.onAlphaChange=function(value){this.hsva.a=value.v/value.rgX;this.updateColorPicker();this.directiveInstance.sliderChanged({slider:"alpha",value:this.hsva.a,color:this.outputColor})};ColorPickerComponent.prototype.onHexInput=function(value){if(value===null){this.updateColorPicker()}else{this.setColorFromString(value,true,false);this.directiveInstance.inputChanged({input:"hex",value:value,color:this.outputColor})}};ColorPickerComponent.prototype.onRedInput=function(value){var rgba=this.service.hsvaToRgba(this.hsva);rgba.r=value.v/value.rg;this.hsva=this.service.rgbaToHsva(rgba);this.updateColorPicker();this.directiveInstance.inputChanged({input:"red",value:rgba.r,color:this.outputColor})};ColorPickerComponent.prototype.onBlueInput=function(value){var rgba=this.service.hsvaToRgba(this.hsva);rgba.b=value.v/value.rg;this.hsva=this.service.rgbaToHsva(rgba);this.updateColorPicker();this.directiveInstance.inputChanged({input:"blue",value:rgba.b,color:this.outputColor})};ColorPickerComponent.prototype.onGreenInput=function(value){var rgba=this.service.hsvaToRgba(this.hsva);rgba.g=value.v/value.rg;this.hsva=this.service.rgbaToHsva(rgba);this.updateColorPicker();this.directiveInstance.inputChanged({input:"green",value:rgba.g,color:this.outputColor})};ColorPickerComponent.prototype.onAlphaInput=function(value){this.hsva.a=value.v/value.rg;this.updateColorPicker();this.directiveInstance.inputChanged({input:"alpha",value:this.hsva.a,color:this.outputColor})};ColorPickerComponent.prototype.onHueInput=function(value){this.hsva.h=value.v/value.rg;this.updateColorPicker();this.directiveInstance.inputChanged({input:"hue",value:this.hsva.h,color:this.outputColor})};ColorPickerComponent.prototype.onLightnessInput=function(value){var hsla=this.service.hsva2hsla(this.hsva);hsla.l=value.v/value.rg;this.hsva=this.service.hsla2hsva(hsla);this.updateColorPicker();this.directiveInstance.inputChanged({input:"lightness",value:hsla.l,color:this.outputColor})};ColorPickerComponent.prototype.onSaturationInput=function(value){var hsla=this.service.hsva2hsla(this.hsva);hsla.s=value.v/value.rg;this.hsva=this.service.hsla2hsva(hsla);this.updateColorPicker();this.directiveInstance.inputChanged({input:"saturation",value:hsla.s,color:this.outputColor})};ColorPickerComponent.prototype.onAddPresetColor=function(event,value){event.stopPropagation();if(!this.cpPresetColors.filter(function(color){return color===value}).length){this.cpPresetColors=this.cpPresetColors.concat(value);this.directiveInstance.presetColorsChanged(this.cpPresetColors)}};ColorPickerComponent.prototype.onRemovePresetColor=function(event,value){event.stopPropagation();this.cpPresetColors=this.cpPresetColors.filter(function(color){return color!==value});this.directiveInstance.presetColorsChanged(this.cpPresetColors)};ColorPickerComponent.prototype.openColorPicker=function(){var _this=this;if(!this.show){this.show=true;this.hidden=true;setTimeout(function(){_this.hidden=false;_this.setDialogPosition();_this.cdRef.detectChanges()},0);this.directiveInstance.toggle(true);if(!this.isIE10){document.addEventListener("mousedown",this.listenerMouseDown)}window.addEventListener("resize",this.listenerResize)}};ColorPickerComponent.prototype.closeColorPicker=function(){if(this.show){this.show=false;this.directiveInstance.toggle(false);if(!this.isIE10){document.removeEventListener("mousedown",this.listenerMouseDown)}window.removeEventListener("resize",this.listenerResize);if(!this.cdRef["destroyed"]){this.cdRef.detectChanges()}}};ColorPickerComponent.prototype.updateColorPicker=function(emit,update){if(emit===void 0){emit=true}if(update===void 0){update=true}if(this.sliderDimMax){var lastOutput=this.outputColor;var hsla=this.service.hsva2hsla(this.hsva);var rgba=this.service.denormalizeRGBA(this.service.hsvaToRgba(this.hsva));var hue=this.service.denormalizeRGBA(this.service.hsvaToRgba(new Hsva(this.hsva.h,1,1,1)));if(update){this.hslaText=new Hsla(Math.round(hsla.h*360),Math.round(hsla.s*100),Math.round(hsla.l*100),Math.round(hsla.a*100)/100);this.rgbaText=new Rgba(rgba.r,rgba.g,rgba.b,Math.round(rgba.a*100)/100);var allowHex8=this.cpAlphaChannel==="always"||this.cpAlphaChannel==="hex8";this.hexText=this.service.rgbaToHex(rgba,allowHex8)}this.hueSliderColor="rgb("+hue.r+","+hue.g+","+hue.b+")";this.alphaSliderColor="rgb("+rgba.r+","+rgba.g+","+rgba.b+")";this.outputColor=this.service.outputFormat(this.hsva,this.cpOutputFormat,this.cpAlphaChannel);this.selectedColor=this.service.outputFormat(this.hsva,"rgba",null);this.slider=new SliderPosition((this.sliderH||this.hsva.h)*this.sliderDimMax.h-8,this.hsva.s*this.sliderDimMax.s-8,(1-this.hsva.v)*this.sliderDimMax.v-8,this.hsva.a*this.sliderDimMax.a-8);if(emit&&lastOutput!==this.outputColor){this.directiveInstance.colorChanged(this.outputColor)}}};ColorPickerComponent.prototype.setDialogPosition=function(){if(this.cpDialogDisplay==="inline"){this.position="relative"}else{var dialogHeight=this.dialogElement.nativeElement.offsetHeight;var position="static",transform="",style=null;var parentNode=null,transformNode=null;var node=this.directiveElementRef.nativeElement.parentNode;while(node!==null&&node.tagName!=="HTML"){style=window.getComputedStyle(node);position=style.getPropertyValue("position");transform=style.getPropertyValue("transform");if(position!=="static"&&parentNode===null){parentNode=node}if(transform&&transform!=="none"&&transformNode===null){transformNode=node}if(position==="fixed"){parentNode=transformNode;break}node=node.parentNode}var boxDirective=this.createBox(this.directiveElementRef.nativeElement,position!=="fixed");if(this.useRootViewContainer||position==="fixed"&&!parentNode){this.top=boxDirective.top;this.left=boxDirective.left}else{if(parentNode===null){parentNode=node}var boxParent=this.createBox(parentNode,position!=="fixed");this.top=boxDirective.top-boxParent.top;this.left=boxDirective.left-boxParent.left}if(position==="fixed"){this.position="fixed"}if(this.cpPosition==="left"){this.top+=boxDirective.height*this.cpPositionOffset/100-this.dialogArrowOffset;this.left-=this.cpWidth+this.dialogArrowSize-2}else if(this.cpPosition==="top"){this.arrowTop=dialogHeight-1;this.top-=dialogHeight+this.dialogArrowSize;this.left+=this.cpPositionOffset/100*boxDirective.width-this.dialogArrowOffset}else if(this.cpPosition==="bottom"){this.top+=boxDirective.height+this.dialogArrowSize;this.left+=this.cpPositionOffset/100*boxDirective.width-this.dialogArrowOffset}else{this.top+=boxDirective.height*this.cpPositionOffset/100-this.dialogArrowOffset;this.left+=boxDirective.width+this.dialogArrowSize-2}}};ColorPickerComponent.prototype.createBox=function(element,offset){return{top:element.getBoundingClientRect().top+(offset?window.pageYOffset:0),left:element.getBoundingClientRect().left+(offset?window.pageXOffset:0),width:element.offsetWidth,height:element.offsetHeight}};ColorPickerComponent.prototype.isDescendant=function(parent,child){var node=child.parentNode;while(node!==null){if(node===parent){return true}node=node.parentNode}return false};ColorPickerComponent.decorators=[{type:core.Component,args:[{selector:"color-picker",template:'<div #dialogPopup class="color-picker" [style.visibility]="hidden || !show ? \'hidden\' : \'visible\'" [style.top.px]="top" [style.left.px]="left" [style.position]="position" [style.height.px]="cpHeight" [style.width.px]="cpWidth"><div *ngIf="cpDialogDisplay==\'popup\'" class="arrow arrow-{{cpPosition}}" [style.top.px]="arrowTop"></div><div class="saturation-lightness" [slider] [rgX]="1" [rgY]="1" [style.background-color]="hueSliderColor" (newValue)="onColorChange($event)" (dragStart)="onDragStart(\'saturation-lightness\')" (dragEnd)="onDragEnd(\'saturation-lightness\')"><div class="cursor" [style.top.px]="slider.v" [style.left.px]="slider.s"></div></div><div class="hue-alpha box"><div class="left"><div class="selected-color-background"></div><div class="selected-color" [style.background-color]="selectedColor"></div><button *ngIf="cpAddColorButton" class="{{cpAddColorButtonClass}}" [disabled]="cpPresetColors && cpPresetColors.length >= cpMaxPresetColorsLength" (click)="onAddPresetColor($event, selectedColor)">{{cpAddColorButtonText}}</button></div><div class="right"><div *ngIf="cpAlphaChannel===\'disabled\'" style="height: 16px;"></div><div #hueSlider class="hue" [slider] [rgX]="1" (newValue)="onHueChange($event)" (dragStart)="onDragStart(\'hue\')" (dragEnd)="onDragEnd(\'hue\')"><div class="cursor" [style.left.px]="slider.h"></div></div><div #alphaSlider class="alpha" [slider] [rgX]="1" [style.display]="cpAlphaChannel === \'disabled\' ? \'none\' : \'block\'" [style.background-color]="alphaSliderColor" (newValue)="onAlphaChange($event)" (dragStart)="onDragStart(\'alpha\')" (dragEnd)="onDragEnd(\'alpha\')"><div class="cursor" [style.left.px]="slider.a"></div></div></div></div><div *ngIf="!cpDisableInput" class="hsla-text" [style.display]="format !== 2 ? \'none\' : \'block\'"><div class="box"><input type="number" pattern="[0-9]*" min="0" max="360" [text] [rg]="360" [value]="hslaText.h" (newValue)="onHueInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="100" [text] [rg]="100" [value]="hslaText.s" (newValue)="onSaturationInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="100" [text] [rg]="100" [value]="hslaText.l" (newValue)="onLightnessInput($event)"> <input *ngIf="cpAlphaChannel!==\'disabled\'" type="number" pattern="[0-9]+([.,][0-9]{1,2})?" min="0" max="1" step="0.1" [text] [rg]="1" [value]="hslaText.a" (newValue)="onAlphaInput($event)"></div><div class="box"><div>H</div><div>S</div><div>L</div><div *ngIf="cpAlphaChannel!==\'disabled\'">A</div></div></div><div *ngIf="!cpDisableInput" [style.display]="format !== 1 ? \'none\' : \'block\'" class="rgba-text"><div class="box"><input type="number" pattern="[0-9]*" min="0" max="255" [text] [rg]="255" [value]="rgbaText.r" (newValue)="onRedInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="255" [text] [rg]="255" [value]="rgbaText.g" (newValue)="onGreenInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="255" [text] [rg]="255" [value]="rgbaText.b" (newValue)="onBlueInput($event)"> <input *ngIf="cpAlphaChannel!==\'disabled\'" type="number" pattern="[0-9]+([.,][0-9]{1,2})?" min="0" max="1" step="0.1" [text] [rg]="1" [value]="rgbaText.a" (newValue)="onAlphaInput($event)"></div><div class="box"><div>R</div><div>G</div><div>B</div><div *ngIf="cpAlphaChannel!==\'disabled\'">A</div></div></div><div *ngIf="!cpDisableInput" class="hex-text" [style.display]="format !== 0 ? \'none\' : \'block\'"><div class="box"><input [text] [value]="hexText" (blur)="onHexInput(null)" (newValue)="onHexInput($event)"></div><div class="box"><div>Hex</div></div></div><div *ngIf="!cpDisableInput" class="type-policy" (click)="onFormatToggle()"></div><div *ngIf="cpPresetColors?.length || cpAddColorButton" class="preset-area"><hr><div class="preset-label">{{cpPresetLabel}}</div><div *ngIf="cpPresetColors?.length"><div *ngFor="let color of cpPresetColors" class="preset-color" [style.backgroundColor]="color" (click)="setColorFromString(color)"><span *ngIf="cpAddColorButton" class="{{cpRemoveColorButtonClass}}" (click)="onRemovePresetColor($event, color)"></span></div></div><div *ngIf="!cpPresetColors?.length && cpAddColorButton" class="{{cpPresetEmptyMessageClass}}">{{cpPresetEmptyMessage}}</div></div><div *ngIf="cpOKButton || cpCancelButton" class="button-area"><button *ngIf="cpOKButton" type="button" class="{{cpOKButtonClass}}" (click)="onAcceptColor($event)">{{cpOKButtonText}}</button> <button *ngIf="cpCancelButton" type="button" class="{{cpCancelButtonClass}}" (click)="onCancelColor($event)">{{cpCancelButtonText}}</button></div></div>',styles:[".color-picker{position:absolute;z-index:100000;width:230px;height:auto;border:#777 solid 1px;cursor:default;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#fff}.color-picker *{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;margin:0;font-size:11px}.color-picker input{height:26px;min-width:0;font-size:13px;text-align:center;color:#000}.color-picker input:invalid{box-shadow:none}.color-picker input:-moz-ui-invalid{box-shadow:none}.color-picker input:-moz-submit-invalid{box-shadow:none}.color-picker input::-webkit-inner-spin-button,.color-picker input::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.color-picker .arrow{position:absolute;z-index:999999;width:0;height:0;border-style:solid}.color-picker .arrow.arrow-top{left:8px;border-width:10px 5px;border-color:#777 transparent transparent transparent}.color-picker .arrow.arrow-left{top:8px;left:100%;border-width:5px 10px;border-color:transparent transparent transparent #777}.color-picker .arrow.arrow-right{top:8px;left:-20px;border-width:5px 10px;border-color:transparent #777 transparent transparent}.color-picker .arrow.arrow-bottom{top:-20px;left:8px;border-width:10px 5px;border-color:transparent transparent #777 transparent}.color-picker .cursor{position:relative;width:16px;height:16px;border:#222 solid 2px;border-radius:50%;cursor:default}.color-picker .box{display:flex;padding:4px 8px}.color-picker .box .left{position:relative;padding:16px 8px}.color-picker .box .right{-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;padding:12px 8px}.color-picker .button-area{padding:0 16px 16px;text-align:right}.color-picker .preset-area{padding:4px 15px}.color-picker .preset-area .preset-label{width:100%;padding:4px;font-size:11px;text-align:left;color:#555}.color-picker .preset-area .preset-color{position:relative;display:inline-block;width:18px;height:18px;margin:4px 6px 8px;border:#a9a9a9 solid 1px;border-radius:25%;cursor:pointer}.color-picker .preset-area .preset-empty-message{min-height:18px;margin-top:4px;margin-bottom:8px;font-style:italic;text-align:center}.color-picker .hex-text{width:100%;padding:4px 8px;font-size:11px}.color-picker .hex-text .box{padding:0 24px 8px 8px}.color-picker .hex-text .box div{float:left;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;text-align:center;color:#555;clear:left}.color-picker .hex-text .box input{-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;padding:1px;border:#a9a9a9 solid 1px}.color-picker .hsla-text,.color-picker .rgba-text{width:100%;padding:4px 8px;font-size:11px}.color-picker .hsla-text .box,.color-picker .rgba-text .box{padding:0 24px 8px 8px}.color-picker .hsla-text .box div,.color-picker .rgba-text .box div{-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:8px;text-align:center;color:#555}.color-picker .hsla-text .box div:last-child,.color-picker .rgba-text .box div:last-child{margin-right:0}.color-picker .hsla-text .box input,.color-picker .rgba-text .box input{float:left;-webkit-flex:1;-ms-flex:1;flex:1;min-width:0;padding:1px;margin:0 8px 0 0;border:#a9a9a9 solid 1px}.color-picker .hsla-text .box input:last-child,.color-picker .rgba-text .box input:last-child{margin-right:0}.color-picker .hue-alpha{margin-bottom:3px}.color-picker .hue{width:100%;height:16px;margin-bottom:16px;border:none;cursor:pointer;background-size:100% 100%;background-image:url()}.color-picker .alpha{width:100%;height:16px;border:none;cursor:pointer;background-size:100% 100%;background-image:url()}.color-picker .type-policy{position:absolute;top:218px;right:12px;width:16px;height:24px;background-size:8px 16px;background-image:url();background-repeat:no-repeat;background-position:center}.color-picker .selected-color{position:absolute;top:16px;left:8px;width:40px;height:40px;border:1px solid #a9a9a9;border-radius:50%}.color-picker .selected-color-background{width:40px;height:40px;border-radius:50%;background-image:url()}.color-picker .saturation-lightness{width:100%;height:130px;border:none;cursor:pointer;background-size:100% 100%;background-image:url()}.color-picker .cp-add-color-button-class{position:absolute;display:inline;padding:0;margin:3px -3px;border:0;cursor:pointer;background:0 0}.color-picker .cp-add-color-button-class:hover{text-decoration:underline}.color-picker .cp-add-color-button-class:disabled{cursor:not-allowed;color:#999}.color-picker .cp-add-color-button-class:disabled:hover{text-decoration:none}.color-picker .cp-remove-color-button-class{position:absolute;top:-5px;right:-5px;display:block;width:10px;height:10px;border-radius:50%;cursor:pointer;text-align:center;background:#fff;box-shadow:1px 1px 5px #333}.color-picker .cp-remove-color-button-class::before{content:'x';position:relative;bottom:3.5px;display:inline-block;font-size:10px}"],encapsulation:core.ViewEncapsulation.None}]}];ColorPickerComponent.ctorParameters=function(){return[{type:core.ElementRef},{type:core.ChangeDetectorRef},{type:ColorPickerService}]};ColorPickerComponent.propDecorators={hueSlider:[{type:core.ViewChild,args:["hueSlider"]}],alphaSlider:[{type:core.ViewChild,args:["alphaSlider"]}],dialogElement:[{type:core.ViewChild,args:["dialogPopup"]}]};return ColorPickerComponent}();var ColorPickerDirective=function(){function ColorPickerDirective(injector,cfr,appRef,vcRef,elRef,service){this.injector=injector;this.cfr=cfr;this.appRef=appRef;this.vcRef=vcRef;this.elRef=elRef;this.service=service;this.dialogCreated=false;this.ignoreChanges=false;this.cpWidth="230px";this.cpHeight="auto";this.cpToggle=false;this.cpIgnoredElements=[];this.cpDisableInput=false;this.cpAlphaChannel="enabled";this.cpOutputFormat="hex";this.cpFallbackColor="#fff";this.cpDialogDisplay="popup";this.cpSaveClickOutside=true;this.cpUseRootViewContainer=false;this.cpPosition="right";this.cpPositionOffset="0%";this.cpPositionRelativeToArrow=false;this.cpOKButton=false;this.cpOKButtonText="OK";this.cpOKButtonClass="cp-ok-button-class";this.cpCancelButton=false;this.cpCancelButtonText="Cancel";this.cpCancelButtonClass="cp-cancel-button-class";this.cpPresetLabel="Preset colors";this.cpMaxPresetColorsLength=6;this.cpPresetEmptyMessage="No colors added";this.cpPresetEmptyMessageClass="preset-empty-message";this.cpAddColorButton=false;this.cpAddColorButtonText="Add color";this.cpAddColorButtonClass="cp-add-color-button-class";this.cpRemoveColorButtonClass="cp-remove-color-button-class";this.cpInputChange=new core.EventEmitter(true);this.cpToggleChange=new core.EventEmitter(true);this.cpSliderChange=new core.EventEmitter(true);this.cpSliderDragEnd=new core.EventEmitter(true);this.cpSliderDragStart=new core.EventEmitter(true);this.cpPresetColorsChange=new core.EventEmitter(true);this.colorPickerCancel=new core.EventEmitter(true);this.colorPickerSelect=new core.EventEmitter(true);this.colorPickerChange=new core.EventEmitter(false)}ColorPickerDirective.prototype.handleClick=function(event){this.inputFocus()};ColorPickerDirective.prototype.handleFocus=function(event){this.inputFocus()};ColorPickerDirective.prototype.handleInput=function(event){this.inputChange(event.target.value)};ColorPickerDirective.prototype.ngOnInit=function(){this.colorPicker=this.colorPicker||this.cpFallbackColor||"rgba(0, 0, 0, 1)"};ColorPickerDirective.prototype.ngOnDestroy=function(){if(this.cmpRef!==undefined){this.cmpRef.destroy()}};ColorPickerDirective.prototype.ngOnChanges=function(changes){if(changes.cpToggle){if(changes.cpToggle.currentValue){this.openDialog()}if(!changes.cpToggle.currentValue&&this.dialog){this.dialog.closeDialog()}}if(changes.colorPicker){if(this.dialog&&!this.ignoreChanges){if(this.cpDialogDisplay==="inline"){this.dialog.setInitialColor(changes.colorPicker.currentValue)}this.dialog.setColorFromString(changes.colorPicker.currentValue,false)}this.ignoreChanges=false}if(changes.cpPresetLabel||changes.cpPresetColors){if(this.dialog){this.dialog.setPresetConfig(this.cpPresetLabel,this.cpPresetColors)}}};ColorPickerDirective.prototype.openDialog=function(){this.colorPicker=this.colorPicker||this.cpFallbackColor||"rgba(0, 0, 0, 1)";if(!this.dialogCreated){var vcRef=this.vcRef;this.dialogCreated=true;if(this.cpUseRootViewContainer&&this.cpDialogDisplay!=="inline"){var classOfRootComponent=this.appRef.componentTypes[0];var appInstance=this.injector.get(classOfRootComponent);vcRef=appInstance.vcRef||appInstance.viewContainerRef||this.vcRef;if(vcRef===this.vcRef){console.warn("You are using cpUseRootViewContainer, "+"but the root component is not exposing viewContainerRef!"+"Please expose it by adding 'public vcRef: ViewContainerRef' to the constructor.")}}var compFactory=this.cfr.resolveComponentFactory(ColorPickerComponent);var injector=core.ReflectiveInjector.fromResolvedProviders([],vcRef.parentInjector);this.cmpRef=vcRef.createComponent(compFactory,0,injector,[]);this.cmpRef.instance.setupDialog(this,this.elRef,this.colorPicker,this.cpWidth,this.cpHeight,this.cpDialogDisplay,this.cpAlphaChannel,this.cpOutputFormat,this.cpDisableInput,this.cpIgnoredElements,this.cpSaveClickOutside,this.cpUseRootViewContainer,this.cpPosition,this.cpPositionOffset,this.cpPositionRelativeToArrow,this.cpPresetLabel,this.cpPresetColors,this.cpMaxPresetColorsLength,this.cpPresetEmptyMessage,this.cpPresetEmptyMessageClass,this.cpOKButton,this.cpOKButtonClass,this.cpOKButtonText,this.cpCancelButton,this.cpCancelButtonClass,this.cpCancelButtonText,this.cpAddColorButton,this.cpAddColorButtonClass,this.cpAddColorButtonText,this.cpRemoveColorButtonClass);this.dialog=this.cmpRef.instance;if(this.vcRef!==vcRef){this.cmpRef.changeDetectorRef.detectChanges()}}else if(this.dialog){this.dialog.openDialog(this.colorPicker)}};ColorPickerDirective.prototype.toggle=function(value){this.cpToggleChange.emit(value)};ColorPickerDirective.prototype.colorChanged=function(value,ignore){if(ignore===void 0){ignore=true}this.ignoreChanges=ignore;this.colorPickerChange.emit(value)};ColorPickerDirective.prototype.colorCanceled=function(){this.colorPickerCancel.emit()};ColorPickerDirective.prototype.colorSelected=function(value){this.colorPickerSelect.emit(value)};ColorPickerDirective.prototype.inputFocus=function(){var element=this.elRef.nativeElement;if(this.cpIgnoredElements.filter(function(item){return item===element}).length===0){this.openDialog()}};ColorPickerDirective.prototype.inputChange=function(value){if(this.dialog){this.dialog.setColorFromString(value,true)}else{this.colorPicker=value||this.cpFallbackColor||"rgba(0, 0, 0, 1)";this.colorPickerChange.emit(this.colorPicker)}};ColorPickerDirective.prototype.inputChanged=function(event){this.cpInputChange.emit(event)};ColorPickerDirective.prototype.sliderChanged=function(event){this.cpSliderChange.emit(event)};ColorPickerDirective.prototype.sliderDragEnd=function(event){this.cpSliderDragEnd.emit(event)};ColorPickerDirective.prototype.sliderDragStart=function(event){this.cpSliderDragStart.emit(event)};ColorPickerDirective.prototype.presetColorsChanged=function(value){this.cpPresetColorsChange.emit(value)};ColorPickerDirective.decorators=[{type:core.Directive,args:[{selector:"[colorPicker]"}]}];ColorPickerDirective.ctorParameters=function(){return[{type:core.Injector},{type:core.ComponentFactoryResolver},{type:core.ApplicationRef},{type:core.ViewContainerRef},{type:core.ElementRef},{type:ColorPickerService}]};ColorPickerDirective.propDecorators={colorPicker:[{type:core.Input}],cpWidth:[{type:core.Input}],cpHeight:[{type:core.Input}],cpToggle:[{type:core.Input}],cpIgnoredElements:[{type:core.Input}],cpDisableInput:[{type:core.Input}],cpAlphaChannel:[{type:core.Input}],cpOutputFormat:[{type:core.Input}],cpFallbackColor:[{type:core.Input}],cpDialogDisplay:[{type:core.Input}],cpSaveClickOutside:[{type:core.Input}],cpUseRootViewContainer:[{type:core.Input}],cpPosition:[{type:core.Input}],cpPositionOffset:[{type:core.Input}],cpPositionRelativeToArrow:[{type:core.Input}],cpOKButton:[{type:core.Input}],cpOKButtonText:[{type:core.Input}],cpOKButtonClass:[{type:core.Input}],cpCancelButton:[{type:core.Input}],cpCancelButtonText:[{type:core.Input}],cpCancelButtonClass:[{type:core.Input}],cpPresetLabel:[{type:core.Input}],cpPresetColors:[{type:core.Input}],cpMaxPresetColorsLength:[{type:core.Input}],cpPresetEmptyMessage:[{type:core.Input}],cpPresetEmptyMessageClass:[{type:core.Input}],cpAddColorButton:[{type:core.Input}],cpAddColorButtonText:[{type:core.Input}],cpAddColorButtonClass:[{type:core.Input}],cpRemoveColorButtonClass:[{type:core.Input}],cpInputChange:[{type:core.Output}],cpToggleChange:[{type:core.Output}],cpSliderChange:[{type:core.Output}],cpSliderDragEnd:[{type:core.Output}],cpSliderDragStart:[{type:core.Output}],cpPresetColorsChange:[{type:core.Output}],colorPickerCancel:[{type:core.Output}],colorPickerSelect:[{type:core.Output}],colorPickerChange:[{type:core.Output}],handleClick:[{type:core.HostListener,args:["click",["$event"]]}],handleFocus:[{type:core.HostListener,args:["focus",["$event"]]}],handleInput:[{type:core.HostListener,args:["input",["$event"]]}]};return ColorPickerDirective}();var ColorPickerModule=function(){function ColorPickerModule(){}ColorPickerModule.decorators=[{type:core.NgModule,args:[{imports:[common.CommonModule],exports:[ColorPickerDirective],providers:[ColorPickerService],declarations:[ColorPickerComponent,ColorPickerDirective,TextDirective,SliderDirective],entryComponents:[ColorPickerComponent]}]}];ColorPickerModule.ctorParameters=function(){return[]};return ColorPickerModule}();exports.Cmyk=Cmyk;exports.Hsla=Hsla;exports.Hsva=Hsva;exports.Rgba=Rgba;exports.TextDirective=TextDirective;exports.SliderDirective=SliderDirective;exports.ColorPickerComponent=ColorPickerComponent;exports.ColorPickerDirective=ColorPickerDirective;exports.ColorPickerModule=ColorPickerModule;exports.ColorPickerService=ColorPickerService;Object.defineProperty(exports,"__esModule",{value:true})}); | ||
(function(global,factory){typeof exports==="object"&&typeof module!=="undefined"?factory(exports,require("@angular/core"),require("@angular/common")):typeof define==="function"&&define.amd?define(["exports","@angular/core","@angular/common"],factory):factory((global.zef=global.zef||{},global.zef.ngxColorPicker={}),global.ng.core,global.ng.common)})(this,function(exports,core,common){"use strict";var Cmyk=function(){function Cmyk(c,m,y,k){this.c=c;this.m=m;this.y=y;this.k=k}return Cmyk}();var Hsla=function(){function Hsla(h,s,l,a){this.h=h;this.s=s;this.l=l;this.a=a}return Hsla}();var Hsva=function(){function Hsva(h,s,v,a){this.h=h;this.s=s;this.v=v;this.a=a}return Hsva}();var Rgba=function(){function Rgba(r,g,b,a){this.r=r;this.g=g;this.b=b;this.a=a}return Rgba}();function detectIE(){var ua="";if(typeof navigator!=="undefined"){ua=navigator.userAgent.toLowerCase()}var msie=ua.indexOf("msie ");if(msie>0){return parseInt(ua.substring(msie+5,ua.indexOf(".",msie)),10)}return false}var TextDirective=function(){function TextDirective(){this.newValue=new core.EventEmitter}TextDirective.prototype.inputChange=function(event){var value=event.target.value;if(this.rg===undefined){this.newValue.emit(value)}else{var numeric=parseFloat(value);if(!isNaN(numeric)&&numeric>=0&&numeric<=this.rg){this.newValue.emit({v:numeric,rg:this.rg})}}};TextDirective.decorators=[{type:core.Directive,args:[{selector:"[text]"}]}];TextDirective.ctorParameters=function(){return[]};TextDirective.propDecorators={rg:[{type:core.Input}],text:[{type:core.Input}],newValue:[{type:core.Output}],inputChange:[{type:core.HostListener,args:["input",["$event"]]}]};return TextDirective}();var SliderDirective=function(){function SliderDirective(elRef){var _this=this;this.elRef=elRef;this.dragEnd=new core.EventEmitter;this.dragStart=new core.EventEmitter;this.newValue=new core.EventEmitter;this.listenerMove=function(event){return _this.move(event)};this.listenerStop=function(){return _this.stop()}}SliderDirective.prototype.mouseDown=function(event){this.start(event)};SliderDirective.prototype.touchStart=function(event){this.start(event)};SliderDirective.prototype.move=function(event){event.preventDefault();this.setCursor(event)};SliderDirective.prototype.start=function(event){this.setCursor(event);document.addEventListener("mouseup",this.listenerStop);document.addEventListener("touchend",this.listenerStop);document.addEventListener("mousemove",this.listenerMove);document.addEventListener("touchmove",this.listenerMove);this.dragStart.emit()};SliderDirective.prototype.stop=function(){document.removeEventListener("mouseup",this.listenerStop);document.removeEventListener("touchend",this.listenerStop);document.removeEventListener("mousemove",this.listenerMove);document.removeEventListener("touchmove",this.listenerMove);this.dragEnd.emit()};SliderDirective.prototype.getX=function(event){var position=this.elRef.nativeElement.getBoundingClientRect();var pageX=event.pageX!==undefined?event.pageX:event.touches[0].pageX;return pageX-position.left-window.pageXOffset};SliderDirective.prototype.getY=function(event){var position=this.elRef.nativeElement.getBoundingClientRect();var pageY=event.pageY!==undefined?event.pageY:event.touches[0].pageY;return pageY-position.top-window.pageYOffset};SliderDirective.prototype.setCursor=function(event){var width=this.elRef.nativeElement.offsetWidth;var height=this.elRef.nativeElement.offsetHeight;var x=Math.max(0,Math.min(this.getX(event),width));var y=Math.max(0,Math.min(this.getY(event),height));if(this.rgX!==undefined&&this.rgY!==undefined){this.newValue.emit({s:x/width,v:1-y/height,rgX:this.rgX,rgY:this.rgY})}else if(this.rgX===undefined&&this.rgY!==undefined){this.newValue.emit({v:y/height,rgY:this.rgY})}else if(this.rgX!==undefined&&this.rgY===undefined){this.newValue.emit({v:x/width,rgX:this.rgX})}};SliderDirective.decorators=[{type:core.Directive,args:[{selector:"[slider]"}]}];SliderDirective.ctorParameters=function(){return[{type:core.ElementRef}]};SliderDirective.propDecorators={rgX:[{type:core.Input}],rgY:[{type:core.Input}],slider:[{type:core.Input}],dragEnd:[{type:core.Output}],dragStart:[{type:core.Output}],newValue:[{type:core.Output}],mouseDown:[{type:core.HostListener,args:["mousedown",["$event"]]}],touchStart:[{type:core.HostListener,args:["touchstart",["$event"]]}]};return SliderDirective}();var SliderPosition=function(){function SliderPosition(h,s,v,a){this.h=h;this.s=s;this.v=v;this.a=a}return SliderPosition}();var SliderDimension=function(){function SliderDimension(h,s,v,a){this.h=h;this.s=s;this.v=v;this.a=a}return SliderDimension}();var ColorPickerService=function(){function ColorPickerService(){this.active=null}ColorPickerService.prototype.setActive=function(active){if(this.active&&this.active!==active&&this.active.cpDialogDisplay!=="inline"){this.active.closeColorPicker()}this.active=active};ColorPickerService.prototype.hsva2hsla=function(hsva){var h=hsva.h,s=hsva.s,v=hsva.v,a=hsva.a;if(v===0){return new Hsla(h,0,0,a)}else if(s===0&&v===1){return new Hsla(h,1,1,a)}else{var l=v*(2-s)/2;return new Hsla(h,v*s/(1-Math.abs(2*l-1)),l,a)}};ColorPickerService.prototype.hsla2hsva=function(hsla){var h=Math.min(hsla.h,1),s=Math.min(hsla.s,1);var l=Math.min(hsla.l,1),a=Math.min(hsla.a,1);if(l===0){return new Hsva(h,0,0,a)}else{var v=l+s*(1-Math.abs(2*l-1))/2;return new Hsva(h,2*(v-l)/v,v,a)}};ColorPickerService.prototype.hsvaToRgba=function(hsva){var r,g,b;var h=hsva.h,s=hsva.s,v=hsva.v,a=hsva.a;var i=Math.floor(h*6);var f=h*6-i;var p=v*(1-s);var q=v*(1-f*s);var t=v*(1-(1-f)*s);switch(i%6){case 0:r=v,g=t,b=p;break;case 1:r=q,g=v,b=p;break;case 2:r=p,g=v,b=t;break;case 3:r=p,g=q,b=v;break;case 4:r=t,g=p,b=v;break;case 5:r=v,g=p,b=q;break}return new Rgba(r,g,b,a)};ColorPickerService.prototype.rgbaToCmyk=function(rgba){var k=1-Math.max(rgba.r,rgba.g,rgba.b);if(k===1){return new Cmyk(0,0,0,1)}else{var c=(1-rgba.r-k)/(1-k);var m=(1-rgba.g-k)/(1-k);var y=(1-rgba.b-k)/(1-k);return new Cmyk(c,m,y,k)}};ColorPickerService.prototype.rgbaToHsva=function(rgba){var h,s;var r=Math.min(rgba.r,1),g=Math.min(rgba.g,1);var b=Math.min(rgba.b,1),a=Math.min(rgba.a,1);var max=Math.max(r,g,b),min=Math.min(r,g,b);var v=max,d=max-min;s=max===0?0:d/max;if(max===min){h=0}else{switch(max){case r:h=(g-b)/d+(g<b?6:0);break;case g:h=(b-r)/d+2;break;case b:h=(r-g)/d+4;break}h/=6}return new Hsva(h,s,v,a)};ColorPickerService.prototype.rgbaToHex=function(rgba,allowHex8){var hex="#"+(1<<24|rgba.r<<16|rgba.g<<8|rgba.b).toString(16).substr(1);if(allowHex8){hex+=(1<<8|Math.round(rgba.a*255)).toString(16).substr(1)}return hex};ColorPickerService.prototype.denormalizeRGBA=function(rgba){return new Rgba(Math.round(rgba.r*255),Math.round(rgba.g*255),Math.round(rgba.b*255),rgba.a)};ColorPickerService.prototype.stringToHsva=function(colorString,allowHex8){if(colorString===void 0){colorString=""}if(allowHex8===void 0){allowHex8=false}var hsva=null;colorString=(colorString||"").toLowerCase();var stringParsers=[{re:/(rgb)a?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*%?,\s*(\d{1,3})\s*%?(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/,parse:function(execResult){return new Rgba(parseInt(execResult[2],10)/255,parseInt(execResult[3],10)/255,parseInt(execResult[4],10)/255,isNaN(parseFloat(execResult[5]))?1:parseFloat(execResult[5]))}},{re:/(hsl)a?\(\s*(\d{1,3})\s*,\s*(\d{1,3})%\s*,\s*(\d{1,3})%\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/,parse:function(execResult){return new Hsla(parseInt(execResult[2],10)/360,parseInt(execResult[3],10)/100,parseInt(execResult[4],10)/100,isNaN(parseFloat(execResult[5]))?1:parseFloat(execResult[5]))}}];if(allowHex8){stringParsers.push({re:/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})?$/,parse:function(execResult){return new Rgba(parseInt(execResult[1],16)/255,parseInt(execResult[2],16)/255,parseInt(execResult[3],16)/255,parseInt(execResult[4]||"FF",16)/255)}})}else{stringParsers.push({re:/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})$/,parse:function(execResult){return new Rgba(parseInt(execResult[1],16)/255,parseInt(execResult[2],16)/255,parseInt(execResult[3],16)/255,1)}},{re:/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])$/,parse:function(execResult){return new Rgba(parseInt(execResult[1]+execResult[1],16)/255,parseInt(execResult[2]+execResult[2],16)/255,parseInt(execResult[3]+execResult[3],16)/255,1)}})}for(var key in stringParsers){if(stringParsers.hasOwnProperty(key)){var parser=stringParsers[key];var match=parser.re.exec(colorString),color=match&&parser.parse(match);if(color){if(color instanceof Rgba){hsva=this.rgbaToHsva(color)}else if(color instanceof Hsla){hsva=this.hsla2hsva(color)}return hsva}}}return hsva};ColorPickerService.prototype.outputFormat=function(hsva,outputFormat,alphaChannel){switch(outputFormat){case"hsla":var hsla=this.hsva2hsla(hsva);var hslaText=new Hsla(Math.round(hsla.h*360),Math.round(hsla.s*100),Math.round(hsla.l*100),Math.round(hsla.a*100)/100);if(hsva.a<1||alphaChannel==="always"){return"hsla("+hslaText.h+","+hslaText.s+"%,"+hslaText.l+"%,"+hslaText.a+")"}else{return"hsl("+hslaText.h+","+hslaText.s+"%,"+hslaText.l+"%)"}case"rgba":var rgba=this.denormalizeRGBA(this.hsvaToRgba(hsva));if(hsva.a<1||alphaChannel==="always"){return"rgba("+rgba.r+","+rgba.g+","+rgba.b+","+Math.round(rgba.a*100)/100+")"}else{return"rgb("+rgba.r+","+rgba.g+","+rgba.b+")"}default:var allowHex8=alphaChannel==="always"||alphaChannel==="hex8";return this.rgbaToHex(this.denormalizeRGBA(this.hsvaToRgba(hsva)),allowHex8)}};ColorPickerService.decorators=[{type:core.Injectable}];ColorPickerService.ctorParameters=function(){return[]};return ColorPickerService}();var ColorPickerComponent=function(){function ColorPickerComponent(elRef,cdRef,service){this.elRef=elRef;this.cdRef=cdRef;this.service=service;this.isIE10=false;this.dialogArrowSize=10;this.dialogArrowOffset=15;this.useRootViewContainer=false}ColorPickerComponent.prototype.ngOnInit=function(){var _this=this;this.slider=new SliderPosition(0,0,0,0);var hueWidth=this.hueSlider.nativeElement.offsetWidth;var alphaWidth=this.alphaSlider.nativeElement.offsetWidth;this.sliderDimMax=new SliderDimension(hueWidth,this.cpWidth,130,alphaWidth);if(this.cpOutputFormat==="rgba"){this.format=1}else if(this.cpOutputFormat==="hsla"){this.format=2}else{this.format=0}this.listenerMouseDown=function(event){_this.onMouseDown(event)};this.listenerResize=function(){_this.onResize()};this.openDialog(this.initialColor,false)};ColorPickerComponent.prototype.ngOnDestroy=function(){this.closeDialog()};ColorPickerComponent.prototype.ngAfterViewInit=function(){if(this.cpWidth!==230){var hueWidth=this.hueSlider.nativeElement.offsetWidth;var alphaWidth=this.alphaSlider.nativeElement.offsetWidth;this.sliderDimMax=new SliderDimension(hueWidth,this.cpWidth,130,alphaWidth);this.updateColorPicker(false);this.cdRef.detectChanges()}};ColorPickerComponent.prototype.openDialog=function(color,emit){if(emit===void 0){emit=true}this.service.setActive(this);if(!this.width){this.cpWidth=this.directiveElementRef.nativeElement.offsetWidth}this.setInitialColor(color);this.setColorFromString(color,emit);this.openColorPicker()};ColorPickerComponent.prototype.closeDialog=function(){this.closeColorPicker()};ColorPickerComponent.prototype.setupDialog=function(instance,elementRef,color,cpWidth,cpHeight,cpDialogDisplay,cpAlphaChannel,cpOutputFormat,cpDisableInput,cpIgnoredElements,cpSaveClickOutside,cpUseRootViewContainer,cpPosition,cpPositionOffset,cpPositionRelativeToArrow,cpPresetLabel,cpPresetColors,cpMaxPresetColorsLength,cpPresetEmptyMessage,cpPresetEmptyMessageClass,cpOKButton,cpOKButtonClass,cpOKButtonText,cpCancelButton,cpCancelButtonClass,cpCancelButtonText,cpAddColorButton,cpAddColorButtonClass,cpAddColorButtonText,cpRemoveColorButtonClass){this.setInitialColor(color);this.isIE10=detectIE()===10;this.directiveInstance=instance;this.directiveElementRef=elementRef;this.cpDisableInput=cpDisableInput;this.cpAlphaChannel=cpAlphaChannel;this.cpOutputFormat=cpOutputFormat;this.cpDialogDisplay=cpDialogDisplay;this.cpIgnoredElements=cpIgnoredElements;this.cpSaveClickOutside=cpSaveClickOutside;this.useRootViewContainer=cpUseRootViewContainer;this.width=this.cpWidth=parseInt(cpWidth,10);this.height=this.cpHeight=parseInt(cpHeight,10);this.cpPosition=cpPosition;this.cpPositionOffset=parseInt(cpPositionOffset,10);this.cpOKButton=cpOKButton;this.cpOKButtonText=cpOKButtonText;this.cpOKButtonClass=cpOKButtonClass;this.cpCancelButton=cpCancelButton;this.cpCancelButtonText=cpCancelButtonText;this.cpCancelButtonClass=cpCancelButtonClass;this.setPresetConfig(cpPresetLabel,cpPresetColors);this.cpMaxPresetColorsLength=cpMaxPresetColorsLength;this.cpPresetEmptyMessage=cpPresetEmptyMessage;this.cpPresetEmptyMessageClass=cpPresetEmptyMessageClass;this.cpAddColorButton=cpAddColorButton;this.cpAddColorButtonText=cpAddColorButtonText;this.cpAddColorButtonClass=cpAddColorButtonClass;this.cpRemoveColorButtonClass=cpRemoveColorButtonClass;if(!cpPositionRelativeToArrow){this.dialogArrowOffset=0}if(this.cpDialogDisplay==="inline"){this.dialogArrowSize=0;this.dialogArrowOffset=0}if(cpOutputFormat==="hex"&&cpAlphaChannel!=="always"&&cpAlphaChannel!=="hex8"){this.cpAlphaChannel="disabled"}};ColorPickerComponent.prototype.setInitialColor=function(color){this.initialColor=color};ColorPickerComponent.prototype.setPresetConfig=function(cpPresetLabel,cpPresetColors){this.cpPresetLabel=cpPresetLabel;this.cpPresetColors=cpPresetColors};ColorPickerComponent.prototype.setColorFromString=function(value,emit,update){if(emit===void 0){emit=true}if(update===void 0){update=true}var hsva;if(this.cpAlphaChannel==="always"||this.cpAlphaChannel==="hex8"){hsva=this.service.stringToHsva(value,true);if(!hsva&&!this.hsva){hsva=this.service.stringToHsva(value,false)}}else{hsva=this.service.stringToHsva(value,false)}if(hsva){this.hsva=hsva;this.updateColorPicker(emit,update)}};ColorPickerComponent.prototype.onResize=function(){if(this.position==="fixed"){this.setDialogPosition()}else if(this.cpDialogDisplay!=="inline"){this.closeColorPicker()}};ColorPickerComponent.prototype.onDragEnd=function(slider){this.directiveInstance.sliderDragEnd({slider:slider,color:this.outputColor})};ColorPickerComponent.prototype.onDragStart=function(slider){this.directiveInstance.sliderDragStart({slider:slider,color:this.outputColor})};ColorPickerComponent.prototype.onMouseDown=function(event){if(!this.isIE10&&this.cpDialogDisplay==="popup"&&event.target!==this.directiveElementRef.nativeElement&&!this.isDescendant(this.elRef.nativeElement,event.target)&&this.cpIgnoredElements.filter(function(item){return item===event.target}).length===0){if(!this.cpSaveClickOutside){this.setColorFromString(this.initialColor,false);this.directiveInstance.colorChanged(this.initialColor)}this.closeColorPicker()}};ColorPickerComponent.prototype.onAcceptColor=function(event){event.stopPropagation();if(this.cpDialogDisplay==="popup"){this.closeColorPicker()}if(this.outputColor){this.directiveInstance.colorSelected(this.outputColor)}};ColorPickerComponent.prototype.onCancelColor=function(event){event.stopPropagation();this.setColorFromString(this.initialColor,true);if(this.cpDialogDisplay==="popup"){this.directiveInstance.colorChanged(this.initialColor,true);this.closeColorPicker()}this.directiveInstance.colorCanceled()};ColorPickerComponent.prototype.onFormatToggle=function(){this.format=(this.format+1)%3};ColorPickerComponent.prototype.onColorChange=function(value){this.hsva.s=value.s/value.rgX;this.hsva.v=value.v/value.rgY;this.updateColorPicker();this.directiveInstance.sliderChanged({slider:"lightness",value:this.hsva.v,color:this.outputColor});this.directiveInstance.sliderChanged({slider:"saturation",value:this.hsva.s,color:this.outputColor})};ColorPickerComponent.prototype.onHueChange=function(value){this.hsva.h=value.v/value.rgX;this.sliderH=this.hsva.h;this.updateColorPicker();this.directiveInstance.sliderChanged({slider:"hue",value:this.hsva.h,color:this.outputColor})};ColorPickerComponent.prototype.onAlphaChange=function(value){this.hsva.a=value.v/value.rgX;this.updateColorPicker();this.directiveInstance.sliderChanged({slider:"alpha",value:this.hsva.a,color:this.outputColor})};ColorPickerComponent.prototype.onHexInput=function(value){if(value===null){this.updateColorPicker()}else{this.setColorFromString(value,true,false);this.directiveInstance.inputChanged({input:"hex",value:value,color:this.outputColor})}};ColorPickerComponent.prototype.onRedInput=function(value){var rgba=this.service.hsvaToRgba(this.hsva);rgba.r=value.v/value.rg;this.hsva=this.service.rgbaToHsva(rgba);this.updateColorPicker();this.directiveInstance.inputChanged({input:"red",value:rgba.r,color:this.outputColor})};ColorPickerComponent.prototype.onBlueInput=function(value){var rgba=this.service.hsvaToRgba(this.hsva);rgba.b=value.v/value.rg;this.hsva=this.service.rgbaToHsva(rgba);this.updateColorPicker();this.directiveInstance.inputChanged({input:"blue",value:rgba.b,color:this.outputColor})};ColorPickerComponent.prototype.onGreenInput=function(value){var rgba=this.service.hsvaToRgba(this.hsva);rgba.g=value.v/value.rg;this.hsva=this.service.rgbaToHsva(rgba);this.updateColorPicker();this.directiveInstance.inputChanged({input:"green",value:rgba.g,color:this.outputColor})};ColorPickerComponent.prototype.onAlphaInput=function(value){this.hsva.a=value.v/value.rg;this.updateColorPicker();this.directiveInstance.inputChanged({input:"alpha",value:this.hsva.a,color:this.outputColor})};ColorPickerComponent.prototype.onHueInput=function(value){this.hsva.h=value.v/value.rg;this.updateColorPicker();this.directiveInstance.inputChanged({input:"hue",value:this.hsva.h,color:this.outputColor})};ColorPickerComponent.prototype.onLightnessInput=function(value){var hsla=this.service.hsva2hsla(this.hsva);hsla.l=value.v/value.rg;this.hsva=this.service.hsla2hsva(hsla);this.updateColorPicker();this.directiveInstance.inputChanged({input:"lightness",value:hsla.l,color:this.outputColor})};ColorPickerComponent.prototype.onSaturationInput=function(value){var hsla=this.service.hsva2hsla(this.hsva);hsla.s=value.v/value.rg;this.hsva=this.service.hsla2hsva(hsla);this.updateColorPicker();this.directiveInstance.inputChanged({input:"saturation",value:hsla.s,color:this.outputColor})};ColorPickerComponent.prototype.onAddPresetColor=function(event,value){event.stopPropagation();if(!this.cpPresetColors.filter(function(color){return color===value}).length){this.cpPresetColors=this.cpPresetColors.concat(value);this.directiveInstance.presetColorsChanged(this.cpPresetColors)}};ColorPickerComponent.prototype.onRemovePresetColor=function(event,value){event.stopPropagation();this.cpPresetColors=this.cpPresetColors.filter(function(color){return color!==value});this.directiveInstance.presetColorsChanged(this.cpPresetColors)};ColorPickerComponent.prototype.openColorPicker=function(){var _this=this;if(!this.show){this.show=true;this.hidden=true;setTimeout(function(){_this.hidden=false;_this.setDialogPosition();_this.cdRef.detectChanges()},0);this.directiveInstance.toggle(true);if(!this.isIE10){document.addEventListener("mousedown",this.listenerMouseDown)}window.addEventListener("resize",this.listenerResize)}};ColorPickerComponent.prototype.closeColorPicker=function(){if(this.show){this.show=false;this.directiveInstance.toggle(false);if(!this.isIE10){document.removeEventListener("mousedown",this.listenerMouseDown)}window.removeEventListener("resize",this.listenerResize);if(!this.cdRef["destroyed"]){this.cdRef.detectChanges()}}};ColorPickerComponent.prototype.updateColorPicker=function(emit,update){if(emit===void 0){emit=true}if(update===void 0){update=true}if(this.sliderDimMax){var lastOutput=this.outputColor;var hsla=this.service.hsva2hsla(this.hsva);var rgba=this.service.denormalizeRGBA(this.service.hsvaToRgba(this.hsva));var hue=this.service.denormalizeRGBA(this.service.hsvaToRgba(new Hsva(this.sliderH||this.hsva.h,1,1,1)));if(update){this.hslaText=new Hsla(Math.round(hsla.h*360),Math.round(hsla.s*100),Math.round(hsla.l*100),Math.round(hsla.a*100)/100);this.rgbaText=new Rgba(rgba.r,rgba.g,rgba.b,Math.round(rgba.a*100)/100);var allowHex8=this.cpAlphaChannel==="always"||this.cpAlphaChannel==="hex8";this.hexText=this.service.rgbaToHex(rgba,allowHex8)}this.hueSliderColor="rgb("+hue.r+","+hue.g+","+hue.b+")";this.alphaSliderColor="rgb("+rgba.r+","+rgba.g+","+rgba.b+")";this.outputColor=this.service.outputFormat(this.hsva,this.cpOutputFormat,this.cpAlphaChannel);this.selectedColor=this.service.outputFormat(this.hsva,"rgba",null);this.slider=new SliderPosition((this.sliderH||this.hsva.h)*this.sliderDimMax.h-8,this.hsva.s*this.sliderDimMax.s-8,(1-this.hsva.v)*this.sliderDimMax.v-8,this.hsva.a*this.sliderDimMax.a-8);if(emit&&lastOutput!==this.outputColor){this.directiveInstance.colorChanged(this.outputColor)}}};ColorPickerComponent.prototype.setDialogPosition=function(){if(this.cpDialogDisplay==="inline"){this.position="relative"}else{var dialogHeight=this.dialogElement.nativeElement.offsetHeight;var position="static",transform="",style=null;var parentNode=null,transformNode=null;var node=this.directiveElementRef.nativeElement.parentNode;while(node!==null&&node.tagName!=="HTML"){style=window.getComputedStyle(node);position=style.getPropertyValue("position");transform=style.getPropertyValue("transform");if(position!=="static"&&parentNode===null){parentNode=node}if(transform&&transform!=="none"&&transformNode===null){transformNode=node}if(position==="fixed"){parentNode=transformNode;break}node=node.parentNode}var boxDirective=this.createBox(this.directiveElementRef.nativeElement,position!=="fixed");if(this.useRootViewContainer||position==="fixed"&&!parentNode){this.top=boxDirective.top;this.left=boxDirective.left}else{if(parentNode===null){parentNode=node}var boxParent=this.createBox(parentNode,position!=="fixed");this.top=boxDirective.top-boxParent.top;this.left=boxDirective.left-boxParent.left}if(position==="fixed"){this.position="fixed"}if(this.cpPosition==="left"){this.top+=boxDirective.height*this.cpPositionOffset/100-this.dialogArrowOffset;this.left-=this.cpWidth+this.dialogArrowSize-2}else if(this.cpPosition==="top"){this.arrowTop=dialogHeight-1;this.top-=dialogHeight+this.dialogArrowSize;this.left+=this.cpPositionOffset/100*boxDirective.width-this.dialogArrowOffset}else if(this.cpPosition==="bottom"){this.top+=boxDirective.height+this.dialogArrowSize;this.left+=this.cpPositionOffset/100*boxDirective.width-this.dialogArrowOffset}else{this.top+=boxDirective.height*this.cpPositionOffset/100-this.dialogArrowOffset;this.left+=boxDirective.width+this.dialogArrowSize-2}}};ColorPickerComponent.prototype.createBox=function(element,offset){return{top:element.getBoundingClientRect().top+(offset?window.pageYOffset:0),left:element.getBoundingClientRect().left+(offset?window.pageXOffset:0),width:element.offsetWidth,height:element.offsetHeight}};ColorPickerComponent.prototype.isDescendant=function(parent,child){var node=child.parentNode;while(node!==null){if(node===parent){return true}node=node.parentNode}return false};ColorPickerComponent.decorators=[{type:core.Component,args:[{selector:"color-picker",template:'<div #dialogPopup class="color-picker" [style.visibility]="hidden || !show ? \'hidden\' : \'visible\'" [style.top.px]="top" [style.left.px]="left" [style.position]="position" [style.height.px]="cpHeight" [style.width.px]="cpWidth"><div *ngIf="cpDialogDisplay==\'popup\'" class="arrow arrow-{{cpPosition}}" [style.top.px]="arrowTop"></div><div class="saturation-lightness" [slider] [rgX]="1" [rgY]="1" [style.background-color]="hueSliderColor" (newValue)="onColorChange($event)" (dragStart)="onDragStart(\'saturation-lightness\')" (dragEnd)="onDragEnd(\'saturation-lightness\')"><div class="cursor" [style.top.px]="slider.v" [style.left.px]="slider.s"></div></div><div class="hue-alpha box"><div class="left"><div class="selected-color-background"></div><div class="selected-color" [style.background-color]="selectedColor"></div><button *ngIf="cpAddColorButton" class="{{cpAddColorButtonClass}}" [disabled]="cpPresetColors && cpPresetColors.length >= cpMaxPresetColorsLength" (click)="onAddPresetColor($event, selectedColor)">{{cpAddColorButtonText}}</button></div><div class="right"><div *ngIf="cpAlphaChannel===\'disabled\'" style="height: 16px;"></div><div #hueSlider class="hue" [slider] [rgX]="1" (newValue)="onHueChange($event)" (dragStart)="onDragStart(\'hue\')" (dragEnd)="onDragEnd(\'hue\')"><div class="cursor" [style.left.px]="slider.h"></div></div><div #alphaSlider class="alpha" [slider] [rgX]="1" [style.display]="cpAlphaChannel === \'disabled\' ? \'none\' : \'block\'" [style.background-color]="alphaSliderColor" (newValue)="onAlphaChange($event)" (dragStart)="onDragStart(\'alpha\')" (dragEnd)="onDragEnd(\'alpha\')"><div class="cursor" [style.left.px]="slider.a"></div></div></div></div><div *ngIf="!cpDisableInput" class="hsla-text" [style.display]="format !== 2 ? \'none\' : \'block\'"><div class="box"><input type="number" pattern="[0-9]*" min="0" max="360" [text] [rg]="360" [value]="hslaText.h" (newValue)="onHueInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="100" [text] [rg]="100" [value]="hslaText.s" (newValue)="onSaturationInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="100" [text] [rg]="100" [value]="hslaText.l" (newValue)="onLightnessInput($event)"> <input *ngIf="cpAlphaChannel!==\'disabled\'" type="number" pattern="[0-9]+([.,][0-9]{1,2})?" min="0" max="1" step="0.1" [text] [rg]="1" [value]="hslaText.a" (newValue)="onAlphaInput($event)"></div><div class="box"><div>H</div><div>S</div><div>L</div><div *ngIf="cpAlphaChannel!==\'disabled\'">A</div></div></div><div *ngIf="!cpDisableInput" [style.display]="format !== 1 ? \'none\' : \'block\'" class="rgba-text"><div class="box"><input type="number" pattern="[0-9]*" min="0" max="255" [text] [rg]="255" [value]="rgbaText.r" (newValue)="onRedInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="255" [text] [rg]="255" [value]="rgbaText.g" (newValue)="onGreenInput($event)"> <input type="number" pattern="[0-9]*" min="0" max="255" [text] [rg]="255" [value]="rgbaText.b" (newValue)="onBlueInput($event)"> <input *ngIf="cpAlphaChannel!==\'disabled\'" type="number" pattern="[0-9]+([.,][0-9]{1,2})?" min="0" max="1" step="0.1" [text] [rg]="1" [value]="rgbaText.a" (newValue)="onAlphaInput($event)"></div><div class="box"><div>R</div><div>G</div><div>B</div><div *ngIf="cpAlphaChannel!==\'disabled\'">A</div></div></div><div *ngIf="!cpDisableInput" class="hex-text" [style.display]="format !== 0 ? \'none\' : \'block\'"><div class="box"><input [text] [value]="hexText" (blur)="onHexInput(null)" (newValue)="onHexInput($event)"></div><div class="box"><div>Hex</div></div></div><div *ngIf="!cpDisableInput" class="type-policy" (click)="onFormatToggle()"></div><div *ngIf="cpPresetColors?.length || cpAddColorButton" class="preset-area"><hr><div class="preset-label">{{cpPresetLabel}}</div><div *ngIf="cpPresetColors?.length"><div *ngFor="let color of cpPresetColors" class="preset-color" [style.backgroundColor]="color" (click)="setColorFromString(color)"><span *ngIf="cpAddColorButton" class="{{cpRemoveColorButtonClass}}" (click)="onRemovePresetColor($event, color)"></span></div></div><div *ngIf="!cpPresetColors?.length && cpAddColorButton" class="{{cpPresetEmptyMessageClass}}">{{cpPresetEmptyMessage}}</div></div><div *ngIf="cpOKButton || cpCancelButton" class="button-area"><button *ngIf="cpOKButton" type="button" class="{{cpOKButtonClass}}" (click)="onAcceptColor($event)">{{cpOKButtonText}}</button> <button *ngIf="cpCancelButton" type="button" class="{{cpCancelButtonClass}}" (click)="onCancelColor($event)">{{cpCancelButtonText}}</button></div></div>',styles:[".color-picker{position:absolute;z-index:100000;width:230px;height:auto;border:#777 solid 1px;cursor:default;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#fff}.color-picker *{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;margin:0;font-size:11px}.color-picker input{height:26px;min-width:0;font-size:13px;text-align:center;color:#000}.color-picker input:invalid{box-shadow:none}.color-picker input:-moz-ui-invalid{box-shadow:none}.color-picker input:-moz-submit-invalid{box-shadow:none}.color-picker input::-webkit-inner-spin-button,.color-picker input::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.color-picker .arrow{position:absolute;z-index:999999;width:0;height:0;border-style:solid}.color-picker .arrow.arrow-top{left:8px;border-width:10px 5px;border-color:#777 transparent transparent transparent}.color-picker .arrow.arrow-left{top:8px;left:100%;border-width:5px 10px;border-color:transparent transparent transparent #777}.color-picker .arrow.arrow-right{top:8px;left:-20px;border-width:5px 10px;border-color:transparent #777 transparent transparent}.color-picker .arrow.arrow-bottom{top:-20px;left:8px;border-width:10px 5px;border-color:transparent transparent #777 transparent}.color-picker .cursor{position:relative;width:16px;height:16px;border:#222 solid 2px;border-radius:50%;cursor:default}.color-picker .box{display:flex;padding:4px 8px}.color-picker .box .left{position:relative;padding:16px 8px}.color-picker .box .right{-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;padding:12px 8px}.color-picker .button-area{padding:0 16px 16px;text-align:right}.color-picker .preset-area{padding:4px 15px}.color-picker .preset-area .preset-label{width:100%;padding:4px;font-size:11px;text-align:left;color:#555}.color-picker .preset-area .preset-color{position:relative;display:inline-block;width:18px;height:18px;margin:4px 6px 8px;border:#a9a9a9 solid 1px;border-radius:25%;cursor:pointer}.color-picker .preset-area .preset-empty-message{min-height:18px;margin-top:4px;margin-bottom:8px;font-style:italic;text-align:center}.color-picker .hex-text{width:100%;padding:4px 8px;font-size:11px}.color-picker .hex-text .box{padding:0 24px 8px 8px}.color-picker .hex-text .box div{float:left;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;text-align:center;color:#555;clear:left}.color-picker .hex-text .box input{-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;padding:1px;border:#a9a9a9 solid 1px}.color-picker .hsla-text,.color-picker .rgba-text{width:100%;padding:4px 8px;font-size:11px}.color-picker .hsla-text .box,.color-picker .rgba-text .box{padding:0 24px 8px 8px}.color-picker .hsla-text .box div,.color-picker .rgba-text .box div{-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:8px;text-align:center;color:#555}.color-picker .hsla-text .box div:last-child,.color-picker .rgba-text .box div:last-child{margin-right:0}.color-picker .hsla-text .box input,.color-picker .rgba-text .box input{float:left;-webkit-flex:1;-ms-flex:1;flex:1;min-width:0;padding:1px;margin:0 8px 0 0;border:#a9a9a9 solid 1px}.color-picker .hsla-text .box input:last-child,.color-picker .rgba-text .box input:last-child{margin-right:0}.color-picker .hue-alpha{margin-bottom:3px}.color-picker .hue{width:100%;height:16px;margin-bottom:16px;border:none;cursor:pointer;background-size:100% 100%;background-image:url()}.color-picker .alpha{width:100%;height:16px;border:none;cursor:pointer;background-size:100% 100%;background-image:url()}.color-picker .type-policy{position:absolute;top:218px;right:12px;width:16px;height:24px;background-size:8px 16px;background-image:url();background-repeat:no-repeat;background-position:center}.color-picker .selected-color{position:absolute;top:16px;left:8px;width:40px;height:40px;border:1px solid #a9a9a9;border-radius:50%}.color-picker .selected-color-background{width:40px;height:40px;border-radius:50%;background-image:url()}.color-picker .saturation-lightness{width:100%;height:130px;border:none;cursor:pointer;background-size:100% 100%;background-image:url()}.color-picker .cp-add-color-button-class{position:absolute;display:inline;padding:0;margin:3px -3px;border:0;cursor:pointer;background:0 0}.color-picker .cp-add-color-button-class:hover{text-decoration:underline}.color-picker .cp-add-color-button-class:disabled{cursor:not-allowed;color:#999}.color-picker .cp-add-color-button-class:disabled:hover{text-decoration:none}.color-picker .cp-remove-color-button-class{position:absolute;top:-5px;right:-5px;display:block;width:10px;height:10px;border-radius:50%;cursor:pointer;text-align:center;background:#fff;box-shadow:1px 1px 5px #333}.color-picker .cp-remove-color-button-class::before{content:'x';position:relative;bottom:3.5px;display:inline-block;font-size:10px}"],encapsulation:core.ViewEncapsulation.None}]}];ColorPickerComponent.ctorParameters=function(){return[{type:core.ElementRef},{type:core.ChangeDetectorRef},{type:ColorPickerService}]};ColorPickerComponent.propDecorators={hueSlider:[{type:core.ViewChild,args:["hueSlider"]}],alphaSlider:[{type:core.ViewChild,args:["alphaSlider"]}],dialogElement:[{type:core.ViewChild,args:["dialogPopup"]}]};return ColorPickerComponent}();var ColorPickerDirective=function(){function ColorPickerDirective(injector,cfr,appRef,vcRef,elRef,service){this.injector=injector;this.cfr=cfr;this.appRef=appRef;this.vcRef=vcRef;this.elRef=elRef;this.service=service;this.dialogCreated=false;this.ignoreChanges=false;this.cpWidth="230px";this.cpHeight="auto";this.cpToggle=false;this.cpIgnoredElements=[];this.cpDisableInput=false;this.cpAlphaChannel="enabled";this.cpOutputFormat="hex";this.cpFallbackColor="#fff";this.cpDialogDisplay="popup";this.cpSaveClickOutside=true;this.cpUseRootViewContainer=false;this.cpPosition="right";this.cpPositionOffset="0%";this.cpPositionRelativeToArrow=false;this.cpOKButton=false;this.cpOKButtonText="OK";this.cpOKButtonClass="cp-ok-button-class";this.cpCancelButton=false;this.cpCancelButtonText="Cancel";this.cpCancelButtonClass="cp-cancel-button-class";this.cpPresetLabel="Preset colors";this.cpMaxPresetColorsLength=6;this.cpPresetEmptyMessage="No colors added";this.cpPresetEmptyMessageClass="preset-empty-message";this.cpAddColorButton=false;this.cpAddColorButtonText="Add color";this.cpAddColorButtonClass="cp-add-color-button-class";this.cpRemoveColorButtonClass="cp-remove-color-button-class";this.cpInputChange=new core.EventEmitter(true);this.cpToggleChange=new core.EventEmitter(true);this.cpSliderChange=new core.EventEmitter(true);this.cpSliderDragEnd=new core.EventEmitter(true);this.cpSliderDragStart=new core.EventEmitter(true);this.cpPresetColorsChange=new core.EventEmitter(true);this.colorPickerCancel=new core.EventEmitter(true);this.colorPickerSelect=new core.EventEmitter(true);this.colorPickerChange=new core.EventEmitter(false)}ColorPickerDirective.prototype.handleClick=function(event){this.inputFocus()};ColorPickerDirective.prototype.handleFocus=function(event){this.inputFocus()};ColorPickerDirective.prototype.handleInput=function(event){this.inputChange(event.target.value)};ColorPickerDirective.prototype.ngOnInit=function(){this.colorPicker=this.colorPicker||this.cpFallbackColor||"rgba(0, 0, 0, 1)"};ColorPickerDirective.prototype.ngOnDestroy=function(){if(this.cmpRef!==undefined){this.cmpRef.destroy()}};ColorPickerDirective.prototype.ngOnChanges=function(changes){if(changes.cpToggle){if(changes.cpToggle.currentValue){this.openDialog()}if(!changes.cpToggle.currentValue&&this.dialog){this.dialog.closeDialog()}}if(changes.colorPicker){if(this.dialog&&!this.ignoreChanges){if(this.cpDialogDisplay==="inline"){this.dialog.setInitialColor(changes.colorPicker.currentValue)}this.dialog.setColorFromString(changes.colorPicker.currentValue,false)}this.ignoreChanges=false}if(changes.cpPresetLabel||changes.cpPresetColors){if(this.dialog){this.dialog.setPresetConfig(this.cpPresetLabel,this.cpPresetColors)}}};ColorPickerDirective.prototype.openDialog=function(){this.colorPicker=this.colorPicker||this.cpFallbackColor||"rgba(0, 0, 0, 1)";if(!this.dialogCreated){var vcRef=this.vcRef;this.dialogCreated=true;if(this.cpUseRootViewContainer&&this.cpDialogDisplay!=="inline"){var classOfRootComponent=this.appRef.componentTypes[0];var appInstance=this.injector.get(classOfRootComponent);vcRef=appInstance.vcRef||appInstance.viewContainerRef||this.vcRef;if(vcRef===this.vcRef){console.warn("You are using cpUseRootViewContainer, "+"but the root component is not exposing viewContainerRef!"+"Please expose it by adding 'public vcRef: ViewContainerRef' to the constructor.")}}var compFactory=this.cfr.resolveComponentFactory(ColorPickerComponent);var injector=core.ReflectiveInjector.fromResolvedProviders([],vcRef.parentInjector);this.cmpRef=vcRef.createComponent(compFactory,0,injector,[]);this.cmpRef.instance.setupDialog(this,this.elRef,this.colorPicker,this.cpWidth,this.cpHeight,this.cpDialogDisplay,this.cpAlphaChannel,this.cpOutputFormat,this.cpDisableInput,this.cpIgnoredElements,this.cpSaveClickOutside,this.cpUseRootViewContainer,this.cpPosition,this.cpPositionOffset,this.cpPositionRelativeToArrow,this.cpPresetLabel,this.cpPresetColors,this.cpMaxPresetColorsLength,this.cpPresetEmptyMessage,this.cpPresetEmptyMessageClass,this.cpOKButton,this.cpOKButtonClass,this.cpOKButtonText,this.cpCancelButton,this.cpCancelButtonClass,this.cpCancelButtonText,this.cpAddColorButton,this.cpAddColorButtonClass,this.cpAddColorButtonText,this.cpRemoveColorButtonClass);this.dialog=this.cmpRef.instance;if(this.vcRef!==vcRef){this.cmpRef.changeDetectorRef.detectChanges()}}else if(this.dialog){this.dialog.openDialog(this.colorPicker)}};ColorPickerDirective.prototype.toggle=function(value){this.cpToggleChange.emit(value)};ColorPickerDirective.prototype.colorChanged=function(value,ignore){if(ignore===void 0){ignore=true}this.ignoreChanges=ignore;this.colorPickerChange.emit(value)};ColorPickerDirective.prototype.colorCanceled=function(){this.colorPickerCancel.emit()};ColorPickerDirective.prototype.colorSelected=function(value){this.colorPickerSelect.emit(value)};ColorPickerDirective.prototype.inputFocus=function(){var element=this.elRef.nativeElement;if(this.cpIgnoredElements.filter(function(item){return item===element}).length===0){this.openDialog()}};ColorPickerDirective.prototype.inputChange=function(value){if(this.dialog){this.dialog.setColorFromString(value,true)}else{this.colorPicker=value||this.cpFallbackColor||"rgba(0, 0, 0, 1)";this.colorPickerChange.emit(this.colorPicker)}};ColorPickerDirective.prototype.inputChanged=function(event){this.cpInputChange.emit(event)};ColorPickerDirective.prototype.sliderChanged=function(event){this.cpSliderChange.emit(event)};ColorPickerDirective.prototype.sliderDragEnd=function(event){this.cpSliderDragEnd.emit(event)};ColorPickerDirective.prototype.sliderDragStart=function(event){this.cpSliderDragStart.emit(event)};ColorPickerDirective.prototype.presetColorsChanged=function(value){this.cpPresetColorsChange.emit(value)};ColorPickerDirective.decorators=[{type:core.Directive,args:[{selector:"[colorPicker]"}]}];ColorPickerDirective.ctorParameters=function(){return[{type:core.Injector},{type:core.ComponentFactoryResolver},{type:core.ApplicationRef},{type:core.ViewContainerRef},{type:core.ElementRef},{type:ColorPickerService}]};ColorPickerDirective.propDecorators={colorPicker:[{type:core.Input}],cpWidth:[{type:core.Input}],cpHeight:[{type:core.Input}],cpToggle:[{type:core.Input}],cpIgnoredElements:[{type:core.Input}],cpDisableInput:[{type:core.Input}],cpAlphaChannel:[{type:core.Input}],cpOutputFormat:[{type:core.Input}],cpFallbackColor:[{type:core.Input}],cpDialogDisplay:[{type:core.Input}],cpSaveClickOutside:[{type:core.Input}],cpUseRootViewContainer:[{type:core.Input}],cpPosition:[{type:core.Input}],cpPositionOffset:[{type:core.Input}],cpPositionRelativeToArrow:[{type:core.Input}],cpOKButton:[{type:core.Input}],cpOKButtonText:[{type:core.Input}],cpOKButtonClass:[{type:core.Input}],cpCancelButton:[{type:core.Input}],cpCancelButtonText:[{type:core.Input}],cpCancelButtonClass:[{type:core.Input}],cpPresetLabel:[{type:core.Input}],cpPresetColors:[{type:core.Input}],cpMaxPresetColorsLength:[{type:core.Input}],cpPresetEmptyMessage:[{type:core.Input}],cpPresetEmptyMessageClass:[{type:core.Input}],cpAddColorButton:[{type:core.Input}],cpAddColorButtonText:[{type:core.Input}],cpAddColorButtonClass:[{type:core.Input}],cpRemoveColorButtonClass:[{type:core.Input}],cpInputChange:[{type:core.Output}],cpToggleChange:[{type:core.Output}],cpSliderChange:[{type:core.Output}],cpSliderDragEnd:[{type:core.Output}],cpSliderDragStart:[{type:core.Output}],cpPresetColorsChange:[{type:core.Output}],colorPickerCancel:[{type:core.Output}],colorPickerSelect:[{type:core.Output}],colorPickerChange:[{type:core.Output}],handleClick:[{type:core.HostListener,args:["click",["$event"]]}],handleFocus:[{type:core.HostListener,args:["focus",["$event"]]}],handleInput:[{type:core.HostListener,args:["input",["$event"]]}]};return ColorPickerDirective}();var ColorPickerModule=function(){function ColorPickerModule(){}ColorPickerModule.decorators=[{type:core.NgModule,args:[{imports:[common.CommonModule],exports:[ColorPickerDirective],providers:[ColorPickerService],declarations:[ColorPickerComponent,ColorPickerDirective,TextDirective,SliderDirective],entryComponents:[ColorPickerComponent]}]}];ColorPickerModule.ctorParameters=function(){return[]};return ColorPickerModule}();exports.Cmyk=Cmyk;exports.Hsla=Hsla;exports.Hsva=Hsva;exports.Rgba=Rgba;exports.TextDirective=TextDirective;exports.SliderDirective=SliderDirective;exports.ColorPickerComponent=ColorPickerComponent;exports.ColorPickerDirective=ColorPickerDirective;exports.ColorPickerModule=ColorPickerModule;exports.ColorPickerService=ColorPickerService;Object.defineProperty(exports,"__esModule",{value:true})}); |
@@ -650,3 +650,3 @@ /** | ||
var /** @type {?} */ rgba = this.service.denormalizeRGBA(this.service.hsvaToRgba(this.hsva)); | ||
var /** @type {?} */ hue = this.service.denormalizeRGBA(this.service.hsvaToRgba(new Hsva(this.hsva.h, 1, 1, 1))); | ||
var /** @type {?} */ hue = this.service.denormalizeRGBA(this.service.hsvaToRgba(new Hsva(this.sliderH || this.hsva.h, 1, 1, 1))); | ||
if (update) { | ||
@@ -653,0 +653,0 @@ this.hslaText = new Hsla(Math.round((hsla.h) * 360), Math.round(hsla.s * 100), Math.round(hsla.l * 100), Math.round(hsla.a * 100) / 100); |
@@ -6,3 +6,3 @@ { | ||
"license": "MIT", | ||
"version": "5.3.2", | ||
"version": "5.3.3", | ||
"main": "./bundles/ngx-color-picker.umd.js", | ||
@@ -9,0 +9,0 @@ "module": "./dist/ngx-color-picker.es5.js", |
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 too big to display
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
707207