diff --git a/dist/pickr.es5.min.js b/dist/pickr.es5.min.js index 5f60c7e8..ad5a8e3c 100644 --- a/dist/pickr.es5.min.js +++ b/dist/pickr.es5.min.js @@ -1,3 +1,3 @@ -/*! Pickr 1.2.6 MIT | https://github.com/Simonwep/pickr */ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.Pickr=e():t.Pickr=e()}(window,function(){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=0)}([function(t,e,n){"use strict";n.r(e);var r={};function o(t,e){var n=Object.keys(t);return Object.getOwnPropertySymbols&&n.push.apply(n,Object.getOwnPropertySymbols(t)),e&&(n=n.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n}function i(t){for(var e=1;e4&&void 0!==arguments[4]?arguments[4]:{};e instanceof HTMLCollection||e instanceof NodeList?e=Array.from(e):Array.isArray(e)||(e=[e]),Array.isArray(n)||(n=[n]);var a=!0,c=!1,l=void 0;try{for(var s,u=e[Symbol.iterator]();!(a=(s=u.next()).done);a=!0){var p=s.value,h=!0,f=!1,d=void 0;try{for(var v,y=n[Symbol.iterator]();!(h=(v=y.next()).done);h=!0){var m=v.value;p[t](m,r,i({capture:!1},o))}}catch(t){f=!0,d=t}finally{try{h||null==y.return||y.return()}finally{if(f)throw d}}}}catch(t){c=!0,l=t}finally{try{a||null==u.return||u.return()}finally{if(c)throw l}}return Array.prototype.slice.call(arguments,1)}function u(t){var e=document.createElement("div");return e.innerHTML=t.trim(),e.firstElementChild}function p(t,e){var n=t.getAttribute(e);return t.removeAttribute(e),n}function h(t){return function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=p(e,":obj"),o=p(e,":ref"),i=r?n[r]={}:n;o&&(n[o]=e);for(var a=0,c=Array.from(e.children);a1&&void 0!==arguments[1]?arguments[1]:function(t){return t};function n(n){var r=[.001,.01,.1][Number(n.shiftKey||2*n.ctrlKey)]*(n.deltaY<0?1:-1),o=0,i=t.selectionStart;t.value=t.value.replace(/[\d.]+/g,function(t,n){return n<=i&&n+t.length>=i?(i=n,e(Number(t),r,o)):(o++,t)}),t.focus(),t.setSelectionRange(i,i),n.preventDefault(),t.dispatchEvent(new Event("input"))}c(t,"focus",function(){return c(window,"wheel",n,{passive:!1})}),c(t,"blur",function(){return l(window,"wheel",n)})}function v(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,i=void 0;try{for(var a,c=t[Symbol.iterator]();!(r=(a=c.next()).done)&&(n.push(a.value),!e||n.length!==e);r=!0);}catch(t){o=!0,i=t}finally{try{r||null==c.return||c.return()}finally{if(o)throw i}}return n}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function y(t){return function(t){if(Array.isArray(t)){for(var e=0,n=new Array(t.length);e1&&(r-=1)}return[360*r,100*o,100*a]}function k(t,e,n,r){return e/=100,n/=100,y(A(255*(1-m(1,(t/=100)*(1-(r/=100))+r)),255*(1-m(1,e*(1-r)+r)),255*(1-m(1,n*(1-r)+r))))}function C(t,e,n){return e/=100,[t,2*(e*=(n/=100)<.5?n:1-n)/(n+e)*100,100*(n+e)]}function S(t){return A.apply(void 0,y(t.match(/.{2}/g).map(function(t){return parseInt(t,16)})))}function O(t){t=t.match(/^[a-zA-Z]+$/)?function(t){if("black"===t.toLowerCase())return"#000000";var e=document.createElement("canvas").getContext("2d");return e.fillStyle=t,"#000000"===e.fillStyle?null:e.fillStyle}(t):t;var e,n={cmyk:/^cmyk[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)/i,rgba:/^((rgba)|rgb)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hsla:/^((hsla)|hsl)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hsva:/^((hsva)|hsv)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hexa:/^#?(([\dA-Fa-f]{3,4})|([\dA-Fa-f]{6})|([\dA-Fa-f]{8}))$/i},r=function(t){return t.map(function(t){return/^(|\d+)\.\d+|\d+$/.test(t)?Number(t):void 0})};t:for(var o in n)if(e=n[o].exec(t)){var i=!!e[2];switch(o){case"cmyk":var a=v(r(e),5),c=a[1],l=a[2],s=a[3],u=a[4];if(c>100||l>100||s>100||u>100)break t;return{values:k(c,l,s,u),type:o};case"rgba":var p=v(r(e),7),h=p[3],f=p[4],d=p[5],m=p[6];if(h>255||f>255||d>255||m<0||m>1||i===!m)break t;return{values:[].concat(y(A(h,f,d)),[m]),a:m,type:o};case"hexa":var b=v(e,2)[1];4!==b.length&&3!==b.length||(b=b.split("").map(function(t){return t+t}).join(""));var g=b.substring(0,6),_=b.substring(6);return _=_?parseInt(_,16)/255:void 0,{values:[].concat(y(S(g)),[_]),a:_,type:o};case"hsla":var w=v(r(e),7),O=w[3],j=w[4],E=w[5],x=w[6];if(O>360||j>100||E>100||x<0||x>1||i===!x)break t;return{values:[].concat(y(C(O,j,E)),[x]),a:x,type:o};case"hsva":var P=v(r(e),7),L=P[3],B=P[4],R=P[5],H=P[6];if(L>360||B>100||R>100||H<0||H>1||i===!H)break t;return{values:[L,B,R,H],a:H,type:o}}}return{values:null,type:null}}function j(t){return function(t){if(Array.isArray(t)){for(var e=0,n=new Array(t.length);e0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1,o=function(t,e){return function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:-1;return e(~n?t.map(function(t){return Number(t.toFixed(n))}):t)}},i={h:t,s:e,v:n,a:r,toHSVA:function(){var t=[i.h,i.s,i.v,i.a];return t.toString=o(t,function(t){return"hsva(".concat(t[0],", ").concat(t[1],"%, ").concat(t[2],"%, ").concat(i.a,")")}),t},toHSLA:function(){var t=[].concat(j(function(t,e,n){var r=(2-(e/=100))*(n/=100)/2;return 0!==r&&(e=1===r?0:r<.5?e*n/(2*r):e*n/(2-2*r)),[t,100*e,100*r]}(i.h,i.s,i.v)),[i.a]);return t.toString=o(t,function(t){return"hsla(".concat(t[0],", ").concat(t[1],"%, ").concat(t[2],"%, ").concat(i.a,")")}),t},toRGBA:function(){var t=[].concat(j(w(i.h,i.s,i.v)),[i.a]);return t.toString=o(t,function(t){return"rgba(".concat(t[0],", ").concat(t[1],", ").concat(t[2],", ").concat(i.a,")")}),t},toCMYK:function(){var t=function(t,e,n){var r,o=w(t,e,n),i=o[0]/255,a=o[1]/255,c=o[2]/255;return[100*(1===(r=m(1-i,1-a,1-c))?0:(1-i-r)/(1-r)),100*(1===r?0:(1-a-r)/(1-r)),100*(1===r?0:(1-c-r)/(1-r)),100*r]}(i.h,i.s,i.v);return t.toString=o(t,function(t){return"cmyk(".concat(t[0],"%, ").concat(t[1],"%, ").concat(t[2],"%, ").concat(t[3],"%)")}),t},toHEXA:function(){var t=function(t,e,n){return w(t,e,n).map(function(t){return _(t).toString(16).padStart(2,"0")})}(i.h,i.s,i.v),e=i.a>=1?"":Number((255*i.a).toFixed(0)).toString(16).toUpperCase().padStart(2,"0");return e&&t.push(e),t.toString=function(){return"#".concat(t.join("").toUpperCase())},t},clone:function(){return E(i.h,i.s,i.v,i.a)}};return i}var x=function(t){return Math.max(Math.min(t,1),0)};function P(t){var e={options:Object.assign({lock:null,onchange:function(){return 0},onstop:function(){return 0}},t),_tapstart:function(t){c(document,["mouseup","touchend","touchcancel"],e._tapstop),c(document,["mousemove","touchmove"],e._tapmove),t.preventDefault(),e._tapmove(t)},_tapmove:function(t){var r=e.options.lock,o=e.cache,i=n.element,a=n.wrapper,c=a.getBoundingClientRect(),l=0,s=0;if(t){var u=t&&t.touches&&t.touches[0];l=t?(u||t).clientX:0,s=t?(u||t).clientY:0,lc.left+c.width&&(l=c.left+c.width),sc.top+c.height&&(s=c.top+c.height),l-=c.left,s-=c.top}else o&&(l=o.x*c.width,s=o.y*c.height);"h"!==r&&(i.style.left="calc(".concat(l/c.width*100,"% - ").concat(i.offsetWidth/2,"px)")),"v"!==r&&(i.style.top="calc(".concat(s/c.height*100,"% - ").concat(i.offsetHeight/2,"px)")),e.cache={x:l/c.width,y:s/c.height};var p=x(l/a.offsetWidth),h=x(s/a.offsetHeight);switch(r){case"v":return n.onchange(p);case"h":return n.onchange(h);default:return n.onchange(p,h)}},_tapstop:function(){e.options.onstop(),l(document,["mouseup","touchend","touchcancel"],e._tapstop),l(document,["mousemove","touchmove"],e._tapmove)},trigger:function(){e._tapmove()},update:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=e.options.wrapper.getBoundingClientRect(),o=r.left,i=r.top,a=r.width,c=r.height;"h"===e.options.lock&&(n=t),e._tapmove({clientX:o+a*t,clientY:i+c*n})},destroy:function(){var t=e.options,n=e._tapstart;l([t.wrapper,t.element],"mousedown",n),l([t.wrapper,t.element],"touchstart",n,{passive:!1})}},n=e.options,r=e._tapstart;return c([n.wrapper,n.element],"mousedown",r),c([n.wrapper,n.element],"touchstart",r,{passive:!1}),e}function L(t){return function(t){if(Array.isArray(t)){for(var e=0,n=new Array(t.length);e0&&void 0!==arguments[0]?arguments[0]:{};t=Object.assign({onchange:function(){return 0},className:"",elements:[]},t);var e=c(t.elements,"click",function(e){t.elements.forEach(function(n){return n.classList[e.target===n?"add":"remove"](t.className)}),t.onchange(e)});return{destroy:function(){return l.apply(r,L(e))}}}function R(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,i=void 0;try{for(var a,c=t[Symbol.iterator]();!(r=(a=c.next()).done)&&(n.push(a.value),!e||n.length!==e);r=!0);}catch(t){o=!0,i=t}finally{try{r||null==c.return||c.return()}finally{if(o)throw i}}return n}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function H(t){var e=t.el,n=t.reference,r=t.padding,o=void 0===r?8:r,i={start:"sme",middle:"mse",end:"ems"},a={top:"tbrl",right:"rltb",bottom:"btrl",left:"lrbt"},c=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:t[e];if(n)return n;var r=e.split("-"),o=R(r,2),i=o[0],a=o[1],c=void 0===a?"middle":a,l="top"===i||"bottom"===i;return t[e]={position:i,variant:c,isVertical:l}}}();return{update:function(t){var r=c(t),l=r.position,s=r.variant,u=r.isVertical,p=n.getBoundingClientRect(),h=e.getBoundingClientRect(),f=function(t){return t?{s:p.left+p.width-h.width,m:-h.width/2+(p.left+p.width/2),e:p.left}:{s:p.bottom-h.height,m:p.bottom-p.height/2-h.height/2,e:p.bottom-p.height}},d={};function v(t,n,r){var o="top"===r,i=o?h.height:h.width,a=window[o?"innerHeight":"innerWidth"],c=!0,l=!1,s=void 0;try{for(var u,p=t[Symbol.iterator]();!(c=(u=p.next()).done);c=!0){var f=n[u.value],v=d[r]="".concat(f,"px");if(f>0&&f+i>/g).reduce(function(t,e,n,r){return t=t.querySelector(e),n\n\n '.concat(r?"":'','\n\n
\n
\n
\n \n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n
\n\n
\n\n
\n \n\n \n \n \n \n \n\n \n \n \n
\n
\n \n ")),(u=s.interaction).options.find(function(t){return!t.hidden&&!t.classList.add("active")}),u.type=function(){return u.options.find(function(t){return t.classList.contains("active")})},s),p.useAsButton&&(this._root.button=p.el),document.body.appendChild(this._root.root)}},{key:"_finalBuild",value:function(){var t=this.options,e=this._root;if(document.body.removeChild(e.root),t.inline){var n=t.el.parentElement;t.el.nextSibling?n.insertBefore(e.app,t.el.nextSibling):n.appendChild(e.app)}else document.body.appendChild(e.app);t.useAsButton?t.inline&&t.el.remove():t.el.parentNode.replaceChild(e.root,t.el),t.disabled&&this.disable(),t.comparison||(e.button.style.transition="none",t.useAsButton||(e.preview.lastColor.style.transition="none")),this.hide()}},{key:"_buildComponents",value:function(){var t=this,e=this.options.components,n=(t.options.sliders||"v").repeat(2),r=M(n.match(/^[vh]+$/g)?n:[],2),o=r[0],i=r[1],a={palette:P({element:t._root.palette.picker,wrapper:t._root.palette.palette,onstop:function(){return t._emit("changestop",t)},onchange:function(n,r){if(e.palette){var o=t._color,i=t._root,a=t.options;t._recalc&&(o.s=100*n,o.v=100-100*r,o.v<0&&(o.v=0),t._updateOutput());var c=o.toRGBA().toString(0);this.element.style.background=c,this.wrapper.style.background="\n linear-gradient(to top, rgba(0, 0, 0, ".concat(o.a,"), transparent),\n linear-gradient(to left, hsla(").concat(o.h,", 100%, 50%, ").concat(o.a,"), rgba(255, 255, 255, ").concat(o.a,"))\n "),a.comparison||(i.button.style.color=c,a.useAsButton||(i.preview.lastColor.style.color=c)),i.preview.currentColor.style.color=c,t.options.comparison||i.button.classList.remove("clear")}}}),hue:P({lock:"v"===i?"h":"v",element:t._root.hue.picker,wrapper:t._root.hue.slider,onstop:function(){return t._emit("changestop",t)},onchange:function(n){e.hue&&e.palette&&(t._recalc&&(t._color.h=360*n),this.element.style.backgroundColor="hsl(".concat(t._color.h,", 100%, 50%)"),a.palette.trigger())}}),opacity:P({lock:"v"===o?"h":"v",element:t._root.opacity.picker,wrapper:t._root.opacity.slider,onstop:function(){return t._emit("changestop",t)},onchange:function(n){e.opacity&&e.palette&&(t._recalc&&(t._color.a=Math.round(100*n)/100),this.element.style.background="rgba(0, 0, 0, ".concat(t._color.a,")"),a.palette.trigger())}}),selectable:B({elements:t._root.interaction.options,className:"active",onchange:function(e){t._representation=e.target.getAttribute("data-type").toUpperCase(),t._recalc&&t._updateOutput()}})};this._components=a}},{key:"_bindEvents",value:function(){var t=this,e=this._root,n=this.options,r=[c(e.interaction.clear,"click",function(){return t._clearColor()}),c([e.interaction.cancel,e.preview.lastColor],"click",function(){t._emit("cancel",t),t.setHSVA.apply(t,D(t._lastColor.toHSVA()).concat([!0]))}),c(e.interaction.save,"click",function(){!t.applyColor()&&!n.showAlways&&t.hide()}),c(e.interaction.result,["keyup","input"],function(e){t.setColor(e.target.value,!0)&&!t._initializingActive&&t._emit("change",t._color),e.stopImmediatePropagation()}),c(e.interaction.result,["focus","blur"],function(e){t._recalc="blur"===e.type,t._recalc&&t._updateOutput()}),c([e.palette.palette,e.palette.picker,e.hue.slider,e.hue.picker,e.opacity.slider,e.opacity.picker],["mousedown","touchstart"],function(){return t._recalc=!0})];if(!n.showAlways){var o=n.closeWithKey;r.push(c(e.button,"click",function(){return t.isOpen()?t.hide():t.show()}),c(document,"keyup",function(e){return t.isOpen()&&(e.key===o||e.code===o)&&t.hide()}),c(document,["touchstart","mousedown"],function(n){t.isOpen()&&!f(n).some(function(t){return t===e.app||t===e.button})&&t.hide()},{capture:!0}))}if(n.adjustableNumbers){var i={rgba:[255,255,255,1],hsva:[360,100,100,1],hsla:[360,100,100,1],cmyk:[100,100,100,100]};d(e.interaction.result,function(e,n,r){var o=i[t.getColorRepresentation().toLowerCase()];if(o){var a=o[r],c=e+(a>=100?1e3*n:n);return c<=0?0:Number((c0&&void 0!==arguments[0]&&arguments[0],e=this._root,n=this.options;n.useAsButton||(e.button.style.color="rgba(0, 0, 0, 0.15)"),e.button.classList.add("clear"),n.showAlways||this.hide(),this._initializingActive||t||(this._emit("save",null),this._emit("clear",this))}},{key:"_parseLocalColor",value:function(t){var e=O(t),n=e.values,r=e.type,o=e.a,i=this.options.lockOpacity,a=void 0!==o&&1!==o;return n&&3===n.length&&(n[3]=void 0),{values:!n||i&&a?null:n,type:r}}},{key:"_emit",value:function(t){for(var e=this,n=arguments.length,r=new Array(n>1?n-1:0),o=1;o'));return o.swatches.appendChild(a),r.push({element:a,hsvaColorObject:i}),this._eventBindings.push(c(a,"click",function(){e.setHSVA.apply(e,D(i.toHSVA()).concat([!0])),e._emit("swatchselect",i),e._emit("change",i)})),!0}return!1}},{key:"removeSwatch",value:function(t){var e=this._swatchColors[t];if(e){var n=e.element;return this._root.swatches.removeChild(n),this._swatchColors.splice(t,1),!0}return!1}},{key:"applyColor",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0],e=this._root,n=e.preview,r=e.button,o=this._color.toRGBA().toString();n.lastColor.style.color=o,this.options.useAsButton||(r.style.color=o),r.classList.remove("clear"),this._lastColor=this._color.clone(),this._initializingActive||t||this._emit("save",this._color)}},{key:"destroy",value:function(){var t=this;this._eventBindings.forEach(function(t){return l.apply(r,D(t))}),Object.keys(this._components).forEach(function(e){return t._components[e].destroy()})}},{key:"destroyAndRemove",value:function(){var t=this;this.destroy();var e=this._root,n=e.root,r=e.app;n.parentElement&&n.parentElement.removeChild(n),r.parentElement.removeChild(r),Object.keys(this).forEach(function(e){return t[e]=null})}},{key:"hide",value:function(){return this.options.inline||(this._root.app.classList.remove("visible"),this._emit("hide",this)),this}},{key:"show",value:function(){return this.options.disabled||(this._root.app.classList.add("visible"),this._rePositioningPicker(),this._emit("show",this)),this}},{key:"isOpen",value:function(){return this._root.app.classList.contains("visible")}},{key:"setHSVA",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:360,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1,o=arguments.length>4&&void 0!==arguments[4]&&arguments[4],i=this._recalc;if(this._recalc=!1,t<0||t>360||e<0||e>100||n<0||n>100||r<0||r>1)return!1;this._color=E(t,e,n,r);var a=this._components,c=a.hue,l=a.opacity,s=a.palette;return c.update(t/360),l.update(r),s.update(e/100,1-n/100),o||this.applyColor(),i&&this._updateOutput(),this._recalc=i,!0}},{key:"setColor",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];if(null===t)return this._clearColor(e),!0;var n=this._parseLocalColor(t),r=n.values,o=n.type;if(r){var i=o.toUpperCase(),a=this._root.interaction.options,c=a.find(function(t){return t.getAttribute("data-type")===i});if(c&&!c.hidden){var l=!0,s=!1,u=void 0;try{for(var p,h=a[Symbol.iterator]();!(l=(p=h.next()).done);l=!0){var f=p.value;f.classList[f===c?"add":"remove"]("active")}}catch(t){s=!0,u=t}finally{try{l||null==h.return||h.return()}finally{if(s)throw u}}}return this.setColorRepresentation(i),this.setHSVA.apply(this,D(r).concat([e]))}return!1}},{key:"setColorRepresentation",value:function(t){return t=t.toUpperCase(),!!this._root.interaction.options.find(function(e){return e.getAttribute("data-type").startsWith(t)&&!e.click()})}},{key:"getColorRepresentation",value:function(){return this._representation}},{key:"getColor",value:function(){return this._color}},{key:"getRoot",value:function(){return this._root}},{key:"disable",value:function(){return this.hide(),this.options.disabled=!0,this._root.button.classList.add("disabled"),this}},{key:"enable",value:function(){return this.options.disabled=!1,this._root.button.classList.remove("disabled"),this}}])&&T(e.prototype,n),o&&T(e,o),t}();V.utils=r,V.libs={HSVaColor:E,Moveable:P,Nanopop:H,Selectable:B},V.create=function(t){return new V(t)},V.version="1.2.6";e.default=V}]).default}); +/*! Pickr 1.2.7 MIT | https://github.com/Simonwep/pickr */ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.Pickr=e():t.Pickr=e()}(window,function(){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=0)}([function(t,e,n){"use strict";n.r(e);var r={};function o(t,e){var n=Object.keys(t);return Object.getOwnPropertySymbols&&n.push.apply(n,Object.getOwnPropertySymbols(t)),e&&(n=n.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n}function i(t){for(var e=1;e4&&void 0!==arguments[4]?arguments[4]:{};e instanceof HTMLCollection||e instanceof NodeList?e=Array.from(e):Array.isArray(e)||(e=[e]),Array.isArray(n)||(n=[n]);var a=!0,c=!1,l=void 0;try{for(var s,u=e[Symbol.iterator]();!(a=(s=u.next()).done);a=!0){var p=s.value,h=!0,f=!1,d=void 0;try{for(var v,y=n[Symbol.iterator]();!(h=(v=y.next()).done);h=!0){var m=v.value;p[t](m,r,i({capture:!1},o))}}catch(t){f=!0,d=t}finally{try{h||null==y.return||y.return()}finally{if(f)throw d}}}}catch(t){c=!0,l=t}finally{try{a||null==u.return||u.return()}finally{if(c)throw l}}return Array.prototype.slice.call(arguments,1)}function u(t){var e=document.createElement("div");return e.innerHTML=t.trim(),e.firstElementChild}function p(t,e){var n=t.getAttribute(e);return t.removeAttribute(e),n}function h(t){return function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=p(e,":obj"),o=p(e,":ref"),i=r?n[r]={}:n;o&&(n[o]=e);for(var a=0,c=Array.from(e.children);a1&&void 0!==arguments[1]?arguments[1]:function(t){return t};function n(n){var r=[.001,.01,.1][Number(n.shiftKey||2*n.ctrlKey)]*(n.deltaY<0?1:-1),o=0,i=t.selectionStart;t.value=t.value.replace(/[\d.]+/g,function(t,n){return n<=i&&n+t.length>=i?(i=n,e(Number(t),r,o)):(o++,t)}),t.focus(),t.setSelectionRange(i,i),n.preventDefault(),t.dispatchEvent(new Event("input"))}c(t,"focus",function(){return c(window,"wheel",n,{passive:!1})}),c(t,"blur",function(){return l(window,"wheel",n)})}function v(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,i=void 0;try{for(var a,c=t[Symbol.iterator]();!(r=(a=c.next()).done)&&(n.push(a.value),!e||n.length!==e);r=!0);}catch(t){o=!0,i=t}finally{try{r||null==c.return||c.return()}finally{if(o)throw i}}return n}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function y(t){return function(t){if(Array.isArray(t)){for(var e=0,n=new Array(t.length);e1&&(r-=1)}return[360*r,100*o,100*a]}function k(t,e,n,r){return e/=100,n/=100,y(A(255*(1-m(1,(t/=100)*(1-(r/=100))+r)),255*(1-m(1,e*(1-r)+r)),255*(1-m(1,n*(1-r)+r))))}function C(t,e,n){return e/=100,[t,2*(e*=(n/=100)<.5?n:1-n)/(n+e)*100,100*(n+e)]}function S(t){return A.apply(void 0,y(t.match(/.{2}/g).map(function(t){return parseInt(t,16)})))}function O(t){t=t.match(/^[a-zA-Z]+$/)?function(t){if("black"===t.toLowerCase())return"#000000";var e=document.createElement("canvas").getContext("2d");return e.fillStyle=t,"#000000"===e.fillStyle?null:e.fillStyle}(t):t;var e,n={cmyk:/^cmyk[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)/i,rgba:/^((rgba)|rgb)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hsla:/^((hsla)|hsl)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hsva:/^((hsva)|hsv)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hexa:/^#?(([\dA-Fa-f]{3,4})|([\dA-Fa-f]{6})|([\dA-Fa-f]{8}))$/i},r=function(t){return t.map(function(t){return/^(|\d+)\.\d+|\d+$/.test(t)?Number(t):void 0})};t:for(var o in n)if(e=n[o].exec(t)){var i=!!e[2];switch(o){case"cmyk":var a=v(r(e),5),c=a[1],l=a[2],s=a[3],u=a[4];if(c>100||l>100||s>100||u>100)break t;return{values:k(c,l,s,u),type:o};case"rgba":var p=v(r(e),7),h=p[3],f=p[4],d=p[5],m=p[6];if(h>255||f>255||d>255||m<0||m>1||i===!m)break t;return{values:[].concat(y(A(h,f,d)),[m]),a:m,type:o};case"hexa":var b=v(e,2)[1];4!==b.length&&3!==b.length||(b=b.split("").map(function(t){return t+t}).join(""));var g=b.substring(0,6),_=b.substring(6);return _=_?parseInt(_,16)/255:void 0,{values:[].concat(y(S(g)),[_]),a:_,type:o};case"hsla":var w=v(r(e),7),O=w[3],j=w[4],E=w[5],x=w[6];if(O>360||j>100||E>100||x<0||x>1||i===!x)break t;return{values:[].concat(y(C(O,j,E)),[x]),a:x,type:o};case"hsva":var P=v(r(e),7),L=P[3],B=P[4],R=P[5],H=P[6];if(L>360||B>100||R>100||H<0||H>1||i===!H)break t;return{values:[L,B,R,H],a:H,type:o}}}return{values:null,type:null}}function j(t){return function(t){if(Array.isArray(t)){for(var e=0,n=new Array(t.length);e0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1,o=function(t,e){return function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:-1;return e(~n?t.map(function(t){return Number(t.toFixed(n))}):t)}},i={h:t,s:e,v:n,a:r,toHSVA:function(){var t=[i.h,i.s,i.v,i.a];return t.toString=o(t,function(t){return"hsva(".concat(t[0],", ").concat(t[1],"%, ").concat(t[2],"%, ").concat(i.a,")")}),t},toHSLA:function(){var t=[].concat(j(function(t,e,n){var r=(2-(e/=100))*(n/=100)/2;return 0!==r&&(e=1===r?0:r<.5?e*n/(2*r):e*n/(2-2*r)),[t,100*e,100*r]}(i.h,i.s,i.v)),[i.a]);return t.toString=o(t,function(t){return"hsla(".concat(t[0],", ").concat(t[1],"%, ").concat(t[2],"%, ").concat(i.a,")")}),t},toRGBA:function(){var t=[].concat(j(w(i.h,i.s,i.v)),[i.a]);return t.toString=o(t,function(t){return"rgba(".concat(t[0],", ").concat(t[1],", ").concat(t[2],", ").concat(i.a,")")}),t},toCMYK:function(){var t=function(t,e,n){var r,o=w(t,e,n),i=o[0]/255,a=o[1]/255,c=o[2]/255;return[100*(1===(r=m(1-i,1-a,1-c))?0:(1-i-r)/(1-r)),100*(1===r?0:(1-a-r)/(1-r)),100*(1===r?0:(1-c-r)/(1-r)),100*r]}(i.h,i.s,i.v);return t.toString=o(t,function(t){return"cmyk(".concat(t[0],"%, ").concat(t[1],"%, ").concat(t[2],"%, ").concat(t[3],"%)")}),t},toHEXA:function(){var t=function(t,e,n){return w(t,e,n).map(function(t){return _(t).toString(16).padStart(2,"0")})}(i.h,i.s,i.v),e=i.a>=1?"":Number((255*i.a).toFixed(0)).toString(16).toUpperCase().padStart(2,"0");return e&&t.push(e),t.toString=function(){return"#".concat(t.join("").toUpperCase())},t},clone:function(){return E(i.h,i.s,i.v,i.a)}};return i}var x=function(t){return Math.max(Math.min(t,1),0)};function P(t){var e={options:Object.assign({lock:null,onchange:function(){return 0},onstop:function(){return 0}},t),_tapstart:function(t){c(document,["mouseup","touchend","touchcancel"],e._tapstop),c(document,["mousemove","touchmove"],e._tapmove),t.preventDefault(),e._tapmove(t)},_tapmove:function(t){var r=e.options.lock,o=e.cache,i=n.element,a=n.wrapper,c=a.getBoundingClientRect(),l=0,s=0;if(t){var u=t&&t.touches&&t.touches[0];l=t?(u||t).clientX:0,s=t?(u||t).clientY:0,lc.left+c.width&&(l=c.left+c.width),sc.top+c.height&&(s=c.top+c.height),l-=c.left,s-=c.top}else o&&(l=o.x*c.width,s=o.y*c.height);"h"!==r&&(i.style.left="calc(".concat(l/c.width*100,"% - ").concat(i.offsetWidth/2,"px)")),"v"!==r&&(i.style.top="calc(".concat(s/c.height*100,"% - ").concat(i.offsetHeight/2,"px)")),e.cache={x:l/c.width,y:s/c.height};var p=x(l/a.offsetWidth),h=x(s/a.offsetHeight);switch(r){case"v":return n.onchange(p);case"h":return n.onchange(h);default:return n.onchange(p,h)}},_tapstop:function(){e.options.onstop(),l(document,["mouseup","touchend","touchcancel"],e._tapstop),l(document,["mousemove","touchmove"],e._tapmove)},trigger:function(){e._tapmove()},update:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=e.options.wrapper.getBoundingClientRect(),o=r.left,i=r.top,a=r.width,c=r.height;"h"===e.options.lock&&(n=t),e._tapmove({clientX:o+a*t,clientY:i+c*n})},destroy:function(){var t=e.options,n=e._tapstart;l([t.wrapper,t.element],"mousedown",n),l([t.wrapper,t.element],"touchstart",n,{passive:!1})}},n=e.options,r=e._tapstart;return c([n.wrapper,n.element],"mousedown",r),c([n.wrapper,n.element],"touchstart",r,{passive:!1}),e}function L(t){return function(t){if(Array.isArray(t)){for(var e=0,n=new Array(t.length);e0&&void 0!==arguments[0]?arguments[0]:{};t=Object.assign({onchange:function(){return 0},className:"",elements:[]},t);var e=c(t.elements,"click",function(e){t.elements.forEach(function(n){return n.classList[e.target===n?"add":"remove"](t.className)}),t.onchange(e)});return{destroy:function(){return l.apply(r,L(e))}}}function R(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,i=void 0;try{for(var a,c=t[Symbol.iterator]();!(r=(a=c.next()).done)&&(n.push(a.value),!e||n.length!==e);r=!0);}catch(t){o=!0,i=t}finally{try{r||null==c.return||c.return()}finally{if(o)throw i}}return n}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function H(t){var e=t.el,n=t.reference,r=t.padding,o=void 0===r?8:r,i={start:"sme",middle:"mse",end:"ems"},a={top:"tbrl",right:"rltb",bottom:"btrl",left:"lrbt"},c=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:t[e];if(n)return n;var r=e.split("-"),o=R(r,2),i=o[0],a=o[1],c=void 0===a?"middle":a,l="top"===i||"bottom"===i;return t[e]={position:i,variant:c,isVertical:l}}}();return{update:function(t){var r=c(t),l=r.position,s=r.variant,u=r.isVertical,p=n.getBoundingClientRect(),h=e.getBoundingClientRect(),f=function(t){return t?{s:p.left+p.width-h.width,m:-h.width/2+(p.left+p.width/2),e:p.left}:{s:p.bottom-h.height,m:p.bottom-p.height/2-h.height/2,e:p.bottom-p.height}},d={};function v(t,n,r){var o="top"===r,i=o?h.height:h.width,a=window[o?"innerHeight":"innerWidth"],c=!0,l=!1,s=void 0;try{for(var u,p=t[Symbol.iterator]();!(c=(u=p.next()).done);c=!0){var f=n[u.value],v=d[r]="".concat(f,"px");if(f>0&&f+i>/g).reduce(function(t,e,n,r){return t=t.querySelector(e),n\n\n '.concat(r?"":'','\n\n
\n
\n
\n \n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n
\n\n
\n\n
\n \n\n \n \n \n \n \n\n \n \n \n
\n
\n \n ")),(u=s.interaction).options.find(function(t){return!t.hidden&&!t.classList.add("active")}),u.type=function(){return u.options.find(function(t){return t.classList.contains("active")})},s),p.useAsButton&&(this._root.button=p.el),document.body.appendChild(this._root.root)}},{key:"_finalBuild",value:function(){var t=this.options,e=this._root;if(document.body.removeChild(e.root),t.inline){var n=t.el.parentElement;t.el.nextSibling?n.insertBefore(e.app,t.el.nextSibling):n.appendChild(e.app)}else document.body.appendChild(e.app);t.useAsButton?t.inline&&t.el.remove():t.el.parentNode.replaceChild(e.root,t.el),t.disabled&&this.disable(),t.comparison||(e.button.style.transition="none",t.useAsButton||(e.preview.lastColor.style.transition="none")),this.hide()}},{key:"_buildComponents",value:function(){var t=this,e=this.options.components,n=(t.options.sliders||"v").repeat(2),r=M(n.match(/^[vh]+$/g)?n:[],2),o=r[0],i=r[1],a={palette:P({element:t._root.palette.picker,wrapper:t._root.palette.palette,onstop:function(){return t._emit("changestop",t)},onchange:function(n,r){if(e.palette){var o=t._color,i=t._root,a=t.options;t._recalc&&(o.s=100*n,o.v=100-100*r,o.v<0&&(o.v=0),t._updateOutput());var c=o.toRGBA().toString(0);this.element.style.background=c,this.wrapper.style.background="\n linear-gradient(to top, rgba(0, 0, 0, ".concat(o.a,"), transparent),\n linear-gradient(to left, hsla(").concat(o.h,", 100%, 50%, ").concat(o.a,"), rgba(255, 255, 255, ").concat(o.a,"))\n "),a.comparison||(i.button.style.color=c,a.useAsButton||(i.preview.lastColor.style.color=c)),i.preview.currentColor.style.color=c,t.options.comparison||i.button.classList.remove("clear")}}}),hue:P({lock:"v"===i?"h":"v",element:t._root.hue.picker,wrapper:t._root.hue.slider,onstop:function(){return t._emit("changestop",t)},onchange:function(n){e.hue&&e.palette&&(t._recalc&&(t._color.h=360*n),this.element.style.backgroundColor="hsl(".concat(t._color.h,", 100%, 50%)"),a.palette.trigger())}}),opacity:P({lock:"v"===o?"h":"v",element:t._root.opacity.picker,wrapper:t._root.opacity.slider,onstop:function(){return t._emit("changestop",t)},onchange:function(n){e.opacity&&e.palette&&(t._recalc&&(t._color.a=Math.round(100*n)/100),this.element.style.background="rgba(0, 0, 0, ".concat(t._color.a,")"),a.palette.trigger())}}),selectable:B({elements:t._root.interaction.options,className:"active",onchange:function(e){t._representation=e.target.getAttribute("data-type").toUpperCase(),t._recalc&&t._updateOutput()}})};this._components=a}},{key:"_bindEvents",value:function(){var t=this,e=this._root,n=this.options,r=[c(e.interaction.clear,"click",function(){return t._clearColor()}),c([e.interaction.cancel,e.preview.lastColor],"click",function(){t._emit("cancel",t),t.setHSVA.apply(t,D(t._lastColor.toHSVA()).concat([!0]))}),c(e.interaction.save,"click",function(){!t.applyColor()&&!n.showAlways&&t.hide()}),c(e.interaction.result,["keyup","input"],function(e){t.setColor(e.target.value,!0)&&!t._initializingActive&&t._emit("change",t._color),e.stopImmediatePropagation()}),c(e.interaction.result,["focus","blur"],function(e){t._recalc="blur"===e.type,t._recalc&&t._updateOutput()}),c([e.palette.palette,e.palette.picker,e.hue.slider,e.hue.picker,e.opacity.slider,e.opacity.picker],["mousedown","touchstart"],function(){return t._recalc=!0})];if(!n.showAlways){var o=n.closeWithKey;r.push(c(e.button,"click",function(){return t.isOpen()?t.hide():t.show()}),c(document,"keyup",function(e){return t.isOpen()&&(e.key===o||e.code===o)&&t.hide()}),c(document,["touchstart","mousedown"],function(n){t.isOpen()&&!f(n).some(function(t){return t===e.app||t===e.button})&&t.hide()},{capture:!0}))}if(n.adjustableNumbers){var i={rgba:[255,255,255,1],hsva:[360,100,100,1],hsla:[360,100,100,1],cmyk:[100,100,100,100]};d(e.interaction.result,function(e,n,r){var o=i[t.getColorRepresentation().toLowerCase()];if(o){var a=o[r],c=e+(a>=100?1e3*n:n);return c<=0?0:Number((c0&&void 0!==arguments[0]&&arguments[0],e=this._root,n=this.options;n.useAsButton||(e.button.style.color="rgba(0, 0, 0, 0.15)"),e.button.classList.add("clear"),n.showAlways||this.hide(),this._initializingActive||t||(this._emit("save",null),this._emit("clear",this))}},{key:"_parseLocalColor",value:function(t){var e=O(t),n=e.values,r=e.type,o=e.a,i=this.options.lockOpacity,a=void 0!==o&&1!==o;return n&&3===n.length&&(n[3]=void 0),{values:!n||i&&a?null:n,type:r}}},{key:"_emit",value:function(t){for(var e=this,n=arguments.length,r=new Array(n>1?n-1:0),o=1;o'));return o.swatches.appendChild(a),r.push({element:a,hsvaColorObject:i}),this._eventBindings.push(c(a,"click",function(){e.setHSVA.apply(e,D(i.toHSVA()).concat([!0])),e._emit("swatchselect",i),e._emit("change",i)})),!0}return!1}},{key:"removeSwatch",value:function(t){var e=this._swatchColors[t];if(e){var n=e.element;return this._root.swatches.removeChild(n),this._swatchColors.splice(t,1),!0}return!1}},{key:"applyColor",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0],e=this._root,n=e.preview,r=e.button,o=this._color.toRGBA().toString();n.lastColor.style.color=o,this.options.useAsButton||(r.style.color=o),r.classList.remove("clear"),this._lastColor=this._color.clone(),this._initializingActive||t||this._emit("save",this._color)}},{key:"destroy",value:function(){var t=this;this._eventBindings.forEach(function(t){return l.apply(r,D(t))}),Object.keys(this._components).forEach(function(e){return t._components[e].destroy()})}},{key:"destroyAndRemove",value:function(){var t=this;this.destroy();var e=this._root,n=e.root,r=e.app;n.parentElement&&n.parentElement.removeChild(n),r.parentElement.removeChild(r),Object.keys(this).forEach(function(e){return t[e]=null})}},{key:"hide",value:function(){return this.options.inline||(this._root.app.classList.remove("visible"),this._emit("hide",this)),this}},{key:"show",value:function(){return this.options.disabled||(this._root.app.classList.add("visible"),this._rePositioningPicker(),this._emit("show",this)),this}},{key:"isOpen",value:function(){return this._root.app.classList.contains("visible")}},{key:"setHSVA",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:360,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1,o=arguments.length>4&&void 0!==arguments[4]&&arguments[4],i=this._recalc;if(this._recalc=!1,t<0||t>360||e<0||e>100||n<0||n>100||r<0||r>1)return!1;this._color=E(t,e,n,r);var a=this._components,c=a.hue,l=a.opacity,s=a.palette;return c.update(t/360),l.update(r),s.update(e/100,1-n/100),o||this.applyColor(),i&&this._updateOutput(),this._recalc=i,!0}},{key:"setColor",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];if(null===t)return this._clearColor(e),!0;var n=this._parseLocalColor(t),r=n.values,o=n.type;if(r){var i=o.toUpperCase(),a=this._root.interaction.options,c=a.find(function(t){return t.getAttribute("data-type")===i});if(c&&!c.hidden){var l=!0,s=!1,u=void 0;try{for(var p,h=a[Symbol.iterator]();!(l=(p=h.next()).done);l=!0){var f=p.value;f.classList[f===c?"add":"remove"]("active")}}catch(t){s=!0,u=t}finally{try{l||null==h.return||h.return()}finally{if(s)throw u}}}return this.setColorRepresentation(i),this.setHSVA.apply(this,D(r).concat([e]))}return!1}},{key:"setColorRepresentation",value:function(t){return t=t.toUpperCase(),!!this._root.interaction.options.find(function(e){return e.getAttribute("data-type").startsWith(t)&&!e.click()})}},{key:"getColorRepresentation",value:function(){return this._representation}},{key:"getColor",value:function(){return this._color}},{key:"getRoot",value:function(){return this._root}},{key:"disable",value:function(){return this.hide(),this.options.disabled=!0,this._root.button.classList.add("disabled"),this}},{key:"enable",value:function(){return this.options.disabled=!1,this._root.button.classList.remove("disabled"),this}}])&&T(e.prototype,n),o&&T(e,o),t}();V.utils=r,V.libs={HSVaColor:E,Moveable:P,Nanopop:H,Selectable:B},V.create=function(t){return new V(t)},V.version="1.2.7";e.default=V}]).default}); //# sourceMappingURL=pickr.es5.min.js.map \ No newline at end of file diff --git a/dist/pickr.es5.min.js.map b/dist/pickr.es5.min.js.map index d2d643af..d8292775 100644 --- a/dist/pickr.es5.min.js.map +++ b/dist/pickr.es5.min.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap","webpack:///./src/js/utils/utils.js","webpack:///./src/js/utils/color.js","webpack:///./src/js/utils/hsvacolor.js","webpack:///./src/js/libs/moveable.js","webpack:///./src/js/libs/selectable.js","webpack:///./src/js/libs/nanopop.js","webpack:///./src/js/pickr.js","webpack:///./src/js/template.js"],"names":["root","factory","exports","module","define","amd","window","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","on","eventListener","off","method","elements","events","fn","options","arguments","length","undefined","HTMLCollection","NodeList","Array","from","isArray","_iteratorNormalCompletion","_didIteratorError","_iteratorError","_step","_iterator","iterator","next","done","el","_iteratorNormalCompletion2","_didIteratorError2","_iteratorError2","_step2","_iterator2","ev","_objectSpread","capture","err","return","slice","createElementFromString","html","div","document","createElement","innerHTML","trim","firstElementChild","removeAttribute","getAttribute","createFromTemplate","str","resolve","element","base","con","subtree","_i","_Array$from","children","child","arr","sub","push","keys","eventPath","evt","path","composedPath","target","parentElement","adjustableInputNumbers","mapper","v","handleScroll","e","inc","Number","shiftKey","ctrlKey","deltaY","index","selectionStart","replace","focus","setSelectionRange","preventDefault","dispatchEvent","Event","passive","min","Math","max","floor","round","hsvToRgb","h","f","q","mod","rgbToHsv","g","b","minVal","maxVal","delta","dr","dg","db","cmykToHsv","y","k","_toConsumableArray","hslToHsv","hexToHsv","hex","apply","match","map","parseInt","parseToHSVA","toLowerCase","ctx","getContext","fillStyle","standardizeColor","regex","cmyk","rgba","hsla","hsva","hexa","numarize","array","test","invalid","type","exec","alpha","_numarize2","_slicedToArray","values","_numarize4","a","concat","split","join","raw","substring","_numarize6","_numarize8","HSVaColor","original","precision","toFixed","that","toHSVA","toString","toHSLA","hsvacolor_toConsumableArray","hsvToHsl","toRGBA","toCMYK","rgb","hsvToCmyk","toHEXA","padStart","hsvToHex","toUpperCase","clone","clamp","Moveable","opt","assign","lock","onchange","onstop","_tapstart","_","_tapstop","_tapmove","cache","wrapper","getBoundingClientRect","x","touch","touches","clientX","clientY","left","width","top","height","style","offsetWidth","offsetHeight","cx","cy","trigger","update","_that$options$wrapper","destroy","Selectable","className","onTap","forEach","classList","selectable_toConsumableArray","Nanopop","_ref","reference","_ref$padding","padding","vBehaviour","start","middle","end","hBehaviour","right","bottom","getInfo","pos","cached","_pos$split","_pos$split2","nanopop_slicedToArray","position","_pos$split2$","variant","isVertical","_getInfo","rb","eb","variants","vertical","leastApplied","bevs","vars","styleprop","adder","win","sv","_i2","_arr2","rot","v2Ok","v1Ok","Pickr","_this","this","_classCallCheck","pickr_defineProperty","init","save","hide","show","clear","change","changestop","cancel","swatchselect","appClass","theme","useAsButton","disabled","comparison","closeOnScroll","outputPrecision","lockOpacity","autoReposition","components","interaction","strings","swatches","inline","sliders","default","defaultRepresentation","adjustableNumbers","showAlways","closeWithKey","_opt","includes","preview","opacity","hue","palette","_preBuild","_buildComponents","_bindEvents","_finalBuild","color","addSwatch","_nanopop","_root","button","app","requestAnimationFrame","cb","body","setColor","_rePositioningPicker","_representation","setColorRepresentation","_initializingActive","_emit","lo","hidden","int","reduce","pv","cv","ci","querySelector","shadowRoot","input","find","add","contains","appendChild","removeChild","parent","nextSibling","insertBefore","remove","parentNode","replaceChild","disable","transition","lastColor","inst","cs","repeat","_ref2","pickr_slicedToArray","so","sh","picker","_color","_recalc","_updateOutput","cssRGBaString","background","currentColor","slider","backgroundColor","selectable","_components","_this2","eventBindings","_clearColor","setHSVA","pickr_toConsumableArray","_lastColor","applyColor","result","stopImmediatePropagation","ck","isOpen","code","some","ranges","step","range","getColorRepresentation","nv","toPrecision","timeout","setTimeout","rs","clearTimeout","_eventBindings","matchMedia","matches","margin","silent","_parseToHSVA","alphaMakesAChange","event","_this3","_len","args","_key","_eventListener","callBacks","indexOf","splice","_this4","_parseLocalColor","_swatchColors","hsvaColorObject","swatchColor","_this$_root","_this5","_this6","_this$_root2","recalc","_this$_components","string","_this$_parseLocalColo2","utype","startsWith","click","utils","libs","version"],"mappings":"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","file":"pickr.es5.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Pickr\"] = factory();\n\telse\n\t\troot[\"Pickr\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\n * Add event(s) to element(s).\n * @param elements DOM-Elements\n * @param events Event names\n * @param fn Callback\n * @param options Optional options\n * @return Array passed arguments\n */\nexport const on = eventListener.bind(null, 'addEventListener');\n\n/**\n * Remove event(s) from element(s).\n * @param elements DOM-Elements\n * @param events Event names\n * @param fn Callback\n * @param options Optional options\n * @return Array passed arguments\n */\nexport const off = eventListener.bind(null, 'removeEventListener');\n\nfunction eventListener(method, elements, events, fn, options = {}) {\n\n // Normalize array\n if (elements instanceof HTMLCollection || elements instanceof NodeList) {\n elements = Array.from(elements);\n } else if (!Array.isArray(elements)) {\n elements = [elements];\n }\n\n if (!Array.isArray(events)) {\n events = [events];\n }\n\n for (const el of elements) {\n for (const ev of events) {\n el[method](ev, fn, {capture: false, ...options});\n }\n }\n\n return Array.prototype.slice.call(arguments, 1);\n}\n\n/**\n * Creates an DOM-Element out of a string (Single element).\n * @param html HTML representing a single element\n * @returns {Element | null} The element.\n */\nexport function createElementFromString(html) {\n const div = document.createElement('div');\n div.innerHTML = html.trim();\n return div.firstElementChild;\n}\n\n/**\n * Removes an attribute from a HTMLElement and returns the value.\n * @param el\n * @param name\n * @return {string}\n */\nexport function removeAttribute(el, name) {\n const value = el.getAttribute(name);\n el.removeAttribute(name);\n return value;\n}\n\n/**\n * Creates a new html element, every element which has\n * a ':ref' attribute will be saved in a object (which will be returned)\n * where the value of ':ref' is the object-key and the value the HTMLElement.\n *\n * It's possible to create a hierarchy if you add a ':obj' attribute. Every\n * sibling will be added to the object which will get the name from the 'data-con' attribute.\n *\n * If you want to create an Array out of multiple elements, you can use the ':arr' attribute,\n * the value defines the key and all elements, which has the same parent and the same 'data-arr' attribute,\n * would be added to it.\n *\n * @param str - The HTML String.\n */\nexport function createFromTemplate(str) {\n\n // Recursive function to resolve template\n function resolve(element, base = {}) {\n\n // Check key and container attribute\n const con = removeAttribute(element, ':obj');\n const key = removeAttribute(element, ':ref');\n const subtree = con ? (base[con] = {}) : base;\n\n // Check and save element\n key && (base[key] = element);\n for (const child of Array.from(element.children)) {\n const arr = removeAttribute(child, ':arr');\n const sub = resolve(child, arr ? {} : subtree);\n\n if (arr) {\n\n // Check if there is already an array and add element\n (subtree[arr] || (subtree[arr] = []))\n .push(Object.keys(sub).length ? sub : child);\n }\n }\n\n return base;\n }\n\n return resolve(createElementFromString(str));\n}\n\n/**\n * Polyfill for safari & firefox for the eventPath event property.\n * @param evt The event object.\n * @return [String] event path.\n */\nexport function eventPath(evt) {\n let path = evt.path || (evt.composedPath && evt.composedPath());\n if (path) return path;\n\n let el = evt.target.parentElement;\n path = [evt.target, el];\n while (el = el.parentElement) path.push(el);\n\n path.push(document, window);\n return path;\n}\n\n/**\n * Creates the ability to change numbers in an input field with the scroll-wheel.\n * @param el\n * @param mapper\n */\nexport function adjustableInputNumbers(el, mapper = v => v) {\n\n function handleScroll(e) {\n const inc = ([0.001, 0.01, 0.1])[Number(e.shiftKey || e.ctrlKey * 2)] * (e.deltaY < 0 ? 1 : -1);\n\n let index = 0;\n let off = el.selectionStart;\n el.value = el.value.replace(/[\\d.]+/g, (v, i) => {\n\n // Check if number is in cursor range and increase it\n if (i <= off && i + v.length >= off) {\n off = i;\n return mapper(Number(v), inc, index);\n }\n\n index++;\n return v;\n });\n\n el.focus();\n el.setSelectionRange(off, off);\n\n // Prevent default and trigger input event\n e.preventDefault();\n el.dispatchEvent(new Event('input'));\n }\n\n // Bind events\n on(el, 'focus', () => on(window, 'wheel', handleScroll, {passive: false}));\n on(el, 'blur', () => off(window, 'wheel', handleScroll));\n}\n","// Shorthands\nconst {min, max, floor, round} = Math;\n\n/**\n * Tries to convert a color name to rgb/a hex representation\n * @param name\n * @returns {string | CanvasGradient | CanvasPattern}\n */\nfunction standardizeColor(name) {\n\n // Since invalid color's will be parsed as black, filter them out\n if (name.toLowerCase() === 'black') {\n return '#000000';\n }\n\n const ctx = document.createElement('canvas').getContext('2d');\n ctx.fillStyle = name;\n return ctx.fillStyle === '#000000' ? null : ctx.fillStyle;\n}\n\n/**\n * Convert HSV spectrum to RGB.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {number[]} Array with rgb values.\n */\nexport function hsvToRgb(h, s, v) {\n h = (h / 360) * 6;\n s /= 100;\n v /= 100;\n\n let i = floor(h);\n\n let f = h - i;\n let p = v * (1 - s);\n let q = v * (1 - f * s);\n let t = v * (1 - (1 - f) * s);\n\n let mod = i % 6;\n let r = [v, q, p, p, t, v][mod];\n let g = [t, v, v, q, p, p][mod];\n let b = [p, p, t, v, v, q][mod];\n\n return [\n r * 255,\n g * 255,\n b * 255\n ];\n}\n\n/**\n * Convert HSV spectrum to Hex.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {string[]} Hex values\n */\nexport function hsvToHex(h, s, v) {\n return hsvToRgb(h, s, v).map(v =>\n round(v).toString(16).padStart(2, '0')\n );\n}\n\n/**\n * Convert HSV spectrum to CMYK.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {number[]} CMYK values\n */\nexport function hsvToCmyk(h, s, v) {\n const rgb = hsvToRgb(h, s, v);\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n let k, c, m, y;\n\n k = min(1 - r, 1 - g, 1 - b);\n\n c = k === 1 ? 0 : (1 - r - k) / (1 - k);\n m = k === 1 ? 0 : (1 - g - k) / (1 - k);\n y = k === 1 ? 0 : (1 - b - k) / (1 - k);\n\n return [\n c * 100,\n m * 100,\n y * 100,\n k * 100\n ];\n}\n\n/**\n * Convert HSV spectrum to HSL.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {number[]} HSL values\n */\nexport function hsvToHsl(h, s, v) {\n s /= 100, v /= 100;\n\n let l = (2 - s) * v / 2;\n\n if (l !== 0) {\n if (l === 1) {\n s = 0;\n } else if (l < 0.5) {\n s = s * v / (l * 2);\n } else {\n s = s * v / (2 - l * 2);\n }\n }\n\n return [\n h,\n s * 100,\n l * 100\n ];\n}\n\n/**\n * Convert RGB to HSV.\n * @param r Red\n * @param g Green\n * @param b Blue\n * @return {number[]} HSV values.\n */\nfunction rgbToHsv(r, g, b) {\n r /= 255, g /= 255, b /= 255;\n\n let h, s, v;\n const minVal = min(r, g, b);\n const maxVal = max(r, g, b);\n const delta = maxVal - minVal;\n\n v = maxVal;\n if (delta === 0) {\n h = s = 0;\n } else {\n s = delta / maxVal;\n let dr = (((maxVal - r) / 6) + (delta / 2)) / delta;\n let dg = (((maxVal - g) / 6) + (delta / 2)) / delta;\n let db = (((maxVal - b) / 6) + (delta / 2)) / delta;\n\n if (r === maxVal) {\n h = db - dg;\n } else if (g === maxVal) {\n h = (1 / 3) + dr - db;\n } else if (b === maxVal) {\n h = (2 / 3) + dg - dr;\n }\n\n if (h < 0) {\n h += 1;\n } else if (h > 1) {\n h -= 1;\n }\n }\n\n return [\n h * 360,\n s * 100,\n v * 100\n ];\n}\n\n/**\n * Convert CMYK to HSV.\n * @param c Cyan\n * @param m Magenta\n * @param y Yellow\n * @param k Key (Black)\n * @return {number[]} HSV values.\n */\nfunction cmykToHsv(c, m, y, k) {\n c /= 100;\n m /= 100;\n y /= 100;\n k /= 100;\n\n const r = (1 - min(1, c * (1 - k) + k)) * 255;\n const g = (1 - min(1, m * (1 - k) + k)) * 255;\n const b = (1 - min(1, y * (1 - k) + k)) * 255;\n\n return [...rgbToHsv(r, g, b)];\n}\n\n/**\n * Convert HSL to HSV.\n * @param h Hue\n * @param s Saturation\n * @param l Lightness\n * @return {number[]} HSV values.\n */\nfunction hslToHsv(h, s, l) {\n s /= 100;\n l /= 100;\n s *= l < 0.5 ? l : 1 - l;\n\n let ns = (2 * s / (l + s)) * 100;\n let v = (l + s) * 100;\n return [h, ns, v];\n}\n\n/**\n * Convert HEX to HSV.\n * @param hex Hexadecimal string of rgb colors, can have length 3 or 6.\n * @return {number[]} HSV values.\n */\nfunction hexToHsv(hex) {\n return rgbToHsv(...hex.match(/.{2}/g).map(v => parseInt(v, 16)));\n}\n\n/**\n * Try's to parse a string which represents a color to a HSV array.\n * Current supported types are cmyk, rgba, hsla and hexadecimal.\n * @param str\n * @return {*}\n */\nexport function parseToHSVA(str) {\n\n // Check if string is a color-name\n str = str.match(/^[a-zA-Z]+$/) ? standardizeColor(str) : str;\n\n // Regular expressions to match different types of color represention\n const regex = {\n cmyk: /^cmyk[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)/i,\n rgba: /^((rgba)|rgb)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i,\n hsla: /^((hsla)|hsl)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i,\n hsva: /^((hsva)|hsv)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i,\n hexa: /^#?(([\\dA-Fa-f]{3,4})|([\\dA-Fa-f]{6})|([\\dA-Fa-f]{8}))$/i\n };\n\n /**\n * Takes an Array of any type, convert strings which represents\n * a number to a number an anything else to undefined.\n * @param array\n * @return {*}\n */\n const numarize = array => array.map(v => /^(|\\d+)\\.\\d+|\\d+$/.test(v) ? Number(v) : undefined);\n\n let match;\n invalid: for (const type in regex) {\n\n // Check if current scheme passed\n if (!(match = regex[type].exec(str)))\n continue;\n\n // match[2] does only contain a truly value if rgba, hsla, or hsla got matched\n const alpha = !!match[2];\n\n // Try to convert\n switch (type) {\n case 'cmyk': {\n let [, c, m, y, k] = numarize(match);\n\n if (c > 100 || m > 100 || y > 100 || k > 100)\n break invalid;\n\n return {values: cmykToHsv(c, m, y, k), type};\n }\n case 'rgba': {\n let [, , , r, g, b, a] = numarize(match);\n\n if (r > 255 || g > 255 || b > 255 || a < 0 || a > 1 || (alpha === !a))\n break invalid;\n\n return {values: [...rgbToHsv(r, g, b), a], a, type};\n }\n case 'hexa': {\n let [, hex] = match;\n\n if (hex.length === 4 || hex.length === 3) {\n hex = hex.split('').map(v => v + v).join('');\n }\n\n const raw = hex.substring(0, 6);\n let a = hex.substring(6);\n\n // Convert 0 - 255 to 0 - 1 for opacity\n a = a ? (parseInt(a, 16) / 255) : undefined;\n\n return {values: [...hexToHsv(raw), a], a, type};\n }\n case 'hsla': {\n let [, , , h, s, l, a] = numarize(match);\n\n if (h > 360 || s > 100 || l > 100 || a < 0 || a > 1 || (alpha === !a))\n break invalid;\n\n return {values: [...hslToHsv(h, s, l), a], a, type};\n }\n case 'hsva': {\n let [, , , h, s, v, a] = numarize(match);\n\n if (h > 360 || s > 100 || v > 100 || a < 0 || a > 1 || (alpha === !a))\n break invalid;\n\n return {values: [h, s, v, a], a, type};\n }\n }\n }\n\n return {values: null, type: null};\n}\n","import {hsvToHsl, hsvToRgb, hsvToCmyk, hsvToHex} from './color';\n\n/**\n * Simple class which holds the properties\n * of the color represention model hsla (hue saturation lightness alpha)\n */\nexport function HSVaColor(h = 0, s = 0, v = 0, a = 1) {\n const mapper = (original, next) => (precision = -1) => {\n return next(~precision ? original.map(v => Number(v.toFixed(precision))) : original);\n };\n\n const that = {\n h, s, v, a,\n\n toHSVA() {\n const hsva = [that.h, that.s, that.v, that.a];\n hsva.toString = mapper(hsva, arr => `hsva(${arr[0]}, ${arr[1]}%, ${arr[2]}%, ${that.a})`);\n return hsva;\n },\n\n toHSLA() {\n const hsla = [...hsvToHsl(that.h, that.s, that.v), that.a];\n hsla.toString = mapper(hsla, arr => `hsla(${arr[0]}, ${arr[1]}%, ${arr[2]}%, ${that.a})`);\n return hsla;\n },\n\n toRGBA() {\n const rgba = [...hsvToRgb(that.h, that.s, that.v), that.a];\n rgba.toString = mapper(rgba, arr => `rgba(${arr[0]}, ${arr[1]}, ${arr[2]}, ${that.a})`);\n return rgba;\n },\n\n toCMYK() {\n const cmyk = hsvToCmyk(that.h, that.s, that.v);\n cmyk.toString = mapper(cmyk, arr => `cmyk(${arr[0]}%, ${arr[1]}%, ${arr[2]}%, ${arr[3]}%)`);\n return cmyk;\n },\n\n toHEXA() {\n const hex = hsvToHex(that.h, that.s, that.v);\n\n // Check if alpha channel make sense, convert it to 255 number space, convert\n // to hex and pad it with zeros if needet.\n const alpha = that.a >= 1 ? '' : Number((that.a * 255).toFixed(0))\n .toString(16)\n .toUpperCase().padStart(2, '0');\n\n alpha && hex.push(alpha);\n hex.toString = () => `#${hex.join('').toUpperCase()}`;\n return hex;\n },\n\n clone: () => HSVaColor(that.h, that.s, that.v, that.a)\n };\n\n return that;\n}\n","import * as _ from '../utils/utils';\n\nconst clamp = v => Math.max(Math.min(v, 1), 0);\nexport default function Moveable(opt) {\n\n const that = {\n\n // Assign default values\n options: Object.assign({\n lock: null,\n onchange: () => 0,\n onstop: () => 0\n }, opt),\n\n _tapstart(evt) {\n _.on(document, ['mouseup', 'touchend', 'touchcancel'], that._tapstop);\n _.on(document, ['mousemove', 'touchmove'], that._tapmove);\n\n // Prevent default touch event\n evt.preventDefault();\n\n // Trigger\n that._tapmove(evt);\n },\n\n _tapmove(evt) {\n const {options: {lock}, cache} = that;\n const {element, wrapper} = options;\n const b = wrapper.getBoundingClientRect();\n\n let x = 0, y = 0;\n if (evt) {\n const touch = evt && evt.touches && evt.touches[0];\n x = evt ? (touch || evt).clientX : 0;\n y = evt ? (touch || evt).clientY : 0;\n\n // Reset to bounds\n if (x < b.left) x = b.left;\n else if (x > b.left + b.width) x = b.left + b.width;\n if (y < b.top) y = b.top;\n else if (y > b.top + b.height) y = b.top + b.height;\n\n // Normalize\n x -= b.left;\n y -= b.top;\n } else if (cache) {\n x = cache.x * b.width;\n y = cache.y * b.height;\n }\n\n if (lock !== 'h') {\n element.style.left = `calc(${x / b.width * 100}% - ${element.offsetWidth / 2}px)`;\n }\n\n if (lock !== 'v') {\n element.style.top = `calc(${y / b.height * 100}% - ${element.offsetHeight / 2}px)`;\n }\n\n that.cache = {x: x / b.width, y: y / b.height};\n const cx = clamp(x / wrapper.offsetWidth);\n const cy = clamp(y / wrapper.offsetHeight);\n\n switch (lock) {\n case 'v':\n return options.onchange(cx);\n case 'h':\n return options.onchange(cy);\n default:\n return options.onchange(cx, cy);\n }\n },\n\n _tapstop() {\n that.options.onstop();\n _.off(document, ['mouseup', 'touchend', 'touchcancel'], that._tapstop);\n _.off(document, ['mousemove', 'touchmove'], that._tapmove);\n },\n\n trigger() {\n that._tapmove();\n },\n\n update(x = 0, y = 0) {\n const {left, top, width, height} = that.options.wrapper.getBoundingClientRect();\n\n if (that.options.lock === 'h') {\n y = x;\n }\n\n that._tapmove({\n clientX: left + width * x,\n clientY: top + height * y\n });\n },\n\n destroy() {\n const {options, _tapstart} = that;\n _.off([options.wrapper, options.element], 'mousedown', _tapstart);\n _.off([options.wrapper, options.element], 'touchstart', _tapstart, {\n passive: false\n });\n }\n };\n\n // Initilize\n const {options, _tapstart} = that;\n _.on([options.wrapper, options.element], 'mousedown', _tapstart);\n _.on([options.wrapper, options.element], 'touchstart', _tapstart, {\n passive: false\n });\n\n return that;\n}\n","import * as _ from '../utils/utils';\r\n\r\nexport default function Selectable(opt = {}) {\r\n opt = Object.assign({\r\n onchange: () => 0,\r\n className: '',\r\n elements: []\r\n }, opt);\r\n\r\n const onTap = _.on(opt.elements, 'click', evt => {\r\n opt.elements.forEach(e =>\r\n e.classList[evt.target === e ? 'add' : 'remove'](opt.className)\r\n );\r\n\r\n opt.onchange(evt);\r\n });\r\n\r\n return {\r\n destroy: () => _.off(...onTap)\r\n };\r\n}\r\n","/**\r\n * Micro positioning-engine\r\n * @param el\r\n * @param reference\r\n * @param pos\r\n * @param padding\r\n * @returns {{update(): void}}\r\n * @constructor\r\n */\r\nexport default function Nanopop({el, reference, padding = 8}) {\r\n const vBehaviour = {start: 'sme', middle: 'mse', end: 'ems'};\r\n const hBehaviour = {top: 'tbrl', right: 'rltb', bottom: 'btrl', left: 'lrbt'};\r\n\r\n const getInfo = ((cache = {}) => (pos, cached = cache[pos]) => {\r\n if (cached) return cached;\r\n const [position, variant = 'middle'] = pos.split('-');\r\n const isVertical = (position === 'top' || position === 'bottom');\r\n\r\n return cache[pos] = {\r\n position,\r\n variant,\r\n isVertical\r\n };\r\n })();\r\n\r\n return {\r\n update(pos) {\r\n const {position, variant, isVertical} = getInfo(pos);\r\n const rb = reference.getBoundingClientRect();\r\n const eb = el.getBoundingClientRect();\r\n\r\n const positions = vertical => vertical ? {\r\n t: rb.top - eb.height - padding,\r\n b: rb.bottom + padding\r\n } : {\r\n r: rb.right + padding,\r\n l: rb.left - eb.width - padding\r\n };\r\n\r\n const variants = vertical => vertical ? {\r\n s: rb.left + rb.width - eb.width,\r\n m: (-eb.width / 2) + (rb.left + rb.width / 2),\r\n e: rb.left\r\n } : {\r\n s: rb.bottom - eb.height,\r\n m: rb.bottom - rb.height / 2 - eb.height / 2,\r\n e: rb.bottom - rb.height\r\n };\r\n\r\n const leastApplied = {};\r\n\r\n function apply(bevs, vars, styleprop) {\r\n const vertical = styleprop === 'top';\r\n const adder = vertical ? eb.height : eb.width;\r\n const win = window[vertical ? 'innerHeight' : 'innerWidth'];\r\n\r\n for (const ch of bevs) {\r\n const v = vars[ch];\r\n const sv = leastApplied[styleprop] = `${v}px`;\r\n\r\n if (v > 0 && (v + adder) < win) {\r\n el.style[styleprop] = sv;\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n for (const rot of [isVertical, !isVertical]) {\r\n const v2Ok = apply(hBehaviour[position], positions(rot), rot ? 'top' : 'left');\r\n const v1Ok = apply(vBehaviour[variant], variants(rot), rot ? 'left' : 'top');\r\n\r\n if (v2Ok && v1Ok) {\r\n return;\r\n }\r\n }\r\n\r\n el.style.left = leastApplied.left;\r\n el.style.top = leastApplied.top;\r\n }\r\n };\r\n}\r\n","// Import utils\nimport * as _ from './utils/utils';\nimport {parseToHSVA} from './utils/color';\n\n// Import classes\nimport {HSVaColor} from './utils/hsvacolor';\nimport Moveable from './libs/moveable';\nimport Selectable from './libs/selectable';\nimport Nanopop from './libs/nanopop';\nimport buildPickr from './template';\n\nclass Pickr {\n\n // Will be used to prevent specific actions during initilization\n _initializingActive = true;\n\n // If the current color value should be recalculated\n _recalc = true;\n\n // Current and last color for comparison\n _color = HSVaColor();\n _lastColor = HSVaColor();\n _swatchColors = [];\n\n // Evenlistener name: [callbacks]\n _eventListener = {\n init: [],\n save: [],\n hide: [],\n show: [],\n clear: [],\n change: [],\n changestop: [],\n cancel: [],\n swatchselect: []\n };\n\n constructor(opt) {\n\n // Assign default values\n this.options = opt = Object.assign({\n appClass: null,\n theme: 'classic',\n useAsButton: false,\n disabled: false,\n comparison: true,\n closeOnScroll: false,\n outputPrecision: 0,\n lockOpacity: false,\n autoReposition: true,\n\n components: {\n interaction: {}\n },\n\n strings: {},\n swatches: null,\n inline: false,\n sliders: null,\n\n default: '#42445a',\n defaultRepresentation: null,\n position: 'bottom-middle',\n adjustableNumbers: true,\n showAlways: false,\n\n closeWithKey: 'Escape'\n }, opt);\n\n const {swatches, inline, components, theme, sliders, lockOpacity} = opt;\n\n if (['nano', 'monolith'].includes(theme) && !sliders) {\n opt.sliders = 'h';\n }\n\n // Check interaction section\n if (!components.interaction) {\n components.interaction = {};\n }\n\n // Overwrite palette if preview, opacity or hue are true\n const {preview, opacity, hue, palette} = components;\n components.opacity = (!lockOpacity && opacity);\n components.palette = palette || preview || opacity || hue;\n\n // Per default enabled if inline\n if (inline) {\n opt.showAlways = true;\n }\n\n // Initialize picker\n this._preBuild();\n this._buildComponents();\n this._bindEvents();\n this._finalBuild();\n\n // Append pre-defined swatch colors\n if (swatches && swatches.length) {\n swatches.forEach(color => this.addSwatch(color));\n }\n\n // Initialize positioning engine\n this._nanopop = Nanopop({\n reference: this._root.button,\n el: this._root.app\n });\n\n // Initilization is finish, pickr is visible and ready for usage\n const {app} = this._root;\n const that = this;\n requestAnimationFrame((function cb() {\n\n if (!app.offsetWidth && app.parentElement !== document.body) {\n return requestAnimationFrame(cb);\n }\n\n // Apply default color\n that.setColor(opt.default);\n that._rePositioningPicker();\n\n // Initialize color representation\n if (opt.defaultRepresentation) {\n that._representation = opt.defaultRepresentation;\n that.setColorRepresentation(that._representation);\n }\n\n // Show pickr if locked\n if (opt.showAlways) {\n that.show();\n }\n\n // Initialization is done - pickr is usable, fire init event\n that._initializingActive = false;\n that._emit('init');\n }));\n }\n\n // Does only the absolutly basic thing to initialize the components\n _preBuild() {\n const opt = this.options;\n\n // Check if element is selector\n if (typeof opt.el === 'string') {\n\n // Resolve possible shadow dom access\n opt.el = opt.el.split(/>>/g).reduce((pv, cv, ci, a) => {\n pv = pv.querySelector(cv);\n return ci < a.length - 1 ? pv.shadowRoot : pv;\n }, document);\n }\n\n // Create element and append it to body to\n // prevent initialization errors\n this._root = buildPickr(opt);\n\n // Check if a custom button is used\n if (opt.useAsButton) {\n this._root.button = opt.el; // Replace button with customized button\n }\n\n document.body.appendChild(this._root.root);\n }\n\n _finalBuild() {\n const opt = this.options;\n const root = this._root;\n\n // Remove from body\n document.body.removeChild(root.root);\n\n if (opt.inline) {\n const parent = opt.el.parentElement;\n\n if (opt.el.nextSibling) {\n parent.insertBefore(root.app, opt.el.nextSibling);\n } else {\n parent.appendChild(root.app);\n }\n } else {\n document.body.appendChild(root.app);\n }\n\n // Don't replace the the element if a custom button is used\n if (!opt.useAsButton) {\n\n // Replace element with actual color-picker\n opt.el.parentNode.replaceChild(root.root, opt.el);\n } else if (opt.inline) {\n opt.el.remove();\n }\n\n // Check if it should be immediatly disabled\n if (opt.disabled) {\n this.disable();\n }\n\n // Check if color comparison is disabled, if yes - remove transitions so everything keeps smoothly\n if (!opt.comparison) {\n root.button.style.transition = 'none';\n if (!opt.useAsButton) {\n root.preview.lastColor.style.transition = 'none';\n }\n }\n\n this.hide();\n }\n\n _buildComponents() {\n\n // Instance reference\n const inst = this;\n const cs = this.options.components;\n const sliders = (inst.options.sliders || 'v').repeat(2);\n const [so, sh] = sliders.match(/^[vh]+$/g) ? sliders : [];\n\n const components = {\n\n palette: Moveable({\n element: inst._root.palette.picker,\n wrapper: inst._root.palette.palette,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(x, y) {\n if (!cs.palette) return;\n const {_color, _root, options} = inst;\n\n // Update the input field only if the user is currently not typing\n if (inst._recalc) {\n\n // Calculate saturation based on the position\n _color.s = x * 100;\n\n // Calculate the value\n _color.v = 100 - y * 100;\n\n // Prevent falling under zero\n _color.v < 0 ? _color.v = 0 : 0;\n inst._updateOutput();\n }\n\n // Set picker and gradient color\n let cssRGBaString = _color.toRGBA().toString(0);\n this.element.style.background = cssRGBaString;\n this.wrapper.style.background = `\n linear-gradient(to top, rgba(0, 0, 0, ${_color.a}), transparent),\n linear-gradient(to left, hsla(${_color.h}, 100%, 50%, ${_color.a}), rgba(255, 255, 255, ${_color.a}))\n `;\n\n // Check if color is locked\n if (!options.comparison) {\n _root.button.style.color = cssRGBaString;\n\n if (!options.useAsButton) {\n _root.preview.lastColor.style.color = cssRGBaString;\n }\n }\n\n // Change current color\n _root.preview.currentColor.style.color = cssRGBaString;\n\n if (!inst.options.comparison) {\n\n // If the user changes the color, remove the cleared icon\n _root.button.classList.remove('clear');\n }\n }\n }),\n\n hue: Moveable({\n lock: sh === 'v' ? 'h' : 'v',\n element: inst._root.hue.picker,\n wrapper: inst._root.hue.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.hue || !cs.palette) return;\n\n // Calculate hue\n if (inst._recalc) {\n inst._color.h = v * 360;\n }\n\n // Update color\n this.element.style.backgroundColor = `hsl(${inst._color.h}, 100%, 50%)`;\n components.palette.trigger();\n }\n }),\n\n opacity: Moveable({\n lock: so === 'v' ? 'h' : 'v',\n element: inst._root.opacity.picker,\n wrapper: inst._root.opacity.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.opacity || !cs.palette) return;\n\n // Calculate opacity\n if (inst._recalc) {\n inst._color.a = Math.round(v * 1e2) / 100;\n }\n\n // Update color\n this.element.style.background = `rgba(0, 0, 0, ${inst._color.a})`;\n components.palette.trigger();\n }\n }),\n\n selectable: Selectable({\n elements: inst._root.interaction.options,\n className: 'active',\n\n onchange(e) {\n inst._representation = e.target.getAttribute('data-type').toUpperCase();\n inst._recalc && inst._updateOutput();\n }\n })\n };\n\n this._components = components;\n }\n\n _bindEvents() {\n const {_root, options} = this;\n\n const eventBindings = [\n\n // Clear color\n _.on(_root.interaction.clear, 'click', () => this._clearColor()),\n\n // Select last color on click\n _.on([\n _root.interaction.cancel,\n _root.preview.lastColor\n ], 'click', () => {\n this._emit('cancel', this);\n this.setHSVA(...this._lastColor.toHSVA(), true);\n }),\n\n // Save color\n _.on(_root.interaction.save, 'click', () => {\n !this.applyColor() && !options.showAlways && this.hide();\n }),\n\n _.on(_root.interaction.result, ['keyup', 'input'], e => {\n\n // Fire listener if initialization is finish and changed color was valid\n if (this.setColor(e.target.value, true) && !this._initializingActive) {\n this._emit('change', this._color);\n }\n\n e.stopImmediatePropagation();\n }),\n\n // Detect user input and disable auto-recalculation\n _.on(_root.interaction.result, ['focus', 'blur'], e => {\n this._recalc = e.type === 'blur';\n this._recalc && this._updateOutput();\n }),\n\n // Cancel input detection on color change\n _.on([\n _root.palette.palette,\n _root.palette.picker,\n _root.hue.slider,\n _root.hue.picker,\n _root.opacity.slider,\n _root.opacity.picker\n ], ['mousedown', 'touchstart'], () => this._recalc = true)\n ];\n\n // Provide hiding / showing abilities only if showAlways is false\n if (!options.showAlways) {\n const ck = options.closeWithKey;\n\n eventBindings.push(\n // Save and hide / show picker\n _.on(_root.button, 'click', () => this.isOpen() ? this.hide() : this.show()),\n\n // Close with escape key\n _.on(document, 'keyup', e => this.isOpen() && (e.key === ck || e.code === ck) && this.hide()),\n\n // Cancel selecting if the user taps behind the color picker\n _.on(document, ['touchstart', 'mousedown'], e => {\n if (this.isOpen() && !_.eventPath(e).some(el => el === _root.app || el === _root.button)) {\n this.hide();\n }\n }, {capture: true})\n );\n }\n\n // Make input adjustable if enabled\n if (options.adjustableNumbers) {\n const ranges = {\n rgba: [255, 255, 255, 1],\n hsva: [360, 100, 100, 1],\n hsla: [360, 100, 100, 1],\n cmyk: [100, 100, 100, 100]\n };\n\n _.adjustableInputNumbers(_root.interaction.result, (o, step, index) => {\n const range = ranges[this.getColorRepresentation().toLowerCase()];\n\n if (range) {\n const max = range[index];\n\n // Calculate next reasonable number\n const nv = o + (max >= 100 ? step * 1000 : step);\n\n // Apply range of zero up to max, fix floating-point issues\n return nv <= 0 ? 0 : Number((nv < max ? nv : max).toPrecision(3));\n } else {\n return o;\n }\n });\n }\n\n if (options.autoReposition && !options.inline) {\n let timeout = null;\n const that = this;\n\n // Re-calc position on window resize, scroll and wheel\n eventBindings.push(\n _.on(window, ['scroll', 'resize'], () => {\n if (that.isOpen()) {\n\n if (options.closeOnScroll) {\n that.hide();\n }\n\n if (timeout === null) {\n timeout = setTimeout(() => timeout = null, 100);\n\n // Update position on every frame\n requestAnimationFrame(function rs() {\n that._rePositioningPicker();\n (timeout !== null) && requestAnimationFrame(rs);\n });\n } else {\n clearTimeout(timeout);\n timeout = setTimeout(() => timeout = null, 100);\n }\n }\n }, {capture: true})\n );\n }\n\n // Save bindings\n this._eventBindings = eventBindings;\n }\n\n _rePositioningPicker() {\n const {options} = this;\n\n // No repositioning needed if inline\n if (!options.inline) {\n const {app} = this._root;\n\n if (matchMedia('(max-width: 576px)').matches) {\n Object.assign(app.style, {\n margin: 'auto',\n height: `${app.getBoundingClientRect().height}px`,\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n });\n } else {\n Object.assign(app.style, {\n margin: null,\n right: null,\n top: null,\n bottom: null,\n left: null,\n height: null\n });\n\n this._nanopop.update(options.position);\n }\n }\n }\n\n _updateOutput() {\n const {_root, _color, options} = this;\n\n // Check if component is present\n if (_root.interaction.type()) {\n\n // Construct function name and call if present\n const method = `to${_root.interaction.type().getAttribute('data-type')}`;\n _root.interaction.result.value = typeof _color[method] === 'function' ?\n _color[method]().toString(options.outputPrecision) : '';\n }\n\n // Fire listener if initialization is finish\n if (!this._initializingActive && this._recalc) {\n this._emit('change', _color);\n }\n }\n\n _clearColor(silent = false) {\n const {_root, options} = this;\n\n // Change only the button color if it isn't customized\n if (!options.useAsButton) {\n _root.button.style.color = 'rgba(0, 0, 0, 0.15)';\n }\n\n _root.button.classList.add('clear');\n\n if (!options.showAlways) {\n this.hide();\n }\n\n if (!this._initializingActive && !silent) {\n\n // Fire listener\n this._emit('save', null);\n this._emit('clear', this);\n }\n }\n\n _parseLocalColor(str) {\n const {values, type, a} = parseToHSVA(str);\n const {lockOpacity} = this.options;\n const alphaMakesAChange = a !== undefined && a !== 1;\n\n // If no opacity is applied, add undefined at the very end which gets\n // set to 1 in setHSVA\n if (values && values.length === 3) {\n values[3] = undefined;\n }\n\n return {\n values: (!values || (lockOpacity && alphaMakesAChange)) ? null : values,\n type\n };\n }\n\n _emit(event, ...args) {\n this._eventListener[event].forEach(cb => cb(...args, this));\n }\n\n on(event, cb) {\n\n // Validate\n if (typeof cb === 'function' && typeof event === 'string' && event in this._eventListener) {\n this._eventListener[event].push(cb);\n }\n\n return this;\n }\n\n off(event, cb) {\n const callBacks = this._eventListener[event];\n\n if (callBacks) {\n const index = callBacks.indexOf(cb);\n\n if (~index) {\n callBacks.splice(index, 1);\n }\n }\n\n return this;\n }\n\n /**\n * Appends a color to the swatch palette\n * @param color\n * @returns {boolean}\n */\n addSwatch(color) {\n const {values} = this._parseLocalColor(color);\n\n if (values) {\n const {_swatchColors, _root} = this;\n const hsvaColorObject = HSVaColor(...values);\n\n // Create new swatch HTMLElement\n const element = _.createElementFromString(\n `'}\r\n\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n `);\r\n\r\n const int = root.interaction;\r\n\r\n // Select option which is not hidden\r\n int.options.find(o => !o.hidden && !o.classList.add('active'));\r\n\r\n // Create method to find currenlty active option\r\n int.type = () => int.options.find(e => e.classList.contains('active'));\r\n return root;\r\n}\r\n"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap","webpack:///./src/js/utils/utils.js","webpack:///./src/js/utils/color.js","webpack:///./src/js/utils/hsvacolor.js","webpack:///./src/js/libs/moveable.js","webpack:///./src/js/libs/selectable.js","webpack:///./src/js/libs/nanopop.js","webpack:///./src/js/pickr.js","webpack:///./src/js/template.js"],"names":["root","factory","exports","module","define","amd","window","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","on","eventListener","off","method","elements","events","fn","options","arguments","length","undefined","HTMLCollection","NodeList","Array","from","isArray","_iteratorNormalCompletion","_didIteratorError","_iteratorError","_step","_iterator","iterator","next","done","el","_iteratorNormalCompletion2","_didIteratorError2","_iteratorError2","_step2","_iterator2","ev","_objectSpread","capture","err","return","slice","createElementFromString","html","div","document","createElement","innerHTML","trim","firstElementChild","removeAttribute","getAttribute","createFromTemplate","str","resolve","element","base","con","subtree","_i","_Array$from","children","child","arr","sub","push","keys","eventPath","evt","path","composedPath","target","parentElement","adjustableInputNumbers","mapper","v","handleScroll","e","inc","Number","shiftKey","ctrlKey","deltaY","index","selectionStart","replace","focus","setSelectionRange","preventDefault","dispatchEvent","Event","passive","min","Math","max","floor","round","hsvToRgb","h","f","q","mod","rgbToHsv","g","b","minVal","maxVal","delta","dr","dg","db","cmykToHsv","y","k","_toConsumableArray","hslToHsv","hexToHsv","hex","apply","match","map","parseInt","parseToHSVA","toLowerCase","ctx","getContext","fillStyle","standardizeColor","regex","cmyk","rgba","hsla","hsva","hexa","numarize","array","test","invalid","type","exec","alpha","_numarize2","_slicedToArray","values","_numarize4","a","concat","split","join","raw","substring","_numarize6","_numarize8","HSVaColor","original","precision","toFixed","that","toHSVA","toString","toHSLA","hsvacolor_toConsumableArray","hsvToHsl","toRGBA","toCMYK","rgb","hsvToCmyk","toHEXA","padStart","hsvToHex","toUpperCase","clone","clamp","Moveable","opt","assign","lock","onchange","onstop","_tapstart","_","_tapstop","_tapmove","cache","wrapper","getBoundingClientRect","x","touch","touches","clientX","clientY","left","width","top","height","style","offsetWidth","offsetHeight","cx","cy","trigger","update","_that$options$wrapper","destroy","Selectable","className","onTap","forEach","classList","selectable_toConsumableArray","Nanopop","_ref","reference","_ref$padding","padding","vBehaviour","start","middle","end","hBehaviour","right","bottom","getInfo","pos","cached","_pos$split","_pos$split2","nanopop_slicedToArray","position","_pos$split2$","variant","isVertical","_getInfo","rb","eb","variants","vertical","leastApplied","bevs","vars","styleprop","adder","win","sv","_i2","_arr2","rot","v2Ok","v1Ok","Pickr","_this","this","_classCallCheck","pickr_defineProperty","init","save","hide","show","clear","change","changestop","cancel","swatchselect","appClass","theme","useAsButton","disabled","comparison","closeOnScroll","outputPrecision","lockOpacity","autoReposition","components","interaction","strings","swatches","inline","sliders","default","defaultRepresentation","adjustableNumbers","showAlways","closeWithKey","_opt","includes","preview","opacity","hue","palette","_preBuild","_buildComponents","_bindEvents","_finalBuild","color","addSwatch","_nanopop","_root","button","app","requestAnimationFrame","cb","body","setColor","_rePositioningPicker","_representation","setColorRepresentation","_initializingActive","_emit","lo","hidden","int","reduce","pv","cv","ci","querySelector","shadowRoot","input","find","add","contains","appendChild","removeChild","parent","nextSibling","insertBefore","remove","parentNode","replaceChild","disable","transition","lastColor","inst","cs","repeat","_ref2","pickr_slicedToArray","so","sh","picker","_color","_recalc","_updateOutput","cssRGBaString","background","currentColor","slider","backgroundColor","selectable","_components","_this2","eventBindings","_clearColor","setHSVA","pickr_toConsumableArray","_lastColor","applyColor","result","stopImmediatePropagation","ck","isOpen","code","some","ranges","step","range","getColorRepresentation","nv","toPrecision","timeout","setTimeout","rs","clearTimeout","_eventBindings","matchMedia","matches","margin","silent","_parseToHSVA","alphaMakesAChange","event","_this3","_len","args","_key","_eventListener","callBacks","indexOf","splice","_this4","_parseLocalColor","_swatchColors","hsvaColorObject","swatchColor","_this$_root","_this5","_this6","_this$_root2","recalc","_this$_components","string","_this$_parseLocalColo2","utype","startsWith","click","utils","libs","version"],"mappings":"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","file":"pickr.es5.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Pickr\"] = factory();\n\telse\n\t\troot[\"Pickr\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\n * Add event(s) to element(s).\n * @param elements DOM-Elements\n * @param events Event names\n * @param fn Callback\n * @param options Optional options\n * @return Array passed arguments\n */\nexport const on = eventListener.bind(null, 'addEventListener');\n\n/**\n * Remove event(s) from element(s).\n * @param elements DOM-Elements\n * @param events Event names\n * @param fn Callback\n * @param options Optional options\n * @return Array passed arguments\n */\nexport const off = eventListener.bind(null, 'removeEventListener');\n\nfunction eventListener(method, elements, events, fn, options = {}) {\n\n // Normalize array\n if (elements instanceof HTMLCollection || elements instanceof NodeList) {\n elements = Array.from(elements);\n } else if (!Array.isArray(elements)) {\n elements = [elements];\n }\n\n if (!Array.isArray(events)) {\n events = [events];\n }\n\n for (const el of elements) {\n for (const ev of events) {\n el[method](ev, fn, {capture: false, ...options});\n }\n }\n\n return Array.prototype.slice.call(arguments, 1);\n}\n\n/**\n * Creates an DOM-Element out of a string (Single element).\n * @param html HTML representing a single element\n * @returns {Element | null} The element.\n */\nexport function createElementFromString(html) {\n const div = document.createElement('div');\n div.innerHTML = html.trim();\n return div.firstElementChild;\n}\n\n/**\n * Removes an attribute from a HTMLElement and returns the value.\n * @param el\n * @param name\n * @return {string}\n */\nexport function removeAttribute(el, name) {\n const value = el.getAttribute(name);\n el.removeAttribute(name);\n return value;\n}\n\n/**\n * Creates a new html element, every element which has\n * a ':ref' attribute will be saved in a object (which will be returned)\n * where the value of ':ref' is the object-key and the value the HTMLElement.\n *\n * It's possible to create a hierarchy if you add a ':obj' attribute. Every\n * sibling will be added to the object which will get the name from the 'data-con' attribute.\n *\n * If you want to create an Array out of multiple elements, you can use the ':arr' attribute,\n * the value defines the key and all elements, which has the same parent and the same 'data-arr' attribute,\n * would be added to it.\n *\n * @param str - The HTML String.\n */\nexport function createFromTemplate(str) {\n\n // Recursive function to resolve template\n function resolve(element, base = {}) {\n\n // Check key and container attribute\n const con = removeAttribute(element, ':obj');\n const key = removeAttribute(element, ':ref');\n const subtree = con ? (base[con] = {}) : base;\n\n // Check and save element\n key && (base[key] = element);\n for (const child of Array.from(element.children)) {\n const arr = removeAttribute(child, ':arr');\n const sub = resolve(child, arr ? {} : subtree);\n\n if (arr) {\n\n // Check if there is already an array and add element\n (subtree[arr] || (subtree[arr] = []))\n .push(Object.keys(sub).length ? sub : child);\n }\n }\n\n return base;\n }\n\n return resolve(createElementFromString(str));\n}\n\n/**\n * Polyfill for safari & firefox for the eventPath event property.\n * @param evt The event object.\n * @return [String] event path.\n */\nexport function eventPath(evt) {\n let path = evt.path || (evt.composedPath && evt.composedPath());\n if (path) return path;\n\n let el = evt.target.parentElement;\n path = [evt.target, el];\n while (el = el.parentElement) path.push(el);\n\n path.push(document, window);\n return path;\n}\n\n/**\n * Creates the ability to change numbers in an input field with the scroll-wheel.\n * @param el\n * @param mapper\n */\nexport function adjustableInputNumbers(el, mapper = v => v) {\n\n function handleScroll(e) {\n const inc = ([0.001, 0.01, 0.1])[Number(e.shiftKey || e.ctrlKey * 2)] * (e.deltaY < 0 ? 1 : -1);\n\n let index = 0;\n let off = el.selectionStart;\n el.value = el.value.replace(/[\\d.]+/g, (v, i) => {\n\n // Check if number is in cursor range and increase it\n if (i <= off && i + v.length >= off) {\n off = i;\n return mapper(Number(v), inc, index);\n }\n\n index++;\n return v;\n });\n\n el.focus();\n el.setSelectionRange(off, off);\n\n // Prevent default and trigger input event\n e.preventDefault();\n el.dispatchEvent(new Event('input'));\n }\n\n // Bind events\n on(el, 'focus', () => on(window, 'wheel', handleScroll, {passive: false}));\n on(el, 'blur', () => off(window, 'wheel', handleScroll));\n}\n","// Shorthands\nconst {min, max, floor, round} = Math;\n\n/**\n * Tries to convert a color name to rgb/a hex representation\n * @param name\n * @returns {string | CanvasGradient | CanvasPattern}\n */\nfunction standardizeColor(name) {\n\n // Since invalid color's will be parsed as black, filter them out\n if (name.toLowerCase() === 'black') {\n return '#000000';\n }\n\n const ctx = document.createElement('canvas').getContext('2d');\n ctx.fillStyle = name;\n return ctx.fillStyle === '#000000' ? null : ctx.fillStyle;\n}\n\n/**\n * Convert HSV spectrum to RGB.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {number[]} Array with rgb values.\n */\nexport function hsvToRgb(h, s, v) {\n h = (h / 360) * 6;\n s /= 100;\n v /= 100;\n\n let i = floor(h);\n\n let f = h - i;\n let p = v * (1 - s);\n let q = v * (1 - f * s);\n let t = v * (1 - (1 - f) * s);\n\n let mod = i % 6;\n let r = [v, q, p, p, t, v][mod];\n let g = [t, v, v, q, p, p][mod];\n let b = [p, p, t, v, v, q][mod];\n\n return [\n r * 255,\n g * 255,\n b * 255\n ];\n}\n\n/**\n * Convert HSV spectrum to Hex.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {string[]} Hex values\n */\nexport function hsvToHex(h, s, v) {\n return hsvToRgb(h, s, v).map(v =>\n round(v).toString(16).padStart(2, '0')\n );\n}\n\n/**\n * Convert HSV spectrum to CMYK.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {number[]} CMYK values\n */\nexport function hsvToCmyk(h, s, v) {\n const rgb = hsvToRgb(h, s, v);\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n let k, c, m, y;\n\n k = min(1 - r, 1 - g, 1 - b);\n\n c = k === 1 ? 0 : (1 - r - k) / (1 - k);\n m = k === 1 ? 0 : (1 - g - k) / (1 - k);\n y = k === 1 ? 0 : (1 - b - k) / (1 - k);\n\n return [\n c * 100,\n m * 100,\n y * 100,\n k * 100\n ];\n}\n\n/**\n * Convert HSV spectrum to HSL.\n * @param h Hue\n * @param s Saturation\n * @param v Value\n * @returns {number[]} HSL values\n */\nexport function hsvToHsl(h, s, v) {\n s /= 100, v /= 100;\n\n let l = (2 - s) * v / 2;\n\n if (l !== 0) {\n if (l === 1) {\n s = 0;\n } else if (l < 0.5) {\n s = s * v / (l * 2);\n } else {\n s = s * v / (2 - l * 2);\n }\n }\n\n return [\n h,\n s * 100,\n l * 100\n ];\n}\n\n/**\n * Convert RGB to HSV.\n * @param r Red\n * @param g Green\n * @param b Blue\n * @return {number[]} HSV values.\n */\nfunction rgbToHsv(r, g, b) {\n r /= 255, g /= 255, b /= 255;\n\n let h, s, v;\n const minVal = min(r, g, b);\n const maxVal = max(r, g, b);\n const delta = maxVal - minVal;\n\n v = maxVal;\n if (delta === 0) {\n h = s = 0;\n } else {\n s = delta / maxVal;\n let dr = (((maxVal - r) / 6) + (delta / 2)) / delta;\n let dg = (((maxVal - g) / 6) + (delta / 2)) / delta;\n let db = (((maxVal - b) / 6) + (delta / 2)) / delta;\n\n if (r === maxVal) {\n h = db - dg;\n } else if (g === maxVal) {\n h = (1 / 3) + dr - db;\n } else if (b === maxVal) {\n h = (2 / 3) + dg - dr;\n }\n\n if (h < 0) {\n h += 1;\n } else if (h > 1) {\n h -= 1;\n }\n }\n\n return [\n h * 360,\n s * 100,\n v * 100\n ];\n}\n\n/**\n * Convert CMYK to HSV.\n * @param c Cyan\n * @param m Magenta\n * @param y Yellow\n * @param k Key (Black)\n * @return {number[]} HSV values.\n */\nfunction cmykToHsv(c, m, y, k) {\n c /= 100;\n m /= 100;\n y /= 100;\n k /= 100;\n\n const r = (1 - min(1, c * (1 - k) + k)) * 255;\n const g = (1 - min(1, m * (1 - k) + k)) * 255;\n const b = (1 - min(1, y * (1 - k) + k)) * 255;\n\n return [...rgbToHsv(r, g, b)];\n}\n\n/**\n * Convert HSL to HSV.\n * @param h Hue\n * @param s Saturation\n * @param l Lightness\n * @return {number[]} HSV values.\n */\nfunction hslToHsv(h, s, l) {\n s /= 100;\n l /= 100;\n s *= l < 0.5 ? l : 1 - l;\n\n let ns = (2 * s / (l + s)) * 100;\n let v = (l + s) * 100;\n return [h, ns, v];\n}\n\n/**\n * Convert HEX to HSV.\n * @param hex Hexadecimal string of rgb colors, can have length 3 or 6.\n * @return {number[]} HSV values.\n */\nfunction hexToHsv(hex) {\n return rgbToHsv(...hex.match(/.{2}/g).map(v => parseInt(v, 16)));\n}\n\n/**\n * Try's to parse a string which represents a color to a HSV array.\n * Current supported types are cmyk, rgba, hsla and hexadecimal.\n * @param str\n * @return {*}\n */\nexport function parseToHSVA(str) {\n\n // Check if string is a color-name\n str = str.match(/^[a-zA-Z]+$/) ? standardizeColor(str) : str;\n\n // Regular expressions to match different types of color represention\n const regex = {\n cmyk: /^cmyk[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)/i,\n rgba: /^((rgba)|rgb)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i,\n hsla: /^((hsla)|hsl)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i,\n hsva: /^((hsva)|hsv)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i,\n hexa: /^#?(([\\dA-Fa-f]{3,4})|([\\dA-Fa-f]{6})|([\\dA-Fa-f]{8}))$/i\n };\n\n /**\n * Takes an Array of any type, convert strings which represents\n * a number to a number an anything else to undefined.\n * @param array\n * @return {*}\n */\n const numarize = array => array.map(v => /^(|\\d+)\\.\\d+|\\d+$/.test(v) ? Number(v) : undefined);\n\n let match;\n invalid: for (const type in regex) {\n\n // Check if current scheme passed\n if (!(match = regex[type].exec(str)))\n continue;\n\n // match[2] does only contain a truly value if rgba, hsla, or hsla got matched\n const alpha = !!match[2];\n\n // Try to convert\n switch (type) {\n case 'cmyk': {\n let [, c, m, y, k] = numarize(match);\n\n if (c > 100 || m > 100 || y > 100 || k > 100)\n break invalid;\n\n return {values: cmykToHsv(c, m, y, k), type};\n }\n case 'rgba': {\n let [, , , r, g, b, a] = numarize(match);\n\n if (r > 255 || g > 255 || b > 255 || a < 0 || a > 1 || (alpha === !a))\n break invalid;\n\n return {values: [...rgbToHsv(r, g, b), a], a, type};\n }\n case 'hexa': {\n let [, hex] = match;\n\n if (hex.length === 4 || hex.length === 3) {\n hex = hex.split('').map(v => v + v).join('');\n }\n\n const raw = hex.substring(0, 6);\n let a = hex.substring(6);\n\n // Convert 0 - 255 to 0 - 1 for opacity\n a = a ? (parseInt(a, 16) / 255) : undefined;\n\n return {values: [...hexToHsv(raw), a], a, type};\n }\n case 'hsla': {\n let [, , , h, s, l, a] = numarize(match);\n\n if (h > 360 || s > 100 || l > 100 || a < 0 || a > 1 || (alpha === !a))\n break invalid;\n\n return {values: [...hslToHsv(h, s, l), a], a, type};\n }\n case 'hsva': {\n let [, , , h, s, v, a] = numarize(match);\n\n if (h > 360 || s > 100 || v > 100 || a < 0 || a > 1 || (alpha === !a))\n break invalid;\n\n return {values: [h, s, v, a], a, type};\n }\n }\n }\n\n return {values: null, type: null};\n}\n","import {hsvToHsl, hsvToRgb, hsvToCmyk, hsvToHex} from './color';\n\n/**\n * Simple class which holds the properties\n * of the color represention model hsla (hue saturation lightness alpha)\n */\nexport function HSVaColor(h = 0, s = 0, v = 0, a = 1) {\n const mapper = (original, next) => (precision = -1) => {\n return next(~precision ? original.map(v => Number(v.toFixed(precision))) : original);\n };\n\n const that = {\n h, s, v, a,\n\n toHSVA() {\n const hsva = [that.h, that.s, that.v, that.a];\n hsva.toString = mapper(hsva, arr => `hsva(${arr[0]}, ${arr[1]}%, ${arr[2]}%, ${that.a})`);\n return hsva;\n },\n\n toHSLA() {\n const hsla = [...hsvToHsl(that.h, that.s, that.v), that.a];\n hsla.toString = mapper(hsla, arr => `hsla(${arr[0]}, ${arr[1]}%, ${arr[2]}%, ${that.a})`);\n return hsla;\n },\n\n toRGBA() {\n const rgba = [...hsvToRgb(that.h, that.s, that.v), that.a];\n rgba.toString = mapper(rgba, arr => `rgba(${arr[0]}, ${arr[1]}, ${arr[2]}, ${that.a})`);\n return rgba;\n },\n\n toCMYK() {\n const cmyk = hsvToCmyk(that.h, that.s, that.v);\n cmyk.toString = mapper(cmyk, arr => `cmyk(${arr[0]}%, ${arr[1]}%, ${arr[2]}%, ${arr[3]}%)`);\n return cmyk;\n },\n\n toHEXA() {\n const hex = hsvToHex(that.h, that.s, that.v);\n\n // Check if alpha channel make sense, convert it to 255 number space, convert\n // to hex and pad it with zeros if needet.\n const alpha = that.a >= 1 ? '' : Number((that.a * 255).toFixed(0))\n .toString(16)\n .toUpperCase().padStart(2, '0');\n\n alpha && hex.push(alpha);\n hex.toString = () => `#${hex.join('').toUpperCase()}`;\n return hex;\n },\n\n clone: () => HSVaColor(that.h, that.s, that.v, that.a)\n };\n\n return that;\n}\n","import * as _ from '../utils/utils';\n\nconst clamp = v => Math.max(Math.min(v, 1), 0);\nexport default function Moveable(opt) {\n\n const that = {\n\n // Assign default values\n options: Object.assign({\n lock: null,\n onchange: () => 0,\n onstop: () => 0\n }, opt),\n\n _tapstart(evt) {\n _.on(document, ['mouseup', 'touchend', 'touchcancel'], that._tapstop);\n _.on(document, ['mousemove', 'touchmove'], that._tapmove);\n\n // Prevent default touch event\n evt.preventDefault();\n\n // Trigger\n that._tapmove(evt);\n },\n\n _tapmove(evt) {\n const {options: {lock}, cache} = that;\n const {element, wrapper} = options;\n const b = wrapper.getBoundingClientRect();\n\n let x = 0, y = 0;\n if (evt) {\n const touch = evt && evt.touches && evt.touches[0];\n x = evt ? (touch || evt).clientX : 0;\n y = evt ? (touch || evt).clientY : 0;\n\n // Reset to bounds\n if (x < b.left) x = b.left;\n else if (x > b.left + b.width) x = b.left + b.width;\n if (y < b.top) y = b.top;\n else if (y > b.top + b.height) y = b.top + b.height;\n\n // Normalize\n x -= b.left;\n y -= b.top;\n } else if (cache) {\n x = cache.x * b.width;\n y = cache.y * b.height;\n }\n\n if (lock !== 'h') {\n element.style.left = `calc(${x / b.width * 100}% - ${element.offsetWidth / 2}px)`;\n }\n\n if (lock !== 'v') {\n element.style.top = `calc(${y / b.height * 100}% - ${element.offsetHeight / 2}px)`;\n }\n\n that.cache = {x: x / b.width, y: y / b.height};\n const cx = clamp(x / wrapper.offsetWidth);\n const cy = clamp(y / wrapper.offsetHeight);\n\n switch (lock) {\n case 'v':\n return options.onchange(cx);\n case 'h':\n return options.onchange(cy);\n default:\n return options.onchange(cx, cy);\n }\n },\n\n _tapstop() {\n that.options.onstop();\n _.off(document, ['mouseup', 'touchend', 'touchcancel'], that._tapstop);\n _.off(document, ['mousemove', 'touchmove'], that._tapmove);\n },\n\n trigger() {\n that._tapmove();\n },\n\n update(x = 0, y = 0) {\n const {left, top, width, height} = that.options.wrapper.getBoundingClientRect();\n\n if (that.options.lock === 'h') {\n y = x;\n }\n\n that._tapmove({\n clientX: left + width * x,\n clientY: top + height * y\n });\n },\n\n destroy() {\n const {options, _tapstart} = that;\n _.off([options.wrapper, options.element], 'mousedown', _tapstart);\n _.off([options.wrapper, options.element], 'touchstart', _tapstart, {\n passive: false\n });\n }\n };\n\n // Initilize\n const {options, _tapstart} = that;\n _.on([options.wrapper, options.element], 'mousedown', _tapstart);\n _.on([options.wrapper, options.element], 'touchstart', _tapstart, {\n passive: false\n });\n\n return that;\n}\n","import * as _ from '../utils/utils';\r\n\r\nexport default function Selectable(opt = {}) {\r\n opt = Object.assign({\r\n onchange: () => 0,\r\n className: '',\r\n elements: []\r\n }, opt);\r\n\r\n const onTap = _.on(opt.elements, 'click', evt => {\r\n opt.elements.forEach(e =>\r\n e.classList[evt.target === e ? 'add' : 'remove'](opt.className)\r\n );\r\n\r\n opt.onchange(evt);\r\n });\r\n\r\n return {\r\n destroy: () => _.off(...onTap)\r\n };\r\n}\r\n","/**\r\n * Micro positioning-engine\r\n * @param el\r\n * @param reference\r\n * @param pos\r\n * @param padding\r\n * @returns {{update(): void}}\r\n * @constructor\r\n */\r\nexport default function Nanopop({el, reference, padding = 8}) {\r\n const vBehaviour = {start: 'sme', middle: 'mse', end: 'ems'};\r\n const hBehaviour = {top: 'tbrl', right: 'rltb', bottom: 'btrl', left: 'lrbt'};\r\n\r\n const getInfo = ((cache = {}) => (pos, cached = cache[pos]) => {\r\n if (cached) return cached;\r\n const [position, variant = 'middle'] = pos.split('-');\r\n const isVertical = (position === 'top' || position === 'bottom');\r\n\r\n return cache[pos] = {\r\n position,\r\n variant,\r\n isVertical\r\n };\r\n })();\r\n\r\n return {\r\n update(pos) {\r\n const {position, variant, isVertical} = getInfo(pos);\r\n const rb = reference.getBoundingClientRect();\r\n const eb = el.getBoundingClientRect();\r\n\r\n const positions = vertical => vertical ? {\r\n t: rb.top - eb.height - padding,\r\n b: rb.bottom + padding\r\n } : {\r\n r: rb.right + padding,\r\n l: rb.left - eb.width - padding\r\n };\r\n\r\n const variants = vertical => vertical ? {\r\n s: rb.left + rb.width - eb.width,\r\n m: (-eb.width / 2) + (rb.left + rb.width / 2),\r\n e: rb.left\r\n } : {\r\n s: rb.bottom - eb.height,\r\n m: rb.bottom - rb.height / 2 - eb.height / 2,\r\n e: rb.bottom - rb.height\r\n };\r\n\r\n const leastApplied = {};\r\n\r\n function apply(bevs, vars, styleprop) {\r\n const vertical = styleprop === 'top';\r\n const adder = vertical ? eb.height : eb.width;\r\n const win = window[vertical ? 'innerHeight' : 'innerWidth'];\r\n\r\n for (const ch of bevs) {\r\n const v = vars[ch];\r\n const sv = leastApplied[styleprop] = `${v}px`;\r\n\r\n if (v > 0 && (v + adder) < win) {\r\n el.style[styleprop] = sv;\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n for (const rot of [isVertical, !isVertical]) {\r\n const v2Ok = apply(hBehaviour[position], positions(rot), rot ? 'top' : 'left');\r\n const v1Ok = apply(vBehaviour[variant], variants(rot), rot ? 'left' : 'top');\r\n\r\n if (v2Ok && v1Ok) {\r\n return;\r\n }\r\n }\r\n\r\n el.style.left = leastApplied.left;\r\n el.style.top = leastApplied.top;\r\n }\r\n };\r\n}\r\n","// Import utils\nimport * as _ from './utils/utils';\nimport {parseToHSVA} from './utils/color';\n\n// Import classes\nimport {HSVaColor} from './utils/hsvacolor';\nimport Moveable from './libs/moveable';\nimport Selectable from './libs/selectable';\nimport Nanopop from './libs/nanopop';\nimport buildPickr from './template';\n\nclass Pickr {\n\n // Will be used to prevent specific actions during initilization\n _initializingActive = true;\n\n // If the current color value should be recalculated\n _recalc = true;\n\n // Current and last color for comparison\n _color = HSVaColor();\n _lastColor = HSVaColor();\n _swatchColors = [];\n\n // Evenlistener name: [callbacks]\n _eventListener = {\n init: [],\n save: [],\n hide: [],\n show: [],\n clear: [],\n change: [],\n changestop: [],\n cancel: [],\n swatchselect: []\n };\n\n constructor(opt) {\n\n // Assign default values\n this.options = opt = Object.assign({\n appClass: null,\n theme: 'classic',\n useAsButton: false,\n disabled: false,\n comparison: true,\n closeOnScroll: false,\n outputPrecision: 0,\n lockOpacity: false,\n autoReposition: true,\n\n components: {\n interaction: {}\n },\n\n strings: {},\n swatches: null,\n inline: false,\n sliders: null,\n\n default: '#42445a',\n defaultRepresentation: null,\n position: 'bottom-middle',\n adjustableNumbers: true,\n showAlways: false,\n\n closeWithKey: 'Escape'\n }, opt);\n\n const {swatches, inline, components, theme, sliders, lockOpacity} = opt;\n\n if (['nano', 'monolith'].includes(theme) && !sliders) {\n opt.sliders = 'h';\n }\n\n // Check interaction section\n if (!components.interaction) {\n components.interaction = {};\n }\n\n // Overwrite palette if preview, opacity or hue are true\n const {preview, opacity, hue, palette} = components;\n components.opacity = (!lockOpacity && opacity);\n components.palette = palette || preview || opacity || hue;\n\n // Per default enabled if inline\n if (inline) {\n opt.showAlways = true;\n }\n\n // Initialize picker\n this._preBuild();\n this._buildComponents();\n this._bindEvents();\n this._finalBuild();\n\n // Append pre-defined swatch colors\n if (swatches && swatches.length) {\n swatches.forEach(color => this.addSwatch(color));\n }\n\n // Initialize positioning engine\n this._nanopop = Nanopop({\n reference: this._root.button,\n el: this._root.app\n });\n\n // Initilization is finish, pickr is visible and ready for usage\n const {app} = this._root;\n const that = this;\n requestAnimationFrame((function cb() {\n\n if (!app.offsetWidth && app.parentElement !== document.body) {\n return requestAnimationFrame(cb);\n }\n\n // Apply default color\n that.setColor(opt.default);\n that._rePositioningPicker();\n\n // Initialize color representation\n if (opt.defaultRepresentation) {\n that._representation = opt.defaultRepresentation;\n that.setColorRepresentation(that._representation);\n }\n\n // Show pickr if locked\n if (opt.showAlways) {\n that.show();\n }\n\n // Initialization is done - pickr is usable, fire init event\n that._initializingActive = false;\n that._emit('init');\n }));\n }\n\n // Does only the absolutly basic thing to initialize the components\n _preBuild() {\n const opt = this.options;\n\n // Check if element is selector\n if (typeof opt.el === 'string') {\n\n // Resolve possible shadow dom access\n opt.el = opt.el.split(/>>/g).reduce((pv, cv, ci, a) => {\n pv = pv.querySelector(cv);\n return ci < a.length - 1 ? pv.shadowRoot : pv;\n }, document);\n }\n\n // Create element and append it to body to\n // prevent initialization errors\n this._root = buildPickr(opt);\n\n // Check if a custom button is used\n if (opt.useAsButton) {\n this._root.button = opt.el; // Replace button with customized button\n }\n\n document.body.appendChild(this._root.root);\n }\n\n _finalBuild() {\n const opt = this.options;\n const root = this._root;\n\n // Remove from body\n document.body.removeChild(root.root);\n\n if (opt.inline) {\n const parent = opt.el.parentElement;\n\n if (opt.el.nextSibling) {\n parent.insertBefore(root.app, opt.el.nextSibling);\n } else {\n parent.appendChild(root.app);\n }\n } else {\n document.body.appendChild(root.app);\n }\n\n // Don't replace the the element if a custom button is used\n if (!opt.useAsButton) {\n\n // Replace element with actual color-picker\n opt.el.parentNode.replaceChild(root.root, opt.el);\n } else if (opt.inline) {\n opt.el.remove();\n }\n\n // Check if it should be immediatly disabled\n if (opt.disabled) {\n this.disable();\n }\n\n // Check if color comparison is disabled, if yes - remove transitions so everything keeps smoothly\n if (!opt.comparison) {\n root.button.style.transition = 'none';\n if (!opt.useAsButton) {\n root.preview.lastColor.style.transition = 'none';\n }\n }\n\n this.hide();\n }\n\n _buildComponents() {\n\n // Instance reference\n const inst = this;\n const cs = this.options.components;\n const sliders = (inst.options.sliders || 'v').repeat(2);\n const [so, sh] = sliders.match(/^[vh]+$/g) ? sliders : [];\n\n const components = {\n\n palette: Moveable({\n element: inst._root.palette.picker,\n wrapper: inst._root.palette.palette,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(x, y) {\n if (!cs.palette) return;\n const {_color, _root, options} = inst;\n\n // Update the input field only if the user is currently not typing\n if (inst._recalc) {\n\n // Calculate saturation based on the position\n _color.s = x * 100;\n\n // Calculate the value\n _color.v = 100 - y * 100;\n\n // Prevent falling under zero\n _color.v < 0 ? _color.v = 0 : 0;\n inst._updateOutput();\n }\n\n // Set picker and gradient color\n let cssRGBaString = _color.toRGBA().toString(0);\n this.element.style.background = cssRGBaString;\n this.wrapper.style.background = `\n linear-gradient(to top, rgba(0, 0, 0, ${_color.a}), transparent),\n linear-gradient(to left, hsla(${_color.h}, 100%, 50%, ${_color.a}), rgba(255, 255, 255, ${_color.a}))\n `;\n\n // Check if color is locked\n if (!options.comparison) {\n _root.button.style.color = cssRGBaString;\n\n if (!options.useAsButton) {\n _root.preview.lastColor.style.color = cssRGBaString;\n }\n }\n\n // Change current color\n _root.preview.currentColor.style.color = cssRGBaString;\n\n if (!inst.options.comparison) {\n\n // If the user changes the color, remove the cleared icon\n _root.button.classList.remove('clear');\n }\n }\n }),\n\n hue: Moveable({\n lock: sh === 'v' ? 'h' : 'v',\n element: inst._root.hue.picker,\n wrapper: inst._root.hue.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.hue || !cs.palette) return;\n\n // Calculate hue\n if (inst._recalc) {\n inst._color.h = v * 360;\n }\n\n // Update color\n this.element.style.backgroundColor = `hsl(${inst._color.h}, 100%, 50%)`;\n components.palette.trigger();\n }\n }),\n\n opacity: Moveable({\n lock: so === 'v' ? 'h' : 'v',\n element: inst._root.opacity.picker,\n wrapper: inst._root.opacity.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.opacity || !cs.palette) return;\n\n // Calculate opacity\n if (inst._recalc) {\n inst._color.a = Math.round(v * 1e2) / 100;\n }\n\n // Update color\n this.element.style.background = `rgba(0, 0, 0, ${inst._color.a})`;\n components.palette.trigger();\n }\n }),\n\n selectable: Selectable({\n elements: inst._root.interaction.options,\n className: 'active',\n\n onchange(e) {\n inst._representation = e.target.getAttribute('data-type').toUpperCase();\n inst._recalc && inst._updateOutput();\n }\n })\n };\n\n this._components = components;\n }\n\n _bindEvents() {\n const {_root, options} = this;\n\n const eventBindings = [\n\n // Clear color\n _.on(_root.interaction.clear, 'click', () => this._clearColor()),\n\n // Select last color on click\n _.on([\n _root.interaction.cancel,\n _root.preview.lastColor\n ], 'click', () => {\n this._emit('cancel', this);\n this.setHSVA(...this._lastColor.toHSVA(), true);\n }),\n\n // Save color\n _.on(_root.interaction.save, 'click', () => {\n !this.applyColor() && !options.showAlways && this.hide();\n }),\n\n _.on(_root.interaction.result, ['keyup', 'input'], e => {\n\n // Fire listener if initialization is finish and changed color was valid\n if (this.setColor(e.target.value, true) && !this._initializingActive) {\n this._emit('change', this._color);\n }\n\n e.stopImmediatePropagation();\n }),\n\n // Detect user input and disable auto-recalculation\n _.on(_root.interaction.result, ['focus', 'blur'], e => {\n this._recalc = e.type === 'blur';\n this._recalc && this._updateOutput();\n }),\n\n // Cancel input detection on color change\n _.on([\n _root.palette.palette,\n _root.palette.picker,\n _root.hue.slider,\n _root.hue.picker,\n _root.opacity.slider,\n _root.opacity.picker\n ], ['mousedown', 'touchstart'], () => this._recalc = true)\n ];\n\n // Provide hiding / showing abilities only if showAlways is false\n if (!options.showAlways) {\n const ck = options.closeWithKey;\n\n eventBindings.push(\n // Save and hide / show picker\n _.on(_root.button, 'click', () => this.isOpen() ? this.hide() : this.show()),\n\n // Close with escape key\n _.on(document, 'keyup', e => this.isOpen() && (e.key === ck || e.code === ck) && this.hide()),\n\n // Cancel selecting if the user taps behind the color picker\n _.on(document, ['touchstart', 'mousedown'], e => {\n if (this.isOpen() && !_.eventPath(e).some(el => el === _root.app || el === _root.button)) {\n this.hide();\n }\n }, {capture: true})\n );\n }\n\n // Make input adjustable if enabled\n if (options.adjustableNumbers) {\n const ranges = {\n rgba: [255, 255, 255, 1],\n hsva: [360, 100, 100, 1],\n hsla: [360, 100, 100, 1],\n cmyk: [100, 100, 100, 100]\n };\n\n _.adjustableInputNumbers(_root.interaction.result, (o, step, index) => {\n const range = ranges[this.getColorRepresentation().toLowerCase()];\n\n if (range) {\n const max = range[index];\n\n // Calculate next reasonable number\n const nv = o + (max >= 100 ? step * 1000 : step);\n\n // Apply range of zero up to max, fix floating-point issues\n return nv <= 0 ? 0 : Number((nv < max ? nv : max).toPrecision(3));\n } else {\n return o;\n }\n });\n }\n\n if (options.autoReposition && !options.inline) {\n let timeout = null;\n const that = this;\n\n // Re-calc position on window resize, scroll and wheel\n eventBindings.push(\n _.on(window, ['scroll', 'resize'], () => {\n if (that.isOpen()) {\n\n if (options.closeOnScroll) {\n that.hide();\n }\n\n if (timeout === null) {\n timeout = setTimeout(() => timeout = null, 100);\n\n // Update position on every frame\n requestAnimationFrame(function rs() {\n that._rePositioningPicker();\n (timeout !== null) && requestAnimationFrame(rs);\n });\n } else {\n clearTimeout(timeout);\n timeout = setTimeout(() => timeout = null, 100);\n }\n }\n }, {capture: true})\n );\n }\n\n // Save bindings\n this._eventBindings = eventBindings;\n }\n\n _rePositioningPicker() {\n const {options} = this;\n\n // No repositioning needed if inline\n if (!options.inline) {\n const {app} = this._root;\n\n if (matchMedia('(max-width: 576px)').matches) {\n Object.assign(app.style, {\n margin: 'auto',\n height: `${app.getBoundingClientRect().height}px`,\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n });\n } else {\n Object.assign(app.style, {\n margin: null,\n right: null,\n top: null,\n bottom: null,\n left: null,\n height: null\n });\n\n this._nanopop.update(options.position);\n }\n }\n }\n\n _updateOutput() {\n const {_root, _color, options} = this;\n\n // Check if component is present\n if (_root.interaction.type()) {\n\n // Construct function name and call if present\n const method = `to${_root.interaction.type().getAttribute('data-type')}`;\n _root.interaction.result.value = typeof _color[method] === 'function' ?\n _color[method]().toString(options.outputPrecision) : '';\n }\n\n // Fire listener if initialization is finish\n if (!this._initializingActive && this._recalc) {\n this._emit('change', _color);\n }\n }\n\n _clearColor(silent = false) {\n const {_root, options} = this;\n\n // Change only the button color if it isn't customized\n if (!options.useAsButton) {\n _root.button.style.color = 'rgba(0, 0, 0, 0.15)';\n }\n\n _root.button.classList.add('clear');\n\n if (!options.showAlways) {\n this.hide();\n }\n\n if (!this._initializingActive && !silent) {\n\n // Fire listener\n this._emit('save', null);\n this._emit('clear', this);\n }\n }\n\n _parseLocalColor(str) {\n const {values, type, a} = parseToHSVA(str);\n const {lockOpacity} = this.options;\n const alphaMakesAChange = a !== undefined && a !== 1;\n\n // If no opacity is applied, add undefined at the very end which gets\n // set to 1 in setHSVA\n if (values && values.length === 3) {\n values[3] = undefined;\n }\n\n return {\n values: (!values || (lockOpacity && alphaMakesAChange)) ? null : values,\n type\n };\n }\n\n _emit(event, ...args) {\n this._eventListener[event].forEach(cb => cb(...args, this));\n }\n\n on(event, cb) {\n\n // Validate\n if (typeof cb === 'function' && typeof event === 'string' && event in this._eventListener) {\n this._eventListener[event].push(cb);\n }\n\n return this;\n }\n\n off(event, cb) {\n const callBacks = this._eventListener[event];\n\n if (callBacks) {\n const index = callBacks.indexOf(cb);\n\n if (~index) {\n callBacks.splice(index, 1);\n }\n }\n\n return this;\n }\n\n /**\n * Appends a color to the swatch palette\n * @param color\n * @returns {boolean}\n */\n addSwatch(color) {\n const {values} = this._parseLocalColor(color);\n\n if (values) {\n const {_swatchColors, _root} = this;\n const hsvaColorObject = HSVaColor(...values);\n\n // Create new swatch HTMLElement\n const element = _.createElementFromString(\n `'}\r\n\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n `);\r\n\r\n const int = root.interaction;\r\n\r\n // Select option which is not hidden\r\n int.options.find(o => !o.hidden && !o.classList.add('active'));\r\n\r\n // Create method to find currenlty active option\r\n int.type = () => int.options.find(e => e.classList.contains('active'));\r\n return root;\r\n}\r\n"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/pickr.min.js b/dist/pickr.min.js index 3a962a5e..93e7360d 100644 --- a/dist/pickr.min.js +++ b/dist/pickr.min.js @@ -1,3 +1,3 @@ -/*! Pickr 1.2.6 MIT | https://github.com/Simonwep/pickr */ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.Pickr=e():t.Pickr=e()}(window,function(){return function(t){var e={};function o(n){if(e[n])return e[n].exports;var i=e[n]={i:n,l:!1,exports:{}};return t[n].call(i.exports,i,i.exports,o),i.l=!0,i.exports}return o.m=t,o.c=e,o.d=function(t,e,n){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(t,e){if(1&e&&(t=o(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)o.d(n,i,function(e){return t[e]}.bind(null,i));return n},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=0)}([function(t,e,o){"use strict";o.r(e);var n={};function i(t,e){var o=Object.keys(t);return Object.getOwnPropertySymbols&&o.push.apply(o,Object.getOwnPropertySymbols(t)),e&&(o=o.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),o}function r(t){for(var e=1;et)){function o(o){const n=[.001,.01,.1][Number(o.shiftKey||2*o.ctrlKey)]*(o.deltaY<0?1:-1);let i=0,r=t.selectionStart;t.value=t.value.replace(/[\d.]+/g,(t,o)=>o<=r&&o+t.length>=r?(r=o,e(Number(t),n,i)):(i++,t)),t.focus(),t.setSelectionRange(r,r),o.preventDefault(),t.dispatchEvent(new Event("input"))}c(t,"focus",()=>c(window,"wheel",o,{passive:!1})),c(t,"blur",()=>a(window,"wheel",o))}const{min:m,max:v,floor:b,round:y}=Math;function g(t,e,o){e/=100,o/=100;let n=b(t=t/360*6),i=t-n,r=o*(1-e),s=o*(1-i*e),c=o*(1-(1-i)*e),a=n%6;return[255*[o,s,r,r,c,o][a],255*[c,o,o,s,r,r][a],255*[r,r,c,o,o,s][a]]}function _(t,e,o){let n=(2-(e/=100))*(o/=100)/2;return 0!==n&&(e=1===n?0:n<.5?e*o/(2*n):e*o/(2-2*n)),[t,100*e,100*n]}function w(t,e,o){let n,i,r;const s=m(t/=255,e/=255,o/=255),c=v(t,e,o),a=c-s;if(0===a)n=i=0;else{i=a/c;let r=((c-t)/6+a/2)/a,s=((c-e)/6+a/2)/a,l=((c-o)/6+a/2)/a;t===c?n=l-s:e===c?n=1/3+r-l:o===c&&(n=2/3+s-r),n<0?n+=1:n>1&&(n-=1)}return[360*n,100*i,100*(r=c)]}function C(t,e,o,n){return e/=100,o/=100,[...w(255*(1-m(1,(t/=100)*(1-(n/=100))+n)),255*(1-m(1,e*(1-n)+n)),255*(1-m(1,o*(1-n)+n)))]}function A(t,e,o){return e/=100,[t,2*(e*=(o/=100)<.5?o:1-o)/(o+e)*100,100*(o+e)]}function k(t){return w(...t.match(/.{2}/g).map(t=>parseInt(t,16)))}function O(t){t=t.match(/^[a-zA-Z]+$/)?function(t){if("black"===t.toLowerCase())return"#000000";const e=document.createElement("canvas").getContext("2d");return e.fillStyle=t,"#000000"===e.fillStyle?null:e.fillStyle}(t):t;const e={cmyk:/^cmyk[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)/i,rgba:/^((rgba)|rgb)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hsla:/^((hsla)|hsl)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hsva:/^((hsva)|hsv)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i,hexa:/^#?(([\dA-Fa-f]{3,4})|([\dA-Fa-f]{6})|([\dA-Fa-f]{8}))$/i},o=t=>t.map(t=>/^(|\d+)\.\d+|\d+$/.test(t)?Number(t):void 0);let n;t:for(const i in e){if(!(n=e[i].exec(t)))continue;const r=!!n[2];switch(i){case"cmyk":{let[,t,e,r,s]=o(n);if(t>100||e>100||r>100||s>100)break t;return{values:C(t,e,r,s),type:i}}case"rgba":{let[,,,t,e,s,c]=o(n);if(t>255||e>255||s>255||c<0||c>1||r===!c)break t;return{values:[...w(t,e,s),c],a:c,type:i}}case"hexa":{let[,t]=n;4!==t.length&&3!==t.length||(t=t.split("").map(t=>t+t).join(""));const e=t.substring(0,6);let o=t.substring(6);return o=o?parseInt(o,16)/255:void 0,{values:[...k(e),o],a:o,type:i}}case"hsla":{let[,,,t,e,s,c]=o(n);if(t>360||e>100||s>100||c<0||c>1||r===!c)break t;return{values:[...A(t,e,s),c],a:c,type:i}}case"hsva":{let[,,,t,e,s,c]=o(n);if(t>360||e>100||s>100||c<0||c>1||r===!c)break t;return{values:[t,e,s,c],a:c,type:i}}}}return{values:null,type:null}}function S(t=0,e=0,o=0,n=1){const i=(t,e)=>(o=-1)=>e(~o?t.map(t=>Number(t.toFixed(o))):t),r={h:t,s:e,v:o,a:n,toHSVA(){const t=[r.h,r.s,r.v,r.a];return t.toString=i(t,t=>"hsva(".concat(t[0],", ").concat(t[1],"%, ").concat(t[2],"%, ").concat(r.a,")")),t},toHSLA(){const t=[..._(r.h,r.s,r.v),r.a];return t.toString=i(t,t=>"hsla(".concat(t[0],", ").concat(t[1],"%, ").concat(t[2],"%, ").concat(r.a,")")),t},toRGBA(){const t=[...g(r.h,r.s,r.v),r.a];return t.toString=i(t,t=>"rgba(".concat(t[0],", ").concat(t[1],", ").concat(t[2],", ").concat(r.a,")")),t},toCMYK(){const t=function(t,e,o){const n=g(t,e,o),i=n[0]/255,r=n[1]/255,s=n[2]/255;let c,a,l,p;return[100*(a=1===(c=m(1-i,1-r,1-s))?0:(1-i-c)/(1-c)),100*(l=1===c?0:(1-r-c)/(1-c)),100*(p=1===c?0:(1-s-c)/(1-c)),100*c]}(r.h,r.s,r.v);return t.toString=i(t,t=>"cmyk(".concat(t[0],"%, ").concat(t[1],"%, ").concat(t[2],"%, ").concat(t[3],"%)")),t},toHEXA(){const t=function(t,e,o){return g(t,e,o).map(t=>y(t).toString(16).padStart(2,"0"))}(r.h,r.s,r.v),e=r.a>=1?"":Number((255*r.a).toFixed(0)).toString(16).toUpperCase().padStart(2,"0");return e&&t.push(e),t.toString=()=>"#".concat(t.join("").toUpperCase()),t},clone:()=>S(r.h,r.s,r.v,r.a)};return r}const j=t=>Math.max(Math.min(t,1),0);function P(t){const e={options:Object.assign({lock:null,onchange:()=>0,onstop:()=>0},t),_tapstart(t){c(document,["mouseup","touchend","touchcancel"],e._tapstop),c(document,["mousemove","touchmove"],e._tapmove),t.preventDefault(),e._tapmove(t)},_tapmove(t){const{options:{lock:n},cache:i}=e,{element:r,wrapper:s}=o,c=s.getBoundingClientRect();let a=0,l=0;if(t){const e=t&&t.touches&&t.touches[0];a=t?(e||t).clientX:0,l=t?(e||t).clientY:0,ac.left+c.width&&(a=c.left+c.width),lc.top+c.height&&(l=c.top+c.height),a-=c.left,l-=c.top}else i&&(a=i.x*c.width,l=i.y*c.height);"h"!==n&&(r.style.left="calc(".concat(a/c.width*100,"% - ").concat(r.offsetWidth/2,"px)")),"v"!==n&&(r.style.top="calc(".concat(l/c.height*100,"% - ").concat(r.offsetHeight/2,"px)")),e.cache={x:a/c.width,y:l/c.height};const p=j(a/s.offsetWidth),u=j(l/s.offsetHeight);switch(n){case"v":return o.onchange(p);case"h":return o.onchange(u);default:return o.onchange(p,u)}},_tapstop(){e.options.onstop(),a(document,["mouseup","touchend","touchcancel"],e._tapstop),a(document,["mousemove","touchmove"],e._tapmove)},trigger(){e._tapmove()},update(t=0,o=0){const{left:n,top:i,width:r,height:s}=e.options.wrapper.getBoundingClientRect();"h"===e.options.lock&&(o=t),e._tapmove({clientX:n+r*t,clientY:i+s*o})},destroy(){const{options:t,_tapstart:o}=e;a([t.wrapper,t.element],"mousedown",o),a([t.wrapper,t.element],"touchstart",o,{passive:!1})}},{options:o,_tapstart:n}=e;return c([o.wrapper,o.element],"mousedown",n),c([o.wrapper,o.element],"touchstart",n,{passive:!1}),e}function L(t={}){t=Object.assign({onchange:()=>0,className:"",elements:[]},t);const e=c(t.elements,"click",e=>{t.elements.forEach(o=>o.classList[e.target===o?"add":"remove"](t.className)),t.onchange(e)});return{destroy:()=>a(...e)}}function x({el:t,reference:e,padding:o=8}){const n={start:"sme",middle:"mse",end:"ems"},i={top:"tbrl",right:"rltb",bottom:"btrl",left:"lrbt"},r=((t={})=>(e,o=t[e])=>{if(o)return o;const[n,i="middle"]=e.split("-"),r="top"===n||"bottom"===n;return t[e]={position:n,variant:i,isVertical:r}})();return{update(s){const{position:c,variant:a,isVertical:l}=r(s),p=e.getBoundingClientRect(),u=t.getBoundingClientRect(),h=t=>t?{t:p.top-u.height-o,b:p.bottom+o}:{r:p.right+o,l:p.left-u.width-o},d=t=>t?{s:p.left+p.width-u.width,m:-u.width/2+(p.left+p.width/2),e:p.left}:{s:p.bottom-u.height,m:p.bottom-p.height/2-u.height/2,e:p.bottom-p.height},f={};function m(e,o,n){const i="top"===n,r=i?u.height:u.width,s=window[i?"innerHeight":"innerWidth"];for(const i of e){const e=o[i],c=f[n]="".concat(e,"px");if(e>0&&e+r{const c=t=>t?"":'style="display:none" hidden',a=h('\n
\n\n '.concat(o?"":'','\n\n
\n
\n
\n \n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n
\n\n
\n\n
\n \n\n \n \n \n \n \n\n \n \n \n
\n
\n
\n ")),l=a.interaction;return l.options.find(t=>!t.hidden&&!t.classList.add("active")),l.type=()=>l.options.find(t=>t.classList.contains("active")),a};function B(t,e,o){return e in t?Object.defineProperty(t,e,{value:o,enumerable:!0,configurable:!0,writable:!0}):t[e]=o,t}class R{constructor(t){B(this,"_initializingActive",!0),B(this,"_recalc",!0),B(this,"_color",S()),B(this,"_lastColor",S()),B(this,"_swatchColors",[]),B(this,"_eventListener",{init:[],save:[],hide:[],show:[],clear:[],change:[],changestop:[],cancel:[],swatchselect:[]}),this.options=t=Object.assign({appClass:null,theme:"classic",useAsButton:!1,disabled:!1,comparison:!0,closeOnScroll:!1,outputPrecision:0,lockOpacity:!1,autoReposition:!0,components:{interaction:{}},strings:{},swatches:null,inline:!1,sliders:null,default:"#42445a",defaultRepresentation:null,position:"bottom-middle",adjustableNumbers:!0,showAlways:!1,closeWithKey:"Escape"},t);const{swatches:e,inline:o,components:n,theme:i,sliders:r,lockOpacity:s}=t;["nano","monolith"].includes(i)&&!r&&(t.sliders="h"),n.interaction||(n.interaction={});const{preview:c,opacity:a,hue:l,palette:p}=n;n.opacity=!s&&a,n.palette=p||c||a||l,o&&(t.showAlways=!0),this._preBuild(),this._buildComponents(),this._bindEvents(),this._finalBuild(),e&&e.length&&e.forEach(t=>this.addSwatch(t)),this._nanopop=x({reference:this._root.button,el:this._root.app});const{app:u}=this._root,h=this;requestAnimationFrame(function e(){if(!u.offsetWidth&&u.parentElement!==document.body)return requestAnimationFrame(e);h.setColor(t.default),h._rePositioningPicker(),t.defaultRepresentation&&(h._representation=t.defaultRepresentation,h.setColorRepresentation(h._representation)),t.showAlways&&h.show(),h._initializingActive=!1,h._emit("init")})}_preBuild(){const t=this.options;"string"==typeof t.el&&(t.el=t.el.split(/>>/g).reduce((t,e,o,n)=>(t=t.querySelector(e),ot._emit("changestop",t),onchange(o,n){if(!e.palette)return;const{_color:i,_root:r,options:s}=t;t._recalc&&(i.s=100*o,i.v=100-100*n,i.v<0&&(i.v=0),t._updateOutput());let c=i.toRGBA().toString(0);this.element.style.background=c,this.wrapper.style.background="\n linear-gradient(to top, rgba(0, 0, 0, ".concat(i.a,"), transparent),\n linear-gradient(to left, hsla(").concat(i.h,", 100%, 50%, ").concat(i.a,"), rgba(255, 255, 255, ").concat(i.a,"))\n "),s.comparison||(r.button.style.color=c,s.useAsButton||(r.preview.lastColor.style.color=c)),r.preview.currentColor.style.color=c,t.options.comparison||r.button.classList.remove("clear")}}),hue:P({lock:"v"===i?"h":"v",element:t._root.hue.picker,wrapper:t._root.hue.slider,onstop:()=>t._emit("changestop",t),onchange(o){e.hue&&e.palette&&(t._recalc&&(t._color.h=360*o),this.element.style.backgroundColor="hsl(".concat(t._color.h,", 100%, 50%)"),r.palette.trigger())}}),opacity:P({lock:"v"===n?"h":"v",element:t._root.opacity.picker,wrapper:t._root.opacity.slider,onstop:()=>t._emit("changestop",t),onchange(o){e.opacity&&e.palette&&(t._recalc&&(t._color.a=Math.round(100*o)/100),this.element.style.background="rgba(0, 0, 0, ".concat(t._color.a,")"),r.palette.trigger())}}),selectable:L({elements:t._root.interaction.options,className:"active",onchange(e){t._representation=e.target.getAttribute("data-type").toUpperCase(),t._recalc&&t._updateOutput()}})};this._components=r}_bindEvents(){const{_root:t,options:e}=this,o=[c(t.interaction.clear,"click",()=>this._clearColor()),c([t.interaction.cancel,t.preview.lastColor],"click",()=>{this._emit("cancel",this),this.setHSVA(...this._lastColor.toHSVA(),!0)}),c(t.interaction.save,"click",()=>{!this.applyColor()&&!e.showAlways&&this.hide()}),c(t.interaction.result,["keyup","input"],t=>{this.setColor(t.target.value,!0)&&!this._initializingActive&&this._emit("change",this._color),t.stopImmediatePropagation()}),c(t.interaction.result,["focus","blur"],t=>{this._recalc="blur"===t.type,this._recalc&&this._updateOutput()}),c([t.palette.palette,t.palette.picker,t.hue.slider,t.hue.picker,t.opacity.slider,t.opacity.picker],["mousedown","touchstart"],()=>this._recalc=!0)];if(!e.showAlways){const n=e.closeWithKey;o.push(c(t.button,"click",()=>this.isOpen()?this.hide():this.show()),c(document,"keyup",t=>this.isOpen()&&(t.key===n||t.code===n)&&this.hide()),c(document,["touchstart","mousedown"],e=>{this.isOpen()&&!d(e).some(e=>e===t.app||e===t.button)&&this.hide()},{capture:!0}))}if(e.adjustableNumbers){const e={rgba:[255,255,255,1],hsva:[360,100,100,1],hsla:[360,100,100,1],cmyk:[100,100,100,100]};f(t.interaction.result,(t,o,n)=>{const i=e[this.getColorRepresentation().toLowerCase()];if(i){const e=i[n],r=t+(e>=100?1e3*o:o);return r<=0?0:Number((r{n.isOpen()&&(e.closeOnScroll&&n.hide(),null===t?(t=setTimeout(()=>t=null,100),requestAnimationFrame(function e(){n._rePositioningPicker(),null!==t&&requestAnimationFrame(e)})):(clearTimeout(t),t=setTimeout(()=>t=null,100)))},{capture:!0}))}this._eventBindings=o}_rePositioningPicker(){const{options:t}=this;if(!t.inline){const{app:e}=this._root;matchMedia("(max-width: 576px)").matches?Object.assign(e.style,{margin:"auto",height:"".concat(e.getBoundingClientRect().height,"px"),top:0,bottom:0,left:0,right:0}):(Object.assign(e.style,{margin:null,right:null,top:null,bottom:null,left:null,height:null}),this._nanopop.update(t.position))}}_updateOutput(){const{_root:t,_color:e,options:o}=this;if(t.interaction.type()){const n="to".concat(t.interaction.type().getAttribute("data-type"));t.interaction.result.value="function"==typeof e[n]?e[n]().toString(o.outputPrecision):""}!this._initializingActive&&this._recalc&&this._emit("change",e)}_clearColor(t=!1){const{_root:e,options:o}=this;o.useAsButton||(e.button.style.color="rgba(0, 0, 0, 0.15)"),e.button.classList.add("clear"),o.showAlways||this.hide(),this._initializingActive||t||(this._emit("save",null),this._emit("clear",this))}_parseLocalColor(t){const{values:e,type:o,a:n}=O(t),{lockOpacity:i}=this.options,r=void 0!==n&&1!==n;return e&&3===e.length&&(e[3]=void 0),{values:!e||i&&r?null:e,type:o}}_emit(t,...e){this._eventListener[t].forEach(t=>t(...e,this))}on(t,e){return"function"==typeof e&&"string"==typeof t&&t in this._eventListener&&this._eventListener[t].push(e),this}off(t,e){const o=this._eventListener[t];if(o){const t=o.indexOf(e);~t&&o.splice(t,1)}return this}addSwatch(t){const{values:e}=this._parseLocalColor(t);if(e){const{_swatchColors:t,_root:o}=this,n=S(...e),i=p('','\n\n
\n
\n
\n \n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n\n
\n
\n
\n
\n
\n\n
\n\n
\n \n\n \n \n \n \n \n\n \n \n \n
\n
\n \n ")),l=a.interaction;return l.options.find(t=>!t.hidden&&!t.classList.add("active")),l.type=()=>l.options.find(t=>t.classList.contains("active")),a};function B(t,e,o){return e in t?Object.defineProperty(t,e,{value:o,enumerable:!0,configurable:!0,writable:!0}):t[e]=o,t}class R{constructor(t){B(this,"_initializingActive",!0),B(this,"_recalc",!0),B(this,"_color",S()),B(this,"_lastColor",S()),B(this,"_swatchColors",[]),B(this,"_eventListener",{init:[],save:[],hide:[],show:[],clear:[],change:[],changestop:[],cancel:[],swatchselect:[]}),this.options=t=Object.assign({appClass:null,theme:"classic",useAsButton:!1,disabled:!1,comparison:!0,closeOnScroll:!1,outputPrecision:0,lockOpacity:!1,autoReposition:!0,components:{interaction:{}},strings:{},swatches:null,inline:!1,sliders:null,default:"#42445a",defaultRepresentation:null,position:"bottom-middle",adjustableNumbers:!0,showAlways:!1,closeWithKey:"Escape"},t);const{swatches:e,inline:o,components:n,theme:i,sliders:r,lockOpacity:s}=t;["nano","monolith"].includes(i)&&!r&&(t.sliders="h"),n.interaction||(n.interaction={});const{preview:c,opacity:a,hue:l,palette:p}=n;n.opacity=!s&&a,n.palette=p||c||a||l,o&&(t.showAlways=!0),this._preBuild(),this._buildComponents(),this._bindEvents(),this._finalBuild(),e&&e.length&&e.forEach(t=>this.addSwatch(t)),this._nanopop=x({reference:this._root.button,el:this._root.app});const{app:u}=this._root,h=this;requestAnimationFrame(function e(){if(!u.offsetWidth&&u.parentElement!==document.body)return requestAnimationFrame(e);h.setColor(t.default),h._rePositioningPicker(),t.defaultRepresentation&&(h._representation=t.defaultRepresentation,h.setColorRepresentation(h._representation)),t.showAlways&&h.show(),h._initializingActive=!1,h._emit("init")})}_preBuild(){const t=this.options;"string"==typeof t.el&&(t.el=t.el.split(/>>/g).reduce((t,e,o,n)=>(t=t.querySelector(e),ot._emit("changestop",t),onchange(o,n){if(!e.palette)return;const{_color:i,_root:r,options:s}=t;t._recalc&&(i.s=100*o,i.v=100-100*n,i.v<0&&(i.v=0),t._updateOutput());let c=i.toRGBA().toString(0);this.element.style.background=c,this.wrapper.style.background="\n linear-gradient(to top, rgba(0, 0, 0, ".concat(i.a,"), transparent),\n linear-gradient(to left, hsla(").concat(i.h,", 100%, 50%, ").concat(i.a,"), rgba(255, 255, 255, ").concat(i.a,"))\n "),s.comparison||(r.button.style.color=c,s.useAsButton||(r.preview.lastColor.style.color=c)),r.preview.currentColor.style.color=c,t.options.comparison||r.button.classList.remove("clear")}}),hue:P({lock:"v"===i?"h":"v",element:t._root.hue.picker,wrapper:t._root.hue.slider,onstop:()=>t._emit("changestop",t),onchange(o){e.hue&&e.palette&&(t._recalc&&(t._color.h=360*o),this.element.style.backgroundColor="hsl(".concat(t._color.h,", 100%, 50%)"),r.palette.trigger())}}),opacity:P({lock:"v"===n?"h":"v",element:t._root.opacity.picker,wrapper:t._root.opacity.slider,onstop:()=>t._emit("changestop",t),onchange(o){e.opacity&&e.palette&&(t._recalc&&(t._color.a=Math.round(100*o)/100),this.element.style.background="rgba(0, 0, 0, ".concat(t._color.a,")"),r.palette.trigger())}}),selectable:L({elements:t._root.interaction.options,className:"active",onchange(e){t._representation=e.target.getAttribute("data-type").toUpperCase(),t._recalc&&t._updateOutput()}})};this._components=r}_bindEvents(){const{_root:t,options:e}=this,o=[c(t.interaction.clear,"click",()=>this._clearColor()),c([t.interaction.cancel,t.preview.lastColor],"click",()=>{this._emit("cancel",this),this.setHSVA(...this._lastColor.toHSVA(),!0)}),c(t.interaction.save,"click",()=>{!this.applyColor()&&!e.showAlways&&this.hide()}),c(t.interaction.result,["keyup","input"],t=>{this.setColor(t.target.value,!0)&&!this._initializingActive&&this._emit("change",this._color),t.stopImmediatePropagation()}),c(t.interaction.result,["focus","blur"],t=>{this._recalc="blur"===t.type,this._recalc&&this._updateOutput()}),c([t.palette.palette,t.palette.picker,t.hue.slider,t.hue.picker,t.opacity.slider,t.opacity.picker],["mousedown","touchstart"],()=>this._recalc=!0)];if(!e.showAlways){const n=e.closeWithKey;o.push(c(t.button,"click",()=>this.isOpen()?this.hide():this.show()),c(document,"keyup",t=>this.isOpen()&&(t.key===n||t.code===n)&&this.hide()),c(document,["touchstart","mousedown"],e=>{this.isOpen()&&!d(e).some(e=>e===t.app||e===t.button)&&this.hide()},{capture:!0}))}if(e.adjustableNumbers){const e={rgba:[255,255,255,1],hsva:[360,100,100,1],hsla:[360,100,100,1],cmyk:[100,100,100,100]};f(t.interaction.result,(t,o,n)=>{const i=e[this.getColorRepresentation().toLowerCase()];if(i){const e=i[n],r=t+(e>=100?1e3*o:o);return r<=0?0:Number((r{n.isOpen()&&(e.closeOnScroll&&n.hide(),null===t?(t=setTimeout(()=>t=null,100),requestAnimationFrame(function e(){n._rePositioningPicker(),null!==t&&requestAnimationFrame(e)})):(clearTimeout(t),t=setTimeout(()=>t=null,100)))},{capture:!0}))}this._eventBindings=o}_rePositioningPicker(){const{options:t}=this;if(!t.inline){const{app:e}=this._root;matchMedia("(max-width: 576px)").matches?Object.assign(e.style,{margin:"auto",height:"".concat(e.getBoundingClientRect().height,"px"),top:0,bottom:0,left:0,right:0}):(Object.assign(e.style,{margin:null,right:null,top:null,bottom:null,left:null,height:null}),this._nanopop.update(t.position))}}_updateOutput(){const{_root:t,_color:e,options:o}=this;if(t.interaction.type()){const n="to".concat(t.interaction.type().getAttribute("data-type"));t.interaction.result.value="function"==typeof e[n]?e[n]().toString(o.outputPrecision):""}!this._initializingActive&&this._recalc&&this._emit("change",e)}_clearColor(t=!1){const{_root:e,options:o}=this;o.useAsButton||(e.button.style.color="rgba(0, 0, 0, 0.15)"),e.button.classList.add("clear"),o.showAlways||this.hide(),this._initializingActive||t||(this._emit("save",null),this._emit("clear",this))}_parseLocalColor(t){const{values:e,type:o,a:n}=O(t),{lockOpacity:i}=this.options,r=void 0!==n&&1!==n;return e&&3===e.length&&(e[3]=void 0),{values:!e||i&&r?null:e,type:o}}_emit(t,...e){this._eventListener[t].forEach(t=>t(...e,this))}on(t,e){return"function"==typeof e&&"string"==typeof t&&t in this._eventListener&&this._eventListener[t].push(e),this}off(t,e){const o=this._eventListener[t];if(o){const t=o.indexOf(e);~t&&o.splice(t,1)}return this}addSwatch(t){const{values:e}=this._parseLocalColor(t);if(e){const{_swatchColors:t,_root:o}=this,n=S(...e),i=p(''}\r\n\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n `);\r\n\r\n const int = root.interaction;\r\n\r\n // Select option which is not hidden\r\n int.options.find(o => !o.hidden && !o.classList.add('active'));\r\n\r\n // Create method to find currenlty active option\r\n int.type = () => int.options.find(e => e.classList.contains('active'));\r\n return root;\r\n}\r\n","// Import utils\nimport * as _ from './utils/utils';\nimport {parseToHSVA} from './utils/color';\n\n// Import classes\nimport {HSVaColor} from './utils/hsvacolor';\nimport Moveable from './libs/moveable';\nimport Selectable from './libs/selectable';\nimport Nanopop from './libs/nanopop';\nimport buildPickr from './template';\n\nclass Pickr {\n\n // Will be used to prevent specific actions during initilization\n _initializingActive = true;\n\n // If the current color value should be recalculated\n _recalc = true;\n\n // Current and last color for comparison\n _color = HSVaColor();\n _lastColor = HSVaColor();\n _swatchColors = [];\n\n // Evenlistener name: [callbacks]\n _eventListener = {\n init: [],\n save: [],\n hide: [],\n show: [],\n clear: [],\n change: [],\n changestop: [],\n cancel: [],\n swatchselect: []\n };\n\n constructor(opt) {\n\n // Assign default values\n this.options = opt = Object.assign({\n appClass: null,\n theme: 'classic',\n useAsButton: false,\n disabled: false,\n comparison: true,\n closeOnScroll: false,\n outputPrecision: 0,\n lockOpacity: false,\n autoReposition: true,\n\n components: {\n interaction: {}\n },\n\n strings: {},\n swatches: null,\n inline: false,\n sliders: null,\n\n default: '#42445a',\n defaultRepresentation: null,\n position: 'bottom-middle',\n adjustableNumbers: true,\n showAlways: false,\n\n closeWithKey: 'Escape'\n }, opt);\n\n const {swatches, inline, components, theme, sliders, lockOpacity} = opt;\n\n if (['nano', 'monolith'].includes(theme) && !sliders) {\n opt.sliders = 'h';\n }\n\n // Check interaction section\n if (!components.interaction) {\n components.interaction = {};\n }\n\n // Overwrite palette if preview, opacity or hue are true\n const {preview, opacity, hue, palette} = components;\n components.opacity = (!lockOpacity && opacity);\n components.palette = palette || preview || opacity || hue;\n\n // Per default enabled if inline\n if (inline) {\n opt.showAlways = true;\n }\n\n // Initialize picker\n this._preBuild();\n this._buildComponents();\n this._bindEvents();\n this._finalBuild();\n\n // Append pre-defined swatch colors\n if (swatches && swatches.length) {\n swatches.forEach(color => this.addSwatch(color));\n }\n\n // Initialize positioning engine\n this._nanopop = Nanopop({\n reference: this._root.button,\n el: this._root.app\n });\n\n // Initilization is finish, pickr is visible and ready for usage\n const {app} = this._root;\n const that = this;\n requestAnimationFrame((function cb() {\n\n if (!app.offsetWidth && app.parentElement !== document.body) {\n return requestAnimationFrame(cb);\n }\n\n // Apply default color\n that.setColor(opt.default);\n that._rePositioningPicker();\n\n // Initialize color representation\n if (opt.defaultRepresentation) {\n that._representation = opt.defaultRepresentation;\n that.setColorRepresentation(that._representation);\n }\n\n // Show pickr if locked\n if (opt.showAlways) {\n that.show();\n }\n\n // Initialization is done - pickr is usable, fire init event\n that._initializingActive = false;\n that._emit('init');\n }));\n }\n\n // Does only the absolutly basic thing to initialize the components\n _preBuild() {\n const opt = this.options;\n\n // Check if element is selector\n if (typeof opt.el === 'string') {\n\n // Resolve possible shadow dom access\n opt.el = opt.el.split(/>>/g).reduce((pv, cv, ci, a) => {\n pv = pv.querySelector(cv);\n return ci < a.length - 1 ? pv.shadowRoot : pv;\n }, document);\n }\n\n // Create element and append it to body to\n // prevent initialization errors\n this._root = buildPickr(opt);\n\n // Check if a custom button is used\n if (opt.useAsButton) {\n this._root.button = opt.el; // Replace button with customized button\n }\n\n document.body.appendChild(this._root.root);\n }\n\n _finalBuild() {\n const opt = this.options;\n const root = this._root;\n\n // Remove from body\n document.body.removeChild(root.root);\n\n if (opt.inline) {\n const parent = opt.el.parentElement;\n\n if (opt.el.nextSibling) {\n parent.insertBefore(root.app, opt.el.nextSibling);\n } else {\n parent.appendChild(root.app);\n }\n } else {\n document.body.appendChild(root.app);\n }\n\n // Don't replace the the element if a custom button is used\n if (!opt.useAsButton) {\n\n // Replace element with actual color-picker\n opt.el.parentNode.replaceChild(root.root, opt.el);\n } else if (opt.inline) {\n opt.el.remove();\n }\n\n // Check if it should be immediatly disabled\n if (opt.disabled) {\n this.disable();\n }\n\n // Check if color comparison is disabled, if yes - remove transitions so everything keeps smoothly\n if (!opt.comparison) {\n root.button.style.transition = 'none';\n if (!opt.useAsButton) {\n root.preview.lastColor.style.transition = 'none';\n }\n }\n\n this.hide();\n }\n\n _buildComponents() {\n\n // Instance reference\n const inst = this;\n const cs = this.options.components;\n const sliders = (inst.options.sliders || 'v').repeat(2);\n const [so, sh] = sliders.match(/^[vh]+$/g) ? sliders : [];\n\n const components = {\n\n palette: Moveable({\n element: inst._root.palette.picker,\n wrapper: inst._root.palette.palette,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(x, y) {\n if (!cs.palette) return;\n const {_color, _root, options} = inst;\n\n // Update the input field only if the user is currently not typing\n if (inst._recalc) {\n\n // Calculate saturation based on the position\n _color.s = x * 100;\n\n // Calculate the value\n _color.v = 100 - y * 100;\n\n // Prevent falling under zero\n _color.v < 0 ? _color.v = 0 : 0;\n inst._updateOutput();\n }\n\n // Set picker and gradient color\n let cssRGBaString = _color.toRGBA().toString(0);\n this.element.style.background = cssRGBaString;\n this.wrapper.style.background = `\n linear-gradient(to top, rgba(0, 0, 0, ${_color.a}), transparent),\n linear-gradient(to left, hsla(${_color.h}, 100%, 50%, ${_color.a}), rgba(255, 255, 255, ${_color.a}))\n `;\n\n // Check if color is locked\n if (!options.comparison) {\n _root.button.style.color = cssRGBaString;\n\n if (!options.useAsButton) {\n _root.preview.lastColor.style.color = cssRGBaString;\n }\n }\n\n // Change current color\n _root.preview.currentColor.style.color = cssRGBaString;\n\n if (!inst.options.comparison) {\n\n // If the user changes the color, remove the cleared icon\n _root.button.classList.remove('clear');\n }\n }\n }),\n\n hue: Moveable({\n lock: sh === 'v' ? 'h' : 'v',\n element: inst._root.hue.picker,\n wrapper: inst._root.hue.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.hue || !cs.palette) return;\n\n // Calculate hue\n if (inst._recalc) {\n inst._color.h = v * 360;\n }\n\n // Update color\n this.element.style.backgroundColor = `hsl(${inst._color.h}, 100%, 50%)`;\n components.palette.trigger();\n }\n }),\n\n opacity: Moveable({\n lock: so === 'v' ? 'h' : 'v',\n element: inst._root.opacity.picker,\n wrapper: inst._root.opacity.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.opacity || !cs.palette) return;\n\n // Calculate opacity\n if (inst._recalc) {\n inst._color.a = Math.round(v * 1e2) / 100;\n }\n\n // Update color\n this.element.style.background = `rgba(0, 0, 0, ${inst._color.a})`;\n components.palette.trigger();\n }\n }),\n\n selectable: Selectable({\n elements: inst._root.interaction.options,\n className: 'active',\n\n onchange(e) {\n inst._representation = e.target.getAttribute('data-type').toUpperCase();\n inst._recalc && inst._updateOutput();\n }\n })\n };\n\n this._components = components;\n }\n\n _bindEvents() {\n const {_root, options} = this;\n\n const eventBindings = [\n\n // Clear color\n _.on(_root.interaction.clear, 'click', () => this._clearColor()),\n\n // Select last color on click\n _.on([\n _root.interaction.cancel,\n _root.preview.lastColor\n ], 'click', () => {\n this._emit('cancel', this);\n this.setHSVA(...this._lastColor.toHSVA(), true);\n }),\n\n // Save color\n _.on(_root.interaction.save, 'click', () => {\n !this.applyColor() && !options.showAlways && this.hide();\n }),\n\n _.on(_root.interaction.result, ['keyup', 'input'], e => {\n\n // Fire listener if initialization is finish and changed color was valid\n if (this.setColor(e.target.value, true) && !this._initializingActive) {\n this._emit('change', this._color);\n }\n\n e.stopImmediatePropagation();\n }),\n\n // Detect user input and disable auto-recalculation\n _.on(_root.interaction.result, ['focus', 'blur'], e => {\n this._recalc = e.type === 'blur';\n this._recalc && this._updateOutput();\n }),\n\n // Cancel input detection on color change\n _.on([\n _root.palette.palette,\n _root.palette.picker,\n _root.hue.slider,\n _root.hue.picker,\n _root.opacity.slider,\n _root.opacity.picker\n ], ['mousedown', 'touchstart'], () => this._recalc = true)\n ];\n\n // Provide hiding / showing abilities only if showAlways is false\n if (!options.showAlways) {\n const ck = options.closeWithKey;\n\n eventBindings.push(\n // Save and hide / show picker\n _.on(_root.button, 'click', () => this.isOpen() ? this.hide() : this.show()),\n\n // Close with escape key\n _.on(document, 'keyup', e => this.isOpen() && (e.key === ck || e.code === ck) && this.hide()),\n\n // Cancel selecting if the user taps behind the color picker\n _.on(document, ['touchstart', 'mousedown'], e => {\n if (this.isOpen() && !_.eventPath(e).some(el => el === _root.app || el === _root.button)) {\n this.hide();\n }\n }, {capture: true})\n );\n }\n\n // Make input adjustable if enabled\n if (options.adjustableNumbers) {\n const ranges = {\n rgba: [255, 255, 255, 1],\n hsva: [360, 100, 100, 1],\n hsla: [360, 100, 100, 1],\n cmyk: [100, 100, 100, 100]\n };\n\n _.adjustableInputNumbers(_root.interaction.result, (o, step, index) => {\n const range = ranges[this.getColorRepresentation().toLowerCase()];\n\n if (range) {\n const max = range[index];\n\n // Calculate next reasonable number\n const nv = o + (max >= 100 ? step * 1000 : step);\n\n // Apply range of zero up to max, fix floating-point issues\n return nv <= 0 ? 0 : Number((nv < max ? nv : max).toPrecision(3));\n } else {\n return o;\n }\n });\n }\n\n if (options.autoReposition && !options.inline) {\n let timeout = null;\n const that = this;\n\n // Re-calc position on window resize, scroll and wheel\n eventBindings.push(\n _.on(window, ['scroll', 'resize'], () => {\n if (that.isOpen()) {\n\n if (options.closeOnScroll) {\n that.hide();\n }\n\n if (timeout === null) {\n timeout = setTimeout(() => timeout = null, 100);\n\n // Update position on every frame\n requestAnimationFrame(function rs() {\n that._rePositioningPicker();\n (timeout !== null) && requestAnimationFrame(rs);\n });\n } else {\n clearTimeout(timeout);\n timeout = setTimeout(() => timeout = null, 100);\n }\n }\n }, {capture: true})\n );\n }\n\n // Save bindings\n this._eventBindings = eventBindings;\n }\n\n _rePositioningPicker() {\n const {options} = this;\n\n // No repositioning needed if inline\n if (!options.inline) {\n const {app} = this._root;\n\n if (matchMedia('(max-width: 576px)').matches) {\n Object.assign(app.style, {\n margin: 'auto',\n height: `${app.getBoundingClientRect().height}px`,\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n });\n } else {\n Object.assign(app.style, {\n margin: null,\n right: null,\n top: null,\n bottom: null,\n left: null,\n height: null\n });\n\n this._nanopop.update(options.position);\n }\n }\n }\n\n _updateOutput() {\n const {_root, _color, options} = this;\n\n // Check if component is present\n if (_root.interaction.type()) {\n\n // Construct function name and call if present\n const method = `to${_root.interaction.type().getAttribute('data-type')}`;\n _root.interaction.result.value = typeof _color[method] === 'function' ?\n _color[method]().toString(options.outputPrecision) : '';\n }\n\n // Fire listener if initialization is finish\n if (!this._initializingActive && this._recalc) {\n this._emit('change', _color);\n }\n }\n\n _clearColor(silent = false) {\n const {_root, options} = this;\n\n // Change only the button color if it isn't customized\n if (!options.useAsButton) {\n _root.button.style.color = 'rgba(0, 0, 0, 0.15)';\n }\n\n _root.button.classList.add('clear');\n\n if (!options.showAlways) {\n this.hide();\n }\n\n if (!this._initializingActive && !silent) {\n\n // Fire listener\n this._emit('save', null);\n this._emit('clear', this);\n }\n }\n\n _parseLocalColor(str) {\n const {values, type, a} = parseToHSVA(str);\n const {lockOpacity} = this.options;\n const alphaMakesAChange = a !== undefined && a !== 1;\n\n // If no opacity is applied, add undefined at the very end which gets\n // set to 1 in setHSVA\n if (values && values.length === 3) {\n values[3] = undefined;\n }\n\n return {\n values: (!values || (lockOpacity && alphaMakesAChange)) ? null : values,\n type\n };\n }\n\n _emit(event, ...args) {\n this._eventListener[event].forEach(cb => cb(...args, this));\n }\n\n on(event, cb) {\n\n // Validate\n if (typeof cb === 'function' && typeof event === 'string' && event in this._eventListener) {\n this._eventListener[event].push(cb);\n }\n\n return this;\n }\n\n off(event, cb) {\n const callBacks = this._eventListener[event];\n\n if (callBacks) {\n const index = callBacks.indexOf(cb);\n\n if (~index) {\n callBacks.splice(index, 1);\n }\n }\n\n return this;\n }\n\n /**\n * Appends a color to the swatch palette\n * @param color\n * @returns {boolean}\n */\n addSwatch(color) {\n const {values} = this._parseLocalColor(color);\n\n if (values) {\n const {_swatchColors, _root} = this;\n const hsvaColorObject = HSVaColor(...values);\n\n // Create new swatch HTMLElement\n const element = _.createElementFromString(\n `'}\r\n\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n `);\r\n\r\n const int = root.interaction;\r\n\r\n // Select option which is not hidden\r\n int.options.find(o => !o.hidden && !o.classList.add('active'));\r\n\r\n // Create method to find currenlty active option\r\n int.type = () => int.options.find(e => e.classList.contains('active'));\r\n return root;\r\n}\r\n","// Import utils\nimport * as _ from './utils/utils';\nimport {parseToHSVA} from './utils/color';\n\n// Import classes\nimport {HSVaColor} from './utils/hsvacolor';\nimport Moveable from './libs/moveable';\nimport Selectable from './libs/selectable';\nimport Nanopop from './libs/nanopop';\nimport buildPickr from './template';\n\nclass Pickr {\n\n // Will be used to prevent specific actions during initilization\n _initializingActive = true;\n\n // If the current color value should be recalculated\n _recalc = true;\n\n // Current and last color for comparison\n _color = HSVaColor();\n _lastColor = HSVaColor();\n _swatchColors = [];\n\n // Evenlistener name: [callbacks]\n _eventListener = {\n init: [],\n save: [],\n hide: [],\n show: [],\n clear: [],\n change: [],\n changestop: [],\n cancel: [],\n swatchselect: []\n };\n\n constructor(opt) {\n\n // Assign default values\n this.options = opt = Object.assign({\n appClass: null,\n theme: 'classic',\n useAsButton: false,\n disabled: false,\n comparison: true,\n closeOnScroll: false,\n outputPrecision: 0,\n lockOpacity: false,\n autoReposition: true,\n\n components: {\n interaction: {}\n },\n\n strings: {},\n swatches: null,\n inline: false,\n sliders: null,\n\n default: '#42445a',\n defaultRepresentation: null,\n position: 'bottom-middle',\n adjustableNumbers: true,\n showAlways: false,\n\n closeWithKey: 'Escape'\n }, opt);\n\n const {swatches, inline, components, theme, sliders, lockOpacity} = opt;\n\n if (['nano', 'monolith'].includes(theme) && !sliders) {\n opt.sliders = 'h';\n }\n\n // Check interaction section\n if (!components.interaction) {\n components.interaction = {};\n }\n\n // Overwrite palette if preview, opacity or hue are true\n const {preview, opacity, hue, palette} = components;\n components.opacity = (!lockOpacity && opacity);\n components.palette = palette || preview || opacity || hue;\n\n // Per default enabled if inline\n if (inline) {\n opt.showAlways = true;\n }\n\n // Initialize picker\n this._preBuild();\n this._buildComponents();\n this._bindEvents();\n this._finalBuild();\n\n // Append pre-defined swatch colors\n if (swatches && swatches.length) {\n swatches.forEach(color => this.addSwatch(color));\n }\n\n // Initialize positioning engine\n this._nanopop = Nanopop({\n reference: this._root.button,\n el: this._root.app\n });\n\n // Initilization is finish, pickr is visible and ready for usage\n const {app} = this._root;\n const that = this;\n requestAnimationFrame((function cb() {\n\n if (!app.offsetWidth && app.parentElement !== document.body) {\n return requestAnimationFrame(cb);\n }\n\n // Apply default color\n that.setColor(opt.default);\n that._rePositioningPicker();\n\n // Initialize color representation\n if (opt.defaultRepresentation) {\n that._representation = opt.defaultRepresentation;\n that.setColorRepresentation(that._representation);\n }\n\n // Show pickr if locked\n if (opt.showAlways) {\n that.show();\n }\n\n // Initialization is done - pickr is usable, fire init event\n that._initializingActive = false;\n that._emit('init');\n }));\n }\n\n // Does only the absolutly basic thing to initialize the components\n _preBuild() {\n const opt = this.options;\n\n // Check if element is selector\n if (typeof opt.el === 'string') {\n\n // Resolve possible shadow dom access\n opt.el = opt.el.split(/>>/g).reduce((pv, cv, ci, a) => {\n pv = pv.querySelector(cv);\n return ci < a.length - 1 ? pv.shadowRoot : pv;\n }, document);\n }\n\n // Create element and append it to body to\n // prevent initialization errors\n this._root = buildPickr(opt);\n\n // Check if a custom button is used\n if (opt.useAsButton) {\n this._root.button = opt.el; // Replace button with customized button\n }\n\n document.body.appendChild(this._root.root);\n }\n\n _finalBuild() {\n const opt = this.options;\n const root = this._root;\n\n // Remove from body\n document.body.removeChild(root.root);\n\n if (opt.inline) {\n const parent = opt.el.parentElement;\n\n if (opt.el.nextSibling) {\n parent.insertBefore(root.app, opt.el.nextSibling);\n } else {\n parent.appendChild(root.app);\n }\n } else {\n document.body.appendChild(root.app);\n }\n\n // Don't replace the the element if a custom button is used\n if (!opt.useAsButton) {\n\n // Replace element with actual color-picker\n opt.el.parentNode.replaceChild(root.root, opt.el);\n } else if (opt.inline) {\n opt.el.remove();\n }\n\n // Check if it should be immediatly disabled\n if (opt.disabled) {\n this.disable();\n }\n\n // Check if color comparison is disabled, if yes - remove transitions so everything keeps smoothly\n if (!opt.comparison) {\n root.button.style.transition = 'none';\n if (!opt.useAsButton) {\n root.preview.lastColor.style.transition = 'none';\n }\n }\n\n this.hide();\n }\n\n _buildComponents() {\n\n // Instance reference\n const inst = this;\n const cs = this.options.components;\n const sliders = (inst.options.sliders || 'v').repeat(2);\n const [so, sh] = sliders.match(/^[vh]+$/g) ? sliders : [];\n\n const components = {\n\n palette: Moveable({\n element: inst._root.palette.picker,\n wrapper: inst._root.palette.palette,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(x, y) {\n if (!cs.palette) return;\n const {_color, _root, options} = inst;\n\n // Update the input field only if the user is currently not typing\n if (inst._recalc) {\n\n // Calculate saturation based on the position\n _color.s = x * 100;\n\n // Calculate the value\n _color.v = 100 - y * 100;\n\n // Prevent falling under zero\n _color.v < 0 ? _color.v = 0 : 0;\n inst._updateOutput();\n }\n\n // Set picker and gradient color\n let cssRGBaString = _color.toRGBA().toString(0);\n this.element.style.background = cssRGBaString;\n this.wrapper.style.background = `\n linear-gradient(to top, rgba(0, 0, 0, ${_color.a}), transparent),\n linear-gradient(to left, hsla(${_color.h}, 100%, 50%, ${_color.a}), rgba(255, 255, 255, ${_color.a}))\n `;\n\n // Check if color is locked\n if (!options.comparison) {\n _root.button.style.color = cssRGBaString;\n\n if (!options.useAsButton) {\n _root.preview.lastColor.style.color = cssRGBaString;\n }\n }\n\n // Change current color\n _root.preview.currentColor.style.color = cssRGBaString;\n\n if (!inst.options.comparison) {\n\n // If the user changes the color, remove the cleared icon\n _root.button.classList.remove('clear');\n }\n }\n }),\n\n hue: Moveable({\n lock: sh === 'v' ? 'h' : 'v',\n element: inst._root.hue.picker,\n wrapper: inst._root.hue.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.hue || !cs.palette) return;\n\n // Calculate hue\n if (inst._recalc) {\n inst._color.h = v * 360;\n }\n\n // Update color\n this.element.style.backgroundColor = `hsl(${inst._color.h}, 100%, 50%)`;\n components.palette.trigger();\n }\n }),\n\n opacity: Moveable({\n lock: so === 'v' ? 'h' : 'v',\n element: inst._root.opacity.picker,\n wrapper: inst._root.opacity.slider,\n\n onstop: () => inst._emit('changestop', inst),\n onchange(v) {\n if (!cs.opacity || !cs.palette) return;\n\n // Calculate opacity\n if (inst._recalc) {\n inst._color.a = Math.round(v * 1e2) / 100;\n }\n\n // Update color\n this.element.style.background = `rgba(0, 0, 0, ${inst._color.a})`;\n components.palette.trigger();\n }\n }),\n\n selectable: Selectable({\n elements: inst._root.interaction.options,\n className: 'active',\n\n onchange(e) {\n inst._representation = e.target.getAttribute('data-type').toUpperCase();\n inst._recalc && inst._updateOutput();\n }\n })\n };\n\n this._components = components;\n }\n\n _bindEvents() {\n const {_root, options} = this;\n\n const eventBindings = [\n\n // Clear color\n _.on(_root.interaction.clear, 'click', () => this._clearColor()),\n\n // Select last color on click\n _.on([\n _root.interaction.cancel,\n _root.preview.lastColor\n ], 'click', () => {\n this._emit('cancel', this);\n this.setHSVA(...this._lastColor.toHSVA(), true);\n }),\n\n // Save color\n _.on(_root.interaction.save, 'click', () => {\n !this.applyColor() && !options.showAlways && this.hide();\n }),\n\n _.on(_root.interaction.result, ['keyup', 'input'], e => {\n\n // Fire listener if initialization is finish and changed color was valid\n if (this.setColor(e.target.value, true) && !this._initializingActive) {\n this._emit('change', this._color);\n }\n\n e.stopImmediatePropagation();\n }),\n\n // Detect user input and disable auto-recalculation\n _.on(_root.interaction.result, ['focus', 'blur'], e => {\n this._recalc = e.type === 'blur';\n this._recalc && this._updateOutput();\n }),\n\n // Cancel input detection on color change\n _.on([\n _root.palette.palette,\n _root.palette.picker,\n _root.hue.slider,\n _root.hue.picker,\n _root.opacity.slider,\n _root.opacity.picker\n ], ['mousedown', 'touchstart'], () => this._recalc = true)\n ];\n\n // Provide hiding / showing abilities only if showAlways is false\n if (!options.showAlways) {\n const ck = options.closeWithKey;\n\n eventBindings.push(\n // Save and hide / show picker\n _.on(_root.button, 'click', () => this.isOpen() ? this.hide() : this.show()),\n\n // Close with escape key\n _.on(document, 'keyup', e => this.isOpen() && (e.key === ck || e.code === ck) && this.hide()),\n\n // Cancel selecting if the user taps behind the color picker\n _.on(document, ['touchstart', 'mousedown'], e => {\n if (this.isOpen() && !_.eventPath(e).some(el => el === _root.app || el === _root.button)) {\n this.hide();\n }\n }, {capture: true})\n );\n }\n\n // Make input adjustable if enabled\n if (options.adjustableNumbers) {\n const ranges = {\n rgba: [255, 255, 255, 1],\n hsva: [360, 100, 100, 1],\n hsla: [360, 100, 100, 1],\n cmyk: [100, 100, 100, 100]\n };\n\n _.adjustableInputNumbers(_root.interaction.result, (o, step, index) => {\n const range = ranges[this.getColorRepresentation().toLowerCase()];\n\n if (range) {\n const max = range[index];\n\n // Calculate next reasonable number\n const nv = o + (max >= 100 ? step * 1000 : step);\n\n // Apply range of zero up to max, fix floating-point issues\n return nv <= 0 ? 0 : Number((nv < max ? nv : max).toPrecision(3));\n } else {\n return o;\n }\n });\n }\n\n if (options.autoReposition && !options.inline) {\n let timeout = null;\n const that = this;\n\n // Re-calc position on window resize, scroll and wheel\n eventBindings.push(\n _.on(window, ['scroll', 'resize'], () => {\n if (that.isOpen()) {\n\n if (options.closeOnScroll) {\n that.hide();\n }\n\n if (timeout === null) {\n timeout = setTimeout(() => timeout = null, 100);\n\n // Update position on every frame\n requestAnimationFrame(function rs() {\n that._rePositioningPicker();\n (timeout !== null) && requestAnimationFrame(rs);\n });\n } else {\n clearTimeout(timeout);\n timeout = setTimeout(() => timeout = null, 100);\n }\n }\n }, {capture: true})\n );\n }\n\n // Save bindings\n this._eventBindings = eventBindings;\n }\n\n _rePositioningPicker() {\n const {options} = this;\n\n // No repositioning needed if inline\n if (!options.inline) {\n const {app} = this._root;\n\n if (matchMedia('(max-width: 576px)').matches) {\n Object.assign(app.style, {\n margin: 'auto',\n height: `${app.getBoundingClientRect().height}px`,\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n });\n } else {\n Object.assign(app.style, {\n margin: null,\n right: null,\n top: null,\n bottom: null,\n left: null,\n height: null\n });\n\n this._nanopop.update(options.position);\n }\n }\n }\n\n _updateOutput() {\n const {_root, _color, options} = this;\n\n // Check if component is present\n if (_root.interaction.type()) {\n\n // Construct function name and call if present\n const method = `to${_root.interaction.type().getAttribute('data-type')}`;\n _root.interaction.result.value = typeof _color[method] === 'function' ?\n _color[method]().toString(options.outputPrecision) : '';\n }\n\n // Fire listener if initialization is finish\n if (!this._initializingActive && this._recalc) {\n this._emit('change', _color);\n }\n }\n\n _clearColor(silent = false) {\n const {_root, options} = this;\n\n // Change only the button color if it isn't customized\n if (!options.useAsButton) {\n _root.button.style.color = 'rgba(0, 0, 0, 0.15)';\n }\n\n _root.button.classList.add('clear');\n\n if (!options.showAlways) {\n this.hide();\n }\n\n if (!this._initializingActive && !silent) {\n\n // Fire listener\n this._emit('save', null);\n this._emit('clear', this);\n }\n }\n\n _parseLocalColor(str) {\n const {values, type, a} = parseToHSVA(str);\n const {lockOpacity} = this.options;\n const alphaMakesAChange = a !== undefined && a !== 1;\n\n // If no opacity is applied, add undefined at the very end which gets\n // set to 1 in setHSVA\n if (values && values.length === 3) {\n values[3] = undefined;\n }\n\n return {\n values: (!values || (lockOpacity && alphaMakesAChange)) ? null : values,\n type\n };\n }\n\n _emit(event, ...args) {\n this._eventListener[event].forEach(cb => cb(...args, this));\n }\n\n on(event, cb) {\n\n // Validate\n if (typeof cb === 'function' && typeof event === 'string' && event in this._eventListener) {\n this._eventListener[event].push(cb);\n }\n\n return this;\n }\n\n off(event, cb) {\n const callBacks = this._eventListener[event];\n\n if (callBacks) {\n const index = callBacks.indexOf(cb);\n\n if (~index) {\n callBacks.splice(index, 1);\n }\n }\n\n return this;\n }\n\n /**\n * Appends a color to the swatch palette\n * @param color\n * @returns {boolean}\n */\n addSwatch(color) {\n const {values} = this._parseLocalColor(color);\n\n if (values) {\n const {_swatchColors, _root} = this;\n const hsvaColorObject = HSVaColor(...values);\n\n // Create new swatch HTMLElement\n const element = _.createElementFromString(\n `