diff --git a/CHANGELOG.md b/CHANGELOG.md index a0d3a98..ead8d02 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # Changelog +## [6.0.0] - 2026-03-01 + +- Complete refactoring of the library and how the color conversion is managed +- Fix conversions round trip +- Fix a bug in CMYK to RGB conversion + ## [5.0.0] - 2025-06-06 - Add support for HWB colors (hue, whiteness and blackness) diff --git a/dist/web/colortranslator.js b/dist/web/colortranslator.js index 0d71a8c..ff9ab91 100644 --- a/dist/web/colortranslator.js +++ b/dist/web/colortranslator.js @@ -1 +1 @@ -var colortranslator=function(t){"use strict";const e=255,s=100,r=125,a=150;var i,n,c,o;!function(t){t.HEX="HEX",t.RGB="RGB",t.HWB="HWB",t.HSL="HSL",t.CIELab="CIELab",t.LCH="LCH",t.CMYK="CMYK"}(i||(i={})),t.Harmony=void 0,(n=t.Harmony||(t.Harmony={})).ANALOGOUS="ANALOGOUS",n.COMPLEMENTARY="COMPLEMENTARY",n.SPLIT_COMPLEMENTARY="SPLIT_COMPLEMENTARY",n.TRIADIC="TRIADIC",n.TETRADIC="TETRADIC",n.SQUARE="SQUARE",t.Mix=void 0,(c=t.Mix||(t.Mix={})).ADDITIVE="ADDITIVE",c.SUBTRACTIVE="SUBTRACTIVE",function(t){t.black="#000000",t.silver="#C0C0C0",t.gray="#808080",t.white="#FFFFFF",t.maroon="#800000",t.red="#FF0000",t.purple="#800080",t.fuchsia="#FF00FF",t.green="#008000",t.lime="#00FF00",t.olive="#808000",t.yellow="#FFFF00",t.navy="#000080",t.blue="#0000FF",t.teal="#008080",t.aqua="#00FFFF",t.orange="#FFA500",t.aliceblue="#F0F8FF",t.antiquewhite="#FAEBD7",t.aquamarine="#7FFFD4",t.azure="#F0FFFF",t.beige="#F5F5DC",t.bisque="#FFE4C4",t.blanchedalmond="#FFEBCD",t.blueviolet="#8A2BE2",t.brown="#A52A2A",t.burlywood="#DEB887",t.cadetblue="#5F9EA0",t.chartreuse="#7FFF00",t.chocolate="#D2691E",t.coral="#FF7F50",t.cornflowerblue="#6495ED",t.cornsilk="#FFF8DC",t.crimson="#DC143C",t.cyan="#00FFFF",t.darkblue="#00008B",t.darkcyan="#008B8B",t.darkgoldenrod="#B8860B",t.darkgray="#A9A9A9",t.darkgreen="#006400",t.darkgrey="#A9A9A9",t.darkkhaki="#BDB76B",t.darkmagenta="#8B008B",t.darkolivegreen="#556B2F",t.darkorange="#FF8C00",t.darkorchid="#9932CC",t.darkred="#8B0000",t.darksalmon="#E9967A",t.darkseagreen="#8FBC8F",t.darkslateblue="#483D8B",t.darkslategray="#2F4F4F",t.darkslategrey="#2F4F4F",t.darkturquoise="#00CED1",t.darkviolet="#9400D3",t.deeppink="#FF1493",t.deepskyblue="#00BFFF",t.dimgray="#696969",t.dimgrey="#696969",t.dodgerblue="#1E90FF",t.firebrick="#B22222",t.floralwhite="#FFFAF0",t.forestgreen="#228B22",t.gainsboro="#DCDCDC",t.ghostwhite="#F8F8FF",t.gold="#FFD700",t.goldenrod="#DAA520",t.greenyellow="#ADFF2F",t.grey="#808080",t.honeydew="#F0FFF0",t.hotpink="#FF69B4",t.indianred="#CD5C5C",t.indigo="#4B0082",t.ivory="#FFFFF0",t.khaki="#F0E68C",t.lavender="#E6E6FA",t.lavenderblush="#FFF0F5",t.lawngreen="#7CFC00",t.lemonchiffon="#FFFACD",t.lightblue="#ADD8E6",t.lightcoral="#F08080",t.lightcyan="#E0FFFF",t.lightgoldenrodyellow="#FAFAD2",t.lightgray="#D3D3D3",t.lightgreen="#90EE90",t.lightgrey="#D3D3D3",t.lightpink="#FFB6C1",t.lightsalmon="#FFA07A",t.lightseagreen="#20B2AA",t.lightskyblue="#87CEFA",t.lightslategray="#778899",t.lightslategrey="#778899",t.lightsteelblue="#B0C4DE",t.lightyellow="#FFFFE0",t.limegreen="#32CD32",t.linen="#FAF0E6",t.magenta="#FF00FF",t.mediumaquamarine="#66CDAA",t.mediumblue="#0000CD",t.mediumorchid="#BA55D3",t.mediumpurple="#9370DB",t.mediumseagreen="#3CB371",t.mediumslateblue="#7B68EE",t.mediumspringgreen="#00FA9A",t.mediumturquoise="#48D1CC",t.mediumvioletred="#C71585",t.midnightblue="#191970",t.mintcream="#F5FFFA",t.mistyrose="#FFE4E1",t.moccasin="#FFE4B5",t.navajowhite="#FFDEAD",t.oldlace="#FDF5E6",t.olivedrab="#6B8E23",t.orangered="#FF4500",t.orchid="#DA70D6",t.palegoldenrod="#EEE8AA",t.palegreen="#98FB98",t.paleturquoise="#AFEEEE",t.palevioletred="#DB7093",t.papayawhip="#FFEFD5",t.peachpuff="#FFDAB9",t.peru="#CD853F",t.pink="#FFC0CB",t.plum="#DDA0DD",t.powderblue="#B0E0E6",t.rosybrown="#BC8F8F",t.royalblue="#4169E1",t.saddlebrown="#8B4513",t.salmon="#FA8072",t.sandybrown="#F4A460",t.seagreen="#2E8B57",t.seashell="#FFF5EE",t.sienna="#A0522D",t.skyblue="#87CEEB",t.slateblue="#6A5ACD",t.slategray="#708090",t.slategrey="#708090",t.snow="#FFFAFA",t.springgreen="#00FF7F",t.steelblue="#4682B4",t.tan="#D2B48C",t.thistle="#D8BFD8",t.tomato="#FF6347",t.turquoise="#40E0D0",t.violet="#EE82EE",t.wheat="#F5DEB3",t.whitesmoke="#F5F5F5",t.yellowgreen="#9ACD32",t.rebeccapurple="#663399"}(o||(o={}));const h=Object.keys(o),l={HEX:["R","G","B","A"],RGB:["R","G","B","A"],HSL:["H","S","L","A"],HWB:["H","W","B","A"],CIELab:["L","a","b","A"],LCH:["L","C","H","A"],CMYK:["C","M","Y","K","A"]},u={ABGR:i.RGB,ABHW:i.HWB,ACHL:i.LCH,ACKMY:i.CMYK,AHLS:i.HSL,ALAB:i.CIELab,BGR:i.RGB,BHW:i.HWB,CHL:i.LCH,CKMY:i.CMYK,HLS:i.HSL,LAB:i.CIELab};var d;!function(t){t.NUMBER="number",t.BOOLEAN="boolean"}(d||(d={}));const A={[i.HEX]:/^#(?:(?[a-f\d])(?[a-f\d])(?[a-f\d])(?[a-f\d])?|(?[a-f\d]{2})(?[a-f\d]{2})(?[a-f\d]{2})(?[a-f\d]{2})?)$/i,[i.RGB]:/^rgba?\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)(?:\s*,\s*(?(?:\d*\.)?\d+))?|(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[rgb]|(?:\d*\.)?\d+|calc\([rgb()/*\-+\d.\s]+\)))\s+(?(?:[rgb]|(?:\d*\.)?\d+|calc\([rgb()/*\-+\d.\s]+\)))\s+(?(?:[rgb]|(?:\d*\.)?\d+|calc\([rgb()/*\-+\d.\s]+\)))(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[i.HWB]:/^hwb\s*\(\s*(?:(?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)\s+(?(?:\d*\.)?\d+)%\s+(?(?:\d*\.)?\d+)%(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[hwb]|(?:\d*\.)?\d+|calc\([hwb()/*\-+\d.\s]+\)))\s+(?(?:[hwb]|(?:\d*\.)?\d+|calc\([hwb()/*\-+\d.\s]+\)))%?\s+(?(?:[hwb]|(?:\d*\.)?\d+|calc\([hwb()/*\-+\d.\s]+\)))%?(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[i.HSL]:/^hsla?\s*\(\s*(?:(?-?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)\s*,\s*(?(?:\d*\.)?\d+)%\s*,\s*(?(?:\d*\.)?\d+)%(?:\s*,\s*(?(?:\d*\.)?\d+))?|(?-?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)\s+(?(?:\d*\.)?\d+)%?\s+(?(?:\d*\.)?\d+)%?(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[hsl]|(?:\d*\.)?\d+|calc\([hsl()/*\-+\d.\s]+\)))\s+(?(?:[hsl]|(?:\d*\.)?\d+|calc\([hsl()/*\-+\d.\s]+\)))%?\s+(?(?:[hsl]|(?:\d*\.)?\d+|calc\([hsl()/*\-+\d.\s]+\)))%?(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[i.CIELab]:/^lab\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+%?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[lab]|(?:\d*\.)?\d+|calc\([lab()/*\-+\d.\s]+\)))\s+(?(?:[lab]|(?:\d*\.)?\d+|calc\([lab()/*\-+\d.\s]+\)))\s+(?(?:[lab]|(?:\d*\.)?\d+|calc\([lab()/*\-+\d.\s]+\)))(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[i.LCH]:/^lch\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[lch]|(?:\d*\.)?\d+|calc\([lch()/*\-+\d.\s]+\)))\s+(?(?:[lch]|(?:\d*\.)?\d+|calc\([lch()/*\-+\d.\s]+\)))\s+(?(?:[lch]|(?:\d*\.)?\d+|calc\([lch()/*\-+\d.\s]+\)))(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[i.CMYK]:/^(?:device-cmyk|cmyk)\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)(?:\s*,\s*(?(?:\d*\.)?\d+))?|(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?)\s*\)$/},m={REGEXP:/^calc\(\s*(?[\d./*+-\w\s]+)\s*\)$/,SCOPED:/\(\s*([^()]+)\s*\)/g,DIVISION:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*\/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/,MULTIPLICATION:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*\*\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/,SUM:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*\+\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/,REST:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*-\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/},b=/^(?-?(?:\d*\.)?\d+)(?(?:deg|grad|rad|turn)?)$/,g=/^(-?\d+(?:\.\d+)?|-?\.\d+)%$/,H=/^0x([a-f\d]{1,2})$/i,C=/\{(\d+)\}/g,L=/,( +|\d+)/g,B=/ +/,E="The provided string color doesn't have a correct format",p="The provided color object doesn't have the proper keys or format",F="is not a valid operation for a relative color";var R,_,f;!function(t){t.NONE="none",t.DEGREES="deg",t.GRADIANS="grad",t.RADIANS="rad",t.TURNS="turn"}(R||(R={})),function(t){t.NONE="none",t.PERCENT="percent"}(_||(_={})),function(t){t.DEVICE_CMYK="device-cmyk",t.CMYK="cmyk"}(f||(f={}));const M={decimals:6,legacyCSS:!1,spacesAfterCommas:!1,anglesUnit:R.NONE,rgbUnit:_.NONE,labUnit:_.NONE,lchUnit:_.NONE,cmykUnit:_.PERCENT,alphaUnit:_.NONE,cmykFunction:f.DEVICE_CMYK},S=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),G=t=>+`${t}`.replace(g,"$1"),y=t=>g.test(`${t}`)?G(t):Math.min(+t,100),I=t=>(1===t.length&&(t+=t),parseInt(t,16)),w=t=>{const e=W(t,0).toString(16).toUpperCase();return 1===e.length?`0x0${e}`:`0x${e}`},P=(t,s=!1)=>!s&&g.test(t)?Math.min(e*G(t)/100,e):H.test(t)?(3===t.length&&(t+=t.slice(-1)),s?W(t)/e:W(t)):Math.min(+t,s?1:e),O=t=>g.test(t)?j(r*G(t)/100,-125,r):j(+t,-125,r),D=t=>g.test(t)?j(a*G(t)/100,-150,a):j(+t,-150,a),x=t=>Math.min(g.test(t)?G(t)/100:+t,1),k=t=>[...t].sort().join("").toUpperCase(),W=(t,e=6)=>{const s=Math.pow(10,e);return Math.round(+t*s)/s},j=(t,e,s)=>Math.max(e,Math.min(t,s)),v=t=>180*t/Math.PI,N=t=>t*Math.PI/180,$=360,X=t=>{if("string"==typeof t){const e=t.match(b).groups,s=+e.number;switch(e.units){case R.RADIANS:t=W(v(s));break;case R.TURNS:t=W(s*$);break;case R.GRADIANS:t=W(.9*s);break;case R.DEGREES:default:t=s}}return(t>360||t<0)&&(t-=Math.floor(t/$)*$),t},Y=t=>("string"==typeof t&&(t=g.test(t)?G(t)/100:+t),isNaN(+t)||t>1?1:W(t)),U=(t,e)=>{let s;switch(e){case R.RADIANS:s=W(N(t));break;case R.TURNS:s=W(t/$);break;case R.GRADIANS:s=W(10/9*t);break;case R.DEGREES:case R.NONE:default:s=t}return s},T=e=>`${e}`in t.Mix,K=[[.4360747,.3850649,.1430804],[.2225045,.7168786,.0606169],[.0139322,.0971045,.7141733]],V=[[3.1338561,-1.6168667,-.4906146],[-.9787684,1.9161415,.033454],[.0719453,-.2289914,1.4052427]],q=K.map((t=>t.reduce(((t,e)=>t+e),0))),z=(t,s,r)=>(r<0&&(r+=6),r>=6&&(r-=6),W(r<1?((s-t)*r+t)*e:r<3?s*e:r<4?((s-t)*(4-r)+t)*e:t*e)),Q=t=>t<=.04045?t/12.92:((t+.055)/1.055)**2.4,J=t=>t<=.0031308?12.92*t:1.055*t**(1/2.4)-.055,Z=(t,e,s,r)=>{const a=[0,0,0],i=[t,e,s];return r.forEach(((t,e)=>{t.forEach(((t,s)=>{a[e]+=t*i[s]}))})),a},tt=(t,e,s)=>{e/=100;const r=(s/=100)<=.5?s*(e+1):s+e-s*e,a=2*s-r;return{R:z(a,r,(t/=60)+2),G:z(a,r,t),B:z(a,r,t-2)}},et=(t,s,r,a=1)=>{t/=e,s/=e,r/=e,a=Math.min(a,1);const i=Math.max(t,s,r),n=Math.min(t,s,r),c=i-n;let o=0,h=0;const l=(i+n)/2;if(0!==c){switch(i){case t:o=(s-r)/c%6;break;case s:o=(r-t)/c+2;break;case r:o=(t-s)/c+4}o=W(60*o),o<0&&(o+=360),h=c/(1-Math.abs(2*l-1))}return{H:o,S:W(100*h),L:W(100*l),A:a}},st=(t,s,r)=>{const a=[t/e,s/e,r/e].map(Q),i=Z(a[0],a[1],a[2],K),n=((t,e,s)=>{const r=t=>t>(6/29)**3?Math.cbrt(t):t/(3*(6/29)**2)+4/29,a=r(t/q[0]),i=r(e/q[1]);return[116*i-16,500*(a-i),200*(i-r(s/q[2]))]})(i[0],i[1],i[2]);return{L:n[0],a:n[1],b:n[2]}},rt=(t,s,r)=>{const a=((t,e,s)=>{const r=t=>t>6/29?t**3:3*(6/29)**2*(t-4/29),a=(t+16)/116,i=e/500,n=s/200;return[q[0]*r(a+i),q[1]*r(a),q[2]*r(a-n)]})(t,s,r),i=Z(a[0],a[1],a[2],V).map(J);return{R:j(i[0]*e,0,e),G:j(i[1]*e,0,e),B:j(i[2]*e,0,e)}},at=(t,e,s)=>{const r=Math.sqrt(e**2+s**2),a=v(Math.atan2(s,e));return{L:t,C:r,H:X(a)}},it=(t,e,s)=>{const r=N(s);return{L:t,a:e*Math.cos(r),b:e*Math.sin(r)}},nt=(t,e,s)=>{const r=st(t,e,s);return at(r.L,r.a,r.b)},ct=(t,e,s)=>{const r=it(t,e,s);return rt(r.L,r.a,r.b)},ot=(t,s,r,a=1)=>({H:et(t,s,r,a).H,W:W(Math.min(t,s,r)/e*100),B:W(100*(1-Math.max(t,s,r)/e)),A:a}),ht=(t,s,r)=>{const a=1-(r/=100)-(s/=100),i=a*(1-Math.abs(t/60%2-1));let n=0,c=0,o=0;return t<60?(n=a,c=i,o=0):t>=60&&t<120?(n=i,c=a,o=0):t>=120&&t<180?(n=0,c=a,o=i):t>=180&&t<240?(n=0,c=i,o=a):t>=240&&t<300?(n=i,c=0,o=a):(n=a,c=0,o=i),n+=s,c+=s,o+=s,{R:j(n*e,0,e),G:j(c*e,0,e),B:j(o*e,0,e)}},lt=(t,s,r,a)=>({R:W(e*(1-t)*(a=1-a)),G:W(e*(1-s)*a),B:W(e*(1-r)*a)}),ut=(t,s,r)=>{t/=e,s/=e,r/=e;const a=1-Math.max(t,s,r),i=1-a,n=i&&(i-s)/i,c=i&&(i-r)/i;return{C:W(100*(i&&(i-t)/i)),M:W(100*n),Y:W(100*c),K:W(100*a)}},dt=(t,e)=>{if(t<0&&(t+=360),t>360&&(t-=360),360===t||0===t)return t;const s=[[0,120],[120,180],[180,240],[240,360]],r=[[0,60],[60,120],[120,240],[240,360]],a=e?r:s;let i=0,n=0,c=0,o=0;return(e?s:r).find(((e,s)=>t>=e[0]&&tthis._calculate(e,s).toString())),m.REGEXP.test(r)){m.REGEXP.lastIndex=0;break}a++}this._result=this._getCalcValue(r,s)}else this._result=+e}_division(t,e){return t/e}_multiplication(t,e){return t*e}_sum(t,e){return t+e}_rest(t,e){return t-e}_getCalcValue(t,e){const s=t.match(m.REGEXP).groups.operation,r=this._calculate(s,e);if(Number.isNaN(r))throw new Error(`Invalid value for ${this._colorIndex}. ${s} ${F}`);return r}_calculate(t,e){return this._operations.forEach(((s,r)=>{let a=0;for(;r.test(t)&&a<100;)t=t.replace(r,((t,r,a)=>s(e[r]??+r,e[a]??+a).toString())),a++})),+t}get result(){return this._result}}class gt extends At{get hasPercentageAlpha(){return g.test(this._a)}}class Ht extends gt{constructor(t,s){super();const r=t.match(A.RGB).groups,{r_legacy:a,g_legacy:i,b_legacy:n,a_legacy:c,r:o,g:h,b:l,a:u,from:d,relative_r:m,relative_g:b,relative_b:g,relative_a:H}=r;if(d){const t=s(d),r={r:t.R,g:t.G,b:t.B,alpha:t.A??1},a=new bt("r",m,r).result,i=new bt("g",b,r).result,n=new bt("b",g,r).result,c={R:Math.min(a,e),G:Math.min(i,e),B:Math.min(n,e)};if(H){const t=new bt("alpha",H,r).result;c.A=Math.min(t,1)}this._rgb=c}else{this._r=a??o,this._g=i??h,this._b=n??l,this._a=c??u;const t={R:Math.min(P(this._r),e),G:Math.min(P(this._g),e),B:Math.min(P(this._b),e)};void 0!==this._a&&(t.A=Y(this._a)),this._rgb=t}}get hasPercentageValues(){return g.test(this._r)&&g.test(this._g)&&g.test(this._b)}static test(t){return A.RGB.test(t)}}class Ct extends gt{get angleUnit(){if(this._h){const t=this._h.match(b).groups.units;return""===t?R.NONE:t}return R.NONE}}class Lt extends Ct{constructor(t,e){super();const r=t.match(A.HSL).groups,{h_legacy:a,s_legacy:i,l_legacy:n,a_legacy:c,h:o,s:h,l:l,a:u,from:d,relative_h:m,relative_s:b,relative_l:g,relative_a:H}=r;if(d){const t=e(d),r=et(t.R,t.G,t.B,t.A),a={h:r.H,s:r.S,l:r.L,alpha:r.A},i=new bt("h",m,a).result,n=new bt("s",b,a).result,c=new bt("l",g,a).result,o=tt(j(i,0,360),j(n,0,s),j(c,0,s));if(H){const t=new bt("alpha",H,a).result;o.A=j(t,0,1)}this._rgb=o}else{this._h=a??o,this._s=i??h,this._l=n??l,this._a=c??u;const t=tt(X(this._h),y(this._s),y(this._l));void 0!==this._a&&(t.A=Y(this._a)),this._rgb=t}}static test(t){return A.HSL.test(t)}}class Bt extends Ct{constructor(t,e){super();const r=t.match(A.HWB).groups,{h:a,w:i,b:n,a:c,from:o,relative_h:h,relative_w:l,relative_b:u,relative_a:d}=r;if(o){const t=e(o),r=ot(t.R,t.G,t.B,t.A),a={h:r.H,w:r.W,b:r.B,alpha:r.A},i=new bt("h",h,a).result,n=new bt("w",l,a).result,c=new bt("b",u,a).result,A=ht(j(i,0,360),j(n,0,s),j(c,0,s));if(d){const t=new bt("alpha",d,a).result;A.A=j(t,0,1)}this._rgb=A}else{this._h=a,this._w=i,this._b=n,this._a=c;const t=ht(X(this._h),y(this._w),y(this._b));void 0!==this._a&&(t.A=Y(this._a)),this._rgb=t}}static test(t){return A.HWB.test(t)}}class Et extends gt{constructor(t,e){super();const a=t.match(A.CIELab).groups,{L:i,a:n,b:c,A:o,from:h,relative_L:l,relative_a:u,relative_b:d,relative_A:m}=a;if(h){const t=e(h),a=st(t.R,t.G,t.B),i={l:a.L,a:a.a,b:a.b,alpha:t.A??1},n=new bt("l",l,i).result,c=new bt("a",u,i).result,o=new bt("b",d,i).result,A=rt(j(n,0,s),j(c,-125,r),j(o,-125,r));if(m){const t=new bt("alpha",m,i).result;A.A=j(t,0,1)}this._rgb=A}else{this._L=i,this._A=n,this._B=c,this._a=o;const t=rt(y(this._L),O(this._A),O(this._B));void 0!==this._a&&(t.A=Y(this._a)),this._rgb=t}}get hasPercentageValues(){return g.test(this._L)&&g.test(this._A)&&g.test(this._B)}static test(t){return A.CIELab.test(t)}}class pt extends Ct{constructor(t,e){super();const r=t.match(A.LCH).groups,{l:i,c:n,h:c,a:o,from:h,relative_l:l,relative_c:u,relative_h:d,relative_a:m}=r;if(h){const t=e(h),r=nt(t.R,t.G,t.B),i={l:r.L,c:r.C,h:r.H,alpha:t.A??1},n=new bt("l",l,i).result,c=new bt("c",u,i).result,o=new bt("h",d,i).result,A=ct(j(n,0,s),j(c,-150,a),X(o));if(m){const t=new bt("alpha",m,i).result;A.A=j(t,0,1)}this._rgb=A}else{this._l=i,this._c=n,this._h=c,this._a=o;const t=ct(y(this._l),D(this._c),X(this._h));void 0!==this._a&&(t.A=Y(this._a)),this._rgb=t}}get hasPercentageValues(){return g.test(this._l)&&g.test(this._c)}static test(t){return A.LCH.test(t)}}class Ft extends gt{constructor(t){super();const e=t.match(A.CMYK).groups;this._c=e.c_legacy??e.c,this._m=e.m_legacy??e.m,this._y=e.y_legacy??e.y,this._k=e.k_legacy??e.k,this._a=e.a_legacy??e.a;const s=lt(x(this._c),x(this._m),x(this._y),x(this._k));void 0!==this._a&&(s.A=Y(this._a)),this._rgb=s}get hasPercentageValues(){return g.test(this._c)&&g.test(this._m)&&g.test(this._y)&&g.test(this._k)}static test(t){return A.CMYK.test(t)}}const Rt=t=>"string"==typeof t?(t=>{let e;if(Object.keys(i).some((s=>{if(A[s].test(t))return e=s,!0})),!e&&~h.indexOf(t)&&(e=i.HEX),!e)throw new Error(E);return e})(t):(t=>{let s,r=!1;const a=k(Object.keys(t));if(u[a]&&(s=u[a]),s&&s===i.RGB){const a=Object.entries(t).some((t=>!H.test(`${t[1]}`))),n=Object.entries(t).some((t=>!(g.test(`${t[1]}`)||!H.test(`${t[1]}`)&&!isNaN(+t[1])&&+t[1]<=e)));a&&n&&(r=!0),a||(s=i.HEX)}if(!s||r)throw new Error(p);return s})(t),_t={[i.HEX](t){const e=~h.indexOf(t)?o[t]:t;return new mt(e).rgb},[i.RGB]:t=>new Ht(t,Mt).rgb,[i.HSL]:t=>new Lt(t,Mt).rgb,[i.HWB]:t=>new Bt(t,Mt).rgb,[i.CIELab]:t=>new Et(t,Mt).rgb,[i.LCH]:t=>new pt(t,Mt).rgb,[i.CMYK]:t=>new Ft(t).rgb},ft={[i.HEX](t){const e={R:P(`${t.R}`),G:P(`${t.G}`),B:P(`${t.B}`)};return S(t,"A")&&(e.A=Math.min(P(`${t.A}`,!0),1)),e},[i.RGB](t){return this.HEX(t)},[i.HSL](t){const e=y(`${t.S}`),s=y(`${t.L}`),r=tt(X(t.H),e,s);return S(t,"A")&&(r.A=Y(t.A)),r},[i.HWB](t){const e=y(`${t.W}`),s=y(`${t.B}`),r=ht(X(t.H),e,s);return S(t,"A")&&(r.A=Y(t.A)),r},[i.CIELab](t){const e=y(`${t.L}`),s=O(`${t.a}`),r=O(`${t.b}`),a=rt(e,s,r);return S(t,"A")&&(a.A=Y(t.A)),a},[i.LCH](t){const e=y(`${t.L}`),s=D(`${t.C}`),r=X(`${t.H}`),a=ct(e,s,r);return S(t,"A")&&(a.A=Y(t.A)),a},[i.CMYK](t){const e=x(`${t.C}`),s=x(`${t.M}`),r=x(`${t.Y}`),a=x(`${t.K}`),i=lt(e,s,r,a);return S(t,"A")&&(i.A=Y(t.A)),i}},Mt=(t,e=Rt(t))=>"string"==typeof t?_t[e](t):ft[e](t),St=(t,...e)=>{const s=[],r=[],a=[],i=[],n=[],c=[],o=[],h=Object.values(R),l=Object.values(_),u=Object.values(f),A={legacyCSS:0,spacesAfterCommas:0,cmykFunction:0};for(const t of e)if("string"==typeof t){if(s.push(t),t.includes(",")){A.legacyCSS++;const e=t.match(L);1===new Set(e).size&&B.test(e[0].slice(1))&&A.spacesAfterCommas++}if(Lt.test(t)){const e=new Lt(t,Mt);r.push(e.angleUnit),o.push(e.hasPercentageAlpha);continue}if(Bt.test(t)){const e=new Bt(t,Mt);r.push(e.angleUnit),o.push(e.hasPercentageAlpha);continue}if(Ht.test(t)){const e=new Ht(t,Mt);a.push(e.hasPercentageValues),o.push(e.hasPercentageAlpha);continue}if(Et.test(t)){const e=new Et(t,Mt);i.push(e.hasPercentageValues),o.push(e.hasPercentageAlpha);continue}if(pt.test(t)){const e=new pt(t,Mt);r.push(e.angleUnit),n.push(e.hasPercentageValues),o.push(e.hasPercentageAlpha);continue}if(Ft.test(t)){const e=new Ft(t);c.push(e.hasPercentageValues),t.startsWith("cmyk")&&A.cmykFunction++,o.push(e.hasPercentageAlpha)}}return{decimals:typeof t.decimals===d.NUMBER?t.decimals:M.decimals,legacyCSS:typeof t.legacyCSS===d.BOOLEAN?t.legacyCSS:Boolean(s.length&&A.legacyCSS===s.length)||M.legacyCSS,spacesAfterCommas:typeof t.spacesAfterCommas===d.BOOLEAN?t.spacesAfterCommas:Boolean(s.length&&A.spacesAfterCommas===s.length)||M.spacesAfterCommas,anglesUnit:t.anglesUnit&&h.includes(t.anglesUnit)?t.anglesUnit:1===new Set(r).size?r[0]:M.anglesUnit,rgbUnit:t.rgbUnit&&l.includes(t.rgbUnit)?t.rgbUnit:1===new Set(a).size&&a[0]?_.PERCENT:M.rgbUnit,labUnit:t.labUnit&&l.includes(t.labUnit)?t.labUnit:1===new Set(i).size&&i[0]?_.PERCENT:M.labUnit,lchUnit:t.lchUnit&&l.includes(t.lchUnit)?t.lchUnit:1===new Set(n).size&&n[0]?_.PERCENT:M.lchUnit,cmykUnit:t.cmykUnit&&l.includes(t.cmykUnit)?t.cmykUnit:1!==new Set(c).size||c[0]?M.cmykUnit:_.NONE,alphaUnit:t.alphaUnit&&l.includes(t.alphaUnit)?t.alphaUnit:1===new Set(o).size&&o[0]?_.PERCENT:M.alphaUnit,cmykFunction:t.cmykFunction&&u.includes(t.cmykFunction)?t.cmykFunction:c.length&&c.length===A.cmykFunction?f.CMYK:M.cmykFunction}},Gt=(t,e)=>({H:W(t.H,e),S:W(t.S,e),L:W(t.L,e)}),yt=t=>t?", ":",",It=(t,e)=>{const s=k(Object.keys(t));return l[u[s]].reduce(((s,r,a)=>{const i=t[r];return void 0!==i&&s.push(e(i,a)),s}),[])},wt=(t,e)=>t.replace(C,((t,s)=>`${e[+s-1]}`)),Pt=(t,e,s=!1)=>{const{alphaUnit:r,legacyCSS:a,decimals:i}=e;return r!==_.PERCENT||a&&!s?W(t,i):`${W(100*t,i)}%`},Ot=t=>{const{anglesUnit:e,decimals:s}=t;return(r,a)=>{if(0===a&&e!==R.NONE){return`${W(U(r,e),s)}${e}`}return 3===a?Pt(r,t):W(r,s)}},Dt={[i.HEX]:t=>{const e=It(t,(t=>(t=>{let e=W(t,0).toString(16).toUpperCase();return 1===e.length&&(e=`0${e}`),e})(W(t)))),s=4===e.length?"#{1}{2}{3}{4}":"#{1}{2}{3}";return wt(s,e)},[i.RGB]:(t,s)=>{const{decimals:r,legacyCSS:a,spacesAfterCommas:i,rgbUnit:n}=s,c=yt(i),o=It(t,((t,a)=>n===_.PERCENT&&a<3?`${((t,s)=>W(t/e*100,s))(t,r)}%`:3===a?Pt(t,s):W(t,r))),h=a?4===o.length?`rgba({1}${c}{2}${c}{3}${c}{4})`:`rgb({1}${c}{2}${c}{3})`:4===o.length?"rgb({1} {2} {3} / {4})":"rgb({1} {2} {3})";return wt(h,o)},[i.HSL]:(t,e)=>{const{legacyCSS:s,spacesAfterCommas:r}=e,a=yt(r),i=Ot(e),n=It(t,i),c=s?4===n.length?`hsla({1}${a}{2}%${a}{3}%${a}{4})`:`hsl({1}${a}{2}%${a}{3}%)`:4===n.length?"hsl({1} {2}% {3}% / {4})":"hsl({1} {2}% {3}%)";return wt(c,n)},[i.HWB]:(t,e)=>{const s=Ot(e),r=It(t,s),a=4===r.length?"hwb({1} {2}% {3}% / {4})":"hwb({1} {2}% {3}%)";return wt(a,r)},[i.CIELab]:(t,e)=>{const{decimals:s,labUnit:a}=e,i=It(t,((t,i)=>{if(0===i){const e=W(y(t),s);return a===_.PERCENT?`${e}%`:`${e}`}return i<3?a===_.PERCENT?`${((t,e)=>W(t/r*100,e))(t,s)}%`:W(t,s):Pt(t,e,!0)})),n=4===i.length?"lab({1} {2} {3} / {4})":"lab({1} {2} {3})";return wt(n,i)},[i.LCH]:(t,e)=>{const{decimals:s,lchUnit:r,anglesUnit:i}=e,n=It(t,((t,n)=>{if(0===n){const e=W(y(t),s);return r===_.PERCENT?`${e}%`:`${e}`}if(1===n)return r===_.PERCENT?`${((t,e)=>W(t/a*100,e))(t,s)}%`:W(t,s);if(2===n){if(i!==R.NONE){return`${W(U(t,i),s)}${i}`}return W(t,s)}return Pt(t,e,!0)})),c=4===n.length?"lch({1} {2} {3} / {4})":"lch({1} {2} {3})";return wt(c,n)},[i.CMYK]:(t,e)=>{const{decimals:s,legacyCSS:r,spacesAfterCommas:a,cmykUnit:i,cmykFunction:n}=e,c=yt(a),o=It(t,((t,r)=>i===_.PERCENT&&r<4?`${W(t,s)}%`:4===r?Pt(t,e):W(t/100,s))),h=r?5===o.length?`${n}({1}${c}{2}${c}{3}${c}{4}${c}{5})`:`${n}({1}${c}{2}${c}{3}${c}{4})`:5===o.length?`${n}({1} {2} {3} {4} / {5})`:`${n}({1} {2} {3} {4})`;return wt(h,o)}},xt=(e,s,r)=>s.reduce(((s,a)=>[...s,{...e,H:r===t.Mix.ADDITIVE?X(e.H+a):X(dt(dt(e.H,!1)+a,!0))}]),[{...e}]),kt=(t,e)=>xt(t,[30,-30],e),Wt=(t,e)=>xt(t,[180],e),jt=(t,e)=>xt(t,[150,-150],e),vt=(t,e)=>xt(t,[120,-120],e),Nt=(t,e)=>xt(t,[60,-120,180],e),$t=(t,e)=>xt(t,[90,-90,180],e),Xt={[i.HEX]:t=>({R:w(t.R),G:w(t.G),B:w(t.B)}),HEXA(t){const s=Xt.HEX(t);return s.A=S(t,"A")?w(t.A*e):"0xFF",s},[i.RGB](t,e){const s=Kt(t,e);return S(s,"A")&&delete s.A,s},RGBA(t,e){const s=Xt.RGB(t,e);return s.A=S(t,"A")?W(t.A):1,s},[i.HSL](t,e){const s=et(t.R,t.G,t.B);return delete s.A,Gt(s,e)},HSLA(t,e){const s=Xt.HSL(t,e);return s.A=S(t,"A")?W(t.A,e):1,s},[i.HWB](t,e){const s=ot(t.R,t.G,t.B);return delete s.A,((t,e)=>({H:W(t.H,e),W:W(t.W,e),B:W(t.B,e)}))(s,e)},HWBA(t,e){const s=Xt.HWB(t,e);return s.A=S(t,"A")?W(t.A,e):1,s},[i.CIELab]:(t,e)=>((t,e)=>({L:W(t.L,e),a:W(t.a,e),b:W(t.b,e)}))(st(t.R,t.G,t.B),e),CIELabA(t,e){const s=Xt.CIELab(t,e);return s.A=S(t,"A")?W(t.A,e):1,s},[i.LCH]:(t,e)=>((t,e)=>({L:W(t.L,e),C:W(t.C,e),H:W(t.H,e)}))(nt(t.R,t.G,t.B),e),LCHA(t,e){const s=Xt.LCH(t,e);return s.A=S(t,"A")?W(t.A,e):1,s},[i.CMYK]:(t,e)=>((t,e)=>({C:W(t.C,e),M:W(t.M,e),Y:W(t.Y,e),K:W(t.K,e)}))(ut(t.R,t.G,t.B),e),CMYKA(t,e){const s=Xt.CMYK(t,e);return s.A=S(t,"A")?W(t.A,e):1,s}},Yt=(t,s,r,a)=>{const n=Rt(t),c="string"==typeof t,o=Mt(t,n),h="string"==typeof t&&S(o,"A")||"string"!=typeof t&&S(t,"A"),l=et(o.R,o.G,o.B,o.A);h||delete l.A;const u=r?l.L/(s+1):(100-l.L)/(s+1),d=Array(s).fill(null).map(((t,e)=>({...l,L:l.L+u*(e+1)*(1-2*+r)})));switch(n){case i.HEX:default:return d.map((t=>{const s=tt(t.H,t.S,t.L);return h&&(s.A=t.A),c?h?Dt.HEX({...s,A:W(s.A*e)}):Dt.HEX(s):h?Xt.HEXA(s):Xt.HEX(s)}));case i.RGB:return d.map((t=>{const e=tt(t.H,t.S,t.L);return h&&(e.A=t.A),c?Dt.RGB(e,a):h?Xt.RGBA(e,a.decimals):Xt.RGB(e,a.decimals)}));case i.HSL:return d.map((t=>c?Dt.HSL(t,a):h?Xt.HSLA({...tt(t.H,t.S,t.L),A:t.A},a.decimals):Xt.HSL(tt(t.H,t.S,t.L),a.decimals)));case i.HWB:return d.map((t=>{const e=tt(t.H,t.S,t.L);h&&(e.A=t.A);const s=h?Xt.HWBA(e,a.decimals):Xt.HWB(e,a.decimals);return c?Dt.HWB(s,a):s}));case i.CIELab:return d.map((t=>{const e=tt(t.H,t.S,t.L);h&&(e.A=t.A);const s=h?Xt.CIELabA(e,a.decimals):Xt.CIELab(e,a.decimals);return c?Dt.CIELab(s,a):s}));case i.LCH:return d.map((t=>{const e=tt(t.H,t.S,t.L),s=nt(e.R,e.G,e.B);return h&&(s.A=t.A),c?Dt.LCH(s,a):h?Xt.LCHA({...e,A:t.A},a.decimals):Xt.LCH(e,a.decimals)}))}},Ut={buildHarmony(t,e,s,r){const a=Rt(t),n=Mt(t,a),c=et(n.R,n.G,n.B,n.A),o="string"==typeof t&&S(n,"A")||"string"!=typeof t&&S(t,"A"),h="string"==typeof t;switch(a){case i.HEX:default:return o?this.HEXA(Gt(c,0),e,s,h):this.HEX(Gt(c,0),e,s,h);case i.HSL:return o?this.HSLA(c,e,s,h,r):this.HSL(c,e,s,h,r);case i.HWB:return o?this.HWBA(c,e,s,h,r):this.HWB(c,e,s,h,r);case i.RGB:return o?this.RGBA(c,e,s,h,r):this.RGB(c,e,s,h,r);case i.CIELab:return o?this.CIELabA(c,e,s,h,r):this.CIELab(c,e,s,h,r);case i.LCH:return o?this.LCHA(c,e,s,h,r):this.LCH(c,e,s,h,r)}},[i.HEX]:(t,e,s,r)=>e(t,s).map((t=>r?Dt.HEX(tt(t.H,t.S,t.L)):Xt.HEX(tt(t.H,t.S,t.L)))),HEXA:(t,s,r,a)=>s(t,r).map((t=>a?Dt.HEX({...tt(t.H,t.S,t.L),A:Y(t.A)*e}):Xt.HEXA({...tt(t.H,t.S,t.L),A:Y(t.A)}))),[i.RGB]:(t,e,s,r,a)=>e(t,s).map((t=>r?Dt.RGB(tt(t.H,t.S,t.L),a):Xt.RGB(tt(t.H,t.S,t.L),a.decimals))),RGBA:(t,e,s,r,a)=>e(t,s).map((t=>r?Dt.RGB({...tt(t.H,t.S,t.L),A:Y(t.A)},a):Xt.RGBA({...tt(t.H,t.S,t.L),A:Y(t.A)},a.decimals))),[i.HSL]:(t,e,s,r,a)=>e(t,s).map((t=>r?Dt.HSL({H:t.H,S:t.S,L:t.L},a):Xt.HSL(tt(t.H,t.S,t.L),a.decimals))),HSLA:(t,e,s,r,a)=>e(t,s).map((t=>r?Dt.HSL({...t,A:Y(t.A)},a):Xt.HSLA({...tt(t.H,t.S,t.L),A:Y(t.A)},a.decimals))),[i.HWB]:(t,e,s,r,a)=>e(t,s).map((t=>{const e=tt(t.H,t.S,t.L),s=ot(e.R,e.G,e.B);return r?Dt.HWB({H:s.H,W:s.W,B:s.B},a):Xt.HWB(e,a.decimals)})),HWBA:(t,e,s,r,a)=>e(t,s).map((t=>{const e=tt(t.H,t.S,t.L),s=ot(e.R,e.G,e.B);return r?Dt.HWB({...s,A:Y(t.A)},a):Xt.HWBA({...e,A:Y(t.A)},a.decimals)})),[i.CIELab]:(t,e,s,r,a)=>e(t,s).map((t=>{const e=tt(t.H,t.S,t.L);return r?Dt.CIELab(st(e.R,e.G,e.B),a):Xt.CIELab(e,a.decimals)})),CIELabA:(t,e,s,r,a)=>e(t,s).map((t=>{const e=tt(t.H,t.S,t.L);return r?Dt.CIELab({...st(e.R,e.G,e.B),A:Y(t.A)},a):Xt.CIELabA({...e,A:Y(t.A)},a.decimals)})),[i.LCH]:(t,e,s,r,a)=>e(t,s).map((t=>{const e=tt(t.H,t.S,t.L);return r?Dt.LCH(nt(e.R,e.G,e.B),a):Xt.LCH(e,a.decimals)})),LCHA:(t,e,s,r,a)=>e(t,s).map((t=>{const e=tt(t.H,t.S,t.L);return r?Dt.LCH({...nt(e.R,e.G,e.B),A:Y(t.A)},a):Xt.LCHA({...e,A:Y(t.A)},a.decimals)}))},Tt={mix(s,r){const a=s.map((t=>{const e=Rt(t);return Mt(t,e)})),i=r===t.Mix.SUBTRACTIVE?a.map((t=>{const s=((t,s,r)=>{const a=Math.min(t,s,r),i=Math.min(e-t,e-s,e-r),n=t-a,c=s-a,o=r-a,h=Math.min(n,c),l=n-h,u=(c+h)/2,d=(o+c-h)/2,A=Math.max(l,u,d)/Math.max(n,c,o),m=isNaN(A)||A===1/0||A<=0?1:A;return{R:l/m+i,Y:u/m+i,B:d/m+i}})(t.R,t.G,t.B);return S(t,"A")&&(s.A=t.A),s})):null;function n(s){const a=r===t.Mix.ADDITIVE?{R:0,G:0,B:0,A:0}:{R:0,Y:0,B:0,A:0};return s.reduce(((s,a)=>{const i=S(a,"A")?a.A:1,n={R:Math.min(s.R+a.R*i,e),B:Math.min(s.B+a.B*i,e),A:1-(1-i)*(1-s.A)},c="G"in s?s.G:s.Y,o="G"in a?a.G:a.Y;return{...n,...r===t.Mix.ADDITIVE?{G:Math.min(c+o*i,e)}:{Y:Math.min(c+o*i,e)}}}),a)}let c;if(r===t.Mix.ADDITIVE)c=n(a);else{const t=n(i);c=((t,s,r)=>{const a=Math.min(t,s,r),i=Math.min(e-t,e-s,e-r),n=t-a,c=s-a,o=r-a,h=Math.min(c,o),l=n+c-h,u=c+h,d=2*(o-h),A=Math.max(l,u,d)/Math.max(n,c,o),m=isNaN(A)||A===1/0||A<=0?1:A;return{R:l/m+i,G:u/m+i,B:d/m+i}})(t.R,t.Y,t.B),c.A=t.A}return{R:W(c.R),G:W(c.G),B:W(c.B),A:j(c.A,0,1)}},[i.HEX](t,e,s){const r=this.mix(t,e);return delete r.A,s?Dt.HEX(r):Xt.HEX(r)},HEXA(t,s,r){const a=this.mix(t,s);return a.A=r?Y(a.A)*e:Y(a.A),r?Dt.HEX(a):Xt.HEXA(a)},[i.RGB](t,e,s,r){const a=this.mix(t,e);return delete a.A,s?Dt.RGB(a,r):Xt.RGB(a,r.decimals)},RGBA(t,e,s,r){const a=this.mix(t,e);return s?Dt.RGB(a,r):Xt.RGBA(a,r.decimals)},[i.HSL](t,e,s,r){const a=this.mix(t,e),i=et(a.R,a.G,a.B);return delete a.A,delete i.A,s?Dt.HSL(i,r):Xt.HSL(a,r.decimals)},HSLA(t,e,s,r){const a=this.mix(t,e),i=et(a.R,a.G,a.B,a.A);return s?Dt.HSL(i,r):Xt.HSLA(a,r.decimals)},[i.HWB](t,e,s,r){const a=this.mix(t,e),i=ot(a.R,a.G,a.B);return delete a.A,delete i.A,s?Dt.HWB(i,r):Xt.HWB(a,r.decimals)},HWBA(t,e,s,r){const a=this.mix(t,e),i=ot(a.R,a.G,a.B,a.A);return s?Dt.HWB(i,r):Xt.HWBA(a,r.decimals)},[i.CIELab](t,e,s,r){const a=this.mix(t,e),i=st(a.R,a.G,a.B);return delete a.A,s?Dt.CIELab(i,r):Xt.CIELab(a,r.decimals)},CIELabA(t,e,s,r){const a=this.mix(t,e),i=st(a.R,a.G,a.B);return i.A=a.A,s?Dt.CIELab(i,r):Xt.CIELabA(a,r.decimals)},[i.LCH](t,e,s,r){const a=this.mix(t,e),i=nt(a.R,a.G,a.B);return delete a.A,s?Dt.LCH(i,r):Xt.LCH(a,r.decimals)},LCHA(t,e,s,r){const a=this.mix(t,e),i=nt(a.R,a.G,a.B);return i.A=a.A,s?Dt.LCH(i,r):Xt.LCHA(a,r.decimals)}},Kt=(t,e)=>({R:W(t.R,e),G:W(t.G,e),B:W(t.B,e),...S(t,"A")?{A:W(t.A,e)}:{}}),Vt=(t,e,s,r)=>r(Mt(t,e),s),qt=(t,e,s,r,a)=>{s<1&&(s=5);const i=((t,e,s)=>{const r=s-1,a=(e.R-t.R)/r,i=(e.G-t.G)/r,n=(e.B-t.B)/r,c=Y(t.A),o=(Y(e.A)-c)/r;return Array(s).fill(null).map(((s,h)=>0===h?t:h===r?e:{R:W(t.R+a*h),G:W(t.G+i*h),B:W(t.B+n*h),A:W(c+o*h)}))})(Mt(t),Mt(e),s);return i.map((t=>a(t,r)))};function zt(t){const{from:e,to:s,thirdParameter:r,fourthParameter:a,translateFunction:i,cssFunction:n}=t,c="number"==typeof r?qt(e,s,r,a?.decimals,i):qt(e,s,5,r?.decimals,i);return n?c.map((t=>n(t,St(("number"==typeof r?a:r)??{},e,s)))):c}function Qt(e){const{colors:s,secondParameter:r,thirdParameter:a,colorMixerFunction:i,css:n}=e,c=St(("string"==typeof r?a:r)??{},...s);return i(s,"string"==typeof r?r:t.Mix.ADDITIVE,n,c)}const Jt=(e,s,r,a)=>({[t.Harmony.ANALOGOUS]:Ut.buildHarmony(s,kt,r,a),[t.Harmony.COMPLEMENTARY]:Ut.buildHarmony(s,Wt,r,a),[t.Harmony.SPLIT_COMPLEMENTARY]:Ut.buildHarmony(s,jt,r,a),[t.Harmony.TRIADIC]:Ut.buildHarmony(s,vt,r,a),[t.Harmony.TETRADIC]:Ut.buildHarmony(s,Nt,r,a),[t.Harmony.SQUARE]:Ut.buildHarmony(s,$t,r,a)}[e]),Zt=Object.fromEntries(Object.entries(Tt).map((t=>{const[e,s]=t;return[e,s.bind(Tt)]})));class te{constructor(t,e={}){this._options=St(e,t),this.rgb=Mt(t),this.update("rgb")}update(...t){t.includes("rgb")||this.updateRGB(),t.includes("hsl")||this.updateHSL(),t.includes("hwb")||this.updateHWB(),t.includes("lab")||this.updateLAB(),t.includes("lch")||this.updateLCH(),t.includes("cmyk")||this.updateCMYK()}updateRGB(){this.rgb={...tt(this.hsl.H,this.hsl.S,this.hsl.L),A:this.hsl.A}}updateHSL(){this.hsl=et(this.rgb.R,this.rgb.G,this.rgb.B,this.rgb.A)}updateHWB(){this.hwb=ot(this.rgb.R,this.rgb.G,this.rgb.B,this.rgb.A)}updateLAB(){this.lab={...st(this.rgb.R,this.rgb.G,this.rgb.B),A:this.rgb.A}}updateLCH(){this.lch={...nt(this.rgb.R,this.rgb.G,this.rgb.B),A:this.rgb.A}}updateCMYK(){this.cmyk=ut(this.rgb.R,this.rgb.G,this.rgb.B)}updateRGBFromHWB(){this.rgb={...ht(this.hwb.H,this.hwb.W,this.hwb.B),A:this.rgb.A}}updateRGBFromLCH(){this.rgb={...ct(this.lch.L,this.lch.C,this.lch.H),A:this.rgb.A}}updateRGBFromCMYK(){this.rgb={...lt(this.cmyk.C,this.cmyk.M,this.cmyk.Y,this.cmyk.K),A:this.rgb.A}}updateRGBFromLAB(){this.rgb={...rt(this.lab.L,this.lab.a,this.lab.b),A:this.rgb.A}}updateLCHFromLAB(){this.lch={...at(this.lab.L,this.lab.a,this.lab.b),A:this.lab.A}}updateLABromLCH(){this.lab={...it(this.lch.L,this.lch.C,this.lch.H),A:this.lch.A}}setOptions(t={}){return this._options={...this._options,...t},this}setR(t){this.rgb.R=j(t,0,e),this.update("rgb")}setG(t){return this.rgb.G=j(t,0,e),this.update("rgb"),this}setB(t){return this.rgb.B=j(t,0,e),this.update("rgb"),this}setH(t){return this.hsl.H=X(t),this.update("hsl"),this}setS(t){return this.hsl.S=j(t,0,s),this.update("hsl"),this}setL(t){return this.hsl.L=j(t,0,s),this.update("hsl"),this}setWhiteness(t){return this.hwb.W=j(t,0,s),this.updateRGBFromHWB(),this.update("rgb","hwb"),this}setBlackness(t){return this.hwb.B=j(t,0,s),this.updateRGBFromHWB(),this.update("rgb","hwb"),this}setCIEL(t){return this.lab.L=j(t,0,s),this.updateRGBFromLAB(),this.updateLCHFromLAB(),this.update("rgb","lab","lch"),this}setCIEa(t){return this.lab.a=j(t,-125,r),this.updateRGBFromLAB(),this.updateLCHFromLAB(),this.update("rgb","lab","lch"),this}setCIEb(t){return this.lab.b=j(t,-125,r),this.updateRGBFromLAB(),this.updateLCHFromLAB(),this.update("rgb","lab","lch"),this}setLCHL(t){return this.lch.L=j(t,0,s),this.updateRGBFromLCH(),this.updateLABromLCH(),this.update("rgb","lab","lch"),this}setLCHC(t){return this.lch.C=j(t,0,a),this.updateRGBFromLCH(),this.updateLABromLCH(),this.update("rgb","lab","lch"),this}setLCHH(t){return this.lch.H=X(t),this.updateRGBFromLCH(),this.updateLABromLCH(),this.update("rgb","lab","lch"),this}setA(t){const e=j(t,0,1);return this.rgb.A=e,this.hsl.A=e,this.hwb.A=e,this.lab.A=e,this.lch.A=e,this.cmyk.A=e,this}setC(t){return this.cmyk.C=j(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}setM(t){return this.cmyk.M=j(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}setY(t){return this.cmyk.Y=j(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}setK(t){return this.cmyk.K=j(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}get options(){return this._options}get R(){return W(this.rgb.R,this.options.decimals)}get G(){return W(this.rgb.G,this.options.decimals)}get B(){return W(this.rgb.B,this.options.decimals)}get H(){return W(this.hsl.H,this.options.decimals)}get S(){return W(this.hsl.S,this.options.decimals)}get L(){return W(this.hsl.L,this.options.decimals)}get Whiteness(){return W(this.hwb.W,this.options.decimals)}get Blackness(){return W(this.hwb.B,this.options.decimals)}get CIEL(){return W(this.lab.L,this.options.decimals)}get CIEa(){return W(this.lab.a,this.options.decimals)}get CIEb(){return W(this.lab.b,this.options.decimals)}get LCHL(){return W(this.lch.L,this.options.decimals)}get LCHC(){return W(this.lch.C,this.options.decimals)}get LCHH(){return W(this.lch.H,this.options.decimals)}get A(){return W(this.hsl.A,this.options.decimals)}get C(){return W(this.cmyk.C,this.options.decimals)}get M(){return W(this.cmyk.M,this.options.decimals)}get Y(){return W(this.cmyk.Y,this.options.decimals)}get K(){return W(this.cmyk.K,this.options.decimals)}get HEXObject(){return Xt.HEX(this.rgb)}get HEXAObject(){return Xt.HEXA(this.rgb)}get RGBObject(){return{R:this.R,G:this.G,B:this.B}}get RGBAObject(){return{...this.RGBObject,A:this.A}}get HSLObject(){return{H:this.H,S:this.S,L:this.L}}get HSLAObject(){return{...this.HSLObject,A:this.A}}get HWBObject(){return{H:this.H,W:this.Whiteness,B:this.Blackness}}get HWBAObject(){return{...this.HWBObject,A:this.A}}get CIELabObject(){return{L:this.CIEL,a:this.CIEa,b:this.CIEb}}get CIELabAObject(){return{...this.CIELabObject,A:this.A}}get LCHObject(){return{L:this.LCHL,C:this.LCHC,H:this.LCHH}}get LCHAObject(){return{...this.LCHObject,A:this.A}}get CMYKObject(){return{C:this.C,M:this.M,Y:this.Y,K:this.K}}get CMYKAObject(){return{...this.CMYKObject,A:this.A}}get HEX(){return Dt.HEX({R:this.R,G:this.G,B:this.B})}get HEXA(){return Dt.HEX({R:this.R,G:this.G,B:this.B,A:this.A*e})}get RGB(){return Dt.RGB({R:this.R,G:this.G,B:this.B},this.options)}get RGBA(){return Dt.RGB({R:this.R,G:this.G,B:this.B,A:this.A},this.options)}get HSL(){return Dt.HSL({H:this.H,S:this.S,L:this.L},this.options)}get HSLA(){return Dt.HSL({H:this.H,S:this.S,L:this.L,A:this.A},this.options)}get HWB(){return Dt.HWB({H:this.H,W:this.Whiteness,B:this.Blackness},this.options)}get HWBA(){return Dt.HWB({H:this.H,W:this.Whiteness,B:this.Blackness,A:this.A},this.options)}get CIELab(){return Dt.CIELab({L:this.CIEL,a:this.CIEa,b:this.CIEb},this.options)}get CIELabA(){return Dt.CIELab({L:this.CIEL,a:this.CIEa,b:this.CIEb,A:this.A},this.options)}get LCH(){return Dt.LCH({L:this.LCHL,C:this.LCHC,H:this.LCHH},this.options)}get LCHA(){return Dt.LCH({L:this.LCHL,C:this.LCHC,H:this.LCHH,A:this.A},this.options)}get CMYK(){return Dt.CMYK({C:this.C,M:this.M,Y:this.Y,K:this.K},this.options)}get CMYKA(){return Dt.CMYK({C:this.C,M:this.M,Y:this.Y,K:this.K,A:this.A},this.options)}static toHEXObject(t){const e=Rt(t);return Vt(t,e,0,Xt.HEX)}static toHEX(t){return Dt.HEX(te.toHEXObject(t))}static toHEXAObject(t){const e=Rt(t);return Vt(t,e,0,Xt.HEXA)}static toHEXA(t){return Dt.HEX(te.toHEXAObject(t))}static toRGBObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.RGB)}static toRGB(t,e={}){const s=te.toRGBObject(t,e),r=St(e,t);return Dt.RGB(s,r)}static toRGBAObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.RGBA)}static toRGBA(t,e={}){const s=te.toRGBAObject(t,e),r=St(e,t);return Dt.RGB(s,r)}static toHSLObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.HSL)}static toHSL(t,e={}){const s=te.toHSLObject(t,e),r=St(e,t);return Dt.HSL(s,r)}static toHSLAObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.HSLA)}static toHSLA(t,e={}){const s=te.toHSLAObject(t,e),r=St(e,t);return Dt.HSL(s,r)}static toHWBObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.HWB)}static toHWB(t,e={}){const s=te.toHWBObject(t,e),r=St(e,t);return Dt.HWB(s,r)}static toHWBAObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.HWBA)}static toHWBA(t,e={}){const s=te.toHWBAObject(t,e),r=St(e,t);return Dt.HWB(s,r)}static toCIELabObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.CIELab)}static toCIELab(t,e={}){const s=te.toCIELabObject(t,e),r=St(e,t);return Dt.CIELab(s,r)}static toCIELabAObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.CIELabA)}static toCIELabA(t,e={}){const s=te.toCIELabAObject(t,e),r=St(e,t);return Dt.CIELab(s,r)}static toLCHObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.LCH)}static toLCH(t,e={}){const s=te.toLCHObject(t,e),r=St(e,t);return Dt.LCH(s,r)}static toLCHAObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.LCHA)}static toLCHA(t,e={}){const s=te.toLCHAObject(t,e),r=St(e,t);return Dt.LCH(s,r)}static toCMYKObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.CMYK)}static toCMYK(t,e={}){const s=te.toCMYKObject(t,e),r=St(e,t);return Dt.CMYK(s,r)}static toCMYKAObject(t,e={}){const s=Rt(t);return Vt(t,s,e.decimals,Xt.CMYKA)}static toCMYKA(t,e={}){const s=te.toCMYKAObject(t,e),r=St(e,t);return Dt.CMYK(s,r)}static getBlendHEXObject(t,e,s=5){return qt(t,e,s,0,Xt.HEX)}static getBlendHEX(t,e,s=5){return te.getBlendHEXObject(t,e,s).map((t=>Dt.HEX(t)))}static getBlendHEXAObject(t,e,s=5){return qt(t,e,s,0,Xt.HEXA)}static getBlendHEXA(t,e,s=5){return te.getBlendHEXAObject(t,e,s).map((t=>Dt.HEX(t)))}static getBlendRGBObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.RGB})}static getBlendRGB(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.RGB,cssFunction:Dt.RGB})}static getBlendRGBAObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.RGBA})}static getBlendRGBA(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.RGBA,cssFunction:Dt.RGB})}static getBlendHSLObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HSL})}static getBlendHSL(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HSL,cssFunction:Dt.HSL})}static getBlendHSLAObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HSLA})}static getBlendHSLA(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HSLA,cssFunction:Dt.HSL})}static getBlendHWBObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HWB})}static getBlendHWB(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HWB,cssFunction:Dt.HWB})}static getBlendHWBAObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HWBA})}static getBlendHWBA(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.HWBA,cssFunction:Dt.HWB})}static getBlendCIELabObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.CIELab})}static getBlendCIELab(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.CIELab,cssFunction:Dt.CIELab})}static getBlendCIELabAObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.CIELabA})}static getBlendCIELabA(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.CIELabA,cssFunction:Dt.CIELab})}static getBlendLCHObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.LCH})}static getBlendLCH(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.LCH,cssFunction:Dt.LCH})}static getBlendLCHAObject(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.LCHA})}static getBlendLCHA(t,e,s,r){return zt({from:t,to:e,thirdParameter:s,fourthParameter:r,translateFunction:Xt.LCHA,cssFunction:Dt.LCH})}static getMixHEXObject(e,s=t.Mix.ADDITIVE){return Tt.HEX(e,s,!1)}static getMixHEX(e,s=t.Mix.ADDITIVE){return Tt.HEX(e,s,!0)}static getMixHEXAObject(e,s=t.Mix.ADDITIVE){return Tt.HEXA(e,s,!1)}static getMixHEXA(e,s=t.Mix.ADDITIVE){return Tt.HEXA(e,s,!0)}static getMixRGBObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.RGB,css:!1})}static getMixRGB(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.RGB,css:!0})}static getMixRGBAObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.RGBA,css:!1})}static getMixRGBA(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.RGBA,css:!0})}static getMixHSLObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HSL,css:!1})}static getMixHSL(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HSL,css:!0})}static getMixHSLAObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HSLA,css:!1})}static getMixHSLA(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HSLA,css:!0})}static getMixHWBObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HWB,css:!1})}static getMixHWB(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HWB,css:!0})}static getMixHWBAObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HWBA,css:!1})}static getMixHWBA(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.HWBA,css:!0})}static getMixCIELabObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.CIELab,css:!1})}static getMixCIELab(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.CIELab,css:!0})}static getMixCIELabAObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.CIELabA,css:!1})}static getMixCIELabA(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.CIELabA,css:!0})}static getMixLCHObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.LCH,css:!1})}static getMixLCH(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.LCH,css:!0})}static getMixLCHAObject(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.LCHA,css:!1})}static getMixLCHA(t,e,s){return Qt({colors:t,secondParameter:e,thirdParameter:s,colorMixerFunction:Zt.LCHA,css:!0})}static getShades(t,e,s){return"number"==typeof e?Yt(t,e,!0,St(s||{},t)):Yt(t,5,!0,St(e||{},t))}static getTints(t,e,s){return"number"==typeof e?Yt(t,e,!1,St(s||{},t)):Yt(t,5,!1,St(e||{},t))}static getHarmony(e,s,r,a){return`${s}`in t.Harmony?Jt(s,e,T(r)?r:t.Mix.ADDITIVE,St(T(r)?a||{}:r||{},e)):T(s)?Jt(t.Harmony.COMPLEMENTARY,e,s,St(r||{},e)):Jt(t.Harmony.COMPLEMENTARY,e,t.Mix.ADDITIVE,St(s||{},e))}}return t.ColorTranslator=te,t}({}); +var colortranslator=function(t){"use strict";var e,s,r,a,n,i,c;!function(t){t.NONE="none",t.DEGREES="deg",t.GRADIANS="grad",t.RADIANS="rad",t.TURNS="turn"}(e||(e={})),function(t){t.NONE="none",t.PERCENT="percent"}(s||(s={})),function(t){t.DEVICE_CMYK="device-cmyk",t.CMYK="cmyk"}(r||(r={})),function(t){t.HEX="HEX",t.RGB="RGB",t.HWB="HWB",t.HSL="HSL",t.CIELab="CIELab",t.LCH="LCH",t.CMYK="CMYK"}(a||(a={})),t.Harmony=void 0,(n=t.Harmony||(t.Harmony={})).ANALOGOUS="ANALOGOUS",n.COMPLEMENTARY="COMPLEMENTARY",n.SPLIT_COMPLEMENTARY="SPLIT_COMPLEMENTARY",n.TRIADIC="TRIADIC",n.TETRADIC="TETRADIC",n.SQUARE="SQUARE",t.Mix=void 0,(i=t.Mix||(t.Mix={})).ADDITIVE="ADDITIVE",i.SUBTRACTIVE="SUBTRACTIVE",function(t){t.black="#000000",t.silver="#C0C0C0",t.gray="#808080",t.white="#FFFFFF",t.maroon="#800000",t.red="#FF0000",t.purple="#800080",t.fuchsia="#FF00FF",t.green="#008000",t.lime="#00FF00",t.olive="#808000",t.yellow="#FFFF00",t.navy="#000080",t.blue="#0000FF",t.teal="#008080",t.aqua="#00FFFF",t.orange="#FFA500",t.aliceblue="#F0F8FF",t.antiquewhite="#FAEBD7",t.aquamarine="#7FFFD4",t.azure="#F0FFFF",t.beige="#F5F5DC",t.bisque="#FFE4C4",t.blanchedalmond="#FFEBCD",t.blueviolet="#8A2BE2",t.brown="#A52A2A",t.burlywood="#DEB887",t.cadetblue="#5F9EA0",t.chartreuse="#7FFF00",t.chocolate="#D2691E",t.coral="#FF7F50",t.cornflowerblue="#6495ED",t.cornsilk="#FFF8DC",t.crimson="#DC143C",t.cyan="#00FFFF",t.darkblue="#00008B",t.darkcyan="#008B8B",t.darkgoldenrod="#B8860B",t.darkgray="#A9A9A9",t.darkgreen="#006400",t.darkgrey="#A9A9A9",t.darkkhaki="#BDB76B",t.darkmagenta="#8B008B",t.darkolivegreen="#556B2F",t.darkorange="#FF8C00",t.darkorchid="#9932CC",t.darkred="#8B0000",t.darksalmon="#E9967A",t.darkseagreen="#8FBC8F",t.darkslateblue="#483D8B",t.darkslategray="#2F4F4F",t.darkslategrey="#2F4F4F",t.darkturquoise="#00CED1",t.darkviolet="#9400D3",t.deeppink="#FF1493",t.deepskyblue="#00BFFF",t.dimgray="#696969",t.dimgrey="#696969",t.dodgerblue="#1E90FF",t.firebrick="#B22222",t.floralwhite="#FFFAF0",t.forestgreen="#228B22",t.gainsboro="#DCDCDC",t.ghostwhite="#F8F8FF",t.gold="#FFD700",t.goldenrod="#DAA520",t.greenyellow="#ADFF2F",t.grey="#808080",t.honeydew="#F0FFF0",t.hotpink="#FF69B4",t.indianred="#CD5C5C",t.indigo="#4B0082",t.ivory="#FFFFF0",t.khaki="#F0E68C",t.lavender="#E6E6FA",t.lavenderblush="#FFF0F5",t.lawngreen="#7CFC00",t.lemonchiffon="#FFFACD",t.lightblue="#ADD8E6",t.lightcoral="#F08080",t.lightcyan="#E0FFFF",t.lightgoldenrodyellow="#FAFAD2",t.lightgray="#D3D3D3",t.lightgreen="#90EE90",t.lightgrey="#D3D3D3",t.lightpink="#FFB6C1",t.lightsalmon="#FFA07A",t.lightseagreen="#20B2AA",t.lightskyblue="#87CEFA",t.lightslategray="#778899",t.lightslategrey="#778899",t.lightsteelblue="#B0C4DE",t.lightyellow="#FFFFE0",t.limegreen="#32CD32",t.linen="#FAF0E6",t.magenta="#FF00FF",t.mediumaquamarine="#66CDAA",t.mediumblue="#0000CD",t.mediumorchid="#BA55D3",t.mediumpurple="#9370DB",t.mediumseagreen="#3CB371",t.mediumslateblue="#7B68EE",t.mediumspringgreen="#00FA9A",t.mediumturquoise="#48D1CC",t.mediumvioletred="#C71585",t.midnightblue="#191970",t.mintcream="#F5FFFA",t.mistyrose="#FFE4E1",t.moccasin="#FFE4B5",t.navajowhite="#FFDEAD",t.oldlace="#FDF5E6",t.olivedrab="#6B8E23",t.orangered="#FF4500",t.orchid="#DA70D6",t.palegoldenrod="#EEE8AA",t.palegreen="#98FB98",t.paleturquoise="#AFEEEE",t.palevioletred="#DB7093",t.papayawhip="#FFEFD5",t.peachpuff="#FFDAB9",t.peru="#CD853F",t.pink="#FFC0CB",t.plum="#DDA0DD",t.powderblue="#B0E0E6",t.rosybrown="#BC8F8F",t.royalblue="#4169E1",t.saddlebrown="#8B4513",t.salmon="#FA8072",t.sandybrown="#F4A460",t.seagreen="#2E8B57",t.seashell="#FFF5EE",t.sienna="#A0522D",t.skyblue="#87CEEB",t.slateblue="#6A5ACD",t.slategray="#708090",t.slategrey="#708090",t.snow="#FFFAFA",t.springgreen="#00FF7F",t.steelblue="#4682B4",t.tan="#D2B48C",t.thistle="#D8BFD8",t.tomato="#FF6347",t.turquoise="#40E0D0",t.violet="#EE82EE",t.wheat="#F5DEB3",t.whitesmoke="#F5F5F5",t.yellowgreen="#9ACD32",t.rebeccapurple="#663399"}(c||(c={}));const l={[a.HEX]:/^#(?:(?[a-f\d])(?[a-f\d])(?[a-f\d])(?[a-f\d])?|(?[a-f\d]{2})(?[a-f\d]{2})(?[a-f\d]{2})(?[a-f\d]{2})?)$/i,[a.RGB]:/^rgba?\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)(?:\s*,\s*(?(?:\d*\.)?\d+))?|(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[rgb]|(?:\d*\.)?\d+|calc\([rgb()/*\-+\d.\s]+\)))\s+(?(?:[rgb]|(?:\d*\.)?\d+|calc\([rgb()/*\-+\d.\s]+\)))\s+(?(?:[rgb]|(?:\d*\.)?\d+|calc\([rgb()/*\-+\d.\s]+\)))(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[a.HWB]:/^hwb\s*\(\s*(?:(?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)\s+(?(?:\d*\.)?\d+)%\s+(?(?:\d*\.)?\d+)%(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[hwb]|(?:\d*\.)?\d+|calc\([hwb()/*\-+\d.\s]+\)))\s+(?(?:[hwb]|(?:\d*\.)?\d+|calc\([hwb()/*\-+\d.\s]+\)))%?\s+(?(?:[hwb]|(?:\d*\.)?\d+|calc\([hwb()/*\-+\d.\s]+\)))%?(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[a.HSL]:/^hsla?\s*\(\s*(?:(?-?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)\s*,\s*(?(?:\d*\.)?\d+)%\s*,\s*(?(?:\d*\.)?\d+)%(?:\s*,\s*(?(?:\d*\.)?\d+))?|(?-?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)\s+(?(?:\d*\.)?\d+)%?\s+(?(?:\d*\.)?\d+)%?(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[hsl]|(?:\d*\.)?\d+|calc\([hsl()/*\-+\d.\s]+\)))\s+(?(?:[hsl]|(?:\d*\.)?\d+|calc\([hsl()/*\-+\d.\s]+\)))%?\s+(?(?:[hsl]|(?:\d*\.)?\d+|calc\([hsl()/*\-+\d.\s]+\)))%?(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[a.CIELab]:/^lab\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+%?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[lab]|(?:\d*\.)?\d+|calc\([lab()/*\-+\d.\s]+\)))\s+(?(?:[lab]|(?:\d*\.)?\d+|calc\([lab()/*\-+\d.\s]+\)))\s+(?(?:[lab]|(?:\d*\.)?\d+|calc\([lab()/*\-+\d.\s]+\)))(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[a.LCH]:/^lch\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+%?)\s+(?-?(?:\d*\.)?\d+(?:deg|grad|rad|turn)?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?|from\s+(?(?:\w+|\w+\(\s*[^())]+\s*\)|\w+\(from\s+\w+\(.*\)\s*\)|#[a-fA-F\d]+))\s+(?(?:[lch]|(?:\d*\.)?\d+|calc\([lch()/*\-+\d.\s]+\)))\s+(?(?:[lch]|(?:\d*\.)?\d+|calc\([lch()/*\-+\d.\s]+\)))\s+(?(?:[lch]|(?:\d*\.)?\d+|calc\([lch()/*\-+\d.\s]+\)))(?:\s*\/\s*(?(?:(?:\d*\.)?\d+%?|calc\([()/*\-+\d.\s\w]*(?:alpha)?[()/*\-+\d.\s\w]*\)|alpha)))?)\s*\)$/,[a.CMYK]:/^(?:device-cmyk|cmyk)\s*\(\s*(?:(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)\s*,\s*(?(?:\d*\.)?\d+%?)(?:\s*,\s*(?(?:\d*\.)?\d+))?|(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)\s+(?(?:\d*\.)?\d+%?)(?:\s*\/\s*(?(?:\d*\.)?\d+%?))?)\s*\)$/},h={REGEXP:/^calc\(\s*(?[\d./*+-\w\s]+)\s*\)$/,SCOPED:/\(\s*([^()]+)\s*\)/g,DIVISION:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*\/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/,MULTIPLICATION:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*\*\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/,SUM:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*\+\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/,REST:/\s*(?(?:(?:\d*\.)?\d+|\w+))\s*-\s*(?(?:(?:\d*\.)?\d+|\w+))\s*/},o=/^(?-?(?:\d*\.)?\d+)(?(?:deg|grad|rad|turn)?)$/,u=/^(-?\d+(?:\.\d+)?|-?\.\d+)%$/,d=/^0x([a-f\d]{1,2})$/i,g=/\{(\d+)\}/g,b=/,( +|\d+)/g,C=/ +/,A=255,p=360,m=100,B=125,H=150,L=Object.keys(c),E=Object.freeze({HEX:["R","G","B","A"],RGB:["R","G","B","A"],HSL:["H","S","L","A"],HWB:["H","W","B","A"],CIELab:["L","a","b","A"],LCH:["L","C","H","A"],CMYK:["C","M","Y","K","A"]}),S=Object.freeze({ABGR:a.RGB,ABHW:a.HWB,ACHL:a.LCH,ACKMY:a.CMYK,AHLS:a.HSL,ALAB:a.CIELab,BGR:a.RGB,BHW:a.HWB,CHL:a.LCH,CKMY:a.CMYK,HLS:a.HSL,LAB:a.CIELab}),F=Object.freeze({decimals:6,legacyCSS:!1,spacesAfterCommas:!1,anglesUnit:e.NONE,rgbUnit:s.NONE,labUnit:s.NONE,lchUnit:s.NONE,cmykUnit:s.PERCENT,alphaUnit:s.NONE,cmykFunction:r.DEVICE_CMYK}),R=Object.freeze({NOT_ACCEPTED_INPUT:"The provided string color doesn't have a correct format",NOT_A_VALID_RELATIVE_COLOR:"is not a valid operation for a relative color"}),v=t=>[...t].sort().join("").toUpperCase(),M=t=>"string"==typeof t,y=t=>"number"==typeof t,_=t=>"boolean"==typeof t,f=t=>void 0===t,w=t=>S[v(Object.keys(t))],O=t=>w(t)===a.RGB,G=t=>w(t)===a.HSL,I=t=>w(t)===a.HWB,D=t=>w(t)===a.CIELab,k=t=>w(t)===a.LCH,x=t=>w(t)===a.CMYK,N=t=>+`${t}`.replace(u,"$1"),j=t=>u.test(`${t}`)?N(t):Math.min(+t,100),$=t=>(1===t.length&&(t+=t),parseInt(t,16)),Y=t=>{const e=K(t,0).toString(16).toUpperCase();return 1===e.length?`0x0${e}`:`0x${e}`},T=(t,e=!1)=>!e&&u.test(t)?Math.min(A*N(t)/100,A):d.test(t)?(3===t.length&&(t+=t.slice(-1)),e?K(t)/A:K(t)):Math.min(+t,e?1:A),W=t=>u.test(t)?X(B*N(t)/100,-125,B):X(+t,-125,B),U=t=>u.test(t)?X(H*N(t)/100,-150,H):X(+t,-150,H),P=(t,e)=>{const s=u.test(t)?N(t):+t;return e?Math.min(100*s,100):Math.min(s,100)},K=(t,e=6)=>{const s=Math.pow(10,e);return Math.round(+t*s)/s},X=(t,e,s)=>Math.max(e,Math.min(t,s)),V=t=>180*t/Math.PI,z=t=>t*Math.PI/180,q=t=>{if(M(t)){const s=t.match(o).groups,r=+s.number;switch(s.units){case e.RADIANS:t=K(V(r));break;case e.TURNS:t=K(r*p);break;case e.GRADIANS:t=K(.9*r);break;case e.DEGREES:default:t=r}}return(t>=p||t<0)&&(t-=Math.floor(t/p)*p),t},Q=t=>(M(t)&&(t=u.test(t)?N(t)/100:+t),isNaN(+t)||t>1?1:K(t)),J=(t,s)=>{let r;switch(s){case e.RADIANS:r=K(z(t));break;case e.TURNS:r=K(t/p);break;case e.GRADIANS:r=K(1.1111111111111112*t);break;case e.DEGREES:case e.NONE:default:r=t}return r},Z=e=>`${e}`in t.Mix,tt=t=>{if(t){const s=t.match(o).groups.units;return""===s?e.NONE:s}return e.NONE},et=[[.4360747,.3850649,.1430804],[.2225045,.7168786,.0606169],[.0139322,.0971045,.7141733]],st=[[3.1338561,-1.6168667,-.4906146],[-.9787684,1.9161415,.033454],[.0719453,-.2289914,1.4052427]],rt=et.map((t=>t.reduce(((t,e)=>t+e),0))),at=(t,e,s)=>(s<0&&(s+=6),s>=6&&(s-=6),K(s<1?((e-t)*s+t)*A:s<3?e*A:s<4?((e-t)*(4-s)+t)*A:t*A)),nt=t=>t<=.04045?t/12.92:((t+.055)/1.055)**2.4,it=t=>t<=.0031308?12.92*t:1.055*t**(1/2.4)-.055,ct=(t,e,s,r)=>{const a=[0,0,0],n=[t,e,s];return r.forEach(((t,e)=>{t.forEach(((t,s)=>{a[e]+=t*n[s]}))})),a},lt=(t,e,s)=>{e/=100;const r=(s/=100)<=.5?s*(e+1):s+e-s*e,a=2*s-r;return{R:at(a,r,(t/=60)+2),G:at(a,r,t),B:at(a,r,t-2)}},ht=(t,e,s,r=1)=>{t/=A,e/=A,s/=A,r=Math.min(r,1);const a=Math.max(t,e,s),n=Math.min(t,e,s),i=a-n;let c=0,l=0;const h=(a+n)/2;if(0!==i){switch(a){case t:c=(e-s)/i%6;break;case e:c=(s-t)/i+2;break;case s:c=(t-e)/i+4}c=K(60*c),c<0&&(c+=360),l=i/(1-Math.abs(2*h-1))}return{H:c,S:K(100*l),L:K(100*h),A:r}},ot=(t,e,s)=>{const r=[t/A,e/A,s/A].map(nt),a=ct(r[0],r[1],r[2],et),n=((t,e,s)=>{const r=t=>t>(6/29)**3?Math.cbrt(t):t/(3*(6/29)**2)+4/29,a=r(t/rt[0]),n=r(e/rt[1]);return[116*n-16,500*(a-n),200*(n-r(s/rt[2]))]})(a[0],a[1],a[2]);return{L:n[0],a:n[1],b:n[2]}},ut=(t,e,s)=>{const r=((t,e,s)=>{const r=t=>t>6/29?t**3:3*(6/29)**2*(t-4/29),a=(t+16)/116,n=e/500,i=s/200;return[rt[0]*r(a+n),rt[1]*r(a),rt[2]*r(a-i)]})(t,e,s),a=ct(r[0],r[1],r[2],st).map(it);return{R:X(a[0]*A,0,A),G:X(a[1]*A,0,A),B:X(a[2]*A,0,A)}},dt=(t,e,s)=>{const r=Math.sqrt(e**2+s**2),a=V(Math.atan2(s,e));return{L:t,C:r,H:q(a)}},gt=(t,e,s)=>{const r=z(s);return{L:t,a:e*Math.cos(r),b:e*Math.sin(r)}},bt=(t,e,s)=>{const r=ot(t,e,s);return dt(r.L,r.a,r.b)},Ct=(t,e,s)=>{const r=gt(t,e,s);return ut(r.L,r.a,r.b)},At=(t,e,s,r=1)=>({H:ht(t,e,s,r).H,W:K(Math.min(t,e,s)/A*100),B:K(100*(1-Math.max(t,e,s)/A)),A:r}),pt=(t,e,s)=>{const r=1-(s/=100)-(e/=100),a=r*(1-Math.abs(t/60%2-1));let n,i,c;return t<60?(n=r,i=a,c=0):t>=60&&t<120?(n=a,i=r,c=0):t>=120&&t<180?(n=0,i=r,c=a):t>=180&&t<240?(n=0,i=a,c=r):t>=240&&t<300?(n=a,i=0,c=r):(n=r,i=0,c=a),n+=e,i+=e,c+=e,{R:X(n*A,0,A),G:X(i*A,0,A),B:X(c*A,0,A)}},mt=(t,e,s,r)=>({R:X(K(A*(1-t)*(r=1-r)),0,A),G:X(K(A*(1-e)*r),0,A),B:X(K(A*(1-s)*r),0,A)}),Bt=(t,e,s)=>{t/=A,e/=A,s/=A;const r=1-Math.max(t,e,s),a=1-r,n=a&&(a-e)/a,i=a&&(a-s)/a;return{C:K(100*(a&&(a-t)/a)),M:K(100*n),Y:K(100*i),K:K(100*r)}},Ht=(t,e)=>{if(t<0&&(t+=360),t>360&&(t-=360),360===t||0===t)return t;const s=[[0,120],[120,180],[180,240],[240,360]],r=[[0,60],[60,120],[120,240],[240,360]],a=e?r:s;let n=0,i=0,c=0,l=0;return(e?s:r).find(((e,s)=>t>=e[0]&&t{const e=(t=>f(t.A)?{}:{A:+t.A})(t);return G(t)?{...lt(t.H,t.S,t.L),...e}:I(t)?{...pt(t.H,t.W,t.B),...e}:D(t)?{...ut(t.L,t.a,t.b),...e}:k(t)?{...Ct(t.L,t.C,t.H),...e}:x(t)?{...mt(t.C,t.M,t.Y,t.K),...e}:t},St=t=>t?", ":",",Ft=(t,e)=>{const s=v(Object.keys(t)),r=S[s];return E[r].reduce(((s,r,a)=>{const n=t[r];return void 0!==n&&s.push(e(n,a)),s}),[])},Rt=(t,e)=>t.replace(g,((t,s)=>`${e[+s-1]}`)),vt=(t,e,r=!1)=>{const{alphaUnit:a,legacyCSS:n,decimals:i}=e;return a!==s.PERCENT||n&&!r?K(t,i):`${K(100*t,i)}%`},Mt=t=>{const{anglesUnit:s,decimals:r}=t;return(a,n)=>{if(0===n&&s!==e.NONE){return`${K(J(a,s),r)}${s}`}return 3===n?vt(a,t):K(a,r)}};class yt{constructor(t,e,s){this._operations=new Map([[h.DIVISION,this._division],[h.MULTIPLICATION,this._multiplication],[h.SUM,this._sum],[h.REST,this._rest]]),this._colorIndex=t;let r=e,a=0;if(Number.isNaN(+e))if(e in s)this._result=s[e];else if(h.REGEXP.test(r))h.REGEXP.lastIndex=0,this._result=this._getCalcValue(r,s);else{for(;h.SCOPED.test(r)&&a<100;){if(h.SCOPED.lastIndex=0,r=r.replace(h.SCOPED,((t,e)=>this._calculate(e,s).toString())),h.REGEXP.test(r)){h.REGEXP.lastIndex=0;break}a++}this._result=this._getCalcValue(r,s)}else this._result=+e}_division(t,e){return t/e}_multiplication(t,e){return t*e}_sum(t,e){return t+e}_rest(t,e){return t-e}_getCalcValue(t,e){const s=t.match(h.REGEXP).groups.operation,r=this._calculate(s,e);if(Number.isNaN(r))throw new Error(`Invalid value for ${this._colorIndex}. ${s} ${R.NOT_A_VALID_RELATIVE_COLOR}`);return r}_calculate(t,e){return this._operations.forEach(((s,r)=>{let a=0;for(;r.test(t)&&a<100;)t=t.replace(r,((t,r,a)=>s(e[r]??+r,e[a]??+a).toString())),a++})),+t}get result(){return this._result}}const _t=new class extends Lt{_extract(t){return(~L.indexOf(t)?c[t]:t).match(l.HEX).groups}supports(t){if(M(t))return l.HEX.test(t)||!!~L.indexOf(t);const e=Object.entries(t).some((t=>!d.test(`${t[1]}`)));return O(t)&&!e}parse(t){if(M(t)){const e=this._extract(t),s=e.r??e.rr,r=e.g??e.gg,a=e.b??e.bb,n=e.a??e.aa;return{R:$(s),G:$(r),B:$(a),...f(n)?{}:{A:$(n)/A}}}return{R:T(`${t.R}`),G:T(`${t.G}`),B:T(`${t.B}`),...f(t.A)?{}:{A:Math.min(T(`${t.A}`,!0),1)}}}convert(t,e,s){const r=O(t)?t:Et(t);return{R:Y(r.R),G:Y(r.G),B:Y(r.B),...s?{A:f(r.A)?"0xFF":Y(r.A*A)}:{}}}convertCSS(t,e,s){const r=this.convert(t,e.decimals,s),a=Ft(r,(t=>(t=>{let e=K(t,0).toString(16).toUpperCase();return 1===e.length&&(e=`0${e}`),e})(K(t)))),n=4===a.length?"#{1}{2}{3}{4}":"#{1}{2}{3}";return Rt(n,a)}getCSSOptions(t){const e=this._extract(t);return{hasAlpha:!f(e.a??e.aa)}}get model(){return a.HEX}},ft=new class extends Lt{_extract(t){return t.match(l.RGB).groups}supports(t){if(M(t))return l.RGB.test(t);const e=Object.entries(t).some((t=>!(u.test(`${t[1]}`)||!d.test(`${t[1]}`)&&!isNaN(+t[1])&&+t[1]<=A)));return O(t)&&!e}parse(t,e){if(M(t)){const s=this._extract(t),{r_legacy:r,g_legacy:a,b_legacy:n,a_legacy:i,r:c,g:l,b:h,a:o,from:u,relative_r:d,relative_g:g,relative_b:b,relative_a:C}=s;if(u){const t=e.parse(u),s=Et(t),r={r:s.R,g:s.G,b:s.B,alpha:s.A??1},a=new yt("r",d,r).result,n=new yt("g",g,r).result,i=new yt("b",b,r).result,c={R:Math.min(a,A),G:Math.min(n,A),B:Math.min(i,A)};if(C){const t=new yt("alpha",C,r).result;c.A=Math.min(t,1)}return c}{const t=r??c,e=a??l,s=n??h,u=i??o;return{R:Math.min(T(t),A),G:Math.min(T(e),A),B:Math.min(T(s),A),...f(u)?{}:{A:Q(u)}}}}return{R:T(`${t.R}`),G:T(`${t.G}`),B:T(`${t.B}`),...f(t.A)?{}:{A:Math.min(T(`${t.A}`,!0),1)}}}convert(t,e,s){const r=O(t)?t:Et(t);return this._roundRGBObject({R:r.R,G:r.G,B:r.B,...s?{A:r.A??1}:{}},e)}convertCSS(t,e,r){const{decimals:a,legacyCSS:n,spacesAfterCommas:i,rgbUnit:c}=e,l=this.convert(t,e.decimals,r),h=St(i),o=Ft(l,((t,r)=>c===s.PERCENT&&r<3?`${((t,e)=>K(t/A*100,e))(t,a)}%`:3===r?vt(t,e):K(t,a))),u=n?4===o.length?`rgba({1}${h}{2}${h}{3}${h}{4})`:`rgb({1}${h}{2}${h}{3})`:4===o.length?"rgb({1} {2} {3} / {4})":"rgb({1} {2} {3})";return Rt(u,o)}_roundRGBObject(t,e){return{R:K(t.R,e),G:K(t.G,e),B:K(t.B,e),...f(t.A)?{}:{A:K(t.A,e)}}}getCSSOptions(t){const e=this._extract(t),{r_legacy:s,g_legacy:r,b_legacy:a,a_legacy:n,r:i,g:c,b:l,a:h}=e;return{hasPercentageValues:u.test(s??i)&&u.test(r??c)&&u.test(a??l),hasPercentageAlpha:u.test(n??h),hasAlpha:!f(n??h)}}get model(){return a.RGB}},wt=new class extends Lt{_extract(t){return t.match(l.HSL).groups}supports(t){return M(t)?l.HSL.test(t):G(t)}parse(t,e){if(M(t)){const s=this._extract(t),{h_legacy:r,s_legacy:a,l_legacy:n,a_legacy:i,h:c,s:l,l:h,a:o,from:u,relative_h:d,relative_s:g,relative_l:b,relative_a:C}=s;if(u){const t=e.parse(u),s=Et(t),r=ht(s.R,s.G,s.B,s.A),a={h:r.H,s:r.S,l:r.L,alpha:r.A},n=new yt("h",d,a).result,i=new yt("s",g,a).result,c=new yt("l",b,a).result,l={H:q(n),S:j(i),L:j(c)};if(C){const t=new yt("alpha",C,a).result;l.A=X(t,0,1)}return l}{const t=a??l,e=n??h,s=i??o;return{H:q(r??c),S:j(t),L:j(e),...f(s)?{}:{A:Q(s)}}}}return{H:q(t.H),S:j(`${t.S}`),L:j(`${t.L}`),...f(t.A)?{}:{A:X(+t.A,0,1)}}}convert(t,e,s){let r;if(G(t))r=t;else{const e=Et(t);r=ht(e.R,e.G,e.B,e.A)}return this._roundHSLObject({H:r.H,S:r.S,L:r.L,...s?{A:r.A??1}:{}},e)}convertCSS(t,e,s){const{legacyCSS:r,spacesAfterCommas:a}=e,n=St(a),i=this.convert(t,e.decimals,s),c=Mt(e),l=Ft(i,c),h=r?4===l.length?`hsla({1}${n}{2}%${n}{3}%${n}{4})`:`hsl({1}${n}{2}%${n}{3}%)`:4===l.length?"hsl({1} {2}% {3}% / {4})":"hsl({1} {2}% {3}%)";return Rt(h,l)}_roundHSLObject(t,e){return{H:K(q(t.H),e),S:K(t.S,e),L:K(t.L,e),...f(t.A)?{}:{A:K(t.A,e)}}}getCSSOptions(t){const e=this._extract(t),{h_legacy:s,h:r,a_legacy:a,a:n}=e;return{angleUnit:tt(s??r),hasPercentageAlpha:u.test(a??n),hasAlpha:!f(a??n)}}get model(){return a.HSL}},Ot=new class extends Lt{_extract(t){return t.match(l.HWB).groups}supports(t){return M(t)?l.HWB.test(t):I(t)}parse(t,e){if(M(t)){const s=this._extract(t),{h:r,w:a,b:n,a:i,from:c,relative_h:l,relative_w:h,relative_b:o,relative_a:u}=s;if(c){const t=e.parse(c),s=Et(t),r=At(s.R,s.G,s.B,s.A),a={h:r.H,w:r.W,b:r.B,alpha:r.A},n=new yt("h",l,a).result,i=new yt("w",h,a).result,d=new yt("b",o,a).result,g={H:X(n,0,p),W:X(i,0,m),B:X(d,0,m)};if(u){const t=new yt("alpha",u,a).result;g.A=X(t,0,1)}return g}return{H:q(r),W:j(a),B:j(n),...f(i)?{}:{A:Q(i)}}}return{H:q(t.H),W:j(t.W),B:j(t.B),...f(t.A)?{}:{A:Q(t.A)}}}convert(t,e,s){let r;if(I(t))r=t;else{const e=Et(t);r=At(e.R,e.G,e.B,e.A)}return this._roundHWBObject({H:r.H,W:r.W,B:r.B,...s?{A:r.A??1}:{}},e)}convertCSS(t,e,s){const r=this.convert(t,e.decimals,s),a=Mt(e),n=Ft(r,a),i=4===n.length?"hwb({1} {2}% {3}% / {4})":"hwb({1} {2}% {3}%)";return Rt(i,n)}_roundHWBObject(t,e){return{H:K(q(t.H),e),W:K(t.W,e),B:K(t.B,e),...f(t.A)?{}:{A:K(t.A,e)}}}getCSSOptions(t){const e=this._extract(t);return{angleUnit:tt(e.h),hasPercentageAlpha:u.test(e.a),hasAlpha:!f(e.a)}}get model(){return a.HWB}},Gt=new class extends Lt{_extract(t){return t.match(l.CIELab).groups}supports(t){return M(t)?l.CIELab.test(t):D(t)}parse(t,e){if(M(t)){const s=this._extract(t),{L:r,a:a,b:n,A:i,from:c,relative_L:l,relative_a:h,relative_b:o,relative_A:u}=s;if(c){const t=e.parse(c),s=Et(t),r=ot(s.R,s.G,s.B),a={l:r.L,a:r.a,b:r.b,alpha:s.A??1},n=new yt("l",l,a).result,i=new yt("a",h,a).result,d=new yt("b",o,a).result,g={L:X(n,0,m),a:X(i,-125,B),b:X(d,-125,B)};if(u){const t=new yt("alpha",u,a).result;g.A=X(t,0,1)}return g}return{L:j(r),a:W(a),b:W(n),...f(i)?{}:{A:Q(i)}}}return{L:j(t.L),a:W(`${t.a}`),b:W(`${t.b}`),...f(t.A)?{}:{A:Q(t.A)}}}convert(t,e,s){let r;if(D(t))r=t;else{const e=Et(t);r=ot(e.R,e.G,e.B)}return this._roundCIELabObject({L:r.L,a:r.a,b:r.b,...s?{A:+(t.A??1)}:{}},e)}convertCSS(t,e,r){const{decimals:a,labUnit:n}=e,i=this.convert(t,e.decimals,r),c=Ft(i,((t,r)=>{if(0===r){const e=K(j(t),a);return n===s.PERCENT?`${e}%`:`${e}`}return r<3?n===s.PERCENT?`${((t,e)=>K(t/B*100,e))(t,a)}%`:K(t,a):vt(t,e,!0)})),l=4===c.length?"lab({1} {2} {3} / {4})":"lab({1} {2} {3})";return Rt(l,c)}_roundCIELabObject(t,e){return{L:K(t.L,e),a:K(t.a,e),b:K(t.b,e),...f(t.A)?{}:{A:K(t.A,e)}}}getCSSOptions(t){const e=this._extract(t),{L:s,a:r,b:a,A:n}=e;return{hasPercentageValues:u.test(s)&&u.test(r)&&u.test(a),hasPercentageAlpha:u.test(n),hasAlpha:!f(n)}}get model(){return a.CIELab}},It=new class extends Lt{_extract(t){return t.match(l.LCH).groups}supports(t){return M(t)?l.LCH.test(t):k(t)}parse(t,e){if(M(t)){const s=this._extract(t),{l:r,c:a,h:n,a:i,from:c,relative_l:l,relative_c:h,relative_h:o,relative_a:u}=s;if(c){const t=e.parse(c),s=Et(t),r=bt(s.R,s.G,s.B),a={l:r.L,c:r.C,h:r.H,alpha:s.A??1},n=new yt("l",l,a).result,i=new yt("c",h,a).result,d=new yt("h",o,a).result,g={L:X(n,0,m),C:X(i,-150,H),H:q(d)};if(u){const t=new yt("alpha",u,a).result;g.A=X(t,0,1)}return g}return{L:j(r),C:U(a),H:q(n),...f(i)?{}:{A:Q(i)}}}return{L:j(t.L),C:U(`${t.C}`),H:q(t.H),...f(t.A)?{}:{A:Q(t.A)}}}convert(t,e,s){let r;if(k(t))r=t;else{const e=Et(t);r=bt(e.R,e.G,e.B)}return this._roundLCHObject({L:r.L,C:r.C,H:r.H,...s?{A:+(t.A??1)}:{}},e)}convertCSS(t,r,a){const{decimals:n,lchUnit:i,anglesUnit:c}=r,l=this.convert(t,r.decimals,a),h=Ft(l,((t,a)=>{if(0===a){const e=K(j(t),n);return i===s.PERCENT?`${e}%`:`${e}`}if(1===a)return i===s.PERCENT?`${((t,e)=>K(t/H*100,e))(t,n)}%`:K(t,n);if(2===a){if(c!==e.NONE){return`${K(J(t,c),n)}${c}`}return K(t,n)}return vt(t,r,!0)})),o=4===h.length?"lch({1} {2} {3} / {4})":"lch({1} {2} {3})";return Rt(o,h)}_roundLCHObject(t,e){return{L:K(t.L,e),C:K(t.C,e),H:K(q(t.H),e),...f(t.A)?{}:{A:K(t.A,e)}}}getCSSOptions(t){const e=this._extract(t);return{angleUnit:tt(e.h),hasPercentageValues:u.test(e.l)&&u.test(e.c),hasPercentageAlpha:u.test(e.a),hasAlpha:!f(e.a)}}get model(){return a.LCH}},Dt=new class extends Lt{_extract(t){return t.match(l.CMYK).groups}_shouldMultiplyBy100(...t){return!t.some((t=>+t>1))}supports(t){return M(t)?l.CMYK.test(t):x(t)}parse(t){if(M(t)){const e=this._extract(t),s=e.c_legacy??e.c,r=e.m_legacy??e.m,a=e.y_legacy??e.y,n=e.k_legacy??e.k,i=e.a_legacy??e.a,c=this._shouldMultiplyBy100(s,r,a,n);return{C:P(s,c),M:P(r,c),Y:P(a,c),K:P(n,c),...f(i)?{}:{A:Q(i)}}}const e=this._shouldMultiplyBy100(t.C,t.M,t.Y,t.K);return{C:P(`${t.C}`,e),M:P(`${t.M}`,e),Y:P(`${t.Y}`,e),K:P(`${t.K}`,e),...f(t.A)?{}:{A:Q(t.A)}}}convert(t,e,s){let r;if(x(t))r=t;else{const e=Et(t);r=Bt(e.R,e.G,e.B)}return this._roundCMYKObject({C:r.C,M:r.M,Y:r.Y,K:r.K,...s?{A:+(t.A??1)}:{}},e)}convertCSS(t,e,r){const{decimals:a,legacyCSS:n,spacesAfterCommas:i,cmykUnit:c,cmykFunction:l}=e,h=St(i),o=this.convert(t,e.decimals,r),u=Ft(o,((t,r)=>c===s.PERCENT&&r<4?`${K(t,a)}%`:4===r?vt(t,e):K(t/100,a))),d=n?5===u.length?`${l}({1}${h}{2}${h}{3}${h}{4}${h}{5})`:`${l}({1}${h}{2}${h}{3}${h}{4})`:5===u.length?`${l}({1} {2} {3} {4} / {5})`:`${l}({1} {2} {3} {4})`;return Rt(d,u)}_roundCMYKObject(t,e){return{C:K(t.C,e),M:K(t.M,e),Y:K(t.Y,e),K:K(t.K,e),...f(t.A)?{}:{A:K(t.A,e)}}}getCSSOptions(t){const e=this._extract(t),{c_legacy:s,m_legacy:r,y_legacy:a,k_legacy:n,a_legacy:i,c:c,m:l,y:h,k:o,a:d}=e;return{hasPercentageValues:u.test(s??c)&&u.test(r??l)&&u.test(a??h)&&u.test(n??o),hasPercentageAlpha:u.test(i??d),hasAlpha:!f(i??d)}}get model(){return a.CMYK}},kt=new class{constructor(t){this._parsers=t}getParser(t){const e=Object.values(this._parsers).find((e=>e.supports(t)));if(e)return e;throw new Error(R.NOT_ACCEPTED_INPUT)}parse(t){return this.getParser(t).parse(t,this)}convert(t,e,s=F.decimals,r=!1){const a=this.parse(t);return this._parsers[e].convert(a,s,r)}convertCSS(t,e,s={},r=!1){const a=this.parse(t);return this._parsers[e].convertCSS(a,s,r)}}({[a.HEX]:_t,[a.RGB]:ft,[a.HSL]:wt,[a.HWB]:Ot,[a.CIELab]:Gt,[a.LCH]:It,[a.CMYK]:Dt}),xt=(t,...a)=>{const n=[],i=[],c=[],l=[],h=[],o=[],u=[],d=Object.values(e),g=Object.values(s),A=Object.values(r),p={legacyCSS:0,spacesAfterCommas:0,cmykFunction:0};for(const t of a)if(M(t)){if(n.push(t),t.includes(",")){p.legacyCSS++;const e=t.match(b);1===new Set(e).size&&C.test(e[0].slice(1))&&p.spacesAfterCommas++}if(wt.supports(t)){const e=wt.getCSSOptions(t);i.push(e.angleUnit),u.push(e.hasPercentageAlpha);continue}if(Ot.supports(t)){const e=Ot.getCSSOptions(t);i.push(e.angleUnit),u.push(e.hasPercentageAlpha);continue}if(ft.supports(t)){const e=ft.getCSSOptions(t);c.push(e.hasPercentageValues),u.push(e.hasPercentageAlpha);continue}if(Gt.supports(t)){const e=Gt.getCSSOptions(t);l.push(e.hasPercentageValues),u.push(e.hasPercentageAlpha);continue}if(It.supports(t)){const e=It.getCSSOptions(t);i.push(e.angleUnit),h.push(e.hasPercentageValues),u.push(e.hasPercentageAlpha);continue}if(Dt.supports(t)){const e=Dt.getCSSOptions(t);o.push(e.hasPercentageValues),t.startsWith("cmyk")&&p.cmykFunction++,u.push(e.hasPercentageAlpha)}}return{decimals:y(t.decimals)?t.decimals:F.decimals,legacyCSS:_(t.legacyCSS)?t.legacyCSS:Boolean(n.length&&p.legacyCSS===n.length)||F.legacyCSS,spacesAfterCommas:_(t.spacesAfterCommas)?t.spacesAfterCommas:Boolean(n.length&&p.spacesAfterCommas===n.length)||F.spacesAfterCommas,anglesUnit:t.anglesUnit&&d.includes(t.anglesUnit)?t.anglesUnit:1===new Set(i).size?i[0]:F.anglesUnit,rgbUnit:t.rgbUnit&&g.includes(t.rgbUnit)?t.rgbUnit:1===new Set(c).size&&c[0]?s.PERCENT:F.rgbUnit,labUnit:t.labUnit&&g.includes(t.labUnit)?t.labUnit:1===new Set(l).size&&l[0]?s.PERCENT:F.labUnit,lchUnit:t.lchUnit&&g.includes(t.lchUnit)?t.lchUnit:1===new Set(h).size&&h[0]?s.PERCENT:F.lchUnit,cmykUnit:t.cmykUnit&&g.includes(t.cmykUnit)?t.cmykUnit:1!==new Set(o).size||o[0]?F.cmykUnit:s.NONE,alphaUnit:t.alphaUnit&&g.includes(t.alphaUnit)?t.alphaUnit:1===new Set(u).size&&u[0]?s.PERCENT:F.alphaUnit,cmykFunction:t.cmykFunction&&A.includes(t.cmykFunction)?t.cmykFunction:o.length&&o.length===p.cmykFunction?r.CMYK:F.cmykFunction}};function Nt(t,e,s,r,a,n=5,i={}){n<1&&(n=5);const c=kt.parse(t),l=kt.parse(e),h=((t,e,s)=>{const r=s-1,a=(e.R-t.R)/r,n=(e.G-t.G)/r,i=(e.B-t.B)/r,c=Q(t.A),l=(Q(e.A)-c)/r;return Array(s).fill(null).map(((s,h)=>0===h?t:h===r?e:{R:K(t.R+a*h),G:K(t.G+n*h),B:K(t.B+i*h),A:K(c+l*h)}))})(Et(c),Et(l),n);return h.map((n=>r?kt.convertCSS(n,s,xt(i,t,e),a):kt.convert(n,s,i.decimals,a)))}const jt=(t,e)=>[y(t)?t:void 0,y(t)?e:t];function $t(e,s,r,n,i=t.Mix.ADDITIVE,c={}){const l=e.map((t=>kt.convert(t,a.RGB,c.decimals,n))),h=i===t.Mix.SUBTRACTIVE?l.map((t=>{const e=((t,e,s)=>{const r=Math.min(t,e,s),a=Math.min(A-t,A-e,A-s),n=t-r,i=e-r,c=s-r,l=Math.min(n,i),h=n-l,o=(i+l)/2,u=(c+i-l)/2,d=Math.max(h,o,u)/Math.max(n,i,c),g=isNaN(d)||d===1/0||d<=0?1:d;return{R:h/g+a,Y:o/g+a,B:u/g+a}})(t.R,t.G,t.B);return f(t.A)||(e.A=t.A),e})):null;function o(e){const s=i===t.Mix.ADDITIVE?{R:0,G:0,B:0,A:0}:{R:0,Y:0,B:0,A:0};return e.reduce(((e,s)=>{const r=f(s.A)?1:s.A,a={R:Math.min(e.R+s.R*r,A),B:Math.min(e.B+s.B*r,A),A:1-(1-r)*(1-e.A)},n="G"in e?e.G:e.Y,c="G"in s?s.G:s.Y;return{...a,...i===t.Mix.ADDITIVE?{G:Math.min(n+c*r,A)}:{Y:Math.min(n+c*r,A)}}}),s)}let u;if(i===t.Mix.ADDITIVE)u=o(l);else{const t=o(h);u=((t,e,s)=>{const r=Math.min(t,e,s),a=Math.min(A-t,A-e,A-s),n=t-r,i=e-r,c=s-r,l=Math.min(i,c),h=n+i-l,o=i+l,u=2*(c-l),d=Math.max(h,o,u)/Math.max(n,i,c),g=isNaN(d)||d===1/0||d<=0?1:d;return{R:h/g+a,G:o/g+a,B:u/g+a}})(t.R,t.Y,t.B),u.A=t.A}return r?kt.convertCSS(u,s,xt(c,...e),n):kt.convert(u,s,c.decimals,n)}const Yt=(t,e)=>[M(t)?t:void 0,M(t)?e:t];function Tt(t,e,s=5,r={}){const n=M(e),i=kt.getParser(e),c=i.model,l=i.hasAlpha(e),h=kt.convert(e,a.HSL,void 0,l),o=t?h.L/(s+1):(100-h.L)/(s+1),u=Array.from(Array(s)).map(((e,s)=>({...h,L:h.L+o*(s+1)*(1-2*+t)})));return n?u.map((t=>kt.convertCSS(t,c,xt(r,e),l))):u.map((t=>kt.convert(t,c,r.decimals,l)))}const Wt=(t,e)=>[y(t)?t:void 0,y(t)?e:t],Ut=(e,s,r)=>s.reduce(((s,a)=>[...s,{...e,H:r===t.Mix.ADDITIVE?q(e.H+a):q(Ht(Ht(e.H,!1)+a,!0))}]),[{...e}]),Pt=new Map([[t.Harmony.ANALOGOUS,(t,e)=>Ut(t,[30,-30],e)],[t.Harmony.COMPLEMENTARY,(t,e)=>Ut(t,[180],e)],[t.Harmony.SPLIT_COMPLEMENTARY,(t,e)=>Ut(t,[150,-150],e)],[t.Harmony.TRIADIC,(t,e)=>Ut(t,[120,-120],e)],[t.Harmony.TETRADIC,(t,e)=>Ut(t,[60,-120,180],e)],[t.Harmony.SQUARE,(t,e)=>Ut(t,[90,-90,180],e)]]),Kt=(e,s,r)=>`${e}`in t.Harmony?[e,Z(s)?s:t.Mix.ADDITIVE,Z(s)?r:s]:Z(e)?[t.Harmony.COMPLEMENTARY,e,s]:[t.Harmony.COMPLEMENTARY,t.Mix.ADDITIVE,e];return t.ColorTranslator=class{constructor(t,e={}){this._options=xt(e,t);const s=kt.parse(t);switch(w(s)){case a.HSL:this.hsl=s,this.update("hsl");break;case a.HWB:this.hwb=s,this.updateRGBFromHWB(),this.update("hwb","rgb");break;case a.CIELab:this.lab=s,this.updateRGBFromLAB(),this.update("lab","rgb");break;case a.LCH:this.lch=s,this.updateRGBFromLCH(),this.update("lch","rgb");break;case a.CMYK:this.cmyk=s,this.updateRGBFromCMYK(),this.update("cmyk","rgb");break;default:this.rgb=s,this.update("rgb")}}update(...t){t.includes("rgb")||this.updateRGB(),t.includes("hsl")||this.updateHSL(),t.includes("hwb")||this.updateHWB(),t.includes("lab")||this.updateLAB(),t.includes("lch")||this.updateLCH(),t.includes("cmyk")||this.updateCMYK()}updateRGB(){this.rgb={...lt(this.hsl.H,this.hsl.S,this.hsl.L),A:this.hsl.A??1}}updateHSL(){this.hsl=ht(this.rgb.R,this.rgb.G,this.rgb.B,this.rgb.A)}updateHWB(){this.hwb=At(this.rgb.R,this.rgb.G,this.rgb.B,this.rgb.A)}updateLAB(){this.lab={...ot(this.rgb.R,this.rgb.G,this.rgb.B),A:this.rgb.A??1}}updateLCH(){this.lch={...bt(this.rgb.R,this.rgb.G,this.rgb.B),A:this.rgb.A??1}}updateCMYK(){this.cmyk={...Bt(this.rgb.R,this.rgb.G,this.rgb.B),A:this.rgb.A??1}}updateRGBFromHWB(){this.rgb={...pt(this.hwb.H,this.hwb.W,this.hwb.B),A:this.hwb?.A??1}}updateRGBFromLCH(){this.rgb={...Ct(this.lch.L,this.lch.C,this.lch.H),A:this.lch.A??1}}updateRGBFromCMYK(){this.rgb={...mt(this.cmyk.C,this.cmyk.M,this.cmyk.Y,this.cmyk.K),A:this.cmyk.A??1}}updateRGBFromLAB(){this.rgb={...ut(this.lab.L,this.lab.a,this.lab.b),A:this.lab.A??1}}updateLCHFromLAB(){this.lch={...dt(this.lab.L,this.lab.a,this.lab.b),A:this.lab.A}}updateLABromLCH(){this.lab={...gt(this.lch.L,this.lch.C,this.lch.H),A:this.lch.A}}setOptions(t={}){return this._options={...this._options,...t},this}setR(t){this.rgb.R=X(t,0,A),this.update("rgb")}setG(t){return this.rgb.G=X(t,0,A),this.update("rgb"),this}setB(t){return this.rgb.B=X(t,0,A),this.update("rgb"),this}setH(t){return this.hsl.H=q(t),this.update("hsl"),this}setS(t){return this.hsl.S=X(t,0,m),this.update("hsl"),this}setL(t){return this.hsl.L=X(t,0,m),this.update("hsl"),this}setWhiteness(t){return this.hwb.W=X(t,0,m),this.updateRGBFromHWB(),this.update("rgb","hwb"),this}setBlackness(t){return this.hwb.B=X(t,0,m),this.updateRGBFromHWB(),this.update("rgb","hwb"),this}setCIEL(t){return this.lab.L=X(t,0,m),this.updateRGBFromLAB(),this.updateLCHFromLAB(),this.update("rgb","lab","lch"),this}setCIEa(t){return this.lab.a=X(t,-125,B),this.updateRGBFromLAB(),this.updateLCHFromLAB(),this.update("rgb","lab","lch"),this}setCIEb(t){return this.lab.b=X(t,-125,B),this.updateRGBFromLAB(),this.updateLCHFromLAB(),this.update("rgb","lab","lch"),this}setLCHL(t){return this.lch.L=X(t,0,m),this.updateRGBFromLCH(),this.updateLABromLCH(),this.update("rgb","lab","lch"),this}setLCHC(t){return this.lch.C=X(t,0,H),this.updateRGBFromLCH(),this.updateLABromLCH(),this.update("rgb","lab","lch"),this}setLCHH(t){return this.lch.H=q(t),this.updateRGBFromLCH(),this.updateLABromLCH(),this.update("rgb","lab","lch"),this}setA(t){const e=X(t,0,1);return this.rgb.A=e,this.hsl.A=e,this.hwb.A=e,this.lab.A=e,this.lch.A=e,this.cmyk.A=e,this}setC(t){return this.cmyk.C=X(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}setM(t){return this.cmyk.M=X(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}setY(t){return this.cmyk.Y=X(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}setK(t){return this.cmyk.K=X(t,0,100),this.updateRGBFromCMYK(),this.update("cmyk"),this}get options(){return this._options}get R(){return K(this.rgb.R,this.options.decimals)}get G(){return K(this.rgb.G,this.options.decimals)}get B(){return K(this.rgb.B,this.options.decimals)}get H(){return K(this.hsl.H,this.options.decimals)}get S(){return K(this.hsl.S,this.options.decimals)}get L(){return K(this.hsl.L,this.options.decimals)}get Whiteness(){return K(this.hwb.W,this.options.decimals)}get Blackness(){return K(this.hwb.B,this.options.decimals)}get CIEL(){return K(this.lab.L,this.options.decimals)}get CIEa(){return K(this.lab.a,this.options.decimals)}get CIEb(){return K(this.lab.b,this.options.decimals)}get LCHL(){return K(this.lch.L,this.options.decimals)}get LCHC(){return K(this.lch.C,this.options.decimals)}get LCHH(){return K(this.lch.H,this.options.decimals)}get A(){return K(this.hsl.A,this.options.decimals)}get C(){return K(this.cmyk.C,this.options.decimals)}get M(){return K(this.cmyk.M,this.options.decimals)}get Y(){return K(this.cmyk.Y,this.options.decimals)}get K(){return K(this.cmyk.K,this.options.decimals)}get HEXObject(){return kt.convert(this.rgb,a.HEX)}get HEXAObject(){return kt.convert(this.rgb,a.HEX,0,!0)}get RGBObject(){return kt.convert(this.rgb,a.RGB,this.options.decimals)}get RGBAObject(){return kt.convert(this.rgb,a.RGB,this.options.decimals,!0)}get HSLObject(){return kt.convert(this.hsl,a.HSL,this.options.decimals)}get HSLAObject(){return kt.convert(this.hsl,a.HSL,this.options.decimals,!0)}get HWBObject(){return kt.convert(this.hwb,a.HWB,this.options.decimals)}get HWBAObject(){return kt.convert(this.hwb,a.HWB,this.options.decimals,!0)}get CIELabObject(){return kt.convert(this.lab,a.CIELab,this.options.decimals)}get CIELabAObject(){return kt.convert(this.lab,a.CIELab,this.options.decimals,!0)}get LCHObject(){return kt.convert(this.lch,a.LCH,this.options.decimals)}get LCHAObject(){return kt.convert(this.lch,a.LCH,this.options.decimals,!0)}get CMYKObject(){return kt.convert(this.cmyk,a.CMYK,this.options.decimals)}get CMYKAObject(){return kt.convert(this.cmyk,a.CMYK,this.options.decimals,!0)}get HEX(){return kt.convertCSS(this.rgb,a.HEX)}get HEXA(){return kt.convertCSS(this.rgb,a.HEX,{},!0)}get RGB(){return kt.convertCSS(this.rgb,a.RGB,this.options)}get RGBA(){return kt.convertCSS(this.rgb,a.RGB,this.options,!0)}get HSL(){return kt.convertCSS(this.hsl,a.HSL,this.options)}get HSLA(){return kt.convertCSS(this.hsl,a.HSL,this.options,!0)}get HWB(){return kt.convertCSS(this.hwb,a.HWB,this.options)}get HWBA(){return kt.convertCSS(this.hwb,a.HWB,this.options,!0)}get CIELab(){return kt.convertCSS(this.lab,a.CIELab,this.options)}get CIELabA(){return kt.convertCSS(this.lab,a.CIELab,this.options,!0)}get LCH(){return kt.convertCSS(this.lch,a.LCH,this.options)}get LCHA(){return kt.convertCSS(this.lch,a.LCH,this.options,!0)}get CMYK(){return kt.convertCSS(this.cmyk,a.CMYK,this.options)}get CMYKA(){return kt.convertCSS(this.cmyk,a.CMYK,this.options,!0)}static toHEXObject(t){return kt.convert(t,a.HEX)}static toHEX(t){return kt.convertCSS(t,a.HEX)}static toHEXAObject(t){return kt.convert(t,a.HEX,void 0,!0)}static toHEXA(t){return kt.convertCSS(t,a.HEX,void 0,!0)}static toRGBObject(t,e={}){return kt.convert(t,a.RGB,e.decimals)}static toRGB(t,e={}){return kt.convertCSS(t,a.RGB,xt(e,t))}static toRGBAObject(t,e={}){return kt.convert(t,a.RGB,e.decimals,!0)}static toRGBA(t,e={}){return kt.convertCSS(t,a.RGB,xt(e,t),!0)}static toHSLObject(t,e={}){return kt.convert(t,a.HSL,e.decimals)}static toHSL(t,e={}){return kt.convertCSS(t,a.HSL,xt(e,t))}static toHSLAObject(t,e={}){return kt.convert(t,a.HSL,e.decimals,!0)}static toHSLA(t,e={}){return kt.convertCSS(t,a.HSL,xt(e,t),!0)}static toHWBObject(t,e={}){return kt.convert(t,a.HWB,e.decimals)}static toHWB(t,e={}){return kt.convertCSS(t,a.HWB,xt(e,t))}static toHWBAObject(t,e={}){return kt.convert(t,a.HWB,e.decimals,!0)}static toHWBA(t,e={}){return kt.convertCSS(t,a.HWB,xt(e,t),!0)}static toCIELabObject(t,e={}){return kt.convert(t,a.CIELab,e.decimals)}static toCIELab(t,e={}){return kt.convertCSS(t,a.CIELab,xt(e,t))}static toCIELabAObject(t,e={}){return kt.convert(t,a.CIELab,e.decimals,!0)}static toCIELabA(t,e={}){return kt.convertCSS(t,a.CIELab,xt(e,t),!0)}static toLCHObject(t,e={}){return kt.convert(t,a.LCH,e.decimals)}static toLCH(t,e={}){return kt.convertCSS(t,a.LCH,xt(e,t))}static toLCHAObject(t,e={}){return kt.convert(t,a.LCH,e.decimals,!0)}static toLCHA(t,e={}){return kt.convertCSS(t,a.LCH,xt(e,t),!0)}static toCMYKObject(t,e={}){return kt.convert(t,a.CMYK,e.decimals)}static toCMYK(t,e={}){return kt.convertCSS(t,a.CMYK,xt(e,t))}static toCMYKAObject(t,e={}){return kt.convert(t,a.CMYK,e.decimals,!0)}static toCMYKA(t,e={}){return kt.convertCSS(t,a.CMYK,xt(e,t),!0)}static getBlendHEXObject(t,e,s){return Nt(t,e,a.HEX,!1,!1,s)}static getBlendHEX(t,e,s){return Nt(t,e,a.HEX,!0,!1,s)}static getBlendHEXAObject(t,e,s){return Nt(t,e,a.HEX,!1,!0,s)}static getBlendHEXA(t,e,s){return Nt(t,e,a.HEX,!0,!0,s)}static getBlendRGBObject(t,e,s,r){return Nt(t,e,a.RGB,!1,!1,...jt(s,r))}static getBlendRGB(t,e,s,r){return Nt(t,e,a.RGB,!0,!1,...jt(s,r))}static getBlendRGBAObject(t,e,s,r){return Nt(t,e,a.RGB,!1,!0,...jt(s,r))}static getBlendRGBA(t,e,s,r){return Nt(t,e,a.RGB,!0,!0,...jt(s,r))}static getBlendHSLObject(t,e,s,r){return Nt(t,e,a.HSL,!1,!1,...jt(s,r))}static getBlendHSL(t,e,s,r){return Nt(t,e,a.HSL,!0,!1,...jt(s,r))}static getBlendHSLAObject(t,e,s,r){return Nt(t,e,a.HSL,!1,!0,...jt(s,r))}static getBlendHSLA(t,e,s,r){return Nt(t,e,a.HSL,!0,!0,...jt(s,r))}static getBlendHWBObject(t,e,s,r){return Nt(t,e,a.HWB,!1,!1,...jt(s,r))}static getBlendHWB(t,e,s,r){return Nt(t,e,a.HWB,!0,!1,...jt(s,r))}static getBlendHWBAObject(t,e,s,r){return Nt(t,e,a.HWB,!1,!0,...jt(s,r))}static getBlendHWBA(t,e,s,r){return Nt(t,e,a.HWB,!0,!0,...jt(s,r))}static getBlendCIELabObject(t,e,s,r){return Nt(t,e,a.CIELab,!1,!1,...jt(s,r))}static getBlendCIELab(t,e,s,r){return Nt(t,e,a.CIELab,!0,!1,...jt(s,r))}static getBlendCIELabAObject(t,e,s,r){return Nt(t,e,a.CIELab,!1,!0,...jt(s,r))}static getBlendCIELabA(t,e,s,r){return Nt(t,e,a.CIELab,!0,!0,...jt(s,r))}static getBlendLCHObject(t,e,s,r){return Nt(t,e,a.LCH,!1,!1,...jt(s,r))}static getBlendLCH(t,e,s,r){return Nt(t,e,a.LCH,!0,!1,...jt(s,r))}static getBlendLCHAObject(t,e,s,r){return Nt(t,e,a.LCH,!1,!0,...jt(s,r))}static getBlendLCHA(t,e,s,r){return Nt(t,e,a.LCH,!0,!0,...jt(s,r))}static getMixHEXObject(t,e){return $t(t,a.HEX,!1,!1,e)}static getMixHEX(e,s=t.Mix.ADDITIVE){return $t(e,a.HEX,!0,!1,s)}static getMixHEXAObject(e,s=t.Mix.ADDITIVE){return $t(e,a.HEX,!1,!0,s)}static getMixHEXA(e,s=t.Mix.ADDITIVE){return $t(e,a.HEX,!0,!0,s)}static getMixRGBObject(t,e,s){return $t(t,a.RGB,!1,!1,...Yt(e,s))}static getMixRGB(t,e,s){return $t(t,a.RGB,!0,!1,...Yt(e,s))}static getMixRGBAObject(t,e,s){return $t(t,a.RGB,!1,!0,...Yt(e,s))}static getMixRGBA(t,e,s){return $t(t,a.RGB,!0,!0,...Yt(e,s))}static getMixHSLObject(t,e,s){return $t(t,a.HSL,!1,!1,...Yt(e,s))}static getMixHSL(t,e,s){return $t(t,a.HSL,!0,!1,...Yt(e,s))}static getMixHSLAObject(t,e,s){return $t(t,a.HSL,!1,!0,...Yt(e,s))}static getMixHSLA(t,e,s){return $t(t,a.HSL,!0,!0,...Yt(e,s))}static getMixHWBObject(t,e,s){return $t(t,a.HWB,!1,!1,...Yt(e,s))}static getMixHWB(t,e,s){return $t(t,a.HWB,!0,!1,...Yt(e,s))}static getMixHWBAObject(t,e,s){return $t(t,a.HWB,!1,!0,...Yt(e,s))}static getMixHWBA(t,e,s){return $t(t,a.HWB,!0,!0,...Yt(e,s))}static getMixCIELabObject(t,e,s){return $t(t,a.CIELab,!1,!1,...Yt(e,s))}static getMixCIELab(t,e,s){return $t(t,a.CIELab,!0,!1,...Yt(e,s))}static getMixCIELabAObject(t,e,s){return $t(t,a.CIELab,!1,!0,...Yt(e,s))}static getMixCIELabA(t,e,s){return $t(t,a.CIELab,!0,!0,...Yt(e,s))}static getMixLCHObject(t,e,s){return $t(t,a.LCH,!1,!1,...Yt(e,s))}static getMixLCH(t,e,s){return $t(t,a.LCH,!0,!1,...Yt(e,s))}static getMixLCHAObject(t,e,s){return $t(t,a.LCH,!1,!0,...Yt(e,s))}static getMixLCHA(t,e,s){return $t(t,a.LCH,!0,!0,...Yt(e,s))}static getShades(t,e,s){return Tt(!0,t,...Wt(e,s))}static getTints(t,e,s){return Tt(!1,t,...Wt(e,s))}static getHarmony(t,e,s,r){return((t,e,s,r={})=>{const n=Pt.get(e),i=M(t),c=kt.getParser(t),l=c.model,h=c.hasAlpha(t),o=n(kt.convert(t,a.HSL),s);return i?o.map((e=>kt.convertCSS(e,l,xt(r,t),h))):o.map((t=>kt.convert(t,l,r.decimals,h)))})(t,...Kt(e,s,r))}},t}({}); diff --git a/docs/scripts/bundle.js b/docs/scripts/bundle.js index 3ee5aba..f996133 100644 --- a/docs/scripts/bundle.js +++ b/docs/scripts/bundle.js @@ -1 +1 @@ -(()=>{var __webpack_modules__={966(module,exports){eval('{var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;!function(){var r=null;\n(function(){function X(e){function j(){try{J.doScroll("left")}catch(e){P(j,50);return}w("poll")}function w(j){if(!(j.type=="readystatechange"&&x.readyState!="complete")&&((j.type=="load"?n:x)[z](i+j.type,w,!1),!m&&(m=!0)))e.call(n,j.type||j)}var Y=x.addEventListener,m=!1,C=!0,t=Y?"addEventListener":"attachEvent",z=Y?"removeEventListener":"detachEvent",i=Y?"":"on";if(x.readyState=="complete")e.call(n,"lazy");else{if(x.createEventObject&&J.doScroll){try{C=!n.frameElement}catch(A){}C&&j()}x[t](i+"DOMContentLoaded",\nw,!1);x[t](i+"readystatechange",w,!1);n[t](i+"load",w,!1)}}function Q(){S&&X(function(){var e=K.length;$(e?function(){for(var j=0;j=0;){var M=A[m],T=M.src.match(/^[^#?]*\\/run_prettify\\.js(\\?[^#]*)?(?:#.*)?$/);if(T){z=T[1]||"";M.parentNode.removeChild(M);break}}var S=!0,D=\n[],N=[],K=[];z.replace(/[&?]([^&=]+)=([^&]+)/g,function(e,j,w){w=decodeURIComponent(w);j=decodeURIComponent(j);j=="autorun"?S=!/^[0fn]/i.test(w):j=="lang"?D.push(w):j=="skin"?N.push(w):j=="callback"&&K.push(w)});m=0;for(z=D.length;m122||(o<65||k>90||f.push([Math.max(65,k)|32,Math.min(o,90)|32]),o<97||k>122||f.push([Math.max(97,k)&-33,Math.min(o,122)&-33]))}}f.sort(function(f,a){return f[0]-\na[0]||a[1]-f[1]});b=[];g=[];for(a=0;ak[0]&&(k[1]+1>k[0]&&c.push("-"),c.push(h(k[1])));c.push("]");return c.join("")}function e(f){for(var a=f.source.match(/\\[(?:[^\\\\\\]]|\\\\[\\S\\s])*]|\\\\u[\\dA-Fa-f]{4}|\\\\x[\\dA-Fa-f]{2}|\\\\\\d+|\\\\[^\\dux]|\\(\\?[!:=]|[()^]|[^()[\\\\^]+/g),c=a.length,d=[],g=0,k=0;g=2&&f==="["?a[g]=b(o):f!=="\\\\"&&(a[g]=o.replace(/[A-Za-z]/g,function(a){a=a.charCodeAt(0);return"["+String.fromCharCode(a&-33,a|32)+"]"}));return a.join("")}for(var j=0,F=!1,l=!1,I=0,c=a.length;I=5&&"lang-"===y.substring(0,5))&&!(u&&typeof u[1]==="string"))g=!1,y="src";g||(m[B]=y)}k=c;c+=B.length;if(g){g=u[1];var o=B.indexOf(g),H=o+g.length;u[2]&&(H=B.length-u[2].length,o=H-g.length);y=y.substring(5);n(l+k,B.substring(0,o),h,j);n(l+k+o,g,A(y,\ng),j);n(l+k+H,B.substring(H),h,j)}else j.push(l+k,y)}a.g=j}var b={},e;(function(){for(var h=a.concat(d),l=[],i={},c=0,p=h.length;c=0;)b[q.charAt(f)]=m;m=m[1];q=""+m;i.hasOwnProperty(q)||(l.push(m),i[q]=r)}l.push(/[\\S\\s]/);e=j(l)})();var i=d.length;return h}function t(a){var d=[],h=[];a.tripleQuotedStrings?d.push(["str",/^(?:\'\'\'(?:[^\'\\\\]|\\\\[\\S\\s]|\'\'?(?=[^\']))*(?:\'\'\'|$)|"""(?:[^"\\\\]|\\\\[\\S\\s]|""?(?=[^"]))*(?:"""|$)|\'(?:[^\'\\\\]|\\\\[\\S\\s])*(?:\'|$)|"(?:[^"\\\\]|\\\\[\\S\\s])*(?:"|$))/,\nr,"\'\\""]):a.multiLineStrings?d.push(["str",/^(?:\'(?:[^\'\\\\]|\\\\[\\S\\s])*(?:\'|$)|"(?:[^"\\\\]|\\\\[\\S\\s])*(?:"|$)|`(?:[^\\\\`]|\\\\[\\S\\s])*(?:`|$))/,r,"\'\\"`"]):d.push(["str",/^(?:\'(?:[^\\n\\r\'\\\\]|\\\\.)*(?:\'|$)|"(?:[^\\n\\r"\\\\]|\\\\.)*(?:"|$))/,r,"\\"\'"]);a.verbatimStrings&&h.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,r]);var b=a.hashComments;b&&(a.cStyleComments?(b>1?d.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,r,"#"]):d.push(["com",/^#(?:(?:define|e(?:l|nd)if|else|error|ifn?def|include|line|pragma|undef|warning)\\b|[^\\n\\r]*)/,\nr,"#"]),h.push(["str",/^<(?:(?:(?:\\.\\.\\/)*|\\/?)(?:[\\w-]+(?:\\/[\\w-]+)+)?[\\w-]+\\.h(?:h|pp|\\+\\+)?|[a-z]\\w*)>/,r])):d.push(["com",/^#[^\\n\\r]*/,r,"#"]));a.cStyleComments&&(h.push(["com",/^\\/\\/[^\\n\\r]*/,r]),h.push(["com",/^\\/\\*[\\S\\s]*?(?:\\*\\/|$)/,r]));if(b=a.regexLiterals){var e=(b=b>1?"":"\\n\\r")?".":"[\\\\S\\\\s]";h.push(["lang-regex",RegExp("^(?:^^\\\\.?|[+-]|[!=]=?=?|\\\\#|%=?|&&?=?|\\\\(|\\\\*=?|[+\\\\-]=|->|\\\\/=?|::?|<>?>?=?|,|;|\\\\?|@|\\\\[|~|{|\\\\^\\\\^?=?|\\\\|\\\\|?=?|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\\\s*("+\n("/(?=[^/*"+b+"])(?:[^/\\\\x5B\\\\x5C"+b+"]|\\\\x5C"+e+"|\\\\x5B(?:[^\\\\x5C\\\\x5D"+b+"]|\\\\x5C"+e+")*(?:\\\\x5D|$))+/")+")")])}(b=a.types)&&h.push(["typ",b]);b=(""+a.keywords).replace(/^ | $/g,"");b.length&&h.push(["kwd",RegExp("^(?:"+b.replace(/[\\s,]+/g,"|")+")\\\\b"),r]);d.push(["pln",/^\\s+/,r," \\r\\n\\t\\u00a0"]);b="^.[^\\\\s\\\\w.$@\'\\"`/\\\\\\\\]*";a.regexLiterals&&(b+="(?!s*/)");h.push(["lit",/^@[$_a-z][\\w$@]*/i,r],["typ",/^(?:[@_]?[A-Z]+[a-z][\\w$@]*|\\w+_t\\b)/,r],["pln",/^[$_a-z][\\w$@]*/i,r],["lit",/^(?:0x[\\da-f]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+-]?\\d+)?)[a-z]*/i,\nr,"0123456789"],["pln",/^\\\\[\\S\\s]?/,r],["pun",RegExp(b),r]);return C(d,h)}function z(a,d,h){function b(a){var c=a.nodeType;if(c==1&&!j.test(a.className))if("br"===a.nodeName)e(a),a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)b(a);else if((c==3||c==4)&&h){var d=a.nodeValue,i=d.match(m);if(i)c=d.substring(0,i.index),a.nodeValue=c,(d=d.substring(i.index+i[0].length))&&a.parentNode.insertBefore(l.createTextNode(d),a.nextSibling),e(a),c||a.parentNode.removeChild(a)}}\nfunction e(a){function b(a,c){var d=c?a.cloneNode(!1):a,f=a.parentNode;if(f){var f=b(f,1),h=a.nextSibling;f.appendChild(d);for(var e=h;e;e=h)h=e.nextSibling,f.appendChild(e)}return d}for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=b(a.nextSibling,0),d;(d=a.parentNode)&&d.nodeType===1;)a=d;c.push(a)}for(var j=/(?:^|\\s)nocode(?:\\s|$)/,m=/\\r\\n?|\\n/,l=a.ownerDocument,i=l.createElement("li");a.firstChild;)i.appendChild(a.firstChild);for(var c=[i],p=0;p=0;){var b=d[h];U.hasOwnProperty(b)?V.console&&console.warn("cannot override language handler %s",b):U[b]=a}}function A(a,d){if(!a||!U.hasOwnProperty(a))a=/^\\s*=o&&(b+=2);h>=H&&(t+=2)}}finally{if(g)g.style.display=k}}catch(v){V.console&&console.log(v&&v.stack||v)}}var V=window,G=["break,continue,do,else,for,if,return,while"],O=[[G,"auto,case,char,const,default,double,enum,extern,float,goto,inline,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],\n"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],J=[O,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,delegate,dynamic_cast,explicit,export,friend,generic,late_check,mutable,namespace,nullptr,property,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],K=[O,"abstract,assert,boolean,byte,extends,final,finally,implements,import,instanceof,interface,null,native,package,strictfp,super,synchronized,throws,transient"],\nL=[K,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,internal,into,is,let,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var,virtual,where"],O=[O,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],M=[G,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],\nN=[G,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],R=[G,"as,assert,const,copy,drop,enum,extern,fail,false,fn,impl,let,log,loop,match,mod,move,mut,priv,pub,pure,ref,self,static,struct,true,trait,type,unsafe,use"],G=[G,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],Q=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\\d*)\\b/,\nS=/\\S/,T=t({keywords:[J,L,O,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",M,N,G],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),U={};i(T,["default-code"]);i(C([],[["pln",/^[^]*(?:>|$)/],["com",/^<\\!--[\\S\\s]*?(?:--\\>|$)/],["lang-",/^<\\?([\\S\\s]+?)(?:\\?>|$)/],["lang-",/^<%([\\S\\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-",\n/^]*>([\\S\\s]+?)<\\/xmp\\b[^>]*>/i],["lang-js",/^]*>([\\S\\s]*?)(<\\/script\\b[^>]*>)/i],["lang-css",/^]*>([\\S\\s]*?)(<\\/style\\b[^>]*>)/i],["lang-in.tag",/^(<\\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);i(C([["pln",/^\\s+/,r," \\t\\r\\n"],["atv",/^(?:"[^"]*"?|\'[^\']*\'?)/,r,"\\"\'"]],[["tag",/^^<\\/?[a-z](?:[\\w-.:]*\\w)?|\\/?>$/i],["atn",/^(?!style[\\s=]|on)[a-z](?:[\\w:-]*\\w)?/i],["lang-uq.val",/^=\\s*([^\\s"\'>]*(?:[^\\s"\'/>]|\\/(?=\\s)))/],["pun",/^[/<->]+/],\n["lang-js",/^on\\w+\\s*=\\s*"([^"]+)"/i],["lang-js",/^on\\w+\\s*=\\s*\'([^\']+)\'/i],["lang-js",/^on\\w+\\s*=\\s*([^\\s"\'>]+)/i],["lang-css",/^style\\s*=\\s*"([^"]+)"/i],["lang-css",/^style\\s*=\\s*\'([^\']+)\'/i],["lang-css",/^style\\s*=\\s*([^\\s"\'>]+)/i]]),["in.tag"]);i(C([],[["atv",/^[\\S\\s]+/]]),["uq.val"]);i(t({keywords:J,hashComments:!0,cStyleComments:!0,types:Q}),["c","cc","cpp","cxx","cyc","m"]);i(t({keywords:"null,true,false"}),["json"]);i(t({keywords:L,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:Q}),\n["cs"]);i(t({keywords:K,cStyleComments:!0}),["java"]);i(t({keywords:G,hashComments:!0,multiLineStrings:!0}),["bash","bsh","csh","sh"]);i(t({keywords:M,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}),["cv","py","python"]);i(t({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:2}),["perl","pl","pm"]);i(t({keywords:N,\nhashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["rb","ruby"]);i(t({keywords:O,cStyleComments:!0,regexLiterals:!0}),["javascript","js"]);i(t({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,throw,true,try,unless,until,when,while,yes",hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);i(t({keywords:R,cStyleComments:!0,multilineStrings:!0}),["rc","rs","rust"]);\ni(C([],[["str",/^[\\S\\s]+/]]),["regex"]);var X=V.PR={createSimpleLexer:C,registerLangHandler:i,sourceDecorator:t,PR_ATTRIB_NAME:"atn",PR_ATTRIB_VALUE:"atv",PR_COMMENT:"com",PR_DECLARATION:"dec",PR_KEYWORD:"kwd",PR_LITERAL:"lit",PR_NOCODE:"nocode",PR_PLAIN:"pln",PR_PUNCTUATION:"pun",PR_SOURCE:"src",PR_STRING:"str",PR_TAG:"tag",PR_TYPE:"typ",prettyPrintOne:function(a,d,e){var b=document.createElement("div");b.innerHTML="
"+a+"
";b=b.firstChild;e&&z(b,e,!0);D({h:d,j:e,c:b,i:1});return b.innerHTML},\nprettyPrint:e=e=function(a,d){function e(){for(var b=V.PR_SHOULD_USE_CONTINUATION?c.now()+250:Infinity;p -1\n }\n}\n\nfunction normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name)\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~!]/i.test(name) || name === '') {\n throw new TypeError('Invalid character in header field name: \"' + name + '\"')\n }\n return name.toLowerCase()\n}\n\nfunction normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value)\n }\n return value\n}\n\n// Build a destructive iterator for the value list\nfunction iteratorFor(items) {\n var iterator = {\n next: function() {\n var value = items.shift()\n return {done: value === undefined, value: value}\n }\n }\n\n if (support.iterable) {\n iterator[Symbol.iterator] = function() {\n return iterator\n }\n }\n\n return iterator\n}\n\nfunction Headers(headers) {\n this.map = {}\n\n if (headers instanceof Headers) {\n headers.forEach(function(value, name) {\n this.append(name, value)\n }, this)\n } else if (Array.isArray(headers)) {\n headers.forEach(function(header) {\n if (header.length != 2) {\n throw new TypeError('Headers constructor: expected name/value pair to be length 2, found' + header.length)\n }\n this.append(header[0], header[1])\n }, this)\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function(name) {\n this.append(name, headers[name])\n }, this)\n }\n}\n\nHeaders.prototype.append = function(name, value) {\n name = normalizeName(name)\n value = normalizeValue(value)\n var oldValue = this.map[name]\n this.map[name] = oldValue ? oldValue + ', ' + value : value\n}\n\nHeaders.prototype['delete'] = function(name) {\n delete this.map[normalizeName(name)]\n}\n\nHeaders.prototype.get = function(name) {\n name = normalizeName(name)\n return this.has(name) ? this.map[name] : null\n}\n\nHeaders.prototype.has = function(name) {\n return this.map.hasOwnProperty(normalizeName(name))\n}\n\nHeaders.prototype.set = function(name, value) {\n this.map[normalizeName(name)] = normalizeValue(value)\n}\n\nHeaders.prototype.forEach = function(callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this)\n }\n }\n}\n\nHeaders.prototype.keys = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push(name)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.values = function() {\n var items = []\n this.forEach(function(value) {\n items.push(value)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.entries = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push([name, value])\n })\n return iteratorFor(items)\n}\n\nif (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n}\n\nfunction consumed(body) {\n if (body._noBody) return\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'))\n }\n body.bodyUsed = true\n}\n\nfunction fileReaderReady(reader) {\n return new Promise(function(resolve, reject) {\n reader.onload = function() {\n resolve(reader.result)\n }\n reader.onerror = function() {\n reject(reader.error)\n }\n })\n}\n\nfunction readBlobAsArrayBuffer(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n reader.readAsArrayBuffer(blob)\n return promise\n}\n\nfunction readBlobAsText(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n var match = /charset=([A-Za-z0-9_-]+)/.exec(blob.type)\n var encoding = match ? match[1] : 'utf-8'\n reader.readAsText(blob, encoding)\n return promise\n}\n\nfunction readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf)\n var chars = new Array(view.length)\n\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i])\n }\n return chars.join('')\n}\n\nfunction bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0)\n } else {\n var view = new Uint8Array(buf.byteLength)\n view.set(new Uint8Array(buf))\n return view.buffer\n }\n}\n\nfunction Body() {\n this.bodyUsed = false\n\n this._initBody = function(body) {\n /*\n fetch-mock wraps the Response object in an ES6 Proxy to\n provide useful test harness features such as flush. However, on\n ES5 browsers without fetch or Proxy support pollyfills must be used;\n the proxy-pollyfill is unable to proxy an attribute unless it exists\n on the object before the Proxy is created. This change ensures\n Response.bodyUsed exists on the instance, while maintaining the\n semantic of setting Request.bodyUsed in the constructor before\n _initBody is called.\n */\n // eslint-disable-next-line no-self-assign\n this.bodyUsed = this.bodyUsed\n this._bodyInit = body\n if (!body) {\n this._noBody = true;\n this._bodyText = ''\n } else if (typeof body === 'string') {\n this._bodyText = body\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString()\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer)\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer])\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body)\n } else {\n this._bodyText = body = Object.prototype.toString.call(body)\n }\n\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8')\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type)\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n }\n }\n }\n\n if (support.blob) {\n this.blob = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob')\n } else {\n return Promise.resolve(new Blob([this._bodyText]))\n }\n }\n }\n\n this.arrayBuffer = function() {\n if (this._bodyArrayBuffer) {\n var isConsumed = consumed(this)\n if (isConsumed) {\n return isConsumed\n } else if (ArrayBuffer.isView(this._bodyArrayBuffer)) {\n return Promise.resolve(\n this._bodyArrayBuffer.buffer.slice(\n this._bodyArrayBuffer.byteOffset,\n this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength\n )\n )\n } else {\n return Promise.resolve(this._bodyArrayBuffer)\n }\n } else if (support.blob) {\n return this.blob().then(readBlobAsArrayBuffer)\n } else {\n throw new Error('could not read as ArrayBuffer')\n }\n }\n\n this.text = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text')\n } else {\n return Promise.resolve(this._bodyText)\n }\n }\n\n if (support.formData) {\n this.formData = function() {\n return this.text().then(decode)\n }\n }\n\n this.json = function() {\n return this.text().then(JSON.parse)\n }\n\n return this\n}\n\n// HTTP methods whose capitalization should be normalized\nvar methods = ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'TRACE']\n\nfunction normalizeMethod(method) {\n var upcased = method.toUpperCase()\n return methods.indexOf(upcased) > -1 ? upcased : method\n}\n\nfunction Request(input, options) {\n if (!(this instanceof Request)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n\n options = options || {}\n var body = options.body\n\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read')\n }\n this.url = input.url\n this.credentials = input.credentials\n if (!options.headers) {\n this.headers = new Headers(input.headers)\n }\n this.method = input.method\n this.mode = input.mode\n this.signal = input.signal\n if (!body && input._bodyInit != null) {\n body = input._bodyInit\n input.bodyUsed = true\n }\n } else {\n this.url = String(input)\n }\n\n this.credentials = options.credentials || this.credentials || 'same-origin'\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers)\n }\n this.method = normalizeMethod(options.method || this.method || 'GET')\n this.mode = options.mode || this.mode || null\n this.signal = options.signal || this.signal || (function () {\n if ('AbortController' in g) {\n var ctrl = new AbortController();\n return ctrl.signal;\n }\n }());\n this.referrer = null\n\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests')\n }\n this._initBody(body)\n\n if (this.method === 'GET' || this.method === 'HEAD') {\n if (options.cache === 'no-store' || options.cache === 'no-cache') {\n // Search for a '_' parameter in the query string\n var reParamSearch = /([?&])_=[^&]*/\n if (reParamSearch.test(this.url)) {\n // If it already exists then set the value with the current time\n this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime())\n } else {\n // Otherwise add a new '_' parameter to the end with the current time\n var reQueryString = /\\?/\n this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime()\n }\n }\n }\n}\n\nRequest.prototype.clone = function() {\n return new Request(this, {body: this._bodyInit})\n}\n\nfunction decode(body) {\n var form = new FormData()\n body\n .trim()\n .split('&')\n .forEach(function(bytes) {\n if (bytes) {\n var split = bytes.split('=')\n var name = split.shift().replace(/\\+/g, ' ')\n var value = split.join('=').replace(/\\+/g, ' ')\n form.append(decodeURIComponent(name), decodeURIComponent(value))\n }\n })\n return form\n}\n\nfunction parseHeaders(rawHeaders) {\n var headers = new Headers()\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ')\n // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill\n // https://github.com/github/fetch/issues/748\n // https://github.com/zloirock/core-js/issues/751\n preProcessedHeaders\n .split('\\r')\n .map(function(header) {\n return header.indexOf('\\n') === 0 ? header.substr(1, header.length) : header\n })\n .forEach(function(line) {\n var parts = line.split(':')\n var key = parts.shift().trim()\n if (key) {\n var value = parts.join(':').trim()\n try {\n headers.append(key, value)\n } catch (error) {\n console.warn('Response ' + error.message)\n }\n }\n })\n return headers\n}\n\nBody.call(Request.prototype)\n\nfunction Response(bodyInit, options) {\n if (!(this instanceof Response)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n if (!options) {\n options = {}\n }\n\n this.type = 'default'\n this.status = options.status === undefined ? 200 : options.status\n if (this.status < 200 || this.status > 599) {\n throw new RangeError(\"Failed to construct 'Response': The status provided (0) is outside the range [200, 599].\")\n }\n this.ok = this.status >= 200 && this.status < 300\n this.statusText = options.statusText === undefined ? '' : '' + options.statusText\n this.headers = new Headers(options.headers)\n this.url = options.url || ''\n this._initBody(bodyInit)\n}\n\nBody.call(Response.prototype)\n\nResponse.prototype.clone = function() {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n })\n}\n\nResponse.error = function() {\n var response = new Response(null, {status: 200, statusText: ''})\n response.ok = false\n response.status = 0\n response.type = 'error'\n return response\n}\n\nvar redirectStatuses = [301, 302, 303, 307, 308]\n\nResponse.redirect = function(url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code')\n }\n\n return new Response(null, {status: status, headers: {location: url}})\n}\n\nvar DOMException = g.DOMException\ntry {\n new DOMException()\n} catch (err) {\n DOMException = function(message, name) {\n this.message = message\n this.name = name\n var error = Error(message)\n this.stack = error.stack\n }\n DOMException.prototype = Object.create(Error.prototype)\n DOMException.prototype.constructor = DOMException\n}\n\nfunction fetch_fetch(input, init) {\n return new Promise(function(resolve, reject) {\n var request = new Request(input, init)\n\n if (request.signal && request.signal.aborted) {\n return reject(new DOMException('Aborted', 'AbortError'))\n }\n\n var xhr = new XMLHttpRequest()\n\n function abortXhr() {\n xhr.abort()\n }\n\n xhr.onload = function() {\n var options = {\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n }\n // This check if specifically for when a user fetches a file locally from the file system\n // Only if the status is out of a normal range\n if (request.url.indexOf('file://') === 0 && (xhr.status < 200 || xhr.status > 599)) {\n options.status = 200;\n } else {\n options.status = xhr.status;\n }\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n var body = 'response' in xhr ? xhr.response : xhr.responseText\n setTimeout(function() {\n resolve(new Response(body, options))\n }, 0)\n }\n\n xhr.onerror = function() {\n setTimeout(function() {\n reject(new TypeError('Network request failed'))\n }, 0)\n }\n\n xhr.ontimeout = function() {\n setTimeout(function() {\n reject(new TypeError('Network request timed out'))\n }, 0)\n }\n\n xhr.onabort = function() {\n setTimeout(function() {\n reject(new DOMException('Aborted', 'AbortError'))\n }, 0)\n }\n\n function fixUrl(url) {\n try {\n return url === '' && g.location.href ? g.location.href : url\n } catch (e) {\n return url\n }\n }\n\n xhr.open(request.method, fixUrl(request.url), true)\n\n if (request.credentials === 'include') {\n xhr.withCredentials = true\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false\n }\n\n if ('responseType' in xhr) {\n if (support.blob) {\n xhr.responseType = 'blob'\n } else if (\n support.arrayBuffer\n ) {\n xhr.responseType = 'arraybuffer'\n }\n }\n\n if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers || (g.Headers && init.headers instanceof g.Headers))) {\n var names = [];\n Object.getOwnPropertyNames(init.headers).forEach(function(name) {\n names.push(normalizeName(name))\n xhr.setRequestHeader(name, normalizeValue(init.headers[name]))\n })\n request.headers.forEach(function(value, name) {\n if (names.indexOf(name) === -1) {\n xhr.setRequestHeader(name, value)\n }\n })\n } else {\n request.headers.forEach(function(value, name) {\n xhr.setRequestHeader(name, value)\n })\n }\n\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr)\n\n xhr.onreadystatechange = function() {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr)\n }\n }\n }\n\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n })\n}\n\nfetch_fetch.polyfill = true\n\nif (!g.fetch) {\n g.fetch = fetch_fetch\n g.Headers = Headers\n g.Request = Request\n g.Response = Response\n}\n\n;// ./src/constants/numbers.ts\nconst MAX_DECIMALS = 6;\nconst DEFAULT_BLEND_STEPS = 5;\nconst DEFAULT_SHADES_TINTS_STEPS = 5;\nconst BASE_255 = 255;\nconst MAX_HUE = 360;\nconst MAX_PCENT = 100;\nconst MAX_ALPHA = 1;\nconst MAX_LAB = 125;\nconst MAX_LCH_C = 150;\n\n;// ./src/constants/enums.ts\nvar ColorModel;\n(function (ColorModel) {\n ColorModel[\"HEX\"] = \"HEX\";\n ColorModel[\"RGB\"] = \"RGB\";\n ColorModel[\"HWB\"] = \"HWB\";\n ColorModel[\"HSL\"] = \"HSL\";\n ColorModel[\"CIELab\"] = \"CIELab\";\n ColorModel[\"LCH\"] = \"LCH\";\n ColorModel[\"CMYK\"] = \"CMYK\";\n})(ColorModel || (ColorModel = {}));\nvar Harmony;\n(function (Harmony) {\n Harmony[\"ANALOGOUS\"] = \"ANALOGOUS\";\n Harmony[\"COMPLEMENTARY\"] = \"COMPLEMENTARY\";\n Harmony[\"SPLIT_COMPLEMENTARY\"] = \"SPLIT_COMPLEMENTARY\";\n Harmony[\"TRIADIC\"] = \"TRIADIC\";\n Harmony[\"TETRADIC\"] = \"TETRADIC\";\n Harmony[\"SQUARE\"] = \"SQUARE\";\n})(Harmony || (Harmony = {}));\nvar Mix;\n(function (Mix) {\n Mix[\"ADDITIVE\"] = \"ADDITIVE\";\n Mix[\"SUBTRACTIVE\"] = \"SUBTRACTIVE\";\n})(Mix || (Mix = {}));\nvar ColorKeywords;\n(function (ColorKeywords) {\n ColorKeywords[\"black\"] = \"#000000\";\n ColorKeywords[\"silver\"] = \"#C0C0C0\";\n ColorKeywords[\"gray\"] = \"#808080\";\n ColorKeywords[\"white\"] = \"#FFFFFF\";\n ColorKeywords[\"maroon\"] = \"#800000\";\n ColorKeywords[\"red\"] = \"#FF0000\";\n ColorKeywords[\"purple\"] = \"#800080\";\n ColorKeywords[\"fuchsia\"] = \"#FF00FF\";\n ColorKeywords[\"green\"] = \"#008000\";\n ColorKeywords[\"lime\"] = \"#00FF00\";\n ColorKeywords[\"olive\"] = \"#808000\";\n ColorKeywords[\"yellow\"] = \"#FFFF00\";\n ColorKeywords[\"navy\"] = \"#000080\";\n ColorKeywords[\"blue\"] = \"#0000FF\";\n ColorKeywords[\"teal\"] = \"#008080\";\n ColorKeywords[\"aqua\"] = \"#00FFFF\";\n ColorKeywords[\"orange\"] = \"#FFA500\";\n ColorKeywords[\"aliceblue\"] = \"#F0F8FF\";\n ColorKeywords[\"antiquewhite\"] = \"#FAEBD7\";\n ColorKeywords[\"aquamarine\"] = \"#7FFFD4\";\n ColorKeywords[\"azure\"] = \"#F0FFFF\";\n ColorKeywords[\"beige\"] = \"#F5F5DC\";\n ColorKeywords[\"bisque\"] = \"#FFE4C4\";\n ColorKeywords[\"blanchedalmond\"] = \"#FFEBCD\";\n ColorKeywords[\"blueviolet\"] = \"#8A2BE2\";\n ColorKeywords[\"brown\"] = \"#A52A2A\";\n ColorKeywords[\"burlywood\"] = \"#DEB887\";\n ColorKeywords[\"cadetblue\"] = \"#5F9EA0\";\n ColorKeywords[\"chartreuse\"] = \"#7FFF00\";\n ColorKeywords[\"chocolate\"] = \"#D2691E\";\n ColorKeywords[\"coral\"] = \"#FF7F50\";\n ColorKeywords[\"cornflowerblue\"] = \"#6495ED\";\n ColorKeywords[\"cornsilk\"] = \"#FFF8DC\";\n ColorKeywords[\"crimson\"] = \"#DC143C\";\n ColorKeywords[\"cyan\"] = \"#00FFFF\";\n ColorKeywords[\"darkblue\"] = \"#00008B\";\n ColorKeywords[\"darkcyan\"] = \"#008B8B\";\n ColorKeywords[\"darkgoldenrod\"] = \"#B8860B\";\n ColorKeywords[\"darkgray\"] = \"#A9A9A9\";\n ColorKeywords[\"darkgreen\"] = \"#006400\";\n ColorKeywords[\"darkgrey\"] = \"#A9A9A9\";\n ColorKeywords[\"darkkhaki\"] = \"#BDB76B\";\n ColorKeywords[\"darkmagenta\"] = \"#8B008B\";\n ColorKeywords[\"darkolivegreen\"] = \"#556B2F\";\n ColorKeywords[\"darkorange\"] = \"#FF8C00\";\n ColorKeywords[\"darkorchid\"] = \"#9932CC\";\n ColorKeywords[\"darkred\"] = \"#8B0000\";\n ColorKeywords[\"darksalmon\"] = \"#E9967A\";\n ColorKeywords[\"darkseagreen\"] = \"#8FBC8F\";\n ColorKeywords[\"darkslateblue\"] = \"#483D8B\";\n ColorKeywords[\"darkslategray\"] = \"#2F4F4F\";\n ColorKeywords[\"darkslategrey\"] = \"#2F4F4F\";\n ColorKeywords[\"darkturquoise\"] = \"#00CED1\";\n ColorKeywords[\"darkviolet\"] = \"#9400D3\";\n ColorKeywords[\"deeppink\"] = \"#FF1493\";\n ColorKeywords[\"deepskyblue\"] = \"#00BFFF\";\n ColorKeywords[\"dimgray\"] = \"#696969\";\n ColorKeywords[\"dimgrey\"] = \"#696969\";\n ColorKeywords[\"dodgerblue\"] = \"#1E90FF\";\n ColorKeywords[\"firebrick\"] = \"#B22222\";\n ColorKeywords[\"floralwhite\"] = \"#FFFAF0\";\n ColorKeywords[\"forestgreen\"] = \"#228B22\";\n ColorKeywords[\"gainsboro\"] = \"#DCDCDC\";\n ColorKeywords[\"ghostwhite\"] = \"#F8F8FF\";\n ColorKeywords[\"gold\"] = \"#FFD700\";\n ColorKeywords[\"goldenrod\"] = \"#DAA520\";\n ColorKeywords[\"greenyellow\"] = \"#ADFF2F\";\n ColorKeywords[\"grey\"] = \"#808080\";\n ColorKeywords[\"honeydew\"] = \"#F0FFF0\";\n ColorKeywords[\"hotpink\"] = \"#FF69B4\";\n ColorKeywords[\"indianred\"] = \"#CD5C5C\";\n ColorKeywords[\"indigo\"] = \"#4B0082\";\n ColorKeywords[\"ivory\"] = \"#FFFFF0\";\n ColorKeywords[\"khaki\"] = \"#F0E68C\";\n ColorKeywords[\"lavender\"] = \"#E6E6FA\";\n ColorKeywords[\"lavenderblush\"] = \"#FFF0F5\";\n ColorKeywords[\"lawngreen\"] = \"#7CFC00\";\n ColorKeywords[\"lemonchiffon\"] = \"#FFFACD\";\n ColorKeywords[\"lightblue\"] = \"#ADD8E6\";\n ColorKeywords[\"lightcoral\"] = \"#F08080\";\n ColorKeywords[\"lightcyan\"] = \"#E0FFFF\";\n ColorKeywords[\"lightgoldenrodyellow\"] = \"#FAFAD2\";\n ColorKeywords[\"lightgray\"] = \"#D3D3D3\";\n ColorKeywords[\"lightgreen\"] = \"#90EE90\";\n ColorKeywords[\"lightgrey\"] = \"#D3D3D3\";\n ColorKeywords[\"lightpink\"] = \"#FFB6C1\";\n ColorKeywords[\"lightsalmon\"] = \"#FFA07A\";\n ColorKeywords[\"lightseagreen\"] = \"#20B2AA\";\n ColorKeywords[\"lightskyblue\"] = \"#87CEFA\";\n ColorKeywords[\"lightslategray\"] = \"#778899\";\n ColorKeywords[\"lightslategrey\"] = \"#778899\";\n ColorKeywords[\"lightsteelblue\"] = \"#B0C4DE\";\n ColorKeywords[\"lightyellow\"] = \"#FFFFE0\";\n ColorKeywords[\"limegreen\"] = \"#32CD32\";\n ColorKeywords[\"linen\"] = \"#FAF0E6\";\n ColorKeywords[\"magenta\"] = \"#FF00FF\";\n ColorKeywords[\"mediumaquamarine\"] = \"#66CDAA\";\n ColorKeywords[\"mediumblue\"] = \"#0000CD\";\n ColorKeywords[\"mediumorchid\"] = \"#BA55D3\";\n ColorKeywords[\"mediumpurple\"] = \"#9370DB\";\n ColorKeywords[\"mediumseagreen\"] = \"#3CB371\";\n ColorKeywords[\"mediumslateblue\"] = \"#7B68EE\";\n ColorKeywords[\"mediumspringgreen\"] = \"#00FA9A\";\n ColorKeywords[\"mediumturquoise\"] = \"#48D1CC\";\n ColorKeywords[\"mediumvioletred\"] = \"#C71585\";\n ColorKeywords[\"midnightblue\"] = \"#191970\";\n ColorKeywords[\"mintcream\"] = \"#F5FFFA\";\n ColorKeywords[\"mistyrose\"] = \"#FFE4E1\";\n ColorKeywords[\"moccasin\"] = \"#FFE4B5\";\n ColorKeywords[\"navajowhite\"] = \"#FFDEAD\";\n ColorKeywords[\"oldlace\"] = \"#FDF5E6\";\n ColorKeywords[\"olivedrab\"] = \"#6B8E23\";\n ColorKeywords[\"orangered\"] = \"#FF4500\";\n ColorKeywords[\"orchid\"] = \"#DA70D6\";\n ColorKeywords[\"palegoldenrod\"] = \"#EEE8AA\";\n ColorKeywords[\"palegreen\"] = \"#98FB98\";\n ColorKeywords[\"paleturquoise\"] = \"#AFEEEE\";\n ColorKeywords[\"palevioletred\"] = \"#DB7093\";\n ColorKeywords[\"papayawhip\"] = \"#FFEFD5\";\n ColorKeywords[\"peachpuff\"] = \"#FFDAB9\";\n ColorKeywords[\"peru\"] = \"#CD853F\";\n ColorKeywords[\"pink\"] = \"#FFC0CB\";\n ColorKeywords[\"plum\"] = \"#DDA0DD\";\n ColorKeywords[\"powderblue\"] = \"#B0E0E6\";\n ColorKeywords[\"rosybrown\"] = \"#BC8F8F\";\n ColorKeywords[\"royalblue\"] = \"#4169E1\";\n ColorKeywords[\"saddlebrown\"] = \"#8B4513\";\n ColorKeywords[\"salmon\"] = \"#FA8072\";\n ColorKeywords[\"sandybrown\"] = \"#F4A460\";\n ColorKeywords[\"seagreen\"] = \"#2E8B57\";\n ColorKeywords[\"seashell\"] = \"#FFF5EE\";\n ColorKeywords[\"sienna\"] = \"#A0522D\";\n ColorKeywords[\"skyblue\"] = \"#87CEEB\";\n ColorKeywords[\"slateblue\"] = \"#6A5ACD\";\n ColorKeywords[\"slategray\"] = \"#708090\";\n ColorKeywords[\"slategrey\"] = \"#708090\";\n ColorKeywords[\"snow\"] = \"#FFFAFA\";\n ColorKeywords[\"springgreen\"] = \"#00FF7F\";\n ColorKeywords[\"steelblue\"] = \"#4682B4\";\n ColorKeywords[\"tan\"] = \"#D2B48C\";\n ColorKeywords[\"thistle\"] = \"#D8BFD8\";\n ColorKeywords[\"tomato\"] = \"#FF6347\";\n ColorKeywords[\"turquoise\"] = \"#40E0D0\";\n ColorKeywords[\"violet\"] = \"#EE82EE\";\n ColorKeywords[\"wheat\"] = \"#F5DEB3\";\n ColorKeywords[\"whitesmoke\"] = \"#F5F5F5\";\n ColorKeywords[\"yellowgreen\"] = \"#9ACD32\";\n ColorKeywords[\"rebeccapurple\"] = \"#663399\";\n})(ColorKeywords || (ColorKeywords = {}));\nconst COLOR_KEYS = Object.keys(ColorKeywords);\nconst COLOR_PROPS = {\n HEX: ['R', 'G', 'B', 'A'],\n RGB: ['R', 'G', 'B', 'A'],\n HSL: ['H', 'S', 'L', 'A'],\n HWB: ['H', 'W', 'B', 'A'],\n CIELab: ['L', 'a', 'b', 'A'],\n LCH: ['L', 'C', 'H', 'A'],\n CMYK: ['C', 'M', 'Y', 'K', 'A']\n};\nconst VALID_COLOR_OBJECTS = {\n ABGR: ColorModel.RGB,\n ABHW: ColorModel.HWB,\n ACHL: ColorModel.LCH,\n ACKMY: ColorModel.CMYK,\n AHLS: ColorModel.HSL,\n ALAB: ColorModel.CIELab,\n BGR: ColorModel.RGB,\n BHW: ColorModel.HWB,\n CHL: ColorModel.LCH,\n CKMY: ColorModel.CMYK,\n HLS: ColorModel.HSL,\n LAB: ColorModel.CIELab\n};\nvar TypeOf;\n(function (TypeOf) {\n TypeOf[\"NUMBER\"] = \"number\";\n TypeOf[\"BOOLEAN\"] = \"boolean\";\n})(TypeOf || (TypeOf = {}));\n\n;// ./src/constants/regexps.ts\n\nconst COLORREGS = {\n [ColorModel.HEX]: /^#(?:(?[a-f\\d])(?[a-f\\d])(?[a-f\\d])(?
[a-f\\d])?|(?[a-f\\d]{2})(?[a-f\\d]{2})(?[a-f\\d]{2})(?[a-f\\d]{2})?)$/i,\n [ColorModel.RGB]: /^rgba?\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?(?:\\d*\\.)?\\d+))?|(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.HWB]: /^hwb\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?(?:\\d*\\.)?\\d+)%\\s+(?(?:\\d*\\.)?\\d+)%(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?\\s+(?(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.HSL]: /^hsla?\\s*\\(\\s*(?:(?-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s*,\\s*(?(?:\\d*\\.)?\\d+)%\\s*,\\s*(?(?:\\d*\\.)?\\d+)%(?:\\s*,\\s*(?(?:\\d*\\.)?\\d+))?|(?-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?(?:\\d*\\.)?\\d+)%?\\s+(?(?:\\d*\\.)?\\d+)%?(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?\\s+(?(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.CIELab]: /^lab\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.LCH]: /^lch\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.CMYK]: /^(?:device-cmyk|cmyk)\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?(?:\\d*\\.)?\\d+))?|(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?)\\s*\\)$/\n};\nconst CALC = {\n REGEXP: /^calc\\(\\s*(?[\\d./*+-\\w\\s]+)\\s*\\)$/,\n SCOPED: /\\(\\s*([^()]+)\\s*\\)/g,\n DIVISION: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n MULTIPLICATION: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\*\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n SUM: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\+\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n REST: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*-\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/\n};\nconst HSL_HUE = /^(?-?(?:\\d*\\.)?\\d+)(?(?:deg|grad|rad|turn)?)$/;\nconst PCENT = /^(-?\\d+(?:\\.\\d+)?|-?\\.\\d+)%$/;\nconst HEX = /^0x([a-f\\d]{1,2})$/i;\nconst TEMPLATE_VAR = /\\{(\\d+)\\}/g;\nconst COMMAS_AND_NEXT_CHARS = /,( +|\\d+)/g;\nconst SPACES = / +/;\n\n;// ./src/constants/errors.ts\nconst ERRORS = {\n NOT_ACCEPTED_STRING_INPUT: 'The provided string color doesn\\'t have a correct format',\n NOT_ACCEPTED_OBJECT_INPUT: 'The provided color object doesn\\'t have the proper keys or format',\n NOT_A_VALID_RELATIVE_COLOR: 'is not a valid operation for a relative color'\n};\n\n;// ./src/@types/index.ts\nvar AnglesUnitEnum;\n(function (AnglesUnitEnum) {\n AnglesUnitEnum[\"NONE\"] = \"none\";\n AnglesUnitEnum[\"DEGREES\"] = \"deg\";\n AnglesUnitEnum[\"GRADIANS\"] = \"grad\";\n AnglesUnitEnum[\"RADIANS\"] = \"rad\";\n AnglesUnitEnum[\"TURNS\"] = \"turn\";\n})(AnglesUnitEnum || (AnglesUnitEnum = {}));\nvar ColorUnitEnum;\n(function (ColorUnitEnum) {\n ColorUnitEnum[\"NONE\"] = \"none\";\n ColorUnitEnum[\"PERCENT\"] = \"percent\";\n})(ColorUnitEnum || (ColorUnitEnum = {}));\nvar CMYKFunctionEnum;\n(function (CMYKFunctionEnum) {\n CMYKFunctionEnum[\"DEVICE_CMYK\"] = \"device-cmyk\";\n CMYKFunctionEnum[\"CMYK\"] = \"cmyk\";\n})(CMYKFunctionEnum || (CMYKFunctionEnum = {}));\n\n;// ./src/constants/options.ts\n\n\nconst DEFAULT_OPTIONS = {\n decimals: MAX_DECIMALS,\n legacyCSS: false,\n spacesAfterCommas: false,\n anglesUnit: AnglesUnitEnum.NONE,\n rgbUnit: ColorUnitEnum.NONE,\n labUnit: ColorUnitEnum.NONE,\n lchUnit: ColorUnitEnum.NONE,\n cmykUnit: ColorUnitEnum.PERCENT,\n alphaUnit: ColorUnitEnum.NONE,\n cmykFunction: CMYKFunctionEnum.DEVICE_CMYK\n};\n\n;// ./src/constants/index.ts\n\n\n\n\n\n\n\n;// ./src/helpers/index.ts\n\n\nconst hasProp = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nconst percentNumber = (percent) => {\n return +`${percent}`.replace(PCENT, '$1');\n};\nconst percent = (percent) => PCENT.test(`${percent}`)\n ? percentNumber(percent)\n : Math.min(+percent, 100);\nconst getDEC = (hex) => {\n if (hex.length === 1) {\n hex += hex;\n }\n return parseInt(hex, 16);\n};\nconst getHEX = (number) => {\n const hex = round(number, 0).toString(16).toUpperCase();\n if (hex.length === 1) {\n return `0x0${hex}`;\n }\n return `0x${hex}`;\n};\nconst toHEX = (h) => {\n let hex = round(h, 0).toString(16).toUpperCase();\n if (hex.length === 1) {\n hex = `0${hex}`;\n }\n return hex;\n};\nconst from255NumberToPercent = (value, decimals) => round(value / BASE_255 * 100, decimals);\nconst from125NumberToPercent = (value, decimals) => round(value / MAX_LAB * 100, decimals);\nconst from150NumberToPercent = (value, decimals) => round(value / MAX_LCH_C * 100, decimals);\nconst getBase255Number = (color, alpha = false) => {\n if (!alpha && PCENT.test(color)) {\n return Math.min(BASE_255 * percentNumber(color) / 100, BASE_255);\n }\n if (HEX.test(color)) {\n if (color.length === 3) {\n color += color.slice(-1);\n }\n return alpha\n ? round(color) / BASE_255\n : round(color);\n }\n return Math.min(+color, alpha ? 1 : BASE_255);\n};\nconst getBase125Number = (color) => {\n if (PCENT.test(color)) {\n return minmax(MAX_LAB * percentNumber(color) / 100, -MAX_LAB, MAX_LAB);\n }\n return minmax(+color, -MAX_LAB, MAX_LAB);\n};\nconst getBase150Number = (color) => {\n if (PCENT.test(color)) {\n return minmax(MAX_LCH_C * percentNumber(color) / 100, -MAX_LCH_C, MAX_LCH_C);\n }\n return minmax(+color, -MAX_LCH_C, MAX_LCH_C);\n};\nconst getCMYKNumber = (color) => Math.min(PCENT.test(color) ? percentNumber(color) / 100 : +color, 1);\nconst getOrderedArrayString = (keys) => [...keys].sort().join('').toUpperCase();\nconst round = (value, decimals = MAX_DECIMALS) => {\n const exp = Math.pow(10, decimals);\n return Math.round(+value * exp) / exp;\n};\nconst minmax = (n, min, max) => Math.max(min, Math.min(n, max));\nconst degrees = (radian) => radian * 180 / Math.PI;\nconst radians = (degrees) => degrees * Math.PI / 180;\nconst pi2 = 360;\nconst normalizeHue = (hue) => {\n if (typeof hue === 'string') {\n const matches = hue.match(HSL_HUE);\n const groups = matches.groups;\n const value = +groups.number;\n const units = groups.units;\n switch (units) {\n case AnglesUnitEnum.RADIANS:\n hue = round(degrees(value));\n break;\n case AnglesUnitEnum.TURNS:\n hue = round(value * pi2);\n break;\n case AnglesUnitEnum.GRADIANS:\n hue = round(9 / 10 * value);\n break;\n case AnglesUnitEnum.DEGREES:\n default:\n hue = value;\n }\n }\n if (hue > 360 || hue < 0) {\n hue -= Math.floor(hue / pi2) * pi2;\n }\n return hue;\n};\nconst normalizeAlpha = (alpha) => {\n if (typeof alpha === 'string') {\n if (PCENT.test(alpha)) {\n alpha = percentNumber(alpha) / 100;\n }\n else {\n alpha = +alpha;\n }\n }\n return (isNaN(+alpha) || alpha > MAX_ALPHA) ? MAX_ALPHA : round(alpha);\n};\nconst translateDegrees = (degrees, units) => {\n let hue;\n switch (units) {\n case AnglesUnitEnum.RADIANS:\n hue = round(radians(degrees));\n break;\n case AnglesUnitEnum.TURNS:\n hue = round(degrees / pi2);\n break;\n case AnglesUnitEnum.GRADIANS:\n hue = round(10 / 9 * degrees);\n break;\n case AnglesUnitEnum.DEGREES:\n case AnglesUnitEnum.NONE:\n default:\n hue = degrees;\n }\n return hue;\n};\nconst isHarmony = (param) => {\n return `${param}` in Harmony;\n};\nconst isMix = (param) => {\n return `${param}` in Mix;\n};\n\n;// ./src/color/translators.ts\n\n\nconst MATRIX_LRGB_XYZ_D50 = [\n [0.4360747, 0.3850649, 0.1430804],\n [0.2225045, 0.7168786, 0.0606169],\n [0.0139322, 0.0971045, 0.7141733]\n];\nconst MATRIX_XYZ_D50_LRGB = [\n [3.1338561, -1.6168667, -0.4906146],\n [-0.9787684, 1.9161415, 0.033454],\n [0.0719453, -0.2289914, 1.4052427]\n];\nconst TRISTIMULUS_D50 = MATRIX_LRGB_XYZ_D50.map((matrix) => {\n return matrix.reduce((sum, value) => sum + value, 0);\n});\nconst hueToRgb = (t1, t2, hue) => {\n if (hue < 0) {\n hue += 6;\n }\n if (hue >= 6) {\n hue -= 6;\n }\n if (hue < 1) {\n return round(((t2 - t1) * hue + t1) * BASE_255);\n }\n else if (hue < 3) {\n return round(t2 * BASE_255);\n }\n else if (hue < 4) {\n return round(((t2 - t1) * (4 - hue) + t1) * BASE_255);\n }\n else {\n return round(t1 * BASE_255);\n }\n};\nconst rgbToLinearLightRgb = (value) => {\n return value <= 0.04045\n ? value / 12.92\n : ((value + 0.055) / 1.055) ** 2.4;\n};\nconst linearLightRgbToRgb = (value) => {\n return value <= 0.0031308\n ? 12.92 * value\n : 1.055 * (value ** (1 / 2.4)) - 0.055;\n};\nconst matrixVectorMultiplication = (v1, v2, v3, matrix) => {\n const result = [0, 0, 0];\n const linearRgb = [v1, v2, v3];\n matrix.forEach((array, index) => {\n array.forEach((value, mindex) => {\n result[index] += value * linearRgb[mindex];\n });\n });\n return result;\n};\nconst from_CIE_XYZ_D50_to_CIE_LAB = (x, y, z) => {\n const f = (t) => {\n return t > (6 / 29) ** 3\n ? Math.cbrt(t)\n : t / (3 * (6 / 29) ** 2) + (4 / 29);\n };\n const fx = f(x / TRISTIMULUS_D50[0]);\n const fy = f(y / TRISTIMULUS_D50[1]);\n const fz = f(z / TRISTIMULUS_D50[2]);\n return [\n 116 * fy - 16,\n 500 * (fx - fy),\n 200 * (fy - fz)\n ];\n};\nconst from_CIE_LAB_to_CIE_XYZ_D50 = (L, a, b) => {\n const f = (t) => {\n return t > 6 / 29\n ? t ** 3\n : 3 * (6 / 29) ** 2 * (t - 4 / 29);\n };\n const fl = (L + 16) / 116;\n const fa = a / 500;\n const fb = b / 200;\n return [\n TRISTIMULUS_D50[0] * f(fl + fa),\n TRISTIMULUS_D50[1] * f(fl),\n TRISTIMULUS_D50[2] * f(fl - fb)\n ];\n};\nconst hslToRgb = (H, S, L) => {\n H /= 60;\n S /= 100;\n L /= 100;\n const t2 = (L <= .5)\n ? L * (S + 1)\n : L + S - (L * S);\n const t1 = L * 2 - t2;\n const R = hueToRgb(t1, t2, H + 2);\n const G = hueToRgb(t1, t2, H);\n const B = hueToRgb(t1, t2, H - 2);\n return { R, G, B };\n};\nconst rgbToHsl = (R, G, B, A = 1) => {\n R /= BASE_255;\n G /= BASE_255;\n B /= BASE_255;\n A = Math.min(A, MAX_ALPHA);\n const MAX = Math.max(R, G, B);\n const MIN = Math.min(R, G, B);\n const D = MAX - MIN;\n let H = 0;\n let S = 0;\n const L = (MAX + MIN) / 2;\n if (D !== 0) {\n switch (MAX) {\n case R:\n H = ((G - B) / D) % 6;\n break;\n case G:\n H = (B - R) / D + 2;\n break;\n case B:\n H = (R - G) / D + 4;\n break;\n }\n H = round(H * 60);\n if (H < 0) {\n H += 360;\n }\n S = D / (1 - Math.abs(2 * L - 1));\n }\n return {\n H,\n S: round(S * 100),\n L: round(L * 100),\n A\n };\n};\nconst rgbToLab = (R, G, B) => {\n const LINEAR_LIGHT_RGB = [\n R / BASE_255,\n G / BASE_255,\n B / BASE_255\n ].map(rgbToLinearLightRgb);\n const CIE_XYZ_D50 = matrixVectorMultiplication(LINEAR_LIGHT_RGB[0], LINEAR_LIGHT_RGB[1], LINEAR_LIGHT_RGB[2], MATRIX_LRGB_XYZ_D50);\n const CIE_LAB = from_CIE_XYZ_D50_to_CIE_LAB(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2]);\n return {\n L: CIE_LAB[0],\n a: CIE_LAB[1],\n b: CIE_LAB[2]\n };\n};\nconst labToRgb = (L, a, b) => {\n const CIE_XYZ_D50 = from_CIE_LAB_to_CIE_XYZ_D50(L, a, b);\n const LINEAR_LIGHT_RGB = matrixVectorMultiplication(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2], MATRIX_XYZ_D50_LRGB);\n const rgb = LINEAR_LIGHT_RGB.map(linearLightRgbToRgb);\n return {\n R: minmax(rgb[0] * BASE_255, 0, BASE_255),\n G: minmax(rgb[1] * BASE_255, 0, BASE_255),\n B: minmax(rgb[2] * BASE_255, 0, BASE_255)\n };\n};\nconst labToLch = (L, a, b) => {\n const C = Math.sqrt(a ** 2 + b ** 2);\n const H = degrees(Math.atan2(b, a));\n return {\n L,\n C,\n H: normalizeHue(H)\n };\n};\nconst lchToLab = (L, C, H) => {\n const radH = radians(H);\n const a = C * Math.cos(radH);\n const b = C * Math.sin(radH);\n return {\n L,\n a,\n b\n };\n};\nconst rgbToLch = (R, G, B) => {\n const lab = rgbToLab(R, G, B);\n return labToLch(lab.L, lab.a, lab.b);\n};\nconst lchToRgb = (L, C, H) => {\n const lab = lchToLab(L, C, H);\n return labToRgb(lab.L, lab.a, lab.b);\n};\nconst rgbToHwb = (R, G, B, A = 1) => {\n const hsl = rgbToHsl(R, G, B, A);\n return {\n H: hsl.H,\n W: round(Math.min(R, G, B) / BASE_255 * 100),\n B: round((1 - Math.max(R, G, B) / BASE_255) * 100),\n A\n };\n};\nconst hwbToRgb = (H, W, B) => {\n W /= 100;\n B /= 100;\n const v = 1 - B;\n const c = v - W;\n const x = c * (1 - Math.abs((H / 60) % 2 - 1));\n let rgbR = 0;\n let rgbG = 0;\n let rgbB = 0;\n if (H < 60) {\n rgbR = c;\n rgbG = x;\n rgbB = 0;\n }\n else if (H >= 60 && H < 120) {\n rgbR = x;\n rgbG = c;\n rgbB = 0;\n }\n else if (H >= 120 && H < 180) {\n rgbR = 0;\n rgbG = c;\n rgbB = x;\n }\n else if (H >= 180 && H < 240) {\n rgbR = 0;\n rgbG = x;\n rgbB = c;\n }\n else if (H >= 240 && H < 300) {\n rgbR = x;\n rgbG = 0;\n rgbB = c;\n }\n else {\n rgbR = c;\n rgbG = 0;\n rgbB = x;\n }\n rgbR += W;\n rgbG += W;\n rgbB += W;\n return {\n R: minmax(rgbR * BASE_255, 0, BASE_255),\n G: minmax(rgbG * BASE_255, 0, BASE_255),\n B: minmax(rgbB * BASE_255, 0, BASE_255)\n };\n};\nconst cmykToRgb = (C, M, Y, K) => {\n K = 1 - K;\n return {\n R: round(BASE_255 * (1 - C) * K),\n G: round(BASE_255 * (1 - M) * K),\n B: round(BASE_255 * (1 - Y) * K)\n };\n};\nconst rgbToCmyk = (R, G, B) => {\n R /= BASE_255;\n G /= BASE_255;\n B /= BASE_255;\n const K = 1 - Math.max(R, G, B);\n const K1 = 1 - K;\n const C = K1 && (K1 - R) / K1;\n const M = K1 && (K1 - G) / K1;\n const Y = K1 && (K1 - B) / K1;\n return {\n C: round(C * 100),\n M: round(M * 100),\n Y: round(Y * 100),\n K: round(K * 100)\n };\n};\nconst rgbToRyb = (R, G, B) => {\n const Iw = Math.min(R, G, B);\n const Ib = Math.min(BASE_255 - R, BASE_255 - G, BASE_255 - B);\n const rRgb = R - Iw;\n const gRgb = G - Iw;\n const bRgb = B - Iw;\n const minRg = Math.min(rRgb, gRgb);\n const rRyb = rRgb - minRg;\n const yRyb = (gRgb + minRg) / 2;\n const bRyb = (bRgb + gRgb - minRg) / 2;\n const n = Math.max(rRyb, yRyb, bRyb) / Math.max(rRgb, gRgb, bRgb);\n const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n return {\n R: rRyb / N + Ib,\n Y: yRyb / N + Ib,\n B: bRyb / N + Ib\n };\n};\nconst rybToRgb = (R, Y, B) => {\n const Iw = Math.min(R, Y, B);\n const Ib = Math.min(BASE_255 - R, BASE_255 - Y, BASE_255 - B);\n const rRyb = R - Iw;\n const yRyb = Y - Iw;\n const bRyb = B - Iw;\n const minYb = Math.min(yRyb, bRyb);\n const rRgb = rRyb + yRyb - minYb;\n const gRgb = yRyb + minYb;\n const bRgb = 2 * (bRyb - minYb);\n const n = Math.max(rRgb, gRgb, bRgb) / Math.max(rRyb, yRyb, bRyb);\n const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n return {\n R: rRgb / N + Ib,\n G: gRgb / N + Ib,\n B: bRgb / N + Ib\n };\n};\nconst hueRyb = (hue, toRyb) => {\n if (hue < 0)\n hue += 360;\n if (hue > 360)\n hue -= 360;\n if (hue === 360 || hue === 0)\n return hue;\n const map1 = [\n [0, 120],\n [120, 180],\n [180, 240],\n [240, 360]\n ];\n const map2 = [\n [0, 60],\n [60, 120],\n [120, 240],\n [240, 360]\n ];\n const from = toRyb ? map1 : map2;\n const to = toRyb ? map2 : map1;\n let A = 0;\n let B = 0;\n let C = 0;\n let D = 0;\n from.find((arr, index) => {\n if (hue >= arr[0] && hue < arr[1]) {\n A = arr[0];\n B = arr[1];\n C = to[index][0];\n D = to[index][1];\n return true;\n }\n return false;\n });\n return C + (hue - A) * ((D - C) / (B - A));\n};\n\n;// ./src/parsers/baseClasses/_RgbClass.ts\nclass RgbClass {\n get rgb() {\n return this._rgb;\n }\n}\n\n;// ./src/parsers/_HEXStringParser.ts\n\n\n\nclass HEXStringParser extends RgbClass {\n constructor(colorString) {\n super();\n const match = colorString.match(COLORREGS.HEX);\n const groups = match.groups;\n this._r = groups.r ?? groups.rr;\n this._g = groups.g ?? groups.gg;\n this._b = groups.b ?? groups.bb;\n this._a = groups.a ?? groups.aa;\n const rgb = {\n R: getDEC(this._r),\n G: getDEC(this._g),\n B: getDEC(this._b)\n };\n if (this._a !== undefined) {\n rgb.A = getDEC(this._a) / BASE_255;\n }\n this._rgb = rgb;\n }\n}\n\n;// ./src/parsers/_CalcParser.ts\n\nconst MAX_STACK = 100;\nclass CalcParser {\n constructor(colorIndex, calc, vars) {\n this._operations = new Map([\n [CALC.DIVISION, this._division],\n [CALC.MULTIPLICATION, this._multiplication],\n [CALC.SUM, this._sum],\n [CALC.REST, this._rest]\n ]);\n this._colorIndex = colorIndex;\n let calcString = calc;\n let stack = 0;\n if (!Number.isNaN(+calc)) {\n this._result = +calc;\n }\n else if (calc in vars) {\n this._result = vars[calc];\n }\n else if (CALC.REGEXP.test(calcString)) {\n CALC.REGEXP.lastIndex = 0;\n this._result = this._getCalcValue(calcString, vars);\n }\n else {\n while (CALC.SCOPED.test(calcString) && stack < MAX_STACK) {\n CALC.SCOPED.lastIndex = 0;\n calcString = calcString.replace(CALC.SCOPED, (__match, operation) => {\n return this._calculate(operation, vars).toString();\n });\n if (CALC.REGEXP.test(calcString)) {\n CALC.REGEXP.lastIndex = 0;\n break;\n }\n stack++;\n }\n this._result = this._getCalcValue(calcString, vars);\n }\n }\n _division(left, right) {\n return left / right;\n }\n _multiplication(left, right) {\n return left * right;\n }\n _sum(left, right) {\n return left + right;\n }\n _rest(left, right) {\n return left - right;\n }\n _getCalcValue(calc, vars) {\n const match = calc.match(CALC.REGEXP);\n const operation = match.groups.operation;\n const value = this._calculate(operation, vars);\n if (Number.isNaN(value)) {\n throw new Error(`Invalid value for ${this._colorIndex}. ${operation} ${ERRORS.NOT_A_VALID_RELATIVE_COLOR}`);\n }\n return value;\n }\n _calculate(operation, vars) {\n this._operations.forEach((method, regExp) => {\n let stack = 0;\n while (regExp.test(operation) && stack < MAX_STACK) {\n operation = operation.replace(regExp, (__match, left, right) => {\n return method(vars[left] ?? +left, vars[right] ?? +right).toString();\n });\n stack++;\n }\n });\n return +operation;\n }\n get result() {\n return this._result;\n }\n}\n\n;// ./src/parsers/baseClasses/_AlphaBaseClass.ts\n\n\nclass AlphaBaseClass extends RgbClass {\n get hasPercentageAlpha() {\n return PCENT.test(this._a);\n }\n}\n\n;// ./src/parsers/_RGBStringParser.ts\n\n\n\n\nclass RGBStringParser extends AlphaBaseClass {\n constructor(colorString, getRGBObject) {\n super();\n const match = colorString.match(COLORREGS.RGB);\n const groups = match.groups;\n const { r_legacy, g_legacy, b_legacy, a_legacy, r, g, b, a, from, relative_r, relative_g, relative_b, relative_a } = groups;\n if (from) {\n const fromRGB = getRGBObject(from);\n const fromRGBVars = {\n r: fromRGB.R,\n g: fromRGB.G,\n b: fromRGB.B,\n alpha: fromRGB.A ?? 1\n };\n const R = new CalcParser('r', relative_r, fromRGBVars).result;\n const G = new CalcParser('g', relative_g, fromRGBVars).result;\n const B = new CalcParser('b', relative_b, fromRGBVars).result;\n const rgb = {\n R: Math.min(R, BASE_255),\n G: Math.min(G, BASE_255),\n B: Math.min(B, BASE_255)\n };\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromRGBVars).result;\n rgb.A = Math.min(A, 1);\n }\n this._rgb = rgb;\n }\n else {\n this._r = r_legacy ?? r;\n this._g = g_legacy ?? g;\n this._b = b_legacy ?? b;\n this._a = a_legacy ?? a;\n const rgb = {\n R: Math.min(getBase255Number(this._r), BASE_255),\n G: Math.min(getBase255Number(this._g), BASE_255),\n B: Math.min(getBase255Number(this._b), BASE_255)\n };\n if (this._a !== undefined) {\n rgb.A = normalizeAlpha(this._a);\n }\n this._rgb = rgb;\n }\n }\n get hasPercentageValues() {\n return (PCENT.test(this._r) &&\n PCENT.test(this._g) &&\n PCENT.test(this._b));\n }\n static test(colorString) {\n return COLORREGS.RGB.test(colorString);\n }\n}\n\n;// ./src/parsers/baseClasses/_HueBaseClass.ts\n\n\n\nclass HueBaseClass extends AlphaBaseClass {\n get angleUnit() {\n if (this._h) {\n const angleUnitMatch = this._h.match(HSL_HUE);\n const angleUnit = angleUnitMatch.groups.units;\n return angleUnit === ''\n ? AnglesUnitEnum.NONE\n : angleUnit;\n }\n return AnglesUnitEnum.NONE;\n }\n}\n\n;// ./src/parsers/_HSLStringParser.ts\n\n\n\n\n\nclass HSLStringParser extends HueBaseClass {\n constructor(colorString, getRGBObject) {\n super();\n const match = colorString.match(COLORREGS.HSL);\n const groups = match.groups;\n const { h_legacy, s_legacy, l_legacy, a_legacy, h, s, l, a, from, relative_h, relative_s, relative_l, relative_a } = groups;\n if (from) {\n const fromRGB = getRGBObject(from);\n const fromHSL = rgbToHsl(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n const fromHSLVars = {\n h: fromHSL.H,\n s: fromHSL.S,\n l: fromHSL.L,\n alpha: fromHSL.A\n };\n const H = new CalcParser('h', relative_h, fromHSLVars).result;\n const S = new CalcParser('s', relative_s, fromHSLVars).result;\n const L = new CalcParser('l', relative_l, fromHSLVars).result;\n const rgb = hslToRgb(minmax(H, 0, MAX_HUE), minmax(S, 0, MAX_PCENT), minmax(L, 0, MAX_PCENT));\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromHSLVars).result;\n rgb.A = minmax(A, 0, MAX_ALPHA);\n }\n this._rgb = rgb;\n }\n else {\n this._h = h_legacy ?? h;\n this._s = s_legacy ?? s;\n this._l = l_legacy ?? l;\n this._a = a_legacy ?? a;\n const rgb = hslToRgb(normalizeHue(this._h), percent(this._s), percent(this._l));\n if (this._a !== undefined) {\n rgb.A = normalizeAlpha(this._a);\n }\n this._rgb = rgb;\n }\n }\n static test(colorString) {\n return COLORREGS.HSL.test(colorString);\n }\n}\n\n;// ./src/parsers/_HWBStringParser.ts\n\n\n\n\n\nclass HWBStringParser extends HueBaseClass {\n constructor(colorString, getRGBObject) {\n super();\n const match = colorString.match(COLORREGS.HWB);\n const groups = match.groups;\n const { h, w, b, a, from, relative_h, relative_w, relative_b, relative_a } = groups;\n if (from) {\n const fromRGB = getRGBObject(from);\n const fromHWB = rgbToHwb(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n const fromHWBVars = {\n h: fromHWB.H,\n w: fromHWB.W,\n b: fromHWB.B,\n alpha: fromHWB.A\n };\n const H = new CalcParser('h', relative_h, fromHWBVars).result;\n const W = new CalcParser('w', relative_w, fromHWBVars).result;\n const B = new CalcParser('b', relative_b, fromHWBVars).result;\n const rgb = hwbToRgb(minmax(H, 0, MAX_HUE), minmax(W, 0, MAX_PCENT), minmax(B, 0, MAX_PCENT));\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromHWBVars).result;\n rgb.A = minmax(A, 0, MAX_ALPHA);\n }\n this._rgb = rgb;\n }\n else {\n this._h = h;\n this._w = w;\n this._b = b;\n this._a = a;\n const rgb = hwbToRgb(normalizeHue(this._h), percent(this._w), percent(this._b));\n if (this._a !== undefined) {\n rgb.A = normalizeAlpha(this._a);\n }\n this._rgb = rgb;\n }\n }\n static test(colorString) {\n return COLORREGS.HWB.test(colorString);\n }\n}\n\n;// ./src/parsers/_CIELabStringParser.ts\n\n\n\n\n\nclass CIELabStringParser extends AlphaBaseClass {\n constructor(colorString, getRGBObject) {\n super();\n const match = colorString.match(COLORREGS.CIELab);\n const groups = match.groups;\n const { L, a, b, A, from, relative_L, relative_a, relative_b, relative_A } = groups;\n if (from) {\n const fromRGB = getRGBObject(from);\n const fromLab = rgbToLab(fromRGB.R, fromRGB.G, fromRGB.B);\n const fromLabVars = {\n l: fromLab.L,\n a: fromLab.a,\n b: fromLab.b,\n alpha: fromRGB.A ?? 1\n };\n const L = new CalcParser('l', relative_L, fromLabVars).result;\n const a = new CalcParser('a', relative_a, fromLabVars).result;\n const b = new CalcParser('b', relative_b, fromLabVars).result;\n const rgb = labToRgb(minmax(L, 0, MAX_PCENT), minmax(a, -MAX_LAB, MAX_LAB), minmax(b, -MAX_LAB, MAX_LAB));\n if (relative_A) {\n const A = new CalcParser('alpha', relative_A, fromLabVars).result;\n rgb.A = minmax(A, 0, MAX_ALPHA);\n }\n this._rgb = rgb;\n }\n else {\n this._L = L;\n this._A = a;\n this._B = b;\n this._a = A;\n const rgb = labToRgb(percent(this._L), getBase125Number(this._A), getBase125Number(this._B));\n if (this._a !== undefined) {\n rgb.A = normalizeAlpha(this._a);\n }\n this._rgb = rgb;\n }\n }\n get hasPercentageValues() {\n return (PCENT.test(this._L) &&\n PCENT.test(this._A) &&\n PCENT.test(this._B));\n }\n static test(colorString) {\n return COLORREGS.CIELab.test(colorString);\n }\n}\n\n;// ./src/parsers/_LCHStringParser.ts\n\n\n\n\n\nclass LCHStringParser extends HueBaseClass {\n constructor(colorString, getRGBObject) {\n super();\n const match = colorString.match(COLORREGS.LCH);\n const groups = match.groups;\n const { l, c, h, a, from, relative_l, relative_c, relative_h, relative_a } = groups;\n if (from) {\n const fromRGB = getRGBObject(from);\n const fromLCH = rgbToLch(fromRGB.R, fromRGB.G, fromRGB.B);\n const fromLCHVars = {\n l: fromLCH.L,\n c: fromLCH.C,\n h: fromLCH.H,\n alpha: fromRGB.A ?? 1\n };\n const L = new CalcParser('l', relative_l, fromLCHVars).result;\n const C = new CalcParser('c', relative_c, fromLCHVars).result;\n const H = new CalcParser('h', relative_h, fromLCHVars).result;\n const rgb = lchToRgb(minmax(L, 0, MAX_PCENT), minmax(C, -MAX_LCH_C, MAX_LCH_C), normalizeHue(H));\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromLCHVars).result;\n rgb.A = minmax(A, 0, MAX_ALPHA);\n }\n this._rgb = rgb;\n }\n else {\n this._l = l;\n this._c = c;\n this._h = h;\n this._a = a;\n const rgb = lchToRgb(percent(this._l), getBase150Number(this._c), normalizeHue(this._h));\n if (this._a !== undefined) {\n rgb.A = normalizeAlpha(this._a);\n }\n this._rgb = rgb;\n }\n }\n get hasPercentageValues() {\n return (PCENT.test(this._l) &&\n PCENT.test(this._c));\n }\n static test(colorString) {\n return COLORREGS.LCH.test(colorString);\n }\n}\n\n;// ./src/parsers/_CMYKStringParser.ts\n\n\n\n\nclass CMYKStringParser extends AlphaBaseClass {\n constructor(colorString) {\n super();\n const match = colorString.match(COLORREGS.CMYK);\n const groups = match.groups;\n this._c = groups.c_legacy ?? groups.c;\n this._m = groups.m_legacy ?? groups.m;\n this._y = groups.y_legacy ?? groups.y;\n this._k = groups.k_legacy ?? groups.k;\n this._a = groups.a_legacy ?? groups.a;\n const rgb = cmykToRgb(getCMYKNumber(this._c), getCMYKNumber(this._m), getCMYKNumber(this._y), getCMYKNumber(this._k));\n if (this._a !== undefined) {\n rgb.A = normalizeAlpha(this._a);\n }\n this._rgb = rgb;\n }\n get hasPercentageValues() {\n return (PCENT.test(this._c) &&\n PCENT.test(this._m) &&\n PCENT.test(this._y) &&\n PCENT.test(this._k));\n }\n static test(colorString) {\n return COLORREGS.CMYK.test(colorString);\n }\n}\n\n;// ./src/parsers/index.ts\n\n\n\n\n\n\n\n\n;// ./src/color/extractors.ts\n\n\n\n\n\nconst getColorModelFromString = (color) => {\n let model;\n Object.keys(ColorModel).some((p) => {\n const reg = COLORREGS[p];\n if (reg.test(color)) {\n model = p;\n return true;\n }\n });\n if (!model &&\n !!~COLOR_KEYS.indexOf(color)) {\n model = ColorModel.HEX;\n }\n if (!model) {\n throw new Error(ERRORS.NOT_ACCEPTED_STRING_INPUT);\n }\n return model;\n};\nconst getColorModelFromObject = (color) => {\n let model;\n let invalid = false;\n const props = getOrderedArrayString(Object.keys(color));\n if (VALID_COLOR_OBJECTS[props]) {\n model = VALID_COLOR_OBJECTS[props];\n }\n if (model && model === ColorModel.RGB) {\n const hasInvalidHex = Object.entries(color).some((item) => {\n return !HEX.test(`${item[1]}`);\n });\n const hasInvalidRegb = Object.entries(color).some((item) => {\n return !(PCENT.test(`${item[1]}`) ||\n (!HEX.test(`${item[1]}`) &&\n !isNaN(+item[1]) &&\n +item[1] <= BASE_255));\n });\n if (hasInvalidHex && hasInvalidRegb) {\n invalid = true;\n }\n if (!hasInvalidHex) {\n model = ColorModel.HEX;\n }\n }\n if (!model || invalid) {\n throw new Error(ERRORS.NOT_ACCEPTED_OBJECT_INPUT);\n }\n return model;\n};\nconst getColorModel = (color) => typeof color === 'string'\n ? getColorModelFromString(color)\n : getColorModelFromObject(color);\nconst getRGBObjectFromString = {\n [ColorModel.HEX](color) {\n const colorStr = !~COLOR_KEYS.indexOf(color)\n ? color\n : ColorKeywords[color];\n return new HEXStringParser(colorStr).rgb;\n },\n [ColorModel.RGB](color) {\n return new RGBStringParser(color, getRGBObject).rgb;\n },\n [ColorModel.HSL](color) {\n return new HSLStringParser(color, getRGBObject).rgb;\n },\n [ColorModel.HWB](color) {\n return new HWBStringParser(color, getRGBObject).rgb;\n },\n [ColorModel.CIELab](color) {\n return new CIELabStringParser(color, getRGBObject).rgb;\n },\n [ColorModel.LCH](color) {\n return new LCHStringParser(color, getRGBObject).rgb;\n },\n [ColorModel.CMYK](color) {\n return new CMYKStringParser(color).rgb;\n }\n};\nconst getRGBObjectFromObject = {\n [ColorModel.HEX](color) {\n const object = {\n R: getBase255Number(`${color.R}`),\n G: getBase255Number(`${color.G}`),\n B: getBase255Number(`${color.B}`)\n };\n if (hasProp(color, 'A')) {\n object.A = Math.min(getBase255Number(`${color.A}`, true), 1);\n }\n return object;\n },\n [ColorModel.RGB](color) {\n return this.HEX(color);\n },\n [ColorModel.HSL](color) {\n const S = percent(`${color.S}`);\n const L = percent(`${color.L}`);\n const RGB = hslToRgb(normalizeHue(color.H), S, L);\n if (hasProp(color, 'A')) {\n RGB.A = normalizeAlpha(color.A);\n }\n return RGB;\n },\n [ColorModel.HWB](color) {\n const W = percent(`${color.W}`);\n const B = percent(`${color.B}`);\n const RGB = hwbToRgb(normalizeHue(color.H), W, B);\n if (hasProp(color, 'A')) {\n RGB.A = normalizeAlpha(color.A);\n }\n return RGB;\n },\n [ColorModel.CIELab](color) {\n const L = percent(`${color.L}`);\n const a = getBase125Number(`${color.a}`);\n const b = getBase125Number(`${color.b}`);\n const RGB = labToRgb(L, a, b);\n if (hasProp(color, 'A')) {\n RGB.A = normalizeAlpha(color.A);\n }\n return RGB;\n },\n [ColorModel.LCH](color) {\n const L = percent(`${color.L}`);\n const C = getBase150Number(`${color.C}`);\n const H = normalizeHue(`${color.H}`);\n const RGB = lchToRgb(L, C, H);\n if (hasProp(color, 'A')) {\n RGB.A = normalizeAlpha(color.A);\n }\n return RGB;\n },\n [ColorModel.CMYK](color) {\n const C = getCMYKNumber(`${color.C}`);\n const M = getCMYKNumber(`${color.M}`);\n const Y = getCMYKNumber(`${color.Y}`);\n const K = getCMYKNumber(`${color.K}`);\n const RGB = cmykToRgb(C, M, Y, K);\n if (hasProp(color, 'A')) {\n RGB.A = normalizeAlpha(color.A);\n }\n return RGB;\n }\n};\nconst getRGBObject = (color, model = getColorModel(color)) => {\n return typeof color === 'string'\n ? getRGBObjectFromString[model](color)\n : getRGBObjectFromObject[model](color);\n};\nconst getOptionsFromColorInput = (options, ...colors) => {\n const cssColors = [];\n const anglesUnits = [];\n const rgbColors = [];\n const labColors = [];\n const lchColors = [];\n const cmykColors = [];\n const alphaValues = [];\n const anglesUnitValues = Object.values(AnglesUnitEnum);\n const colorUnitValues = Object.values(ColorUnitEnum);\n const cmykFunctionValues = Object.values(CMYKFunctionEnum);\n const matchOptions = {\n legacyCSS: 0,\n spacesAfterCommas: 0,\n cmykFunction: 0\n };\n for (const color of colors) {\n if (typeof color === 'string') {\n cssColors.push(color);\n if (color.includes(',')) {\n matchOptions.legacyCSS++;\n const commasWithNextCharacter = color.match(COMMAS_AND_NEXT_CHARS);\n if (new Set(commasWithNextCharacter).size === 1 &&\n SPACES.test(commasWithNextCharacter[0].slice(1))) {\n matchOptions.spacesAfterCommas++;\n }\n }\n if (HSLStringParser.test(color)) {\n const parser = new HSLStringParser(color, getRGBObject);\n anglesUnits.push(parser.angleUnit);\n alphaValues.push(parser.hasPercentageAlpha);\n continue;\n }\n if (HWBStringParser.test(color)) {\n const parser = new HWBStringParser(color, getRGBObject);\n anglesUnits.push(parser.angleUnit);\n alphaValues.push(parser.hasPercentageAlpha);\n continue;\n }\n if (RGBStringParser.test(color)) {\n const parser = new RGBStringParser(color, getRGBObject);\n rgbColors.push(parser.hasPercentageValues);\n alphaValues.push(parser.hasPercentageAlpha);\n continue;\n }\n if (CIELabStringParser.test(color)) {\n const parser = new CIELabStringParser(color, getRGBObject);\n labColors.push(parser.hasPercentageValues);\n alphaValues.push(parser.hasPercentageAlpha);\n continue;\n }\n if (LCHStringParser.test(color)) {\n const parser = new LCHStringParser(color, getRGBObject);\n anglesUnits.push(parser.angleUnit);\n lchColors.push(parser.hasPercentageValues);\n alphaValues.push(parser.hasPercentageAlpha);\n continue;\n }\n if (CMYKStringParser.test(color)) {\n const parser = new CMYKStringParser(color);\n cmykColors.push(parser.hasPercentageValues);\n if (color.startsWith('cmyk')) {\n matchOptions.cmykFunction++;\n }\n alphaValues.push(parser.hasPercentageAlpha);\n }\n }\n }\n return {\n decimals: typeof options.decimals === TypeOf.NUMBER\n ? options.decimals\n : DEFAULT_OPTIONS.decimals,\n legacyCSS: typeof options.legacyCSS === TypeOf.BOOLEAN\n ? options.legacyCSS\n : Boolean(cssColors.length &&\n matchOptions.legacyCSS === cssColors.length) || DEFAULT_OPTIONS.legacyCSS,\n spacesAfterCommas: typeof options.spacesAfterCommas === TypeOf.BOOLEAN\n ? options.spacesAfterCommas\n : Boolean(cssColors.length &&\n matchOptions.spacesAfterCommas === cssColors.length) || DEFAULT_OPTIONS.spacesAfterCommas,\n anglesUnit: options.anglesUnit && anglesUnitValues.includes(options.anglesUnit)\n ? options.anglesUnit\n : (new Set(anglesUnits).size === 1\n ? anglesUnits[0]\n : DEFAULT_OPTIONS.anglesUnit),\n rgbUnit: options.rgbUnit && colorUnitValues.includes(options.rgbUnit)\n ? options.rgbUnit\n : (new Set(rgbColors).size === 1 && rgbColors[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.rgbUnit),\n labUnit: options.labUnit && colorUnitValues.includes(options.labUnit)\n ? options.labUnit\n : (new Set(labColors).size === 1 && labColors[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.labUnit),\n lchUnit: options.lchUnit && colorUnitValues.includes(options.lchUnit)\n ? options.lchUnit\n : (new Set(lchColors).size === 1 && lchColors[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.lchUnit),\n cmykUnit: options.cmykUnit && colorUnitValues.includes(options.cmykUnit)\n ? options.cmykUnit\n : (new Set(cmykColors).size === 1 && !cmykColors[0]\n ? ColorUnitEnum.NONE\n : DEFAULT_OPTIONS.cmykUnit),\n alphaUnit: options.alphaUnit && colorUnitValues.includes(options.alphaUnit)\n ? options.alphaUnit\n : (new Set(alphaValues).size === 1 && alphaValues[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.alphaUnit),\n cmykFunction: options.cmykFunction && cmykFunctionValues.includes(options.cmykFunction)\n ? options.cmykFunction\n : (cmykColors.length && cmykColors.length === matchOptions.cmykFunction\n ? CMYKFunctionEnum.CMYK\n : DEFAULT_OPTIONS.cmykFunction)\n };\n};\n\n;// ./src/color/rounders.ts\n\nconst roundHSLObject = (color, decimals) => {\n return {\n H: round(color.H, decimals),\n S: round(color.S, decimals),\n L: round(color.L, decimals)\n };\n};\nconst roundHWBObject = (color, decimals) => {\n return {\n H: round(color.H, decimals),\n W: round(color.W, decimals),\n B: round(color.B, decimals)\n };\n};\nconst roundCIELabObject = (color, decimals) => {\n return {\n L: round(color.L, decimals),\n a: round(color.a, decimals),\n b: round(color.b, decimals)\n };\n};\nconst roundLCHObject = (color, decimals) => {\n return {\n L: round(color.L, decimals),\n C: round(color.C, decimals),\n H: round(color.H, decimals)\n };\n};\nconst roundCMYKObject = (color, decimals) => {\n return {\n C: round(color.C, decimals),\n M: round(color.M, decimals),\n Y: round(color.Y, decimals),\n K: round(color.K, decimals)\n };\n};\n\n;// ./src/color/css.ts\n\n\n\nconst getComma = (withSpace) => withSpace\n ? ', '\n : ',';\nconst prepareColorForCss = (color, transformer) => {\n const props = getOrderedArrayString(Object.keys(color));\n const model = VALID_COLOR_OBJECTS[props];\n const keys = COLOR_PROPS[model];\n return keys.reduce((result, key, index) => {\n const value = color[key];\n if (typeof value !== 'undefined') {\n result.push(transformer(value, index));\n }\n return result;\n }, []);\n};\nconst getResultFromTemplate = (template, vars) => {\n return template.replace(TEMPLATE_VAR, (__match, indexStr) => {\n const index = +indexStr - 1;\n return `${vars[index]}`;\n });\n};\nconst getAlpha = (value, options, ignoreLegacy = false) => {\n const { alphaUnit, legacyCSS, decimals } = options;\n if (alphaUnit === ColorUnitEnum.PERCENT &&\n (!legacyCSS ||\n ignoreLegacy)) {\n return `${round(value * 100, decimals)}%`;\n }\n return round(value, decimals);\n};\nconst buildHueTransformer = (options) => {\n const { anglesUnit, decimals } = options;\n return (value, index) => {\n if (index === 0 &&\n anglesUnit !== AnglesUnitEnum.NONE) {\n const translated = round(translateDegrees(value, anglesUnit), decimals);\n return `${translated}${anglesUnit}`;\n }\n return index === 3\n ? getAlpha(value, options)\n : round(value, decimals);\n };\n};\nconst CSS = {\n [ColorModel.HEX]: (color) => {\n const transformer = (value) => toHEX(round(value));\n const values = prepareColorForCss(color, transformer);\n const template = values.length === 4\n ? '#{1}{2}{3}{4}'\n : '#{1}{2}{3}';\n return getResultFromTemplate(template, values);\n },\n [ColorModel.RGB]: (color, options) => {\n const { decimals, legacyCSS, spacesAfterCommas, rgbUnit } = options;\n const comma = getComma(spacesAfterCommas);\n const transformer = (value, index) => {\n return rgbUnit === ColorUnitEnum.PERCENT && index < 3\n ? `${from255NumberToPercent(value, decimals)}%`\n : (index === 3\n ? getAlpha(value, options)\n : round(value, decimals));\n };\n const values = prepareColorForCss(color, transformer);\n const template = legacyCSS\n ? (values.length === 4\n ? `rgba({1}${comma}{2}${comma}{3}${comma}{4})`\n : `rgb({1}${comma}{2}${comma}{3})`)\n : (values.length === 4\n ? `rgb({1} {2} {3} / {4})`\n : `rgb({1} {2} {3})`);\n return getResultFromTemplate(template, values);\n },\n [ColorModel.HSL]: (color, options) => {\n const { legacyCSS, spacesAfterCommas } = options;\n const comma = getComma(spacesAfterCommas);\n const transformer = buildHueTransformer(options);\n const values = prepareColorForCss(color, transformer);\n const template = legacyCSS\n ? (values.length === 4\n ? `hsla({1}${comma}{2}%${comma}{3}%${comma}{4})`\n : `hsl({1}${comma}{2}%${comma}{3}%)`)\n : (values.length === 4\n ? `hsl({1} {2}% {3}% / {4})`\n : `hsl({1} {2}% {3}%)`);\n return getResultFromTemplate(template, values);\n },\n [ColorModel.HWB]: (color, options) => {\n const transformer = buildHueTransformer(options);\n const values = prepareColorForCss(color, transformer);\n const template = values.length === 4\n ? `hwb({1} {2}% {3}% / {4})`\n : `hwb({1} {2}% {3}%)`;\n return getResultFromTemplate(template, values);\n },\n [ColorModel.CIELab]: (color, options) => {\n const { decimals, labUnit } = options;\n const transformer = (value, index) => {\n if (index === 0) {\n const L = round(percent(value), decimals);\n return labUnit === ColorUnitEnum.PERCENT\n ? `${L}%`\n : `${L}`;\n }\n if (index < 3) {\n return labUnit === ColorUnitEnum.PERCENT\n ? `${from125NumberToPercent(value, decimals)}%`\n : round(value, decimals);\n }\n return getAlpha(value, options, true);\n };\n const values = prepareColorForCss(color, transformer);\n const template = values.length === 4\n ? `lab({1} {2} {3} / {4})`\n : `lab({1} {2} {3})`;\n return getResultFromTemplate(template, values);\n },\n [ColorModel.LCH]: (color, options) => {\n const { decimals, lchUnit, anglesUnit } = options;\n const transformer = (value, index) => {\n if (index === 0) {\n const L = round(percent(value), decimals);\n return lchUnit === ColorUnitEnum.PERCENT\n ? `${L}%`\n : `${L}`;\n }\n if (index === 1) {\n return lchUnit === ColorUnitEnum.PERCENT\n ? `${from150NumberToPercent(value, decimals)}%`\n : round(value, decimals);\n }\n if (index === 2) {\n if (anglesUnit !== AnglesUnitEnum.NONE) {\n const translated = round(translateDegrees(value, anglesUnit), decimals);\n return `${translated}${anglesUnit}`;\n }\n return round(value, decimals);\n }\n return getAlpha(value, options, true);\n };\n const values = prepareColorForCss(color, transformer);\n const template = values.length === 4\n ? `lch({1} {2} {3} / {4})`\n : `lch({1} {2} {3})`;\n return getResultFromTemplate(template, values);\n },\n [ColorModel.CMYK]: (color, options) => {\n const { decimals, legacyCSS, spacesAfterCommas, cmykUnit, cmykFunction } = options;\n const comma = getComma(spacesAfterCommas);\n const transformer = (value, index) => {\n if (cmykUnit === ColorUnitEnum.PERCENT &&\n index < 4) {\n return `${round(value, decimals)}%`;\n }\n return index === 4\n ? getAlpha(value, options)\n : round(value / 100, decimals);\n };\n const values = prepareColorForCss(color, transformer);\n const template = legacyCSS\n ? (values.length === 5\n ? `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4}${comma}{5})`\n : `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4})`)\n : (values.length === 5\n ? `${cmykFunction}({1} {2} {3} {4} / {5})`\n : `${cmykFunction}({1} {2} {3} {4})`);\n return getResultFromTemplate(template, values);\n }\n};\n\n;// ./src/color/utils.ts\n\n\n\n\n\n\nconst harmony = (color, angles, mode) => angles.reduce((arr, num) => ([\n ...arr,\n {\n ...color,\n H: mode === Mix.ADDITIVE\n ? normalizeHue(color.H + num)\n : normalizeHue(hueRyb(hueRyb(color.H, false) + num, true))\n }\n]), [{ ...color }]);\nconst analogous = (color, mode) => harmony(color, [30, -30], mode);\nconst complementary = (color, mode) => harmony(color, [180], mode);\nconst splitComplementary = (color, mode) => harmony(color, [150, -150], mode);\nconst triadic = (color, mode) => harmony(color, [120, -120], mode);\nconst tetradic = (color, mode) => harmony(color, [60, -120, 180], mode);\nconst square = (color, mode) => harmony(color, [90, -90, 180], mode);\nconst translateColor = {\n [ColorModel.HEX](color) {\n return {\n R: getHEX(color.R),\n G: getHEX(color.G),\n B: getHEX(color.B)\n };\n },\n HEXA(color) {\n const RGB = translateColor.HEX(color);\n RGB.A = hasProp(color, 'A')\n ? getHEX(color.A * BASE_255)\n : '0xFF';\n return RGB;\n },\n [ColorModel.RGB](color, decimals) {\n const RGB = roundRGBObject(color, decimals);\n if (hasProp(RGB, 'A')) {\n delete RGB.A;\n }\n return RGB;\n },\n RGBA(color, decimals) {\n const RGB = translateColor.RGB(color, decimals);\n RGB.A = hasProp(color, 'A')\n ? round(color.A)\n : 1;\n return RGB;\n },\n [ColorModel.HSL](color, decimals) {\n const HSL = rgbToHsl(color.R, color.G, color.B);\n delete HSL.A;\n return roundHSLObject(HSL, decimals);\n },\n HSLA(color, decimals) {\n const HSL = translateColor.HSL(color, decimals);\n HSL.A = hasProp(color, 'A')\n ? round(color.A, decimals)\n : 1;\n return HSL;\n },\n [ColorModel.HWB](color, decimals) {\n const HWB = rgbToHwb(color.R, color.G, color.B);\n delete HWB.A;\n return roundHWBObject(HWB, decimals);\n },\n HWBA(color, decimals) {\n const HWB = translateColor.HWB(color, decimals);\n HWB.A = hasProp(color, 'A')\n ? round(color.A, decimals)\n : 1;\n return HWB;\n },\n [ColorModel.CIELab](color, decimals) {\n const Lab = rgbToLab(color.R, color.G, color.B);\n return roundCIELabObject(Lab, decimals);\n },\n CIELabA(color, decimals) {\n const Lab = translateColor.CIELab(color, decimals);\n Lab.A = hasProp(color, 'A')\n ? round(color.A, decimals)\n : 1;\n return Lab;\n },\n [ColorModel.LCH](color, decimals) {\n const lch = rgbToLch(color.R, color.G, color.B);\n return roundLCHObject(lch, decimals);\n },\n LCHA(color, decimals) {\n const lch = translateColor.LCH(color, decimals);\n lch.A = hasProp(color, 'A')\n ? round(color.A, decimals)\n : 1;\n return lch;\n },\n [ColorModel.CMYK](color, decimals) {\n return roundCMYKObject(rgbToCmyk(color.R, color.G, color.B), decimals);\n },\n CMYKA(color, decimals) {\n const CMYK = translateColor.CMYK(color, decimals);\n CMYK.A = hasProp(color, 'A')\n ? round(color.A, decimals)\n : 1;\n return CMYK;\n }\n};\nconst blend = (from, to, steps) => {\n const div = steps - 1;\n const diffR = (to.R - from.R) / div;\n const diffG = (to.G - from.G) / div;\n const diffB = (to.B - from.B) / div;\n const fromA = normalizeAlpha(from.A);\n const toA = normalizeAlpha(to.A);\n const diffA = (toA - fromA) / div;\n return Array(steps).fill(null).map((__n, i) => {\n if (i === 0) {\n return from;\n }\n if (i === div) {\n return to;\n }\n return {\n R: round(from.R + diffR * i),\n G: round(from.G + diffG * i),\n B: round(from.B + diffB * i),\n A: round(fromA + diffA * i)\n };\n });\n};\nconst getColorMixture = (color, steps, shades, options) => {\n const model = getColorModel(color);\n const isCSS = typeof color === 'string';\n const RGB = getRGBObject(color, model);\n const hasAlpha = ((typeof color === 'string' && hasProp(RGB, 'A')) ||\n (typeof color !== 'string' &&\n hasProp(color, 'A')));\n const HSL = rgbToHsl(RGB.R, RGB.G, RGB.B, RGB.A);\n if (!hasAlpha)\n delete HSL.A;\n const increment = shades\n ? HSL.L / (steps + 1)\n : (100 - HSL.L) / (steps + 1);\n const hslMap = Array(steps).fill(null).map((__n, i) => ({\n ...HSL,\n L: HSL.L + increment * (i + 1) * (1 - +shades * 2)\n }));\n switch (model) {\n case ColorModel.HEX:\n default:\n return hslMap.map((HSLColor) => {\n const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n if (hasAlpha)\n RGBColor.A = HSLColor.A;\n return isCSS\n ? hasAlpha\n ? CSS.HEX({\n ...RGBColor,\n A: round(RGBColor.A * BASE_255)\n })\n : CSS.HEX(RGBColor)\n : hasAlpha\n ? translateColor.HEXA(RGBColor)\n : translateColor.HEX(RGBColor);\n });\n case ColorModel.RGB:\n return hslMap.map((HSLColor) => {\n const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n if (hasAlpha)\n RGBColor.A = HSLColor.A;\n return isCSS\n ? CSS.RGB(RGBColor, options)\n : hasAlpha\n ? translateColor.RGBA(RGBColor, options.decimals)\n : translateColor.RGB(RGBColor, options.decimals);\n // removed by dead control flow\n\n });\n case ColorModel.HSL:\n return hslMap.map((HSLColor) => {\n return isCSS\n ? CSS.HSL(HSLColor, options)\n : hasAlpha\n ? translateColor.HSLA({\n ...hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L),\n A: HSLColor.A\n }, options.decimals)\n : translateColor.HSL(hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L), options.decimals);\n });\n case ColorModel.HWB:\n return hslMap.map((HSLColor) => {\n const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n if (hasAlpha)\n RGBColor.A = HSLColor.A;\n const hwb = hasAlpha\n ? translateColor.HWBA(RGBColor, options.decimals)\n : translateColor.HWB(RGBColor, options.decimals);\n return isCSS\n ? CSS.HWB(hwb, options)\n : hwb;\n });\n case ColorModel.CIELab:\n return hslMap.map((HSLColor) => {\n const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n if (hasAlpha)\n RGBColor.A = HSLColor.A;\n const lab = hasAlpha\n ? translateColor.CIELabA(RGBColor, options.decimals)\n : translateColor.CIELab(RGBColor, options.decimals);\n return isCSS\n ? CSS.CIELab(lab, options)\n : lab;\n });\n case ColorModel.LCH:\n return hslMap.map((HSLColor) => {\n const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n const LCHColor = rgbToLch(RGBColor.R, RGBColor.G, RGBColor.B);\n if (hasAlpha)\n LCHColor.A = HSLColor.A;\n return isCSS\n ? CSS.LCH(LCHColor, options)\n : hasAlpha\n ? translateColor.LCHA({\n ...RGBColor,\n A: HSLColor.A\n }, options.decimals)\n : translateColor.LCH(RGBColor, options.decimals);\n });\n }\n};\nconst colorHarmony = {\n buildHarmony(color, harmonyFunction, mode, options) {\n const model = getColorModel(color);\n const RGB = getRGBObject(color, model);\n const HSL = rgbToHsl(RGB.R, RGB.G, RGB.B, RGB.A);\n const hasAlpha = ((typeof color === 'string' && hasProp(RGB, 'A')) ||\n (typeof color !== 'string' &&\n hasProp(color, 'A')));\n const isCSS = typeof color === 'string';\n switch (model) {\n case ColorModel.HEX:\n default:\n return hasAlpha\n ? this.HEXA(roundHSLObject(HSL, 0), harmonyFunction, mode, isCSS)\n : this.HEX(roundHSLObject(HSL, 0), harmonyFunction, mode, isCSS);\n case ColorModel.HSL:\n return hasAlpha\n ? this.HSLA(HSL, harmonyFunction, mode, isCSS, options)\n : this.HSL(HSL, harmonyFunction, mode, isCSS, options);\n case ColorModel.HWB:\n return hasAlpha\n ? this.HWBA(HSL, harmonyFunction, mode, isCSS, options)\n : this.HWB(HSL, harmonyFunction, mode, isCSS, options);\n case ColorModel.RGB:\n return hasAlpha\n ? this.RGBA(HSL, harmonyFunction, mode, isCSS, options)\n : this.RGB(HSL, harmonyFunction, mode, isCSS, options);\n case ColorModel.CIELab:\n return hasAlpha\n ? this.CIELabA(HSL, harmonyFunction, mode, isCSS, options)\n : this.CIELab(HSL, harmonyFunction, mode, isCSS, options);\n case ColorModel.LCH:\n return hasAlpha\n ? this.LCHA(HSL, harmonyFunction, mode, isCSS, options)\n : this.LCH(HSL, harmonyFunction, mode, isCSS, options);\n }\n },\n [ColorModel.HEX](color, harmonyFunction, mode, css) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => (css\n ? CSS.HEX(hslToRgb(c.H, c.S, c.L))\n : translateColor.HEX(hslToRgb(c.H, c.S, c.L))));\n },\n HEXA(color, harmonyFunction, mode, css) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => (css\n ? CSS.HEX({\n ...hslToRgb(c.H, c.S, c.L),\n A: normalizeAlpha(c.A) * BASE_255\n })\n : translateColor.HEXA({\n ...hslToRgb(c.H, c.S, c.L),\n A: normalizeAlpha(c.A)\n })));\n },\n [ColorModel.RGB](color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => (css\n ? CSS.RGB(hslToRgb(c.H, c.S, c.L), options)\n : translateColor.RGB(hslToRgb(c.H, c.S, c.L), options.decimals)));\n },\n RGBA(color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => (css\n ? CSS.RGB({\n ...hslToRgb(c.H, c.S, c.L),\n A: normalizeAlpha(c.A)\n }, options)\n : translateColor.RGBA({\n ...hslToRgb(c.H, c.S, c.L),\n A: normalizeAlpha(c.A)\n }, options.decimals)));\n },\n [ColorModel.HSL](color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => (css\n ? CSS.HSL({\n H: c.H,\n S: c.S,\n L: c.L\n }, options)\n : translateColor.HSL(hslToRgb(c.H, c.S, c.L), options.decimals)));\n },\n HSLA(color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => (css\n ? CSS.HSL({\n ...c,\n A: normalizeAlpha(c.A)\n }, options)\n : translateColor.HSLA({\n ...hslToRgb(c.H, c.S, c.L),\n A: normalizeAlpha(c.A)\n }, options.decimals)));\n },\n [ColorModel.HWB](color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => {\n const rgb = hslToRgb(c.H, c.S, c.L);\n const hwb = rgbToHwb(rgb.R, rgb.G, rgb.B);\n return css\n ? CSS.HWB({\n H: hwb.H,\n W: hwb.W,\n B: hwb.B\n }, options)\n : translateColor.HWB(rgb, options.decimals);\n });\n },\n HWBA(color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => {\n const rgb = hslToRgb(c.H, c.S, c.L);\n const hwb = rgbToHwb(rgb.R, rgb.G, rgb.B);\n return css\n ? CSS.HWB({\n ...hwb,\n A: normalizeAlpha(c.A)\n }, options)\n : translateColor.HWBA({\n ...rgb,\n A: normalizeAlpha(c.A)\n }, options.decimals);\n });\n },\n [ColorModel.CIELab](color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => {\n const RGB = hslToRgb(c.H, c.S, c.L);\n return (css\n ? CSS.CIELab(rgbToLab(RGB.R, RGB.G, RGB.B), options)\n : translateColor.CIELab(RGB, options.decimals));\n });\n },\n CIELabA(color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => {\n const RGB = hslToRgb(c.H, c.S, c.L);\n return (css\n ? CSS.CIELab({\n ...rgbToLab(RGB.R, RGB.G, RGB.B),\n A: normalizeAlpha(c.A)\n }, options)\n : translateColor.CIELabA({\n ...RGB,\n A: normalizeAlpha(c.A)\n }, options.decimals));\n });\n },\n [ColorModel.LCH](color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => {\n const RGB = hslToRgb(c.H, c.S, c.L);\n return (css\n ? CSS.LCH(rgbToLch(RGB.R, RGB.G, RGB.B), options)\n : translateColor.LCH(RGB, options.decimals));\n });\n },\n LCHA(color, harmonyFunction, mode, css, options) {\n const array = harmonyFunction(color, mode);\n return array.map((c) => {\n const RGB = hslToRgb(c.H, c.S, c.L);\n return (css\n ? CSS.LCH({\n ...rgbToLch(RGB.R, RGB.G, RGB.B),\n A: normalizeAlpha(c.A)\n }, options)\n : translateColor.LCHA({\n ...RGB,\n A: normalizeAlpha(c.A)\n }, options.decimals));\n });\n }\n};\nconst colorMixer = {\n mix(colors, mode) {\n const rgbMap = colors.map((color) => {\n const model = getColorModel(color);\n return getRGBObject(color, model);\n });\n const rybMap = mode === Mix.SUBTRACTIVE\n ? rgbMap.map((color) => {\n const RYB = rgbToRyb(color.R, color.G, color.B);\n if (hasProp(color, 'A')) {\n RYB.A = color.A;\n }\n return RYB;\n })\n : null;\n function createMix(items) {\n const initial = mode === Mix.ADDITIVE\n ? { R: 0, G: 0, B: 0, A: 0 }\n : { R: 0, Y: 0, B: 0, A: 0 };\n return items.reduce((mix, color) => {\n const colorA = hasProp(color, 'A') ? color.A : 1;\n const common = {\n R: Math.min(mix.R + color.R * colorA, BASE_255),\n B: Math.min(mix.B + color.B * colorA, BASE_255),\n A: 1 - (1 - colorA) * (1 - mix.A)\n };\n const mixGY = 'G' in mix\n ? mix.G\n : mix.Y;\n const colorGY = 'G' in color\n ? color.G\n : color.Y;\n return {\n ...common,\n ...(mode === Mix.ADDITIVE\n ? { G: Math.min(mixGY + colorGY * colorA, BASE_255) }\n : { Y: Math.min(mixGY + colorGY * colorA, BASE_255) })\n };\n }, initial);\n }\n let mix;\n if (mode === Mix.ADDITIVE) {\n mix = createMix(rgbMap);\n }\n else {\n const RYB = createMix(rybMap);\n mix = rybToRgb(RYB.R, RYB.Y, RYB.B);\n mix.A = RYB.A;\n }\n return {\n R: round(mix.R),\n G: round(mix.G),\n B: round(mix.B),\n A: minmax(mix.A, 0, 1)\n };\n },\n [ColorModel.HEX](colors, mode, css) {\n const mix = this.mix(colors, mode);\n delete mix.A;\n return (css\n ? CSS.HEX(mix)\n : translateColor.HEX(mix));\n },\n HEXA(colors, mode, css) {\n const mix = this.mix(colors, mode);\n mix.A = css\n ? normalizeAlpha(mix.A) * BASE_255\n : normalizeAlpha(mix.A);\n return (css\n ? CSS.HEX(mix)\n : translateColor.HEXA(mix));\n },\n [ColorModel.RGB](colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n delete mix.A;\n return (css\n ? CSS.RGB(mix, options)\n : translateColor.RGB(mix, options.decimals));\n },\n RGBA(colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n return (css\n ? CSS.RGB(mix, options)\n : translateColor.RGBA(mix, options.decimals));\n },\n [ColorModel.HSL](colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const HSL = rgbToHsl(mix.R, mix.G, mix.B);\n delete mix.A;\n delete HSL.A;\n return (css\n ? CSS.HSL(HSL, options)\n : translateColor.HSL(mix, options.decimals));\n },\n HSLA(colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const HSL = rgbToHsl(mix.R, mix.G, mix.B, mix.A);\n return (css\n ? CSS.HSL(HSL, options)\n : translateColor.HSLA(mix, options.decimals));\n },\n [ColorModel.HWB](colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const HWB = rgbToHwb(mix.R, mix.G, mix.B);\n delete mix.A;\n delete HWB.A;\n return (css\n ? CSS.HWB(HWB, options)\n : translateColor.HWB(mix, options.decimals));\n },\n HWBA(colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const HWB = rgbToHwb(mix.R, mix.G, mix.B, mix.A);\n return (css\n ? CSS.HWB(HWB, options)\n : translateColor.HWBA(mix, options.decimals));\n },\n [ColorModel.CIELab](colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const Lab = rgbToLab(mix.R, mix.G, mix.B);\n delete mix.A;\n return (css\n ? CSS.CIELab(Lab, options)\n : translateColor.CIELab(mix, options.decimals));\n },\n CIELabA(colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const Lab = rgbToLab(mix.R, mix.G, mix.B);\n Lab.A = mix.A;\n return (css\n ? CSS.CIELab(Lab, options)\n : translateColor.CIELabA(mix, options.decimals));\n },\n [ColorModel.LCH](colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const lch = rgbToLch(mix.R, mix.G, mix.B);\n delete mix.A;\n return (css\n ? CSS.LCH(lch, options)\n : translateColor.LCH(mix, options.decimals));\n },\n LCHA(colors, mode, css, options) {\n const mix = this.mix(colors, mode);\n const lch = rgbToLch(mix.R, mix.G, mix.B);\n lch.A = mix.A;\n return (css\n ? CSS.LCH(lch, options)\n : translateColor.LCHA(mix, options.decimals));\n }\n};\nconst roundRGBObject = (color, decimals) => {\n const R = round(color.R, decimals);\n const G = round(color.G, decimals);\n const B = round(color.B, decimals);\n return {\n R,\n G,\n B,\n ...(hasProp(color, 'A')\n ? {\n A: round(color.A, decimals)\n }\n : {})\n };\n};\n\n;// ./src/returns/index.ts\n\n\n\nconst getColorReturn = (color, model, decimals, translateFunction) => {\n const rgbObject = getRGBObject(color, model);\n return translateFunction(rgbObject, decimals);\n};\nconst getBlendReturn = (from, to, steps, decimals, translateFunction) => {\n if (steps < 1)\n steps = DEFAULT_BLEND_STEPS;\n const fromRGBObject = getRGBObject(from);\n const toRGBObject = getRGBObject(to);\n const blendArray = blend(fromRGBObject, toRGBObject, steps);\n return blendArray.map((color) => {\n return translateFunction(color, decimals);\n });\n};\nfunction getBlendReturnWithParameters(params) {\n const { from, to, thirdParameter, fourthParameter, translateFunction, cssFunction } = params;\n const result = typeof thirdParameter === 'number'\n ? getBlendReturn(from, to, thirdParameter, fourthParameter?.decimals, translateFunction)\n : getBlendReturn(from, to, DEFAULT_BLEND_STEPS, thirdParameter?.decimals, translateFunction);\n if (cssFunction) {\n return result.map((color) => cssFunction(color, getOptionsFromColorInput((typeof thirdParameter === 'number'\n ? fourthParameter\n : thirdParameter) ?? {}, from, to)));\n }\n return result;\n}\nfunction getMixReturn(params) {\n const { colors, secondParameter, thirdParameter, colorMixerFunction, css } = params;\n const options = getOptionsFromColorInput((typeof secondParameter === 'string'\n ? thirdParameter\n : secondParameter) ?? {}, ...colors);\n if (typeof secondParameter === 'string') {\n return colorMixerFunction(colors, secondParameter, css, options);\n }\n return colorMixerFunction(colors, Mix.ADDITIVE, css, options);\n}\nconst getHarmonyReturn = (harmony, color, mode, options) => {\n return ({\n [Harmony.ANALOGOUS]: colorHarmony.buildHarmony(color, analogous, mode, options),\n [Harmony.COMPLEMENTARY]: colorHarmony.buildHarmony(color, complementary, mode, options),\n [Harmony.SPLIT_COMPLEMENTARY]: colorHarmony.buildHarmony(color, splitComplementary, mode, options),\n [Harmony.TRIADIC]: colorHarmony.buildHarmony(color, triadic, mode, options),\n [Harmony.TETRADIC]: colorHarmony.buildHarmony(color, tetradic, mode, options),\n [Harmony.SQUARE]: colorHarmony.buildHarmony(color, square, mode, options)\n })[harmony];\n};\n\n;// ./src/index.ts\n\n\n\n\n\n\n\nconst bindedMixers = Object.fromEntries(Object.entries(colorMixer).map((entry) => {\n const [key, fn] = entry;\n return [key, fn.bind(colorMixer)];\n}));\nclass ColorTranslator {\n constructor(color, options = {}) {\n this._options = getOptionsFromColorInput(options, color);\n this.rgb = getRGBObject(color);\n this.update('rgb');\n }\n update(...exclude) {\n if (!exclude.includes('rgb')) {\n this.updateRGB();\n }\n if (!exclude.includes('hsl')) {\n this.updateHSL();\n }\n if (!exclude.includes('hwb')) {\n this.updateHWB();\n }\n if (!exclude.includes('lab')) {\n this.updateLAB();\n }\n if (!exclude.includes('lch')) {\n this.updateLCH();\n }\n if (!exclude.includes('cmyk')) {\n this.updateCMYK();\n }\n }\n updateRGB() {\n this.rgb = {\n ...hslToRgb(this.hsl.H, this.hsl.S, this.hsl.L),\n A: this.hsl.A\n };\n }\n updateHSL() {\n this.hsl = rgbToHsl(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n }\n updateHWB() {\n this.hwb = rgbToHwb(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n }\n updateLAB() {\n this.lab = {\n ...rgbToLab(this.rgb.R, this.rgb.G, this.rgb.B),\n A: this.rgb.A\n };\n }\n updateLCH() {\n this.lch = {\n ...rgbToLch(this.rgb.R, this.rgb.G, this.rgb.B),\n A: this.rgb.A\n };\n }\n updateCMYK() {\n this.cmyk = rgbToCmyk(this.rgb.R, this.rgb.G, this.rgb.B);\n }\n updateRGBFromHWB() {\n this.rgb = {\n ...hwbToRgb(this.hwb.H, this.hwb.W, this.hwb.B),\n A: this.rgb.A\n };\n }\n updateRGBFromLCH() {\n this.rgb = {\n ...lchToRgb(this.lch.L, this.lch.C, this.lch.H),\n A: this.rgb.A\n };\n }\n updateRGBFromCMYK() {\n this.rgb = {\n ...cmykToRgb(this.cmyk.C, this.cmyk.M, this.cmyk.Y, this.cmyk.K),\n A: this.rgb.A\n };\n }\n updateRGBFromLAB() {\n this.rgb = {\n ...labToRgb(this.lab.L, this.lab.a, this.lab.b),\n A: this.rgb.A\n };\n }\n updateLCHFromLAB() {\n this.lch = {\n ...labToLch(this.lab.L, this.lab.a, this.lab.b),\n A: this.lab.A\n };\n }\n updateLABromLCH() {\n this.lab = {\n ...lchToLab(this.lch.L, this.lch.C, this.lch.H),\n A: this.lch.A\n };\n }\n setOptions(options = {}) {\n this._options = {\n ...this._options,\n ...options\n };\n return this;\n }\n setR(R) {\n this.rgb.R = minmax(R, 0, BASE_255);\n this.update('rgb');\n return;\n }\n setG(G) {\n this.rgb.G = minmax(G, 0, BASE_255);\n this.update('rgb');\n return this;\n }\n setB(B) {\n this.rgb.B = minmax(B, 0, BASE_255);\n this.update('rgb');\n return this;\n }\n setH(H) {\n this.hsl.H = normalizeHue(H);\n this.update('hsl');\n return this;\n }\n setS(S) {\n this.hsl.S = minmax(S, 0, MAX_PCENT);\n this.update('hsl');\n return this;\n }\n setL(L) {\n this.hsl.L = minmax(L, 0, MAX_PCENT);\n this.update('hsl');\n return this;\n }\n setWhiteness(W) {\n this.hwb.W = minmax(W, 0, MAX_PCENT);\n this.updateRGBFromHWB();\n this.update('rgb', 'hwb');\n return this;\n }\n setBlackness(B) {\n this.hwb.B = minmax(B, 0, MAX_PCENT);\n this.updateRGBFromHWB();\n this.update('rgb', 'hwb');\n return this;\n }\n setCIEL(L) {\n this.lab.L = minmax(L, 0, MAX_PCENT);\n this.updateRGBFromLAB();\n this.updateLCHFromLAB();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setCIEa(a) {\n this.lab.a = minmax(a, -MAX_LAB, MAX_LAB);\n this.updateRGBFromLAB();\n this.updateLCHFromLAB();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setCIEb(b) {\n this.lab.b = minmax(b, -MAX_LAB, MAX_LAB);\n this.updateRGBFromLAB();\n this.updateLCHFromLAB();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setLCHL(l) {\n this.lch.L = minmax(l, 0, MAX_PCENT);\n this.updateRGBFromLCH();\n this.updateLABromLCH();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setLCHC(c) {\n this.lch.C = minmax(c, 0, MAX_LCH_C);\n this.updateRGBFromLCH();\n this.updateLABromLCH();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setLCHH(h) {\n this.lch.H = normalizeHue(h);\n this.updateRGBFromLCH();\n this.updateLABromLCH();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setA(A) {\n const alpha = minmax(A, 0, MAX_ALPHA);\n this.rgb.A = alpha;\n this.hsl.A = alpha;\n this.hwb.A = alpha;\n this.lab.A = alpha;\n this.lch.A = alpha;\n this.cmyk.A = alpha;\n return this;\n }\n setC(C) {\n this.cmyk.C = minmax(C, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n setM(M) {\n this.cmyk.M = minmax(M, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n setY(Y) {\n this.cmyk.Y = minmax(Y, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n setK(K) {\n this.cmyk.K = minmax(K, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n get options() {\n return this._options;\n }\n get R() {\n return round(this.rgb.R, this.options.decimals);\n }\n get G() {\n return round(this.rgb.G, this.options.decimals);\n }\n get B() {\n return round(this.rgb.B, this.options.decimals);\n }\n get H() {\n return round(this.hsl.H, this.options.decimals);\n }\n get S() {\n return round(this.hsl.S, this.options.decimals);\n }\n get L() {\n return round(this.hsl.L, this.options.decimals);\n }\n get Whiteness() {\n return round(this.hwb.W, this.options.decimals);\n }\n get Blackness() {\n return round(this.hwb.B, this.options.decimals);\n }\n get CIEL() {\n return round(this.lab.L, this.options.decimals);\n }\n get CIEa() {\n return round(this.lab.a, this.options.decimals);\n }\n get CIEb() {\n return round(this.lab.b, this.options.decimals);\n }\n get LCHL() {\n return round(this.lch.L, this.options.decimals);\n }\n get LCHC() {\n return round(this.lch.C, this.options.decimals);\n }\n get LCHH() {\n return round(this.lch.H, this.options.decimals);\n }\n get A() {\n return round(this.hsl.A, this.options.decimals);\n }\n get C() {\n return round(this.cmyk.C, this.options.decimals);\n }\n get M() {\n return round(this.cmyk.M, this.options.decimals);\n }\n get Y() {\n return round(this.cmyk.Y, this.options.decimals);\n }\n get K() {\n return round(this.cmyk.K, this.options.decimals);\n }\n get HEXObject() {\n return translateColor.HEX(this.rgb);\n }\n get HEXAObject() {\n return translateColor.HEXA(this.rgb);\n }\n get RGBObject() {\n return {\n R: this.R,\n G: this.G,\n B: this.B\n };\n }\n get RGBAObject() {\n return {\n ...this.RGBObject,\n A: this.A\n };\n }\n get HSLObject() {\n return {\n H: this.H,\n S: this.S,\n L: this.L\n };\n }\n get HSLAObject() {\n return {\n ...this.HSLObject,\n A: this.A\n };\n }\n get HWBObject() {\n return {\n H: this.H,\n W: this.Whiteness,\n B: this.Blackness\n };\n }\n get HWBAObject() {\n return {\n ...this.HWBObject,\n A: this.A\n };\n }\n get CIELabObject() {\n return {\n L: this.CIEL,\n a: this.CIEa,\n b: this.CIEb\n };\n }\n get CIELabAObject() {\n return {\n ...this.CIELabObject,\n A: this.A\n };\n }\n get LCHObject() {\n return {\n L: this.LCHL,\n C: this.LCHC,\n H: this.LCHH\n };\n }\n get LCHAObject() {\n return {\n ...this.LCHObject,\n A: this.A\n };\n }\n get CMYKObject() {\n return {\n C: this.C,\n M: this.M,\n Y: this.Y,\n K: this.K\n };\n }\n get CMYKAObject() {\n return {\n ...this.CMYKObject,\n A: this.A\n };\n }\n get HEX() {\n return CSS.HEX({\n R: this.R,\n G: this.G,\n B: this.B\n });\n }\n get HEXA() {\n return CSS.HEX({\n R: this.R,\n G: this.G,\n B: this.B,\n A: this.A * BASE_255\n });\n }\n get RGB() {\n return CSS.RGB({\n R: this.R,\n G: this.G,\n B: this.B\n }, this.options);\n }\n get RGBA() {\n return CSS.RGB({\n R: this.R,\n G: this.G,\n B: this.B,\n A: this.A\n }, this.options);\n }\n get HSL() {\n return CSS.HSL({\n H: this.H,\n S: this.S,\n L: this.L\n }, this.options);\n }\n get HSLA() {\n return CSS.HSL({\n H: this.H,\n S: this.S,\n L: this.L,\n A: this.A\n }, this.options);\n }\n get HWB() {\n return CSS.HWB({\n H: this.H,\n W: this.Whiteness,\n B: this.Blackness\n }, this.options);\n }\n get HWBA() {\n return CSS.HWB({\n H: this.H,\n W: this.Whiteness,\n B: this.Blackness,\n A: this.A\n }, this.options);\n }\n get CIELab() {\n return CSS.CIELab({\n L: this.CIEL,\n a: this.CIEa,\n b: this.CIEb\n }, this.options);\n }\n get CIELabA() {\n return CSS.CIELab({\n L: this.CIEL,\n a: this.CIEa,\n b: this.CIEb,\n A: this.A\n }, this.options);\n }\n get LCH() {\n return CSS.LCH({\n L: this.LCHL,\n C: this.LCHC,\n H: this.LCHH\n }, this.options);\n }\n get LCHA() {\n return CSS.LCH({\n L: this.LCHL,\n C: this.LCHC,\n H: this.LCHH,\n A: this.A\n }, this.options);\n }\n get CMYK() {\n return CSS.CMYK({\n C: this.C,\n M: this.M,\n Y: this.Y,\n K: this.K\n }, this.options);\n }\n get CMYKA() {\n return CSS.CMYK({\n C: this.C,\n M: this.M,\n Y: this.Y,\n K: this.K,\n A: this.A\n }, this.options);\n }\n static toHEXObject(color) {\n const model = getColorModel(color);\n return getColorReturn(color, model, 0, translateColor.HEX);\n }\n static toHEX(color) {\n return CSS.HEX(ColorTranslator.toHEXObject(color));\n }\n static toHEXAObject(color) {\n const model = getColorModel(color);\n return getColorReturn(color, model, 0, translateColor.HEXA);\n }\n static toHEXA(color) {\n return CSS.HEX(ColorTranslator.toHEXAObject(color));\n }\n static toRGBObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.RGB);\n }\n static toRGB(color, options = {}) {\n const rgb = ColorTranslator.toRGBObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.RGB(rgb, detectedOptions);\n }\n static toRGBAObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.RGBA);\n }\n static toRGBA(color, options = {}) {\n const rgba = ColorTranslator.toRGBAObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.RGB(rgba, detectedOptions);\n }\n static toHSLObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.HSL);\n }\n static toHSL(color, options = {}) {\n const hsl = ColorTranslator.toHSLObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.HSL(hsl, detectedOptions);\n }\n static toHSLAObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.HSLA);\n }\n static toHSLA(color, options = {}) {\n const hsla = ColorTranslator.toHSLAObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.HSL(hsla, detectedOptions);\n }\n static toHWBObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.HWB);\n }\n static toHWB(color, options = {}) {\n const hwb = ColorTranslator.toHWBObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.HWB(hwb, detectedOptions);\n }\n static toHWBAObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.HWBA);\n }\n static toHWBA(color, options = {}) {\n const hwb = ColorTranslator.toHWBAObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.HWB(hwb, detectedOptions);\n }\n static toCIELabObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.CIELab);\n }\n static toCIELab(color, options = {}) {\n const lab = ColorTranslator.toCIELabObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.CIELab(lab, detectedOptions);\n }\n static toCIELabAObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.CIELabA);\n }\n static toCIELabA(color, options = {}) {\n const lab = ColorTranslator.toCIELabAObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.CIELab(lab, detectedOptions);\n }\n static toLCHObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.LCH);\n }\n static toLCH(color, options = {}) {\n const lch = ColorTranslator.toLCHObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.LCH(lch, detectedOptions);\n }\n static toLCHAObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.LCHA);\n }\n static toLCHA(color, options = {}) {\n const lch = ColorTranslator.toLCHAObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.LCH(lch, detectedOptions);\n }\n static toCMYKObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.CMYK);\n }\n static toCMYK(color, options = {}) {\n const cmyk = ColorTranslator.toCMYKObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.CMYK(cmyk, detectedOptions);\n }\n static toCMYKAObject(color, options = {}) {\n const model = getColorModel(color);\n return getColorReturn(color, model, options.decimals, translateColor.CMYKA);\n }\n static toCMYKA(color, options = {}) {\n const cmyka = ColorTranslator.toCMYKAObject(color, options);\n const detectedOptions = getOptionsFromColorInput(options, color);\n return CSS.CMYK(cmyka, detectedOptions);\n }\n static getBlendHEXObject(from, to, steps = DEFAULT_BLEND_STEPS) {\n return getBlendReturn(from, to, steps, 0, translateColor.HEX);\n }\n static getBlendHEX(from, to, steps = DEFAULT_BLEND_STEPS) {\n return ColorTranslator.getBlendHEXObject(from, to, steps)\n .map((color) => CSS.HEX(color));\n }\n static getBlendHEXAObject(from, to, steps = DEFAULT_BLEND_STEPS) {\n return getBlendReturn(from, to, steps, 0, translateColor.HEXA);\n }\n static getBlendHEXA(from, to, steps = DEFAULT_BLEND_STEPS) {\n return ColorTranslator.getBlendHEXAObject(from, to, steps)\n .map((color) => CSS.HEX(color));\n }\n static getBlendRGBObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.RGB\n });\n }\n static getBlendRGB(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.RGB,\n cssFunction: CSS.RGB\n });\n }\n static getBlendRGBAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.RGBA\n });\n }\n static getBlendRGBA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.RGBA,\n cssFunction: CSS.RGB\n });\n }\n static getBlendHSLObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HSL\n });\n }\n static getBlendHSL(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HSL,\n cssFunction: CSS.HSL\n });\n }\n static getBlendHSLAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HSLA\n });\n }\n static getBlendHSLA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HSLA,\n cssFunction: CSS.HSL\n });\n }\n static getBlendHWBObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HWB\n });\n }\n static getBlendHWB(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HWB,\n cssFunction: CSS.HWB\n });\n }\n static getBlendHWBAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HWBA\n });\n }\n static getBlendHWBA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.HWBA,\n cssFunction: CSS.HWB\n });\n }\n static getBlendCIELabObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.CIELab\n });\n }\n static getBlendCIELab(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.CIELab,\n cssFunction: CSS.CIELab\n });\n }\n static getBlendCIELabAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.CIELabA\n });\n }\n static getBlendCIELabA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.CIELabA,\n cssFunction: CSS.CIELab\n });\n }\n static getBlendLCHObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.LCH\n });\n }\n static getBlendLCH(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.LCH,\n cssFunction: CSS.LCH\n });\n }\n static getBlendLCHAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.LCHA\n });\n }\n static getBlendLCHA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturnWithParameters({\n from,\n to,\n thirdParameter,\n fourthParameter,\n translateFunction: translateColor.LCHA,\n cssFunction: CSS.LCH\n });\n }\n static getMixHEXObject(colors, mode = Mix.ADDITIVE) {\n return colorMixer.HEX(colors, mode, false);\n }\n static getMixHEX(colors, mode = Mix.ADDITIVE) {\n return colorMixer.HEX(colors, mode, true);\n }\n static getMixHEXAObject(colors, mode = Mix.ADDITIVE) {\n return colorMixer.HEXA(colors, mode, false);\n }\n static getMixHEXA(colors, mode = Mix.ADDITIVE) {\n return colorMixer.HEXA(colors, mode, true);\n }\n static getMixRGBObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.RGB,\n css: false\n });\n }\n static getMixRGB(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.RGB,\n css: true\n });\n }\n static getMixRGBAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.RGBA,\n css: false\n });\n }\n static getMixRGBA(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.RGBA,\n css: true\n });\n }\n static getMixHSLObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HSL,\n css: false\n });\n }\n static getMixHSL(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HSL,\n css: true\n });\n }\n static getMixHSLAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HSLA,\n css: false\n });\n }\n static getMixHSLA(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HSLA,\n css: true\n });\n }\n static getMixHWBObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HWB,\n css: false\n });\n }\n static getMixHWB(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HWB,\n css: true\n });\n }\n static getMixHWBAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HWBA,\n css: false\n });\n }\n static getMixHWBA(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.HWBA,\n css: true\n });\n }\n static getMixCIELabObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.CIELab,\n css: false\n });\n }\n static getMixCIELab(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.CIELab,\n css: true\n });\n }\n static getMixCIELabAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.CIELabA,\n css: false\n });\n }\n static getMixCIELabA(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.CIELabA,\n css: true\n });\n }\n static getMixLCHObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.LCH,\n css: false\n });\n }\n static getMixLCH(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.LCH,\n css: true\n });\n }\n static getMixLCHAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.LCHA,\n css: false\n });\n }\n static getMixLCHA(colors, secondParameter, thirdParameter) {\n return getMixReturn({\n colors,\n secondParameter,\n thirdParameter,\n colorMixerFunction: bindedMixers.LCHA,\n css: true\n });\n }\n static getShades(color, secondParameter, thirdParameter) {\n if (typeof secondParameter === 'number') {\n return getColorMixture(color, secondParameter, true, getOptionsFromColorInput(thirdParameter || {}, color));\n }\n return getColorMixture(color, DEFAULT_SHADES_TINTS_STEPS, true, getOptionsFromColorInput(secondParameter || {}, color));\n }\n static getTints(color, secondParameter, thirdParameter) {\n if (typeof secondParameter === 'number') {\n return getColorMixture(color, secondParameter, false, getOptionsFromColorInput(thirdParameter || {}, color));\n }\n return getColorMixture(color, DEFAULT_SHADES_TINTS_STEPS, false, getOptionsFromColorInput(secondParameter || {}, color));\n }\n static getHarmony(color, secondParam, thirdParam, fourthParam) {\n if (isHarmony(secondParam)) {\n return getHarmonyReturn(secondParam, color, isMix(thirdParam)\n ? thirdParam\n : Mix.ADDITIVE, getOptionsFromColorInput(isMix(thirdParam)\n ? (fourthParam || {})\n : thirdParam || {}, color));\n }\n else if (isMix(secondParam)) {\n return getHarmonyReturn(Harmony.COMPLEMENTARY, color, secondParam, getOptionsFromColorInput(thirdParam || {}, color));\n }\n return getHarmonyReturn(Harmony.COMPLEMENTARY, color, Mix.ADDITIVE, getOptionsFromColorInput(secondParam || {}, color));\n }\n}\n\n\n;// ./src/@demo/demo1/index.js\n\n\n/* harmony default export */ const demo1 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const color = new ColorTranslator('hsl(180 100% 50%)', { decimals: 0 });\n\n for (let row = 0; row < 10; row++) {\n\n for (let col = 0; col < 10; col++) {\n\n color\n .setS(row * 10)\n .setL(col * 5 + 30);\n\n const box = document.createElement('div');\n\n box.classList.add('box');\n box.style.background = color.HEX;\n\n box.innerText =\n `R:${color.R}\n G:${color.G}\n B:${color.B}`;\n container.appendChild(box);\n\n }\n }\n\n return container;\n\n});\n;// ./src/@demo/demo2/index.js\n\n\n/* harmony default export */ const demo2 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const color = new ColorTranslator({ R: 255, G: 0, B: 0 });\n const hue = [0, 30, 60, 120, 240, 280, 320, 0];\n let rainbow;\n\n for (let r = 0; r < hue.length; r++) {\n\n color.setH(hue[r]);\n\n const bow = document.createElement('div');\n\n bow.classList.add('rainbow');\n bow.style.background = color.HEX;\n\n if (rainbow) {\n rainbow.appendChild(bow);\n } else {\n container.appendChild(bow);\n }\n\n rainbow = bow;\n }\n\n rainbow.style.background = '#333';\n\n return container;\n\n});\n;// ./src/@demo/demo3/index.js\n\n\n/* harmony default export */ const demo3 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const hsl = { H: 0, S: '90%', L: '50%' };\n const hue = [undefined, 55, 30, 0, 290, 220, 130];\n const total = hue.length;\n\n for (let row = 0; row < total; row++) {\n\n for (let col = 0; col < total; col++) {\n\n let index = total - row + col;\n if (index >= total) {\n index -= total;\n }\n hsl.H = hue[index];\n const rgb = hue[index] === undefined\n ? '#FFF'\n : ColorTranslator.toHEX(hsl);\n const box = document.createElement('div');\n\n box.classList.add('flag');\n box.style.background = rgb;\n\n container.appendChild(box);\n\n }\n }\n\n return container;\n\n});\n;// ./src/@demo/demo4/index.js\n\n\n/* harmony default export */ const demo4 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const hexColors = [\n '#FE2712', '#FE5409', '#FB9902',\n '#FABD03', '#FFFE32', '#D1EA2C',\n '#66B132', '#0392CE', '#0247FE',\n '#3D00A5', '#8601B0', '#A7194B'\n ];\n\n hexColors.forEach((color) => {\n\n const rgb = ColorTranslator.toRGB(color);\n const hsl = ColorTranslator.toHSL(color, { decimals: 0 });\n const hwb = ColorTranslator.toHWB(color, { decimals: 0 });\n const lab = ColorTranslator.toCIELab(color, { decimals: 0 });\n const lch = ColorTranslator.toLCH(color, { decimals: 0 });\n\n const rgbDiv = document.createElement('div');\n const hslDiv = document.createElement('div');\n const hwbDiv = document.createElement('div');\n const labDiv = document.createElement('div');\n const lchDiv = document.createElement('div');\n\n rgbDiv.style.backgroundColor = rgb;\n rgbDiv.textContent = rgb;\n\n hslDiv.style.backgroundColor = hsl;\n hslDiv.textContent = hsl;\n\n hwbDiv.style.backgroundColor = hwb;\n hwbDiv.textContent = hwb;\n\n labDiv.style.backgroundColor = lab;\n labDiv.textContent = lab;\n\n lchDiv.style.backgroundColor = lch;\n lchDiv.textContent = lch;\n\n container.appendChild(rgbDiv);\n container.appendChild(hslDiv);\n container.appendChild(hwbDiv);\n container.appendChild(labDiv);\n container.appendChild(lchDiv);\n\n });\n\n return container;\n\n});\n;// ./src/@demo/demo5/index.js\n\n\n/* harmony default export */ const demo5 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const colors = [\n 'red',\n 'lime',\n 'blue',\n 'aqua',\n 'yellow',\n 'fuchsia'\n ];\n const total = colors.length;\n\n for (let row = 0; row < total; row++) {\n\n const hsl = ColorTranslator.toHSLObject(colors[row]);\n const step = hsl.S / (total - 1);\n\n for (let col = 0; col < total; col++) {\n\n const rgb = ColorTranslator.toHEX(hsl);\n const cmyk = ColorTranslator.toCMYKObject(hsl, { decimals: 0 });\n\n const box = document.createElement('div');\n box.classList.add('box');\n box.style.background = rgb;\n box.innerText = `C:${cmyk.C}\n M:${cmyk.M}\n Y:${cmyk.Y}\n K:${cmyk.K}`;\n\n container.appendChild(box);\n\n hsl.S -= step;\n\n }\n }\n\n return container;\n\n});\n;// ./src/@demo/demo6/index.js\n\n\n/* harmony default export */ const demo6 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const rows = 11;\n const mult = 3;\n\n for (let i = 0; i < rows; i++) {\n\n const blends = ColorTranslator.getBlendHEX('#F00', '#FF0', mult + i * mult);\n\n blends.forEach((blend, index) => {\n const box = document.createElement('div');\n box.classList.add('box', `file${i}`);\n box.style.background = blend;\n box.innerText = index + 1;\n container.appendChild(box);\n });\n\n }\n\n return container;\n\n});\n;// ./src/@demo/demo7/index.js\n\n\n/* harmony default export */ const demo7 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n\n const colors = ['#F00', '#FF8000', '#FF0', '#0F0', '#00F', '#A0F', '#F0A'];\n\n const createBox = (color, type) => {\n const box = document.createElement('div');\n box.classList.add('box');\n box.style.backgroundColor = color;\n if (type) box.dataset.type = type;\n container.appendChild(box);\n };\n\n colors.forEach((color) => {\n const shades = ColorTranslator.getShades(color, 3).reverse();\n const tints = ColorTranslator.getTints(color, 3);\n shades.forEach((shade) => createBox(shade, 'shade'));\n createBox(color);\n tints.forEach((tint) => createBox(tint, 'tint'));\n });\n\n return container;\n\n});\n;// ./src/@demo/demo8/index.js\n\n\n\n/* harmony default export */ const demo8 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n\n const mixes = [\n '#F00',\n '#0F0',\n '#00F',\n [1, 3],\n [1, 2],\n [2, 3],\n [1, 2, 3]\n ];\n\n const fillPlanes = () => {\n const planes = container.querySelectorAll('#planes path');\n planes.forEach((plane, index) => {\n let color = '#CCC';\n if (typeof mixes[index] === 'string') {\n color = mixes[index];\n } else if(mixes[index]) {\n const colors = mixes[index].map((i) => mixes[i - 1]);\n color = mixes[index] = ColorTranslator.getMixHEX(colors);\n }\n plane.setAttribute('fill', color);\n });\n };\n\n fetch('images/color-mixes.svg')\n .then(result => result.text())\n .then((svgCode) => {\n container.innerHTML = svgCode;\n fillPlanes();\n });\n\n return container;\n\n});\n;// ./src/@demo/demo9/index.js\n\n\n/* harmony default export */ const demo9 = ((ColorTranslator, { Mix }) => {\n\n const container = document.createElement('div');\n\n const mixes = [\n '#F00',\n '#FF0',\n '#00F',\n [1, 3],\n [1, 2],\n [2, 3],\n [1, 2, 3]\n ];\n\n const fillPlanes = () => {\n const planes = container.querySelectorAll('#planes path');\n planes.forEach((plane, index) => {\n let color = '#CCC';\n if (typeof mixes[index] === 'string') {\n color = mixes[index];\n } else if(mixes[index]) {\n const colors = mixes[index].map((i) => mixes[i - 1]);\n color = mixes[index] = ColorTranslator.getMixHEX(colors, Mix.SUBTRACTIVE);\n }\n plane.setAttribute('fill', color);\n });\n };\n\n fetch('images/color-mixes.svg')\n .then(result => result.text())\n .then((svgCode) => {\n container.innerHTML = svgCode;\n fillPlanes();\n });\n\n return container;\n\n});\n;// ./src/@demo/demo10/index.js\n\n\n/* harmony default export */ const demo10 = ((ColorTranslator, { Harmony }) => {\n\n const container = document.createElement('div');\n\n const harmonies = [\n { label: 'Complementary', value: Harmony.COMPLEMENTARY },\n { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n { label: 'Analogous', value: Harmony.ANALOGOUS },\n { label: 'Triadic', value: Harmony.TRIADIC },\n { label: 'Tetradic', value: Harmony.TETRADIC },\n { label: 'Square', value: Harmony.SQUARE }\n ];\n\n const baseColor = '#F00';\n\n const createElement = (className, parent) => {\n const div = document.createElement('div');\n div.classList.add(className);\n parent.appendChild(div);\n return div;\n };\n\n const createHarmony = (item) => {\n\n const wrapper = createElement('wrapper', container);\n const wheel = createElement('wheel', wrapper);\n const harmony = createElement('harmony', wrapper);\n createElement('label', wrapper).innerText = item.label;\n\n fetch('images/wheel-additive.svg')\n .then(result => result.text())\n .then((svgCode) => {\n const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value);\n const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n wheel.innerHTML = svgCode;\n harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n });\n\n };\n\n harmonies.forEach((item) => createHarmony(item));\n\n return container;\n\n});\n;// ./src/@demo/demo11/index.js\n\n\n/* harmony default export */ const demo11 = ((ColorTranslator, { Harmony, Mix }) => {\n\n const container = document.createElement('div');\n\n const harmonies = [\n { label: 'Complementary', value: Harmony.COMPLEMENTARY },\n { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n { label: 'Analogous', value: Harmony.ANALOGOUS },\n { label: 'Triadic', value: Harmony.TRIADIC },\n { label: 'Tetradic', value: Harmony.TETRADIC },\n { label: 'Square', value: Harmony.SQUARE }\n ];\n\n const baseColor = '#F00';\n\n const createElement = (className, parent) => {\n const div = document.createElement('div');\n div.classList.add(className);\n parent.appendChild(div);\n return div;\n };\n\n const createHarmony = (item) => {\n\n const wrapper = createElement('wrapper', container);\n const wheel = createElement('wheel', wrapper);\n const harmony = createElement('harmony', wrapper);\n createElement('label', wrapper).innerText = item.label;\n\n fetch('images/wheel-subtractive.svg')\n .then(result => result.text())\n .then((svgCode) => {\n const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value, Mix.SUBTRACTIVE);\n const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n wheel.innerHTML = svgCode;\n harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n });\n\n };\n\n harmonies.forEach((item) => createHarmony(item));\n\n return container;\n\n});\n;// ./src/@demo/demo.js\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst functioToString = (fn) => {\n const article = document.createElement('article');\n const pre = document.createElement('pre');\n article.classList.add('function-container');\n pre.classList.add('prettyprint');\n article.appendChild(pre);\n pre.innerHTML = fn.toString().replace('(ColorTranslator)', '()');\n return article;\n};\n\nconst demos = new Map([\n ['demo1', demo1],\n ['demo2', demo2],\n ['demo3', demo3],\n ['demo4', demo4],\n ['demo5', demo5],\n ['demo6', demo6],\n ['demo7', demo7],\n ['demo8', demo8],\n ['demo9', demo9],\n ['demo10', demo10],\n ['demo11', demo11]\n]);\n\ndocument.addEventListener('DOMContentLoaded', () => {\n demos.forEach((module, div) => {\n const demo = document.getElementById(div);\n const container = document.createElement('div');\n const wrapper = document.createElement('div');\n\n container.classList.add('demo-container');\n wrapper.classList.add('demo-wrapper');\n\n wrapper.appendChild(module(ColorTranslator, { Harmony: Harmony, Mix: Mix }));\n container.appendChild(wrapper);\n demo.appendChild(container);\n demo.appendChild(functioToString(module));\n });\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"967.js","mappings":";;;;AAAA;AACA;AACA;AACA;AACA;AACA,UAAU,qBAAM,oBAAoB,qBAAM;AAC1C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEO;AACP;;AAEA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,kBAAkB,iBAAiB;AACnC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA,qDAAqD;AACrD,QAAQ;AACR;AACA,QAAQ;AACR,4EAA4E;AAC5E;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEO;AACP;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4BAA4B,qBAAqB;AACjD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;;AAEO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA,qCAAqC,4BAA4B;AACjE;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA,6BAA6B,0BAA0B,eAAe;AACtE;;AAEO;AACP;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEO,SAAS,WAAK;AACrB;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA,WAAK;;AAEL;AACA,YAAY,WAAK;AACjB;AACA;AACA;AACA;;;ACjoBO;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACRA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,gCAAgC;AAC1B;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,0BAA0B;AACpB;AACP;AACA;AACA;AACA,CAAC,kBAAkB;AACZ;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,sCAAsC;AAChC;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA,CAAC,wBAAwB;;;AC3MY;AAC9B;AACP,KAAK,UAAU,iFAAiF,EAAE,eAAe,EAAE,eAAe,EAAE,eAAe,EAAE;AACrJ,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACA;AACA,yBAAyB,IAAI;AAC7B,wBAAwB,OAAO;AAC/B;AACA;;;ACvBA;AACP;AACA;AACA;AACA;;;ACJO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,wCAAwC;AAClC;AACP;AACA;AACA;AACA,CAAC,sCAAsC;AAChC;AACP;AACA;AACA;AACA,CAAC,4CAA4C;;;ACjB4B;AAChC;AAClC;AACP,cAAc,YAAY;AAC1B;AACA;AACA,gBAAgB,cAAc;AAC9B,aAAa,aAAa;AAC1B,aAAa,aAAa;AAC1B,aAAa,aAAa;AAC1B,cAAc,aAAa;AAC3B,eAAe,aAAa;AAC5B,kBAAkB,gBAAgB;AAClC;;;ACb0B;AACF;AACQ;AACN;AACD;AACC;;;ACLc;AAC8E;AAC/G;AACA;AACP,eAAe,QAAQ,UAAU,KAAK;AACtC;AACO,6BAA6B,KAAK,SAAS,QAAQ;AAC1D;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA,qBAAqB,IAAI;AACzB;AACA,gBAAgB,IAAI;AACpB;AACO;AACP;AACA;AACA,kBAAkB,IAAI;AACtB;AACA;AACA;AACO,kEAAkE,QAAQ;AAC1E,kEAAkE,OAAO;AACzE,kEAAkE,SAAS;AAC3E;AACP,kBAAkB,KAAK;AACvB,wBAAwB,QAAQ,+BAA+B,QAAQ;AACvE;AACA,QAAQ,GAAG;AACX;AACA;AACA;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA,wCAAwC,QAAQ;AAChD;AACO;AACP,QAAQ,KAAK;AACb,sBAAsB,OAAO,gCAAgC,OAAO,EAAE,OAAO;AAC7E;AACA,2BAA2B,OAAO,EAAE,OAAO;AAC3C;AACO;AACP,QAAQ,KAAK;AACb,sBAAsB,SAAS,gCAAgC,SAAS,EAAE,SAAS;AACnF;AACA,2BAA2B,SAAS,EAAE,SAAS;AAC/C;AACO,0CAA0C,KAAK;AAC/C;AACA,iCAAiC,YAAY;AACpD;AACA;AACA;AACO;AACA;AACA;AACP;AACO;AACP;AACA,kCAAkC,OAAO;AACzC;AACA;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,YAAY,KAAK;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,SAAS,IAAI,SAAS;AAC3D;AACO;AACP;AACA;AACA,aAAa,cAAc;AAC3B;AACA;AACA,aAAa,cAAc;AAC3B;AACA;AACA,aAAa,cAAc;AAC3B;AACA;AACA,aAAa,cAAc;AAC3B,aAAa,cAAc;AAC3B;AACA;AACA;AACA;AACA;AACO;AACP,cAAc,MAAM,KAAK,OAAO;AAChC;AACO;AACP,cAAc,MAAM,KAAK,GAAG;AAC5B;;;ACjIiD;AACwB;AACzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK,0BAA0B,QAAQ;AACtD;AACA;AACA,eAAe,KAAK,MAAM,QAAQ;AAClC;AACA;AACA,eAAe,KAAK,gCAAgC,QAAQ;AAC5D;AACA;AACA,eAAe,KAAK,MAAM,QAAQ;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB,oBAAoB,SAAS;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,KAAK;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACA;AACO;AACP;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,WAAW,MAAM,UAAU,QAAQ,KAAK,QAAQ;AAChD,WAAW,MAAM,UAAU,QAAQ,KAAK,QAAQ;AAChD,WAAW,MAAM,UAAU,QAAQ,KAAK,QAAQ;AAChD;AACA;AACO;AACP;AACA,cAAc,OAAO;AACrB;AACA;AACA;AACA,WAAW,YAAY;AACvB;AACA;AACO;AACP,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA,WAAW,KAAK,qBAAqB,QAAQ;AAC7C,WAAW,KAAK,0BAA0B,QAAQ;AAClD;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM,QAAQ,QAAQ,KAAK,QAAQ;AAC9C,WAAW,MAAM,QAAQ,QAAQ,KAAK,QAAQ;AAC9C,WAAW,MAAM,QAAQ,QAAQ,KAAK,QAAQ;AAC9C;AACA;AACO;AACP;AACA;AACA,WAAW,KAAK,CAAC,QAAQ;AACzB,WAAW,KAAK,CAAC,QAAQ;AACzB,WAAW,KAAK,CAAC,QAAQ;AACzB;AACA;AACO;AACP,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACO;AACP;AACA,wBAAwB,QAAQ,MAAM,QAAQ,MAAM,QAAQ;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,wBAAwB,QAAQ,MAAM,QAAQ,MAAM,QAAQ;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;;AClVO;AACP;AACA;AACA;AACA;;;ACJiD;AACf;AACiB;AAC5C,8BAA8B,QAAQ;AAC7C;AACA;AACA,wCAAwC,SAAS;AACjD;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB;AACA;AACA,oBAAoB,MAAM,YAAY,QAAQ;AAC9C;AACA;AACA;AACA;;;ACtB0C;AAC1C;AACO;AACP;AACA;AACA,aAAa,IAAI;AACjB,aAAa,IAAI;AACjB,aAAa,IAAI;AACjB,aAAa,IAAI;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,IAAI;AACrB,YAAY,IAAI;AAChB;AACA;AACA;AACA,mBAAmB,IAAI;AACvB,gBAAgB,IAAI;AACpB,gDAAgD,IAAI;AACpD;AACA,iBAAiB;AACjB,oBAAoB,IAAI;AACxB,oBAAoB,IAAI;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,IAAI;AACrC;AACA;AACA;AACA,iDAAiD,iBAAiB,IAAI,WAAW,EAAE,MAAM,4BAA4B;AACrH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;;AC1EmC;AACI;AAChC,6BAA6B,QAAQ;AAC5C;AACA,eAAe,KAAK;AACpB;AACA;;;ACNwD;AACI;AACjB;AACoB;AACxD,8BAA8B,cAAc;AACnD;AACA;AACA,wCAAwC,SAAS;AACjD;AACA,gBAAgB,2GAA2G;AAC3H;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC;AACA,+BAA+B,QAAQ;AACvC,+BAA+B,QAAQ;AACvC,+BAA+B,QAAQ;AACvC;AACA;AACA,8BAA8B,UAAU;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,gBAAgB,WAAW,QAAQ;AAC/D,4BAA4B,gBAAgB,WAAW,QAAQ;AAC/D,4BAA4B,gBAAgB,WAAW,QAAQ;AAC/D;AACA;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,gBAAgB,KAAK;AACrB,YAAY,KAAK;AACjB,YAAY,KAAK;AACjB;AACA;AACA,eAAe,SAAS;AACxB;AACA;;;ACxDwC;AACH;AACc;AAC5C,2BAA2B,cAAc;AAChD;AACA;AACA,iDAAiD,OAAO;AACxD;AACA;AACA,kBAAkB,cAAc;AAChC;AACA;AACA,eAAe,cAAc;AAC7B;AACA;;;ACdsE;AACG;AACjB;AACb;AACgB;AACpD,8BAA8B,YAAY;AACjD;AACA;AACA,wCAAwC,SAAS;AACjD;AACA,gBAAgB,2GAA2G;AAC3H;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,wBAAwB,QAAQ,CAAC,MAAM,OAAO,OAAO,GAAG,MAAM,OAAO,SAAS,GAAG,MAAM,OAAO,SAAS;AACvG;AACA,8BAA8B,UAAU;AACxC,wBAAwB,MAAM,OAAO,SAAS;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,QAAQ,CAAC,YAAY,WAAW,OAAO,WAAW,OAAO;AACjF;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;AACA;;;AC7CsE;AACG;AACjB;AACb;AACgB;AACpD,8BAA8B,YAAY;AACjD;AACA;AACA,wCAAwC,SAAS;AACjD;AACA,gBAAgB,mEAAmE;AACnF;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,wBAAwB,QAAQ,CAAC,MAAM,OAAO,OAAO,GAAG,MAAM,OAAO,SAAS,GAAG,MAAM,OAAO,SAAS;AACvG;AACA,8BAA8B,UAAU;AACxC,wBAAwB,MAAM,OAAO,SAAS;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,QAAQ,CAAC,YAAY,WAAW,OAAO,WAAW,OAAO;AACjF;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;AACA;;;AC7C6E;AACA;AACrB;AACb;AACoB;AACxD,iCAAiC,cAAc;AACtD;AACA;AACA,wCAAwC,SAAS;AACjD;AACA,gBAAgB,mEAAmE;AACnF;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,wBAAwB,QAAQ,CAAC,MAAM,OAAO,SAAS,GAAG,MAAM,KAAK,OAAO,EAAE,OAAO,GAAG,MAAM,KAAK,OAAO,EAAE,OAAO;AACnH;AACA,8BAA8B,UAAU;AACxC,wBAAwB,MAAM,OAAO,SAAS;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,QAAQ,CAAC,OAAO,WAAW,gBAAgB,WAAW,gBAAgB;AAC9F;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,gBAAgB,KAAK;AACrB,YAAY,KAAK;AACjB,YAAY,KAAK;AACjB;AACA;AACA,eAAe,SAAS;AACxB;AACA;;;AClD+E;AACY;AACnC;AACb;AACgB;AACpD,8BAA8B,YAAY;AACjD;AACA;AACA,wCAAwC,SAAS;AACjD;AACA,gBAAgB,mEAAmE;AACnF;AACA;AACA,4BAA4B,QAAQ;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,0BAA0B,UAAU;AACpC,wBAAwB,QAAQ,CAAC,MAAM,OAAO,SAAS,GAAG,MAAM,KAAK,SAAS,EAAE,SAAS,GAAG,YAAY;AACxG;AACA,8BAA8B,UAAU;AACxC,wBAAwB,MAAM,OAAO,SAAS;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,QAAQ,CAAC,OAAO,WAAW,gBAAgB,WAAW,YAAY;AAC1F;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,gBAAgB,KAAK;AACrB,YAAY,KAAK;AACjB;AACA;AACA,eAAe,SAAS;AACxB;AACA;;;ACjD8C;AACW;AACV;AACgB;AACxD,+BAA+B,cAAc;AACpD;AACA;AACA,wCAAwC,SAAS;AACjD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,SAAS,CAAC,aAAa,WAAW,aAAa,WAAW,aAAa,WAAW,aAAa;AACnH;AACA,oBAAoB,cAAc;AAClC;AACA;AACA;AACA;AACA,gBAAgB,KAAK;AACrB,YAAY,KAAK;AACjB,YAAY,KAAK;AACjB,YAAY,KAAK;AACjB;AACA;AACA,eAAe,SAAS;AACxB;AACA;;;AC7BqD;AACA;AACA;AACA;AACM;AACN;AACE;;;ACNkB;AACgH;AACnB;AACjB;AAC9D;AACvF;AACA;AACA,gBAAgB,UAAU;AAC1B,oBAAoB,SAAS;AAC7B;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,WAAW,UAAU;AACrB,gBAAgB,UAAU;AAC1B;AACA;AACA,wBAAwB,MAAM;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,qBAAqB;AACvC,QAAQ,mBAAmB;AAC3B,gBAAgB,mBAAmB;AACnC;AACA,2BAA2B,UAAU;AACrC;AACA,oBAAoB,GAAG,SAAS,QAAQ;AACxC,SAAS;AACT;AACA,qBAAqB,KAAK,SAAS,QAAQ;AAC3C,kBAAkB,GAAG,SAAS,QAAQ;AACtC;AACA,gCAAgC,QAAQ;AACxC,SAAS;AACT;AACA;AACA;AACA;AACA,oBAAoB,UAAU;AAC9B;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B;AACA;AACA;AACO;AACP;AACA;AACO;AACP,KAAK,UAAU;AACf,2BAA2B,UAAU;AACrC;AACA,cAAc,aAAa;AAC3B,mBAAmB,eAAe;AAClC,KAAK;AACL,KAAK,UAAU;AACf,mBAAmB,eAAe;AAClC,KAAK;AACL,KAAK,UAAU;AACf,mBAAmB,eAAe;AAClC,KAAK;AACL,KAAK,UAAU;AACf,mBAAmB,eAAe;AAClC,KAAK;AACL,KAAK,UAAU;AACf,mBAAmB,kBAAkB;AACrC,KAAK;AACL,KAAK,UAAU;AACf,mBAAmB,eAAe;AAClC,KAAK;AACL,KAAK,UAAU;AACf,mBAAmB,gBAAgB;AACnC;AACA;AACO;AACP,KAAK,UAAU;AACf;AACA,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C;AACA,YAAY,OAAO;AACnB,gCAAgC,gBAAgB,IAAI,QAAQ;AAC5D;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA,KAAK;AACL,KAAK,UAAU;AACf,kBAAkB,OAAO,IAAI,QAAQ;AACrC,kBAAkB,OAAO,IAAI,QAAQ;AACrC,oBAAoB,QAAQ,CAAC,YAAY;AACzC,YAAY,OAAO;AACnB,oBAAoB,cAAc;AAClC;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,kBAAkB,OAAO,IAAI,QAAQ;AACrC,kBAAkB,OAAO,IAAI,QAAQ;AACrC,oBAAoB,QAAQ,CAAC,YAAY;AACzC,YAAY,OAAO;AACnB,oBAAoB,cAAc;AAClC;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,kBAAkB,OAAO,IAAI,QAAQ;AACrC,kBAAkB,gBAAgB,IAAI,QAAQ;AAC9C,kBAAkB,gBAAgB,IAAI,QAAQ;AAC9C,oBAAoB,QAAQ;AAC5B,YAAY,OAAO;AACnB,oBAAoB,cAAc;AAClC;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,kBAAkB,OAAO,IAAI,QAAQ;AACrC,kBAAkB,gBAAgB,IAAI,QAAQ;AAC9C,kBAAkB,YAAY,IAAI,QAAQ;AAC1C,oBAAoB,QAAQ;AAC5B,YAAY,OAAO;AACnB,oBAAoB,cAAc;AAClC;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,kBAAkB,aAAa,IAAI,QAAQ;AAC3C,kBAAkB,aAAa,IAAI,QAAQ;AAC3C,kBAAkB,aAAa,IAAI,QAAQ;AAC3C,kBAAkB,aAAa,IAAI,QAAQ;AAC3C,oBAAoB,SAAS;AAC7B,YAAY,OAAO;AACnB,oBAAoB,cAAc;AAClC;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,cAAc;AACzD,0CAA0C,aAAa;AACvD,6CAA6C,gBAAgB;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,qBAAqB;AACjF;AACA,oBAAoB,MAAM;AAC1B;AACA;AACA;AACA,gBAAgB,eAAe;AAC/B,mCAAmC,eAAe;AAClD;AACA;AACA;AACA;AACA,gBAAgB,eAAe;AAC/B,mCAAmC,eAAe;AAClD;AACA;AACA;AACA;AACA,gBAAgB,eAAe;AAC/B,mCAAmC,eAAe;AAClD;AACA;AACA;AACA;AACA,gBAAgB,kBAAkB;AAClC,mCAAmC,kBAAkB;AACrD;AACA;AACA;AACA;AACA,gBAAgB,eAAe;AAC/B,mCAAmC,eAAe;AAClD;AACA;AACA;AACA;AACA;AACA,gBAAgB,gBAAgB;AAChC,mCAAmC,gBAAgB;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,MAAM;AACpD;AACA,cAAc,eAAe;AAC7B,gDAAgD,MAAM;AACtD;AACA;AACA,gEAAgE,eAAe;AAC/E,gEAAgE,MAAM;AACtE;AACA;AACA,wEAAwE,eAAe;AACvF;AACA;AACA;AACA;AACA,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,gBAAgB;AAClC,kBAAkB,eAAe;AACjC;AACA;;;AC3QiC;AAC1B;AACP;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACO;AACP;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACO;AACP;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACO;AACP;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACO;AACP;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;;;ACpCuD;AACiC;AAC0E;AAClK;AACA;AACA;AACA;AACA,kBAAkB,qBAAqB;AACvC,kBAAkB,mBAAmB;AACrC,iBAAiB,WAAW;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,4BAA4B,YAAY;AACxC;AACA,kBAAkB,YAAY;AAC9B,KAAK;AACL;AACA;AACA,YAAY,iCAAiC;AAC7C,sBAAsB,aAAa;AACnC;AACA;AACA,kBAAkB,KAAK,wBAAwB;AAC/C;AACA,WAAW,KAAK;AAChB;AACA;AACA,YAAY,uBAAuB;AACnC;AACA;AACA,2BAA2B,cAAc;AACzC,+BAA+B,KAAK,CAAC,gBAAgB;AACrD,sBAAsB,WAAW,EAAE,WAAW;AAC9C;AACA;AACA;AACA,cAAc,KAAK;AACnB;AACA;AACO;AACP,KAAK,UAAU;AACf,uCAAuC,KAAK,CAAC,KAAK;AAClD;AACA;AACA,iBAAiB,GAAG,GAAG,GAAG,EAAE;AAC5B,iBAAiB,GAAG,GAAG,EAAE;AACzB;AACA,KAAK;AACL,KAAK,UAAU;AACf,gBAAgB,kDAAkD;AAClE;AACA;AACA,+BAA+B,aAAa;AAC5C,qBAAqB,sBAAsB,kBAAkB;AAC7D;AACA;AACA,sBAAsB,KAAK;AAC3B;AACA;AACA;AACA;AACA,yBAAyB,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AAC5D,wBAAwB,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AAChD;AACA,wBAAwB,IAAI,IAAI,GAAG,GAAG,EAAE;AACxC,wBAAwB,IAAI,IAAI,EAAE;AAClC;AACA,KAAK;AACL,KAAK,UAAU;AACf,gBAAgB,+BAA+B;AAC/C;AACA;AACA;AACA;AACA;AACA,yBAAyB,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,GAAG,OAAO,EAAE;AAC9D,wBAAwB,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE;AACjD;AACA,wBAAwB,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE;AAC1C,wBAAwB,IAAI,EAAE,GAAG,EAAE;AACnC;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA;AACA,oBAAoB,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE;AACtC,oBAAoB,IAAI,EAAE,GAAG,EAAE;AAC/B;AACA,KAAK;AACL,KAAK,UAAU;AACf,gBAAgB,oBAAoB;AACpC;AACA;AACA,0BAA0B,KAAK,CAAC,OAAO;AACvC,mCAAmC,aAAa;AAChD,yBAAyB,EAAE;AAC3B,yBAAyB,EAAE;AAC3B;AACA;AACA,mCAAmC,aAAa;AAChD,yBAAyB,sBAAsB,kBAAkB;AACjE,sBAAsB,KAAK;AAC3B;AACA;AACA;AACA;AACA;AACA,oBAAoB,IAAI,IAAI,GAAG,GAAG,EAAE;AACpC,oBAAoB,IAAI,IAAI,EAAE;AAC9B;AACA,KAAK;AACL,KAAK,UAAU;AACf,gBAAgB,gCAAgC;AAChD;AACA;AACA,0BAA0B,KAAK,CAAC,OAAO;AACvC,mCAAmC,aAAa;AAChD,yBAAyB,EAAE;AAC3B,yBAAyB,EAAE;AAC3B;AACA;AACA,mCAAmC,aAAa;AAChD,yBAAyB,sBAAsB,kBAAkB;AACjE,sBAAsB,KAAK;AAC3B;AACA;AACA,mCAAmC,cAAc;AACjD,uCAAuC,KAAK,CAAC,gBAAgB;AAC7D,8BAA8B,WAAW,EAAE,WAAW;AACtD;AACA,uBAAuB,KAAK;AAC5B;AACA;AACA;AACA;AACA;AACA,oBAAoB,IAAI,IAAI,GAAG,GAAG,EAAE;AACpC,oBAAoB,IAAI,IAAI,EAAE;AAC9B;AACA,KAAK;AACL,KAAK,UAAU;AACf,gBAAgB,iEAAiE;AACjF;AACA;AACA,6BAA6B,aAAa;AAC1C;AACA,0BAA0B,KAAK,kBAAkB;AACjD;AACA;AACA;AACA,kBAAkB,KAAK;AACvB;AACA;AACA;AACA;AACA,qBAAqB,aAAa,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AAClF,qBAAqB,aAAa,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AACvE;AACA,qBAAqB,aAAa,EAAE,IAAI,IAAI,IAAI,GAAG,GAAG,EAAE;AACxD,qBAAqB,aAAa,EAAE,IAAI,IAAI,IAAI,EAAE;AAClD;AACA;AACA;;;AC1KuD;AACiC;AACqC;AAClE;AACqD;AAC/E;AACjC;AACA;AACA;AACA;AACA,oBAAoB,GAAG;AACvB,cAAc,YAAY;AAC1B,cAAc,YAAY,CAAC,MAAM,CAAC,MAAM;AACxC;AACA,OAAO,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACP,KAAK,UAAU;AACf;AACA,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB;AACA,KAAK;AACL;AACA;AACA,gBAAgB,OAAO;AACvB,cAAc,MAAM,WAAW,QAAQ;AACvC;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA,YAAY,OAAO;AACnB;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,OAAO;AACvB,cAAc,KAAK;AACnB;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,oBAAoB,QAAQ;AAC5B;AACA,eAAe,cAAc;AAC7B,KAAK;AACL;AACA;AACA,gBAAgB,OAAO;AACvB,cAAc,KAAK;AACnB;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,oBAAoB,QAAQ;AAC5B;AACA,eAAe,cAAc;AAC7B,KAAK;AACL;AACA;AACA,gBAAgB,OAAO;AACvB,cAAc,KAAK;AACnB;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,oBAAoB,QAAQ;AAC5B,eAAe,iBAAiB;AAChC,KAAK;AACL;AACA;AACA,gBAAgB,OAAO;AACvB,cAAc,KAAK;AACnB;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,oBAAoB,QAAQ;AAC5B,eAAe,cAAc;AAC7B,KAAK;AACL;AACA;AACA,gBAAgB,OAAO;AACvB,cAAc,KAAK;AACnB;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf,eAAe,eAAe,CAAC,SAAS;AACxC,KAAK;AACL;AACA;AACA,iBAAiB,OAAO;AACxB,cAAc,KAAK;AACnB;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,kBAAkB,cAAc;AAChC,gBAAgB,cAAc;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB;AACA,KAAK;AACL;AACO;AACP,kBAAkB,aAAa;AAC/B;AACA,gBAAgB,YAAY;AAC5B,oDAAoD,OAAO;AAC3D;AACA,YAAY,OAAO;AACnB,gBAAgB,QAAQ;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,aAAa,UAAU;AACvB;AACA;AACA,iCAAiC,QAAQ;AACzC;AACA;AACA;AACA;AACA,0BAA0B,GAAG;AAC7B;AACA,+BAA+B,KAAK,cAAc,QAAQ;AAC1D,yBAAyB;AACzB,0BAA0B,GAAG;AAC7B;AACA;AACA;AACA,aAAa;AACb,aAAa,UAAU;AACvB;AACA,iCAAiC,QAAQ;AACzC;AACA;AACA;AACA,sBAAsB,GAAG;AACzB;AACA;AACA;AACA,gBAAgB;AAAC;AACjB,aAAa;AACb,aAAa,UAAU;AACvB;AACA;AACA,sBAAsB,GAAG;AACzB;AACA;AACA,+BAA+B,QAAQ;AACvC;AACA,yBAAyB;AACzB,6CAA6C,QAAQ;AACrD,aAAa;AACb,aAAa,UAAU;AACvB;AACA,iCAAiC,QAAQ;AACzC;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,GAAG;AACzB;AACA,aAAa;AACb,aAAa,UAAU;AACvB;AACA,iCAAiC,QAAQ;AACzC;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,GAAG;AACzB;AACA,aAAa;AACb,aAAa,UAAU;AACvB;AACA,iCAAiC,QAAQ;AACzC,iCAAiC,QAAQ;AACzC;AACA;AACA;AACA,sBAAsB,GAAG;AACzB;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA,aAAa;AACb;AACA;AACO;AACP;AACA,sBAAsB,aAAa;AACnC,oBAAoB,YAAY;AAChC,oBAAoB,QAAQ;AAC5B,wDAAwD,OAAO;AAC/D;AACA,gBAAgB,OAAO;AACvB;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA,gCAAgC,cAAc;AAC9C,+BAA+B,cAAc;AAC7C,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA,cAAc,GAAG,KAAK,QAAQ;AAC9B,iCAAiC,QAAQ;AACzC,KAAK;AACL;AACA;AACA;AACA,cAAc,GAAG;AACjB,mBAAmB,QAAQ;AAC3B,mBAAmB,cAAc,QAAQ,QAAQ;AACjD,aAAa;AACb;AACA,mBAAmB,QAAQ;AAC3B,mBAAmB,cAAc;AACjC,aAAa;AACb,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA,cAAc,GAAG,KAAK,QAAQ;AAC9B,iCAAiC,QAAQ;AACzC,KAAK;AACL;AACA;AACA;AACA,cAAc,GAAG;AACjB,mBAAmB,QAAQ;AAC3B,mBAAmB,cAAc;AACjC,aAAa;AACb;AACA,mBAAmB,QAAQ;AAC3B,mBAAmB,cAAc;AACjC,aAAa;AACb,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA,cAAc,GAAG;AACjB;AACA;AACA;AACA,aAAa;AACb,iCAAiC,QAAQ;AACzC,KAAK;AACL;AACA;AACA;AACA,cAAc,GAAG;AACjB;AACA,mBAAmB,cAAc;AACjC,aAAa;AACb;AACA,mBAAmB,QAAQ;AAC3B,mBAAmB,cAAc;AACjC,aAAa;AACb,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA,wBAAwB,QAAQ;AAChC,wBAAwB,QAAQ;AAChC;AACA,kBAAkB,GAAG;AACrB;AACA;AACA;AACA,iBAAiB;AACjB;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA,wBAAwB,QAAQ;AAChC,wBAAwB,QAAQ;AAChC;AACA,kBAAkB,GAAG;AACrB;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB,SAAS;AACT,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA,wBAAwB,QAAQ;AAChC;AACA,kBAAkB,GAAG,QAAQ,QAAQ;AACrC;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA,wBAAwB,QAAQ;AAChC;AACA,kBAAkB,GAAG;AACrB,uBAAuB,QAAQ;AAC/B,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB,SAAS;AACT,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA,wBAAwB,QAAQ;AAChC;AACA,kBAAkB,GAAG,KAAK,QAAQ;AAClC;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA,wBAAwB,QAAQ;AAChC;AACA,kBAAkB,GAAG;AACrB,uBAAuB,QAAQ;AAC/B,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB,SAAS;AACT;AACA;AACO;AACP;AACA;AACA,0BAA0B,aAAa;AACvC,mBAAmB,YAAY;AAC/B,SAAS;AACT,gCAAgC,GAAG;AACnC;AACA,4BAA4B,QAAQ;AACpC,oBAAoB,OAAO;AAC3B;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,qCAAqC,GAAG;AACxC,oBAAoB;AACpB,oBAAoB;AACpB;AACA,+BAA+B,OAAO;AACtC;AACA,0DAA0D,QAAQ;AAClE,0DAA0D,QAAQ;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,GAAG;AACpC,4BAA4B,sCAAsC,QAAQ;AAC1E,4BAA4B,sCAAsC,QAAQ,GAAG;AAC7E;AACA,aAAa;AACb;AACA;AACA,qBAAqB,GAAG;AACxB;AACA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,MAAM;AACrB;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL;AACA;AACA;AACA,cAAc,cAAc,UAAU,QAAQ;AAC9C,cAAc,cAAc;AAC5B;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL;AACA;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL;AACA;AACA,oBAAoB,QAAQ;AAC5B;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL;AACA;AACA,oBAAoB,QAAQ;AAC5B;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL;AACA;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL,KAAK,UAAU;AACf;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA,cAAc,GAAG;AACjB;AACA,KAAK;AACL;AACA;AACA,oBAAoB,QAAQ;AAC5B;AACA;AACA,cAAc,GAAG;AACjB;AACA;AACA;AACO;AACP,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB;AACA;AACA;AACA;AACA,YAAY,OAAO;AACnB;AACA,mBAAmB,KAAK;AACxB;AACA,gBAAgB;AAChB;AACA;;;ACvjB+D;AACzB;AACqC;AACpE;AACP,sBAAsB,YAAY;AAClC;AACA;AACO;AACP;AACA,gBAAgB,mBAAmB;AACnC,0BAA0B,YAAY;AACtC,wBAAwB,YAAY;AACpC,uBAAuB,KAAW;AAClC;AACA;AACA,KAAK;AACL;AACO;AACP,YAAY,4EAA4E;AACxF;AACA;AACA,mCAAmC,mBAAmB;AACtD;AACA,wDAAwD,wBAAwB;AAChF;AACA,mCAAmC;AACnC;AACA;AACA;AACO;AACP,YAAY,mEAAmE;AAC/E,oBAAoB,wBAAwB;AAC5C;AACA,gCAAgC;AAChC;AACA;AACA;AACA,sCAAsC,GAAG;AACzC;AACO;AACP;AACA,SAAS,OAAO,aAAa,YAAkB,qBAAqB,SAAe;AACnF,SAAS,OAAO,iBAAiB,YAAkB,qBAAqB,aAAmB;AAC3F,SAAS,OAAO,uBAAuB,YAAkB,qBAAqB,kBAAwB;AACtG,SAAS,OAAO,WAAW,YAAkB,qBAAqB,OAAa;AAC/E,SAAS,OAAO,YAAY,YAAkB,qBAAqB,QAAc;AACjF,SAAS,OAAO,UAAU,YAAkB,qBAAqB,MAAY;AAC7E,KAAK;AACL;;;AChD+I;AACe;AACxH;AACoD;AACzD;AACwC;AAC+C;AACxH,uDAAuD,UAAgB;AACvE;AACA,yBAAyB,UAAgB;AACzC,CAAC;AACM;AACP,mCAAmC;AACnC,wBAAwB,wBAAwB;AAChD,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA,mBAAmB,QAAQ;AAC3B;AACA;AACA,mBAAmB,QAAQ;AAC3B;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA,oBAAoB,SAAS;AAC7B;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,QAAQ;AAC1C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,QAAQ;AAC1C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,QAAQ;AAC1C;AACA;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,KAAK,OAAO,EAAE,OAAO;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,KAAK,OAAO,EAAE,OAAO;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM,OAAO,SAAS;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,cAAoB;AACnC;AACA;AACA,eAAe,cAAoB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,wBAAwB,QAAQ;AAChC,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,sBAAsB,aAAa;AACnC,eAAe,cAAc,kBAAkB,cAAoB;AACnE;AACA;AACA,eAAe,GAAG;AAClB;AACA;AACA,sBAAsB,aAAa;AACnC,eAAe,cAAc,kBAAkB,cAAoB;AACnE;AACA;AACA,eAAe,GAAG;AAClB;AACA,0CAA0C;AAC1C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,oCAAoC;AACpC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,2CAA2C;AAC3C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,qCAAqC;AACrC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,0CAA0C;AAC1C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,oCAAoC;AACpC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,2CAA2C;AAC3C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,qCAAqC;AACrC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,0CAA0C;AAC1C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,oCAAoC;AACpC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,2CAA2C;AAC3C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,qCAAqC;AACrC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,6CAA6C;AAC7C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,uCAAuC;AACvC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,8CAA8C;AAC9C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,wCAAwC;AACxC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,0CAA0C;AAC1C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,oCAAoC;AACpC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,2CAA2C;AAC3C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,qCAAqC;AACrC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,2CAA2C;AAC3C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,qCAAqC;AACrC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,4CAA4C;AAC5C,sBAAsB,aAAa;AACnC,eAAe,cAAc,iCAAiC,cAAoB;AAClF;AACA,sCAAsC;AACtC;AACA,gCAAgC,wBAAwB;AACxD,eAAe,GAAG;AAClB;AACA,+CAA+C,mBAAmB;AAClE,eAAe,cAAc,qBAAqB,cAAoB;AACtE;AACA,yCAAyC,mBAAmB;AAC5D;AACA,4BAA4B,GAAG;AAC/B;AACA,gDAAgD,mBAAmB;AACnE,eAAe,cAAc,qBAAqB,cAAoB;AACtE;AACA,0CAA0C,mBAAmB;AAC7D;AACA,4BAA4B,GAAG;AAC/B;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,SAAS;AACT;AACA;AACA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;AACA,+BAA+B,cAAoB;AACnD,yBAAyB,GAAG;AAC5B,SAAS;AACT;AACA,0CAA0C,GAAG;AAC7C,eAAe,UAAgB;AAC/B;AACA,oCAAoC,GAAG;AACvC,eAAe,UAAgB;AAC/B;AACA,2CAA2C,GAAG;AAC9C,eAAe,UAAgB;AAC/B;AACA,qCAAqC,GAAG;AACxC,eAAe,UAAgB;AAC/B;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,mBAAmB,eAAqB,+BAA+B,wBAAwB,qBAAqB;AACpH;AACA,eAAe,eAAqB,QAAQ,0BAA0B,QAAQ,wBAAwB,sBAAsB;AAC5H;AACA;AACA;AACA,mBAAmB,eAAqB,gCAAgC,wBAAwB,qBAAqB;AACrH;AACA,eAAe,eAAqB,QAAQ,0BAA0B,SAAS,wBAAwB,sBAAsB;AAC7H;AACA;AACA,YAAY,SAAS;AACrB,mBAAmB,gBAAgB,qBAAqB,KAAK;AAC7D;AACA,kBAAkB,GAAG,WAAW,wBAAwB,CAAC,KAAK;AAC9D,oCAAoC;AACpC,kCAAkC;AAClC;AACA,iBAAiB,KAAK;AACtB,mBAAmB,gBAAgB,CAAC,OAAO,oCAAoC,wBAAwB,iBAAiB;AACxH;AACA,eAAe,gBAAgB,CAAC,OAAO,uBAAuB,GAAG,WAAW,wBAAwB,kBAAkB;AACtH;AACA;AACwB;;;AC7/BD;;AAEvB,4CAAe;;AAEf;AACA,6DAA6D,aAAa;;AAE1E,sBAAsB,UAAU;;AAEhC,0BAA0B,UAAU;;AAEpC;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,qBAAqB;AACrB,qBAAqB;AACrB,qBAAqB,QAAQ;AAC7B;;AAEA;AACA;;AAEA;;AAEA,CAAC,E;;AC/BsB;;AAEvB,4CAAe;;AAEf;AACA,wCAAwC,oBAAoB;AAC5D;AACA;;AAEA,oBAAoB,gBAAgB;;AAEpC;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,E;;AC/BsB;;AAEvB,4CAAe;;AAEf;AACA,kBAAkB;AAClB;AACA;;AAEA,sBAAsB,aAAa;;AAEnC,0BAA0B,aAAa;;AAEvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,CAAC,E;;ACjCsB;;AAEvB,4CAAe;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,mDAAmD,aAAa;AAChE,mDAAmD,aAAa;AAChE,sDAAsD,aAAa;AACnE,mDAAmD,aAAa;;AAEhE;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,KAAK;;AAEL;;AAEA,CAAC,E;;ACnDsB;;AAEvB,4CAAe;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,aAAa;;AAEnC;AACA;;AAEA,0BAA0B,aAAa;;AAEvC;AACA,6DAA6D,aAAa;;AAE1E;AACA;AACA;AACA,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC,OAAO;;AAExC;;AAEA;;AAEA;AACA;;AAEA;;AAEA,CAAC,E;;AC1CsB;;AAEvB,4CAAe;;AAEf;AACA;AACA;;AAEA,oBAAoB,UAAU;;AAE9B;;AAEA;AACA;AACA,4CAA4C,EAAE;AAC9C;AACA;AACA;AACA,SAAS;;AAET;;AAEA;;AAEA,CAAC,E;;ACxBsB;;AAEvB,4CAAe;;AAEf;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA,CAAC,E;;AC1BsB;;;AAGvB,4CAAe;;AAEf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA,CAAC,E;;ACxCsB;;AAEvB,4CAAe,oBAAoB,KAAK;;AAExC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA,CAAC,E;;ACvCsB;;AAEvB,6CAAe,oBAAoB,SAAS;;AAE5C;;AAEA;AACA,UAAU,4DAA4D;AACtE,UAAU,kEAAkE;AAC5E,UAAU,wDAAwD;AAClE,UAAU,sDAAsD;AAChE,UAAU,uDAAuD;AACjE,UAAU;AACV;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sFAAsF,MAAM;AAC5F;AACA;AACA;AACA,aAAa;;AAEb;;AAEA;;AAEA;;AAEA,CAAC,E;;AC/CsB;;AAEvB,6CAAe,oBAAoB,cAAc;;AAEjD;;AAEA;AACA,UAAU,4DAA4D;AACtE,UAAU,kEAAkE;AAC5E,UAAU,wDAAwD;AAClE,UAAU,sDAAsD;AAChE,UAAU,uDAAuD;AACjE,UAAU;AACV;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sFAAsF,MAAM;AAC5F;AACA;AACA;AACA,aAAa;;AAEb;;AAEA;;AAEA;;AAEA,CAAC,E;;AC/CqE;AACA;AACH;AAC7C;AACC;AAC6B;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACE;AACA;;AAE9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,mCAAmC,eAAe,IAAI,OAAO,cAAK,OAAE;AACpE;AACA;AACA;AACA,KAAK;AACL,CAAC","sources":["webpack://colortranslator/./node_modules/.pnpm/whatwg-fetch@3.6.20/node_modules/whatwg-fetch/fetch.js?d4cb","webpack://colortranslator/./src/constants/numbers.ts?0f59","webpack://colortranslator/./src/constants/enums.ts?2133","webpack://colortranslator/./src/constants/regexps.ts?4bb6","webpack://colortranslator/./src/constants/errors.ts?dd63","webpack://colortranslator/./src/@types/index.ts?1c15","webpack://colortranslator/./src/constants/options.ts?1ade","webpack://colortranslator/./src/constants/index.ts?9e3e","webpack://colortranslator/./src/helpers/index.ts?0b6c","webpack://colortranslator/./src/color/translators.ts?ffaf","webpack://colortranslator/./src/parsers/baseClasses/_RgbClass.ts?c360","webpack://colortranslator/./src/parsers/_HEXStringParser.ts?fa69","webpack://colortranslator/./src/parsers/_CalcParser.ts?694e","webpack://colortranslator/./src/parsers/baseClasses/_AlphaBaseClass.ts?3f37","webpack://colortranslator/./src/parsers/_RGBStringParser.ts?05e4","webpack://colortranslator/./src/parsers/baseClasses/_HueBaseClass.ts?4028","webpack://colortranslator/./src/parsers/_HSLStringParser.ts?820a","webpack://colortranslator/./src/parsers/_HWBStringParser.ts?1777","webpack://colortranslator/./src/parsers/_CIELabStringParser.ts?23ac","webpack://colortranslator/./src/parsers/_LCHStringParser.ts?9744","webpack://colortranslator/./src/parsers/_CMYKStringParser.ts?355e","webpack://colortranslator/./src/parsers/index.ts?62ce","webpack://colortranslator/./src/color/extractors.ts?52a2","webpack://colortranslator/./src/color/rounders.ts?578b","webpack://colortranslator/./src/color/css.ts?9663","webpack://colortranslator/./src/color/utils.ts?d263","webpack://colortranslator/./src/returns/index.ts?a0d2","webpack://colortranslator/./src/index.ts?0fca","webpack://colortranslator/./src/@demo/demo1/index.js?3965","webpack://colortranslator/./src/@demo/demo2/index.js?d8dc","webpack://colortranslator/./src/@demo/demo3/index.js?d386","webpack://colortranslator/./src/@demo/demo4/index.js?619f","webpack://colortranslator/./src/@demo/demo5/index.js?d8cc","webpack://colortranslator/./src/@demo/demo6/index.js?3a32","webpack://colortranslator/./src/@demo/demo7/index.js?8343","webpack://colortranslator/./src/@demo/demo8/index.js?7725","webpack://colortranslator/./src/@demo/demo9/index.js?8532","webpack://colortranslator/./src/@demo/demo10/index.js?4f67","webpack://colortranslator/./src/@demo/demo11/index.js?dbe6","webpack://colortranslator/./src/@demo/demo.js?9b7d"],"sourcesContent":["/* eslint-disable no-prototype-builtins */\nvar g =\n  (typeof globalThis !== 'undefined' && globalThis) ||\n  (typeof self !== 'undefined' && self) ||\n  // eslint-disable-next-line no-undef\n  (typeof global !== 'undefined' && global) ||\n  {}\n\nvar support = {\n  searchParams: 'URLSearchParams' in g,\n  iterable: 'Symbol' in g && 'iterator' in Symbol,\n  blob:\n    'FileReader' in g &&\n    'Blob' in g &&\n    (function() {\n      try {\n        new Blob()\n        return true\n      } catch (e) {\n        return false\n      }\n    })(),\n  formData: 'FormData' in g,\n  arrayBuffer: 'ArrayBuffer' in g\n}\n\nfunction isDataView(obj) {\n  return obj && DataView.prototype.isPrototypeOf(obj)\n}\n\nif (support.arrayBuffer) {\n  var viewClasses = [\n    '[object Int8Array]',\n    '[object Uint8Array]',\n    '[object Uint8ClampedArray]',\n    '[object Int16Array]',\n    '[object Uint16Array]',\n    '[object Int32Array]',\n    '[object Uint32Array]',\n    '[object Float32Array]',\n    '[object Float64Array]'\n  ]\n\n  var isArrayBufferView =\n    ArrayBuffer.isView ||\n    function(obj) {\n      return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n    }\n}\n\nfunction normalizeName(name) {\n  if (typeof name !== 'string') {\n    name = String(name)\n  }\n  if (/[^a-z0-9\\-#$%&'*+.^_`|~!]/i.test(name) || name === '') {\n    throw new TypeError('Invalid character in header field name: \"' + name + '\"')\n  }\n  return name.toLowerCase()\n}\n\nfunction normalizeValue(value) {\n  if (typeof value !== 'string') {\n    value = String(value)\n  }\n  return value\n}\n\n// Build a destructive iterator for the value list\nfunction iteratorFor(items) {\n  var iterator = {\n    next: function() {\n      var value = items.shift()\n      return {done: value === undefined, value: value}\n    }\n  }\n\n  if (support.iterable) {\n    iterator[Symbol.iterator] = function() {\n      return iterator\n    }\n  }\n\n  return iterator\n}\n\nexport function Headers(headers) {\n  this.map = {}\n\n  if (headers instanceof Headers) {\n    headers.forEach(function(value, name) {\n      this.append(name, value)\n    }, this)\n  } else if (Array.isArray(headers)) {\n    headers.forEach(function(header) {\n      if (header.length != 2) {\n        throw new TypeError('Headers constructor: expected name/value pair to be length 2, found' + header.length)\n      }\n      this.append(header[0], header[1])\n    }, this)\n  } else if (headers) {\n    Object.getOwnPropertyNames(headers).forEach(function(name) {\n      this.append(name, headers[name])\n    }, this)\n  }\n}\n\nHeaders.prototype.append = function(name, value) {\n  name = normalizeName(name)\n  value = normalizeValue(value)\n  var oldValue = this.map[name]\n  this.map[name] = oldValue ? oldValue + ', ' + value : value\n}\n\nHeaders.prototype['delete'] = function(name) {\n  delete this.map[normalizeName(name)]\n}\n\nHeaders.prototype.get = function(name) {\n  name = normalizeName(name)\n  return this.has(name) ? this.map[name] : null\n}\n\nHeaders.prototype.has = function(name) {\n  return this.map.hasOwnProperty(normalizeName(name))\n}\n\nHeaders.prototype.set = function(name, value) {\n  this.map[normalizeName(name)] = normalizeValue(value)\n}\n\nHeaders.prototype.forEach = function(callback, thisArg) {\n  for (var name in this.map) {\n    if (this.map.hasOwnProperty(name)) {\n      callback.call(thisArg, this.map[name], name, this)\n    }\n  }\n}\n\nHeaders.prototype.keys = function() {\n  var items = []\n  this.forEach(function(value, name) {\n    items.push(name)\n  })\n  return iteratorFor(items)\n}\n\nHeaders.prototype.values = function() {\n  var items = []\n  this.forEach(function(value) {\n    items.push(value)\n  })\n  return iteratorFor(items)\n}\n\nHeaders.prototype.entries = function() {\n  var items = []\n  this.forEach(function(value, name) {\n    items.push([name, value])\n  })\n  return iteratorFor(items)\n}\n\nif (support.iterable) {\n  Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n}\n\nfunction consumed(body) {\n  if (body._noBody) return\n  if (body.bodyUsed) {\n    return Promise.reject(new TypeError('Already read'))\n  }\n  body.bodyUsed = true\n}\n\nfunction fileReaderReady(reader) {\n  return new Promise(function(resolve, reject) {\n    reader.onload = function() {\n      resolve(reader.result)\n    }\n    reader.onerror = function() {\n      reject(reader.error)\n    }\n  })\n}\n\nfunction readBlobAsArrayBuffer(blob) {\n  var reader = new FileReader()\n  var promise = fileReaderReady(reader)\n  reader.readAsArrayBuffer(blob)\n  return promise\n}\n\nfunction readBlobAsText(blob) {\n  var reader = new FileReader()\n  var promise = fileReaderReady(reader)\n  var match = /charset=([A-Za-z0-9_-]+)/.exec(blob.type)\n  var encoding = match ? match[1] : 'utf-8'\n  reader.readAsText(blob, encoding)\n  return promise\n}\n\nfunction readArrayBufferAsText(buf) {\n  var view = new Uint8Array(buf)\n  var chars = new Array(view.length)\n\n  for (var i = 0; i < view.length; i++) {\n    chars[i] = String.fromCharCode(view[i])\n  }\n  return chars.join('')\n}\n\nfunction bufferClone(buf) {\n  if (buf.slice) {\n    return buf.slice(0)\n  } else {\n    var view = new Uint8Array(buf.byteLength)\n    view.set(new Uint8Array(buf))\n    return view.buffer\n  }\n}\n\nfunction Body() {\n  this.bodyUsed = false\n\n  this._initBody = function(body) {\n    /*\n      fetch-mock wraps the Response object in an ES6 Proxy to\n      provide useful test harness features such as flush. However, on\n      ES5 browsers without fetch or Proxy support pollyfills must be used;\n      the proxy-pollyfill is unable to proxy an attribute unless it exists\n      on the object before the Proxy is created. This change ensures\n      Response.bodyUsed exists on the instance, while maintaining the\n      semantic of setting Request.bodyUsed in the constructor before\n      _initBody is called.\n    */\n    // eslint-disable-next-line no-self-assign\n    this.bodyUsed = this.bodyUsed\n    this._bodyInit = body\n    if (!body) {\n      this._noBody = true;\n      this._bodyText = ''\n    } else if (typeof body === 'string') {\n      this._bodyText = body\n    } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n      this._bodyBlob = body\n    } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n      this._bodyFormData = body\n    } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n      this._bodyText = body.toString()\n    } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n      this._bodyArrayBuffer = bufferClone(body.buffer)\n      // IE 10-11 can't handle a DataView body.\n      this._bodyInit = new Blob([this._bodyArrayBuffer])\n    } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n      this._bodyArrayBuffer = bufferClone(body)\n    } else {\n      this._bodyText = body = Object.prototype.toString.call(body)\n    }\n\n    if (!this.headers.get('content-type')) {\n      if (typeof body === 'string') {\n        this.headers.set('content-type', 'text/plain;charset=UTF-8')\n      } else if (this._bodyBlob && this._bodyBlob.type) {\n        this.headers.set('content-type', this._bodyBlob.type)\n      } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n        this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n      }\n    }\n  }\n\n  if (support.blob) {\n    this.blob = function() {\n      var rejected = consumed(this)\n      if (rejected) {\n        return rejected\n      }\n\n      if (this._bodyBlob) {\n        return Promise.resolve(this._bodyBlob)\n      } else if (this._bodyArrayBuffer) {\n        return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n      } else if (this._bodyFormData) {\n        throw new Error('could not read FormData body as blob')\n      } else {\n        return Promise.resolve(new Blob([this._bodyText]))\n      }\n    }\n  }\n\n  this.arrayBuffer = function() {\n    if (this._bodyArrayBuffer) {\n      var isConsumed = consumed(this)\n      if (isConsumed) {\n        return isConsumed\n      } else if (ArrayBuffer.isView(this._bodyArrayBuffer)) {\n        return Promise.resolve(\n          this._bodyArrayBuffer.buffer.slice(\n            this._bodyArrayBuffer.byteOffset,\n            this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength\n          )\n        )\n      } else {\n        return Promise.resolve(this._bodyArrayBuffer)\n      }\n    } else if (support.blob) {\n      return this.blob().then(readBlobAsArrayBuffer)\n    } else {\n      throw new Error('could not read as ArrayBuffer')\n    }\n  }\n\n  this.text = function() {\n    var rejected = consumed(this)\n    if (rejected) {\n      return rejected\n    }\n\n    if (this._bodyBlob) {\n      return readBlobAsText(this._bodyBlob)\n    } else if (this._bodyArrayBuffer) {\n      return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n    } else if (this._bodyFormData) {\n      throw new Error('could not read FormData body as text')\n    } else {\n      return Promise.resolve(this._bodyText)\n    }\n  }\n\n  if (support.formData) {\n    this.formData = function() {\n      return this.text().then(decode)\n    }\n  }\n\n  this.json = function() {\n    return this.text().then(JSON.parse)\n  }\n\n  return this\n}\n\n// HTTP methods whose capitalization should be normalized\nvar methods = ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'TRACE']\n\nfunction normalizeMethod(method) {\n  var upcased = method.toUpperCase()\n  return methods.indexOf(upcased) > -1 ? upcased : method\n}\n\nexport function Request(input, options) {\n  if (!(this instanceof Request)) {\n    throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n  }\n\n  options = options || {}\n  var body = options.body\n\n  if (input instanceof Request) {\n    if (input.bodyUsed) {\n      throw new TypeError('Already read')\n    }\n    this.url = input.url\n    this.credentials = input.credentials\n    if (!options.headers) {\n      this.headers = new Headers(input.headers)\n    }\n    this.method = input.method\n    this.mode = input.mode\n    this.signal = input.signal\n    if (!body && input._bodyInit != null) {\n      body = input._bodyInit\n      input.bodyUsed = true\n    }\n  } else {\n    this.url = String(input)\n  }\n\n  this.credentials = options.credentials || this.credentials || 'same-origin'\n  if (options.headers || !this.headers) {\n    this.headers = new Headers(options.headers)\n  }\n  this.method = normalizeMethod(options.method || this.method || 'GET')\n  this.mode = options.mode || this.mode || null\n  this.signal = options.signal || this.signal || (function () {\n    if ('AbortController' in g) {\n      var ctrl = new AbortController();\n      return ctrl.signal;\n    }\n  }());\n  this.referrer = null\n\n  if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n    throw new TypeError('Body not allowed for GET or HEAD requests')\n  }\n  this._initBody(body)\n\n  if (this.method === 'GET' || this.method === 'HEAD') {\n    if (options.cache === 'no-store' || options.cache === 'no-cache') {\n      // Search for a '_' parameter in the query string\n      var reParamSearch = /([?&])_=[^&]*/\n      if (reParamSearch.test(this.url)) {\n        // If it already exists then set the value with the current time\n        this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime())\n      } else {\n        // Otherwise add a new '_' parameter to the end with the current time\n        var reQueryString = /\\?/\n        this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime()\n      }\n    }\n  }\n}\n\nRequest.prototype.clone = function() {\n  return new Request(this, {body: this._bodyInit})\n}\n\nfunction decode(body) {\n  var form = new FormData()\n  body\n    .trim()\n    .split('&')\n    .forEach(function(bytes) {\n      if (bytes) {\n        var split = bytes.split('=')\n        var name = split.shift().replace(/\\+/g, ' ')\n        var value = split.join('=').replace(/\\+/g, ' ')\n        form.append(decodeURIComponent(name), decodeURIComponent(value))\n      }\n    })\n  return form\n}\n\nfunction parseHeaders(rawHeaders) {\n  var headers = new Headers()\n  // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n  // https://tools.ietf.org/html/rfc7230#section-3.2\n  var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ')\n  // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill\n  // https://github.com/github/fetch/issues/748\n  // https://github.com/zloirock/core-js/issues/751\n  preProcessedHeaders\n    .split('\\r')\n    .map(function(header) {\n      return header.indexOf('\\n') === 0 ? header.substr(1, header.length) : header\n    })\n    .forEach(function(line) {\n      var parts = line.split(':')\n      var key = parts.shift().trim()\n      if (key) {\n        var value = parts.join(':').trim()\n        try {\n          headers.append(key, value)\n        } catch (error) {\n          console.warn('Response ' + error.message)\n        }\n      }\n    })\n  return headers\n}\n\nBody.call(Request.prototype)\n\nexport function Response(bodyInit, options) {\n  if (!(this instanceof Response)) {\n    throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n  }\n  if (!options) {\n    options = {}\n  }\n\n  this.type = 'default'\n  this.status = options.status === undefined ? 200 : options.status\n  if (this.status < 200 || this.status > 599) {\n    throw new RangeError(\"Failed to construct 'Response': The status provided (0) is outside the range [200, 599].\")\n  }\n  this.ok = this.status >= 200 && this.status < 300\n  this.statusText = options.statusText === undefined ? '' : '' + options.statusText\n  this.headers = new Headers(options.headers)\n  this.url = options.url || ''\n  this._initBody(bodyInit)\n}\n\nBody.call(Response.prototype)\n\nResponse.prototype.clone = function() {\n  return new Response(this._bodyInit, {\n    status: this.status,\n    statusText: this.statusText,\n    headers: new Headers(this.headers),\n    url: this.url\n  })\n}\n\nResponse.error = function() {\n  var response = new Response(null, {status: 200, statusText: ''})\n  response.ok = false\n  response.status = 0\n  response.type = 'error'\n  return response\n}\n\nvar redirectStatuses = [301, 302, 303, 307, 308]\n\nResponse.redirect = function(url, status) {\n  if (redirectStatuses.indexOf(status) === -1) {\n    throw new RangeError('Invalid status code')\n  }\n\n  return new Response(null, {status: status, headers: {location: url}})\n}\n\nexport var DOMException = g.DOMException\ntry {\n  new DOMException()\n} catch (err) {\n  DOMException = function(message, name) {\n    this.message = message\n    this.name = name\n    var error = Error(message)\n    this.stack = error.stack\n  }\n  DOMException.prototype = Object.create(Error.prototype)\n  DOMException.prototype.constructor = DOMException\n}\n\nexport function fetch(input, init) {\n  return new Promise(function(resolve, reject) {\n    var request = new Request(input, init)\n\n    if (request.signal && request.signal.aborted) {\n      return reject(new DOMException('Aborted', 'AbortError'))\n    }\n\n    var xhr = new XMLHttpRequest()\n\n    function abortXhr() {\n      xhr.abort()\n    }\n\n    xhr.onload = function() {\n      var options = {\n        statusText: xhr.statusText,\n        headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n      }\n      // This check if specifically for when a user fetches a file locally from the file system\n      // Only if the status is out of a normal range\n      if (request.url.indexOf('file://') === 0 && (xhr.status < 200 || xhr.status > 599)) {\n        options.status = 200;\n      } else {\n        options.status = xhr.status;\n      }\n      options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n      var body = 'response' in xhr ? xhr.response : xhr.responseText\n      setTimeout(function() {\n        resolve(new Response(body, options))\n      }, 0)\n    }\n\n    xhr.onerror = function() {\n      setTimeout(function() {\n        reject(new TypeError('Network request failed'))\n      }, 0)\n    }\n\n    xhr.ontimeout = function() {\n      setTimeout(function() {\n        reject(new TypeError('Network request timed out'))\n      }, 0)\n    }\n\n    xhr.onabort = function() {\n      setTimeout(function() {\n        reject(new DOMException('Aborted', 'AbortError'))\n      }, 0)\n    }\n\n    function fixUrl(url) {\n      try {\n        return url === '' && g.location.href ? g.location.href : url\n      } catch (e) {\n        return url\n      }\n    }\n\n    xhr.open(request.method, fixUrl(request.url), true)\n\n    if (request.credentials === 'include') {\n      xhr.withCredentials = true\n    } else if (request.credentials === 'omit') {\n      xhr.withCredentials = false\n    }\n\n    if ('responseType' in xhr) {\n      if (support.blob) {\n        xhr.responseType = 'blob'\n      } else if (\n        support.arrayBuffer\n      ) {\n        xhr.responseType = 'arraybuffer'\n      }\n    }\n\n    if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers || (g.Headers && init.headers instanceof g.Headers))) {\n      var names = [];\n      Object.getOwnPropertyNames(init.headers).forEach(function(name) {\n        names.push(normalizeName(name))\n        xhr.setRequestHeader(name, normalizeValue(init.headers[name]))\n      })\n      request.headers.forEach(function(value, name) {\n        if (names.indexOf(name) === -1) {\n          xhr.setRequestHeader(name, value)\n        }\n      })\n    } else {\n      request.headers.forEach(function(value, name) {\n        xhr.setRequestHeader(name, value)\n      })\n    }\n\n    if (request.signal) {\n      request.signal.addEventListener('abort', abortXhr)\n\n      xhr.onreadystatechange = function() {\n        // DONE (success or failure)\n        if (xhr.readyState === 4) {\n          request.signal.removeEventListener('abort', abortXhr)\n        }\n      }\n    }\n\n    xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n  })\n}\n\nfetch.polyfill = true\n\nif (!g.fetch) {\n  g.fetch = fetch\n  g.Headers = Headers\n  g.Request = Request\n  g.Response = Response\n}\n","export const MAX_DECIMALS = 6;\nexport const DEFAULT_BLEND_STEPS = 5;\nexport const DEFAULT_SHADES_TINTS_STEPS = 5;\nexport const BASE_255 = 255;\nexport const MAX_HUE = 360;\nexport const MAX_PCENT = 100;\nexport const MAX_ALPHA = 1;\nexport const MAX_LAB = 125;\nexport const MAX_LCH_C = 150;\n","export var ColorModel;\n(function (ColorModel) {\n    ColorModel[\"HEX\"] = \"HEX\";\n    ColorModel[\"RGB\"] = \"RGB\";\n    ColorModel[\"HWB\"] = \"HWB\";\n    ColorModel[\"HSL\"] = \"HSL\";\n    ColorModel[\"CIELab\"] = \"CIELab\";\n    ColorModel[\"LCH\"] = \"LCH\";\n    ColorModel[\"CMYK\"] = \"CMYK\";\n})(ColorModel || (ColorModel = {}));\nexport var Harmony;\n(function (Harmony) {\n    Harmony[\"ANALOGOUS\"] = \"ANALOGOUS\";\n    Harmony[\"COMPLEMENTARY\"] = \"COMPLEMENTARY\";\n    Harmony[\"SPLIT_COMPLEMENTARY\"] = \"SPLIT_COMPLEMENTARY\";\n    Harmony[\"TRIADIC\"] = \"TRIADIC\";\n    Harmony[\"TETRADIC\"] = \"TETRADIC\";\n    Harmony[\"SQUARE\"] = \"SQUARE\";\n})(Harmony || (Harmony = {}));\nexport var Mix;\n(function (Mix) {\n    Mix[\"ADDITIVE\"] = \"ADDITIVE\";\n    Mix[\"SUBTRACTIVE\"] = \"SUBTRACTIVE\";\n})(Mix || (Mix = {}));\nexport var ColorKeywords;\n(function (ColorKeywords) {\n    ColorKeywords[\"black\"] = \"#000000\";\n    ColorKeywords[\"silver\"] = \"#C0C0C0\";\n    ColorKeywords[\"gray\"] = \"#808080\";\n    ColorKeywords[\"white\"] = \"#FFFFFF\";\n    ColorKeywords[\"maroon\"] = \"#800000\";\n    ColorKeywords[\"red\"] = \"#FF0000\";\n    ColorKeywords[\"purple\"] = \"#800080\";\n    ColorKeywords[\"fuchsia\"] = \"#FF00FF\";\n    ColorKeywords[\"green\"] = \"#008000\";\n    ColorKeywords[\"lime\"] = \"#00FF00\";\n    ColorKeywords[\"olive\"] = \"#808000\";\n    ColorKeywords[\"yellow\"] = \"#FFFF00\";\n    ColorKeywords[\"navy\"] = \"#000080\";\n    ColorKeywords[\"blue\"] = \"#0000FF\";\n    ColorKeywords[\"teal\"] = \"#008080\";\n    ColorKeywords[\"aqua\"] = \"#00FFFF\";\n    ColorKeywords[\"orange\"] = \"#FFA500\";\n    ColorKeywords[\"aliceblue\"] = \"#F0F8FF\";\n    ColorKeywords[\"antiquewhite\"] = \"#FAEBD7\";\n    ColorKeywords[\"aquamarine\"] = \"#7FFFD4\";\n    ColorKeywords[\"azure\"] = \"#F0FFFF\";\n    ColorKeywords[\"beige\"] = \"#F5F5DC\";\n    ColorKeywords[\"bisque\"] = \"#FFE4C4\";\n    ColorKeywords[\"blanchedalmond\"] = \"#FFEBCD\";\n    ColorKeywords[\"blueviolet\"] = \"#8A2BE2\";\n    ColorKeywords[\"brown\"] = \"#A52A2A\";\n    ColorKeywords[\"burlywood\"] = \"#DEB887\";\n    ColorKeywords[\"cadetblue\"] = \"#5F9EA0\";\n    ColorKeywords[\"chartreuse\"] = \"#7FFF00\";\n    ColorKeywords[\"chocolate\"] = \"#D2691E\";\n    ColorKeywords[\"coral\"] = \"#FF7F50\";\n    ColorKeywords[\"cornflowerblue\"] = \"#6495ED\";\n    ColorKeywords[\"cornsilk\"] = \"#FFF8DC\";\n    ColorKeywords[\"crimson\"] = \"#DC143C\";\n    ColorKeywords[\"cyan\"] = \"#00FFFF\";\n    ColorKeywords[\"darkblue\"] = \"#00008B\";\n    ColorKeywords[\"darkcyan\"] = \"#008B8B\";\n    ColorKeywords[\"darkgoldenrod\"] = \"#B8860B\";\n    ColorKeywords[\"darkgray\"] = \"#A9A9A9\";\n    ColorKeywords[\"darkgreen\"] = \"#006400\";\n    ColorKeywords[\"darkgrey\"] = \"#A9A9A9\";\n    ColorKeywords[\"darkkhaki\"] = \"#BDB76B\";\n    ColorKeywords[\"darkmagenta\"] = \"#8B008B\";\n    ColorKeywords[\"darkolivegreen\"] = \"#556B2F\";\n    ColorKeywords[\"darkorange\"] = \"#FF8C00\";\n    ColorKeywords[\"darkorchid\"] = \"#9932CC\";\n    ColorKeywords[\"darkred\"] = \"#8B0000\";\n    ColorKeywords[\"darksalmon\"] = \"#E9967A\";\n    ColorKeywords[\"darkseagreen\"] = \"#8FBC8F\";\n    ColorKeywords[\"darkslateblue\"] = \"#483D8B\";\n    ColorKeywords[\"darkslategray\"] = \"#2F4F4F\";\n    ColorKeywords[\"darkslategrey\"] = \"#2F4F4F\";\n    ColorKeywords[\"darkturquoise\"] = \"#00CED1\";\n    ColorKeywords[\"darkviolet\"] = \"#9400D3\";\n    ColorKeywords[\"deeppink\"] = \"#FF1493\";\n    ColorKeywords[\"deepskyblue\"] = \"#00BFFF\";\n    ColorKeywords[\"dimgray\"] = \"#696969\";\n    ColorKeywords[\"dimgrey\"] = \"#696969\";\n    ColorKeywords[\"dodgerblue\"] = \"#1E90FF\";\n    ColorKeywords[\"firebrick\"] = \"#B22222\";\n    ColorKeywords[\"floralwhite\"] = \"#FFFAF0\";\n    ColorKeywords[\"forestgreen\"] = \"#228B22\";\n    ColorKeywords[\"gainsboro\"] = \"#DCDCDC\";\n    ColorKeywords[\"ghostwhite\"] = \"#F8F8FF\";\n    ColorKeywords[\"gold\"] = \"#FFD700\";\n    ColorKeywords[\"goldenrod\"] = \"#DAA520\";\n    ColorKeywords[\"greenyellow\"] = \"#ADFF2F\";\n    ColorKeywords[\"grey\"] = \"#808080\";\n    ColorKeywords[\"honeydew\"] = \"#F0FFF0\";\n    ColorKeywords[\"hotpink\"] = \"#FF69B4\";\n    ColorKeywords[\"indianred\"] = \"#CD5C5C\";\n    ColorKeywords[\"indigo\"] = \"#4B0082\";\n    ColorKeywords[\"ivory\"] = \"#FFFFF0\";\n    ColorKeywords[\"khaki\"] = \"#F0E68C\";\n    ColorKeywords[\"lavender\"] = \"#E6E6FA\";\n    ColorKeywords[\"lavenderblush\"] = \"#FFF0F5\";\n    ColorKeywords[\"lawngreen\"] = \"#7CFC00\";\n    ColorKeywords[\"lemonchiffon\"] = \"#FFFACD\";\n    ColorKeywords[\"lightblue\"] = \"#ADD8E6\";\n    ColorKeywords[\"lightcoral\"] = \"#F08080\";\n    ColorKeywords[\"lightcyan\"] = \"#E0FFFF\";\n    ColorKeywords[\"lightgoldenrodyellow\"] = \"#FAFAD2\";\n    ColorKeywords[\"lightgray\"] = \"#D3D3D3\";\n    ColorKeywords[\"lightgreen\"] = \"#90EE90\";\n    ColorKeywords[\"lightgrey\"] = \"#D3D3D3\";\n    ColorKeywords[\"lightpink\"] = \"#FFB6C1\";\n    ColorKeywords[\"lightsalmon\"] = \"#FFA07A\";\n    ColorKeywords[\"lightseagreen\"] = \"#20B2AA\";\n    ColorKeywords[\"lightskyblue\"] = \"#87CEFA\";\n    ColorKeywords[\"lightslategray\"] = \"#778899\";\n    ColorKeywords[\"lightslategrey\"] = \"#778899\";\n    ColorKeywords[\"lightsteelblue\"] = \"#B0C4DE\";\n    ColorKeywords[\"lightyellow\"] = \"#FFFFE0\";\n    ColorKeywords[\"limegreen\"] = \"#32CD32\";\n    ColorKeywords[\"linen\"] = \"#FAF0E6\";\n    ColorKeywords[\"magenta\"] = \"#FF00FF\";\n    ColorKeywords[\"mediumaquamarine\"] = \"#66CDAA\";\n    ColorKeywords[\"mediumblue\"] = \"#0000CD\";\n    ColorKeywords[\"mediumorchid\"] = \"#BA55D3\";\n    ColorKeywords[\"mediumpurple\"] = \"#9370DB\";\n    ColorKeywords[\"mediumseagreen\"] = \"#3CB371\";\n    ColorKeywords[\"mediumslateblue\"] = \"#7B68EE\";\n    ColorKeywords[\"mediumspringgreen\"] = \"#00FA9A\";\n    ColorKeywords[\"mediumturquoise\"] = \"#48D1CC\";\n    ColorKeywords[\"mediumvioletred\"] = \"#C71585\";\n    ColorKeywords[\"midnightblue\"] = \"#191970\";\n    ColorKeywords[\"mintcream\"] = \"#F5FFFA\";\n    ColorKeywords[\"mistyrose\"] = \"#FFE4E1\";\n    ColorKeywords[\"moccasin\"] = \"#FFE4B5\";\n    ColorKeywords[\"navajowhite\"] = \"#FFDEAD\";\n    ColorKeywords[\"oldlace\"] = \"#FDF5E6\";\n    ColorKeywords[\"olivedrab\"] = \"#6B8E23\";\n    ColorKeywords[\"orangered\"] = \"#FF4500\";\n    ColorKeywords[\"orchid\"] = \"#DA70D6\";\n    ColorKeywords[\"palegoldenrod\"] = \"#EEE8AA\";\n    ColorKeywords[\"palegreen\"] = \"#98FB98\";\n    ColorKeywords[\"paleturquoise\"] = \"#AFEEEE\";\n    ColorKeywords[\"palevioletred\"] = \"#DB7093\";\n    ColorKeywords[\"papayawhip\"] = \"#FFEFD5\";\n    ColorKeywords[\"peachpuff\"] = \"#FFDAB9\";\n    ColorKeywords[\"peru\"] = \"#CD853F\";\n    ColorKeywords[\"pink\"] = \"#FFC0CB\";\n    ColorKeywords[\"plum\"] = \"#DDA0DD\";\n    ColorKeywords[\"powderblue\"] = \"#B0E0E6\";\n    ColorKeywords[\"rosybrown\"] = \"#BC8F8F\";\n    ColorKeywords[\"royalblue\"] = \"#4169E1\";\n    ColorKeywords[\"saddlebrown\"] = \"#8B4513\";\n    ColorKeywords[\"salmon\"] = \"#FA8072\";\n    ColorKeywords[\"sandybrown\"] = \"#F4A460\";\n    ColorKeywords[\"seagreen\"] = \"#2E8B57\";\n    ColorKeywords[\"seashell\"] = \"#FFF5EE\";\n    ColorKeywords[\"sienna\"] = \"#A0522D\";\n    ColorKeywords[\"skyblue\"] = \"#87CEEB\";\n    ColorKeywords[\"slateblue\"] = \"#6A5ACD\";\n    ColorKeywords[\"slategray\"] = \"#708090\";\n    ColorKeywords[\"slategrey\"] = \"#708090\";\n    ColorKeywords[\"snow\"] = \"#FFFAFA\";\n    ColorKeywords[\"springgreen\"] = \"#00FF7F\";\n    ColorKeywords[\"steelblue\"] = \"#4682B4\";\n    ColorKeywords[\"tan\"] = \"#D2B48C\";\n    ColorKeywords[\"thistle\"] = \"#D8BFD8\";\n    ColorKeywords[\"tomato\"] = \"#FF6347\";\n    ColorKeywords[\"turquoise\"] = \"#40E0D0\";\n    ColorKeywords[\"violet\"] = \"#EE82EE\";\n    ColorKeywords[\"wheat\"] = \"#F5DEB3\";\n    ColorKeywords[\"whitesmoke\"] = \"#F5F5F5\";\n    ColorKeywords[\"yellowgreen\"] = \"#9ACD32\";\n    ColorKeywords[\"rebeccapurple\"] = \"#663399\";\n})(ColorKeywords || (ColorKeywords = {}));\nexport const COLOR_KEYS = Object.keys(ColorKeywords);\nexport const COLOR_PROPS = {\n    HEX: ['R', 'G', 'B', 'A'],\n    RGB: ['R', 'G', 'B', 'A'],\n    HSL: ['H', 'S', 'L', 'A'],\n    HWB: ['H', 'W', 'B', 'A'],\n    CIELab: ['L', 'a', 'b', 'A'],\n    LCH: ['L', 'C', 'H', 'A'],\n    CMYK: ['C', 'M', 'Y', 'K', 'A']\n};\nexport const VALID_COLOR_OBJECTS = {\n    ABGR: ColorModel.RGB,\n    ABHW: ColorModel.HWB,\n    ACHL: ColorModel.LCH,\n    ACKMY: ColorModel.CMYK,\n    AHLS: ColorModel.HSL,\n    ALAB: ColorModel.CIELab,\n    BGR: ColorModel.RGB,\n    BHW: ColorModel.HWB,\n    CHL: ColorModel.LCH,\n    CKMY: ColorModel.CMYK,\n    HLS: ColorModel.HSL,\n    LAB: ColorModel.CIELab\n};\nexport var TypeOf;\n(function (TypeOf) {\n    TypeOf[\"NUMBER\"] = \"number\";\n    TypeOf[\"BOOLEAN\"] = \"boolean\";\n})(TypeOf || (TypeOf = {}));\n","import { ColorModel } from './enums';\nexport const COLORREGS = {\n    [ColorModel.HEX]: /^#(?:(?<r>[a-f\\d])(?<g>[a-f\\d])(?<b>[a-f\\d])(?<a>[a-f\\d])?|(?<rr>[a-f\\d]{2})(?<gg>[a-f\\d]{2})(?<bb>[a-f\\d]{2})(?<aa>[a-f\\d]{2})?)$/i,\n    [ColorModel.RGB]: /^rgba?\\s*\\(\\s*(?:(?<r_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<g_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<b_legacy>(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?<a_legacy>(?:\\d*\\.)?\\d+))?|(?<r>(?:\\d*\\.)?\\d+%?)\\s+(?<g>(?:\\d*\\.)?\\d+%?)\\s+(?<b>(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_r>(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_g>(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_b>(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.HWB]: /^hwb\\s*\\(\\s*(?:(?<h>(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?<w>(?:\\d*\\.)?\\d+)%\\s+(?<b>(?:\\d*\\.)?\\d+)%(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_h>(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_w>(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?\\s+(?<relative_b>(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.HSL]: /^hsla?\\s*\\(\\s*(?:(?<h_legacy>-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s*,\\s*(?<s_legacy>(?:\\d*\\.)?\\d+)%\\s*,\\s*(?<l_legacy>(?:\\d*\\.)?\\d+)%(?:\\s*,\\s*(?<a_legacy>(?:\\d*\\.)?\\d+))?|(?<h>-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?<s>(?:\\d*\\.)?\\d+)%?\\s+(?<l>(?:\\d*\\.)?\\d+)%?(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_h>(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_s>(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?\\s+(?<relative_l>(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.CIELab]: /^lab\\s*\\(\\s*(?:(?<L>(?:\\d*\\.)?\\d+%?)\\s+(?<a>-?(?:\\d*\\.)?\\d+%?)\\s+(?<b>-?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?<A>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_L>(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_a>(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_b>(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?<relative_A>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.LCH]: /^lch\\s*\\(\\s*(?:(?<l>(?:\\d*\\.)?\\d+%?)\\s+(?<c>-?(?:\\d*\\.)?\\d+%?)\\s+(?<h>-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_l>(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_c>(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_h>(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.CMYK]: /^(?:device-cmyk|cmyk)\\s*\\(\\s*(?:(?<c_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<m_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<y_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<k_legacy>(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?<a_legacy>(?:\\d*\\.)?\\d+))?|(?<c>(?:\\d*\\.)?\\d+%?)\\s+(?<m>(?:\\d*\\.)?\\d+%?)\\s+(?<y>(?:\\d*\\.)?\\d+%?)\\s+(?<k>(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?)\\s*\\)$/\n};\nexport const CALC = {\n    REGEXP: /^calc\\(\\s*(?<operation>[\\d./*+-\\w\\s]+)\\s*\\)$/,\n    SCOPED: /\\(\\s*([^()]+)\\s*\\)/g,\n    DIVISION: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\/\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n    MULTIPLICATION: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\*\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n    SUM: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\+\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n    REST: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*-\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/\n};\nexport const HSL_HUE = /^(?<number>-?(?:\\d*\\.)?\\d+)(?<units>(?:deg|grad|rad|turn)?)$/;\nexport const PCENT = /^(-?\\d+(?:\\.\\d+)?|-?\\.\\d+)%$/;\nexport const HEX = /^0x([a-f\\d]{1,2})$/i;\nexport const TEMPLATE_VAR = /\\{(\\d+)\\}/g;\nexport const COMMAS_AND_NEXT_CHARS = /,( +|\\d+)/g;\nexport const SPACES = / +/;\n","export const ERRORS = {\n    NOT_ACCEPTED_STRING_INPUT: 'The provided string color doesn\\'t have a correct format',\n    NOT_ACCEPTED_OBJECT_INPUT: 'The provided color object doesn\\'t have the proper keys or format',\n    NOT_A_VALID_RELATIVE_COLOR: 'is not a valid operation for a relative color'\n};\n","export var AnglesUnitEnum;\n(function (AnglesUnitEnum) {\n    AnglesUnitEnum[\"NONE\"] = \"none\";\n    AnglesUnitEnum[\"DEGREES\"] = \"deg\";\n    AnglesUnitEnum[\"GRADIANS\"] = \"grad\";\n    AnglesUnitEnum[\"RADIANS\"] = \"rad\";\n    AnglesUnitEnum[\"TURNS\"] = \"turn\";\n})(AnglesUnitEnum || (AnglesUnitEnum = {}));\nexport var ColorUnitEnum;\n(function (ColorUnitEnum) {\n    ColorUnitEnum[\"NONE\"] = \"none\";\n    ColorUnitEnum[\"PERCENT\"] = \"percent\";\n})(ColorUnitEnum || (ColorUnitEnum = {}));\nexport var CMYKFunctionEnum;\n(function (CMYKFunctionEnum) {\n    CMYKFunctionEnum[\"DEVICE_CMYK\"] = \"device-cmyk\";\n    CMYKFunctionEnum[\"CMYK\"] = \"cmyk\";\n})(CMYKFunctionEnum || (CMYKFunctionEnum = {}));\n","import { AnglesUnitEnum, CMYKFunctionEnum, ColorUnitEnum } from '@types';\nimport { MAX_DECIMALS } from './numbers';\nexport const DEFAULT_OPTIONS = {\n    decimals: MAX_DECIMALS,\n    legacyCSS: false,\n    spacesAfterCommas: false,\n    anglesUnit: AnglesUnitEnum.NONE,\n    rgbUnit: ColorUnitEnum.NONE,\n    labUnit: ColorUnitEnum.NONE,\n    lchUnit: ColorUnitEnum.NONE,\n    cmykUnit: ColorUnitEnum.PERCENT,\n    alphaUnit: ColorUnitEnum.NONE,\n    cmykFunction: CMYKFunctionEnum.DEVICE_CMYK\n};\n","export * from './numbers';\nexport * from './enums';\nexport * from './enums-strings';\nexport * from './regexps';\nexport * from './errors';\nexport * from './options';\n","import { AnglesUnitEnum } from '@types';\nimport { BASE_255, Harmony, HEX, HSL_HUE, MAX_ALPHA, MAX_DECIMALS, MAX_LAB, MAX_LCH_C, Mix, PCENT } from '#constants';\nexport const hasProp = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nexport const percentNumber = (percent) => {\n    return +`${percent}`.replace(PCENT, '$1');\n};\nexport const percent = (percent) => PCENT.test(`${percent}`)\n    ? percentNumber(percent)\n    : Math.min(+percent, 100);\nexport const getDEC = (hex) => {\n    if (hex.length === 1) {\n        hex += hex;\n    }\n    return parseInt(hex, 16);\n};\nexport const getHEX = (number) => {\n    const hex = round(number, 0).toString(16).toUpperCase();\n    if (hex.length === 1) {\n        return `0x0${hex}`;\n    }\n    return `0x${hex}`;\n};\nexport const toHEX = (h) => {\n    let hex = round(h, 0).toString(16).toUpperCase();\n    if (hex.length === 1) {\n        hex = `0${hex}`;\n    }\n    return hex;\n};\nexport const from255NumberToPercent = (value, decimals) => round(value / BASE_255 * 100, decimals);\nexport const from125NumberToPercent = (value, decimals) => round(value / MAX_LAB * 100, decimals);\nexport const from150NumberToPercent = (value, decimals) => round(value / MAX_LCH_C * 100, decimals);\nexport const getBase255Number = (color, alpha = false) => {\n    if (!alpha && PCENT.test(color)) {\n        return Math.min(BASE_255 * percentNumber(color) / 100, BASE_255);\n    }\n    if (HEX.test(color)) {\n        if (color.length === 3) {\n            color += color.slice(-1);\n        }\n        return alpha\n            ? round(color) / BASE_255\n            : round(color);\n    }\n    return Math.min(+color, alpha ? 1 : BASE_255);\n};\nexport const getBase125Number = (color) => {\n    if (PCENT.test(color)) {\n        return minmax(MAX_LAB * percentNumber(color) / 100, -MAX_LAB, MAX_LAB);\n    }\n    return minmax(+color, -MAX_LAB, MAX_LAB);\n};\nexport const getBase150Number = (color) => {\n    if (PCENT.test(color)) {\n        return minmax(MAX_LCH_C * percentNumber(color) / 100, -MAX_LCH_C, MAX_LCH_C);\n    }\n    return minmax(+color, -MAX_LCH_C, MAX_LCH_C);\n};\nexport const getCMYKNumber = (color) => Math.min(PCENT.test(color) ? percentNumber(color) / 100 : +color, 1);\nexport const getOrderedArrayString = (keys) => [...keys].sort().join('').toUpperCase();\nexport const round = (value, decimals = MAX_DECIMALS) => {\n    const exp = Math.pow(10, decimals);\n    return Math.round(+value * exp) / exp;\n};\nexport const minmax = (n, min, max) => Math.max(min, Math.min(n, max));\nexport const degrees = (radian) => radian * 180 / Math.PI;\nexport const radians = (degrees) => degrees * Math.PI / 180;\nconst pi2 = 360;\nexport const normalizeHue = (hue) => {\n    if (typeof hue === 'string') {\n        const matches = hue.match(HSL_HUE);\n        const groups = matches.groups;\n        const value = +groups.number;\n        const units = groups.units;\n        switch (units) {\n            case AnglesUnitEnum.RADIANS:\n                hue = round(degrees(value));\n                break;\n            case AnglesUnitEnum.TURNS:\n                hue = round(value * pi2);\n                break;\n            case AnglesUnitEnum.GRADIANS:\n                hue = round(9 / 10 * value);\n                break;\n            case AnglesUnitEnum.DEGREES:\n            default:\n                hue = value;\n        }\n    }\n    if (hue > 360 || hue < 0) {\n        hue -= Math.floor(hue / pi2) * pi2;\n    }\n    return hue;\n};\nexport const normalizeAlpha = (alpha) => {\n    if (typeof alpha === 'string') {\n        if (PCENT.test(alpha)) {\n            alpha = percentNumber(alpha) / 100;\n        }\n        else {\n            alpha = +alpha;\n        }\n    }\n    return (isNaN(+alpha) || alpha > MAX_ALPHA) ? MAX_ALPHA : round(alpha);\n};\nexport const translateDegrees = (degrees, units) => {\n    let hue;\n    switch (units) {\n        case AnglesUnitEnum.RADIANS:\n            hue = round(radians(degrees));\n            break;\n        case AnglesUnitEnum.TURNS:\n            hue = round(degrees / pi2);\n            break;\n        case AnglesUnitEnum.GRADIANS:\n            hue = round(10 / 9 * degrees);\n            break;\n        case AnglesUnitEnum.DEGREES:\n        case AnglesUnitEnum.NONE:\n        default:\n            hue = degrees;\n    }\n    return hue;\n};\nexport const isHarmony = (param) => {\n    return `${param}` in Harmony;\n};\nexport const isMix = (param) => {\n    return `${param}` in Mix;\n};\n","import { BASE_255, MAX_ALPHA } from '#constants';\nimport { degrees, minmax, normalizeHue, radians, round } from '#helpers';\nconst MATRIX_LRGB_XYZ_D50 = [\n    [0.4360747, 0.3850649, 0.1430804],\n    [0.2225045, 0.7168786, 0.0606169],\n    [0.0139322, 0.0971045, 0.7141733]\n];\nconst MATRIX_XYZ_D50_LRGB = [\n    [3.1338561, -1.6168667, -0.4906146],\n    [-0.9787684, 1.9161415, 0.033454],\n    [0.0719453, -0.2289914, 1.4052427]\n];\nconst TRISTIMULUS_D50 = MATRIX_LRGB_XYZ_D50.map((matrix) => {\n    return matrix.reduce((sum, value) => sum + value, 0);\n});\nconst hueToRgb = (t1, t2, hue) => {\n    if (hue < 0) {\n        hue += 6;\n    }\n    if (hue >= 6) {\n        hue -= 6;\n    }\n    if (hue < 1) {\n        return round(((t2 - t1) * hue + t1) * BASE_255);\n    }\n    else if (hue < 3) {\n        return round(t2 * BASE_255);\n    }\n    else if (hue < 4) {\n        return round(((t2 - t1) * (4 - hue) + t1) * BASE_255);\n    }\n    else {\n        return round(t1 * BASE_255);\n    }\n};\nconst rgbToLinearLightRgb = (value) => {\n    return value <= 0.04045\n        ? value / 12.92\n        : ((value + 0.055) / 1.055) ** 2.4;\n};\nconst linearLightRgbToRgb = (value) => {\n    return value <= 0.0031308\n        ? 12.92 * value\n        : 1.055 * (value ** (1 / 2.4)) - 0.055;\n};\nconst matrixVectorMultiplication = (v1, v2, v3, matrix) => {\n    const result = [0, 0, 0];\n    const linearRgb = [v1, v2, v3];\n    matrix.forEach((array, index) => {\n        array.forEach((value, mindex) => {\n            result[index] += value * linearRgb[mindex];\n        });\n    });\n    return result;\n};\nconst from_CIE_XYZ_D50_to_CIE_LAB = (x, y, z) => {\n    const f = (t) => {\n        return t > (6 / 29) ** 3\n            ? Math.cbrt(t)\n            : t / (3 * (6 / 29) ** 2) + (4 / 29);\n    };\n    const fx = f(x / TRISTIMULUS_D50[0]);\n    const fy = f(y / TRISTIMULUS_D50[1]);\n    const fz = f(z / TRISTIMULUS_D50[2]);\n    return [\n        116 * fy - 16,\n        500 * (fx - fy),\n        200 * (fy - fz)\n    ];\n};\nconst from_CIE_LAB_to_CIE_XYZ_D50 = (L, a, b) => {\n    const f = (t) => {\n        return t > 6 / 29\n            ? t ** 3\n            : 3 * (6 / 29) ** 2 * (t - 4 / 29);\n    };\n    const fl = (L + 16) / 116;\n    const fa = a / 500;\n    const fb = b / 200;\n    return [\n        TRISTIMULUS_D50[0] * f(fl + fa),\n        TRISTIMULUS_D50[1] * f(fl),\n        TRISTIMULUS_D50[2] * f(fl - fb)\n    ];\n};\nexport const hslToRgb = (H, S, L) => {\n    H /= 60;\n    S /= 100;\n    L /= 100;\n    const t2 = (L <= .5)\n        ? L * (S + 1)\n        : L + S - (L * S);\n    const t1 = L * 2 - t2;\n    const R = hueToRgb(t1, t2, H + 2);\n    const G = hueToRgb(t1, t2, H);\n    const B = hueToRgb(t1, t2, H - 2);\n    return { R, G, B };\n};\nexport const rgbToHsl = (R, G, B, A = 1) => {\n    R /= BASE_255;\n    G /= BASE_255;\n    B /= BASE_255;\n    A = Math.min(A, MAX_ALPHA);\n    const MAX = Math.max(R, G, B);\n    const MIN = Math.min(R, G, B);\n    const D = MAX - MIN;\n    let H = 0;\n    let S = 0;\n    const L = (MAX + MIN) / 2;\n    if (D !== 0) {\n        switch (MAX) {\n            case R:\n                H = ((G - B) / D) % 6;\n                break;\n            case G:\n                H = (B - R) / D + 2;\n                break;\n            case B:\n                H = (R - G) / D + 4;\n                break;\n        }\n        H = round(H * 60);\n        if (H < 0) {\n            H += 360;\n        }\n        S = D / (1 - Math.abs(2 * L - 1));\n    }\n    return {\n        H,\n        S: round(S * 100),\n        L: round(L * 100),\n        A\n    };\n};\nexport const rgbToLab = (R, G, B) => {\n    const LINEAR_LIGHT_RGB = [\n        R / BASE_255,\n        G / BASE_255,\n        B / BASE_255\n    ].map(rgbToLinearLightRgb);\n    const CIE_XYZ_D50 = matrixVectorMultiplication(LINEAR_LIGHT_RGB[0], LINEAR_LIGHT_RGB[1], LINEAR_LIGHT_RGB[2], MATRIX_LRGB_XYZ_D50);\n    const CIE_LAB = from_CIE_XYZ_D50_to_CIE_LAB(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2]);\n    return {\n        L: CIE_LAB[0],\n        a: CIE_LAB[1],\n        b: CIE_LAB[2]\n    };\n};\nexport const labToRgb = (L, a, b) => {\n    const CIE_XYZ_D50 = from_CIE_LAB_to_CIE_XYZ_D50(L, a, b);\n    const LINEAR_LIGHT_RGB = matrixVectorMultiplication(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2], MATRIX_XYZ_D50_LRGB);\n    const rgb = LINEAR_LIGHT_RGB.map(linearLightRgbToRgb);\n    return {\n        R: minmax(rgb[0] * BASE_255, 0, BASE_255),\n        G: minmax(rgb[1] * BASE_255, 0, BASE_255),\n        B: minmax(rgb[2] * BASE_255, 0, BASE_255)\n    };\n};\nexport const labToLch = (L, a, b) => {\n    const C = Math.sqrt(a ** 2 + b ** 2);\n    const H = degrees(Math.atan2(b, a));\n    return {\n        L,\n        C,\n        H: normalizeHue(H)\n    };\n};\nexport const lchToLab = (L, C, H) => {\n    const radH = radians(H);\n    const a = C * Math.cos(radH);\n    const b = C * Math.sin(radH);\n    return {\n        L,\n        a,\n        b\n    };\n};\nexport const rgbToLch = (R, G, B) => {\n    const lab = rgbToLab(R, G, B);\n    return labToLch(lab.L, lab.a, lab.b);\n};\nexport const lchToRgb = (L, C, H) => {\n    const lab = lchToLab(L, C, H);\n    return labToRgb(lab.L, lab.a, lab.b);\n};\nexport const rgbToHwb = (R, G, B, A = 1) => {\n    const hsl = rgbToHsl(R, G, B, A);\n    return {\n        H: hsl.H,\n        W: round(Math.min(R, G, B) / BASE_255 * 100),\n        B: round((1 - Math.max(R, G, B) / BASE_255) * 100),\n        A\n    };\n};\nexport const hwbToRgb = (H, W, B) => {\n    W /= 100;\n    B /= 100;\n    const v = 1 - B;\n    const c = v - W;\n    const x = c * (1 - Math.abs((H / 60) % 2 - 1));\n    let rgbR = 0;\n    let rgbG = 0;\n    let rgbB = 0;\n    if (H < 60) {\n        rgbR = c;\n        rgbG = x;\n        rgbB = 0;\n    }\n    else if (H >= 60 && H < 120) {\n        rgbR = x;\n        rgbG = c;\n        rgbB = 0;\n    }\n    else if (H >= 120 && H < 180) {\n        rgbR = 0;\n        rgbG = c;\n        rgbB = x;\n    }\n    else if (H >= 180 && H < 240) {\n        rgbR = 0;\n        rgbG = x;\n        rgbB = c;\n    }\n    else if (H >= 240 && H < 300) {\n        rgbR = x;\n        rgbG = 0;\n        rgbB = c;\n    }\n    else {\n        rgbR = c;\n        rgbG = 0;\n        rgbB = x;\n    }\n    rgbR += W;\n    rgbG += W;\n    rgbB += W;\n    return {\n        R: minmax(rgbR * BASE_255, 0, BASE_255),\n        G: minmax(rgbG * BASE_255, 0, BASE_255),\n        B: minmax(rgbB * BASE_255, 0, BASE_255)\n    };\n};\nexport const cmykToRgb = (C, M, Y, K) => {\n    K = 1 - K;\n    return {\n        R: round(BASE_255 * (1 - C) * K),\n        G: round(BASE_255 * (1 - M) * K),\n        B: round(BASE_255 * (1 - Y) * K)\n    };\n};\nexport const rgbToCmyk = (R, G, B) => {\n    R /= BASE_255;\n    G /= BASE_255;\n    B /= BASE_255;\n    const K = 1 - Math.max(R, G, B);\n    const K1 = 1 - K;\n    const C = K1 && (K1 - R) / K1;\n    const M = K1 && (K1 - G) / K1;\n    const Y = K1 && (K1 - B) / K1;\n    return {\n        C: round(C * 100),\n        M: round(M * 100),\n        Y: round(Y * 100),\n        K: round(K * 100)\n    };\n};\nexport const rgbToRyb = (R, G, B) => {\n    const Iw = Math.min(R, G, B);\n    const Ib = Math.min(BASE_255 - R, BASE_255 - G, BASE_255 - B);\n    const rRgb = R - Iw;\n    const gRgb = G - Iw;\n    const bRgb = B - Iw;\n    const minRg = Math.min(rRgb, gRgb);\n    const rRyb = rRgb - minRg;\n    const yRyb = (gRgb + minRg) / 2;\n    const bRyb = (bRgb + gRgb - minRg) / 2;\n    const n = Math.max(rRyb, yRyb, bRyb) / Math.max(rRgb, gRgb, bRgb);\n    const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n    return {\n        R: rRyb / N + Ib,\n        Y: yRyb / N + Ib,\n        B: bRyb / N + Ib\n    };\n};\nexport const rybToRgb = (R, Y, B) => {\n    const Iw = Math.min(R, Y, B);\n    const Ib = Math.min(BASE_255 - R, BASE_255 - Y, BASE_255 - B);\n    const rRyb = R - Iw;\n    const yRyb = Y - Iw;\n    const bRyb = B - Iw;\n    const minYb = Math.min(yRyb, bRyb);\n    const rRgb = rRyb + yRyb - minYb;\n    const gRgb = yRyb + minYb;\n    const bRgb = 2 * (bRyb - minYb);\n    const n = Math.max(rRgb, gRgb, bRgb) / Math.max(rRyb, yRyb, bRyb);\n    const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n    return {\n        R: rRgb / N + Ib,\n        G: gRgb / N + Ib,\n        B: bRgb / N + Ib\n    };\n};\nexport const hueRyb = (hue, toRyb) => {\n    if (hue < 0)\n        hue += 360;\n    if (hue > 360)\n        hue -= 360;\n    if (hue === 360 || hue === 0)\n        return hue;\n    const map1 = [\n        [0, 120],\n        [120, 180],\n        [180, 240],\n        [240, 360]\n    ];\n    const map2 = [\n        [0, 60],\n        [60, 120],\n        [120, 240],\n        [240, 360]\n    ];\n    const from = toRyb ? map1 : map2;\n    const to = toRyb ? map2 : map1;\n    let A = 0;\n    let B = 0;\n    let C = 0;\n    let D = 0;\n    from.find((arr, index) => {\n        if (hue >= arr[0] && hue < arr[1]) {\n            A = arr[0];\n            B = arr[1];\n            C = to[index][0];\n            D = to[index][1];\n            return true;\n        }\n        return false;\n    });\n    return C + (hue - A) * ((D - C) / (B - A));\n};\n","export class RgbClass {\n    get rgb() {\n        return this._rgb;\n    }\n}\n","import { BASE_255, COLORREGS } from '#constants';\nimport { getDEC } from '#helpers';\nimport { RgbClass } from './baseClasses/_RgbClass';\nexport class HEXStringParser extends RgbClass {\n    constructor(colorString) {\n        super();\n        const match = colorString.match(COLORREGS.HEX);\n        const groups = match.groups;\n        this._r = groups.r ?? groups.rr;\n        this._g = groups.g ?? groups.gg;\n        this._b = groups.b ?? groups.bb;\n        this._a = groups.a ?? groups.aa;\n        const rgb = {\n            R: getDEC(this._r),\n            G: getDEC(this._g),\n            B: getDEC(this._b)\n        };\n        if (this._a !== undefined) {\n            rgb.A = getDEC(this._a) / BASE_255;\n        }\n        this._rgb = rgb;\n    }\n}\n","import { CALC, ERRORS } from '#constants';\nconst MAX_STACK = 100;\nexport class CalcParser {\n    constructor(colorIndex, calc, vars) {\n        this._operations = new Map([\n            [CALC.DIVISION, this._division],\n            [CALC.MULTIPLICATION, this._multiplication],\n            [CALC.SUM, this._sum],\n            [CALC.REST, this._rest]\n        ]);\n        this._colorIndex = colorIndex;\n        let calcString = calc;\n        let stack = 0;\n        if (!Number.isNaN(+calc)) {\n            this._result = +calc;\n        }\n        else if (calc in vars) {\n            this._result = vars[calc];\n        }\n        else if (CALC.REGEXP.test(calcString)) {\n            CALC.REGEXP.lastIndex = 0;\n            this._result = this._getCalcValue(calcString, vars);\n        }\n        else {\n            while (CALC.SCOPED.test(calcString) && stack < MAX_STACK) {\n                CALC.SCOPED.lastIndex = 0;\n                calcString = calcString.replace(CALC.SCOPED, (__match, operation) => {\n                    return this._calculate(operation, vars).toString();\n                });\n                if (CALC.REGEXP.test(calcString)) {\n                    CALC.REGEXP.lastIndex = 0;\n                    break;\n                }\n                stack++;\n            }\n            this._result = this._getCalcValue(calcString, vars);\n        }\n    }\n    _division(left, right) {\n        return left / right;\n    }\n    _multiplication(left, right) {\n        return left * right;\n    }\n    _sum(left, right) {\n        return left + right;\n    }\n    _rest(left, right) {\n        return left - right;\n    }\n    _getCalcValue(calc, vars) {\n        const match = calc.match(CALC.REGEXP);\n        const operation = match.groups.operation;\n        const value = this._calculate(operation, vars);\n        if (Number.isNaN(value)) {\n            throw new Error(`Invalid value for ${this._colorIndex}. ${operation} ${ERRORS.NOT_A_VALID_RELATIVE_COLOR}`);\n        }\n        return value;\n    }\n    _calculate(operation, vars) {\n        this._operations.forEach((method, regExp) => {\n            let stack = 0;\n            while (regExp.test(operation) && stack < MAX_STACK) {\n                operation = operation.replace(regExp, (__match, left, right) => {\n                    return method(vars[left] ?? +left, vars[right] ?? +right).toString();\n                });\n                stack++;\n            }\n        });\n        return +operation;\n    }\n    get result() {\n        return this._result;\n    }\n}\n","import { PCENT } from '#constants';\nimport { RgbClass } from './_RgbClass';\nexport class AlphaBaseClass extends RgbClass {\n    get hasPercentageAlpha() {\n        return PCENT.test(this._a);\n    }\n}\n","import { BASE_255, COLORREGS, PCENT } from '#constants';\nimport { getBase255Number, normalizeAlpha } from '#helpers';\nimport { CalcParser } from './_CalcParser';\nimport { AlphaBaseClass } from './baseClasses/_AlphaBaseClass';\nexport class RGBStringParser extends AlphaBaseClass {\n    constructor(colorString, getRGBObject) {\n        super();\n        const match = colorString.match(COLORREGS.RGB);\n        const groups = match.groups;\n        const { r_legacy, g_legacy, b_legacy, a_legacy, r, g, b, a, from, relative_r, relative_g, relative_b, relative_a } = groups;\n        if (from) {\n            const fromRGB = getRGBObject(from);\n            const fromRGBVars = {\n                r: fromRGB.R,\n                g: fromRGB.G,\n                b: fromRGB.B,\n                alpha: fromRGB.A ?? 1\n            };\n            const R = new CalcParser('r', relative_r, fromRGBVars).result;\n            const G = new CalcParser('g', relative_g, fromRGBVars).result;\n            const B = new CalcParser('b', relative_b, fromRGBVars).result;\n            const rgb = {\n                R: Math.min(R, BASE_255),\n                G: Math.min(G, BASE_255),\n                B: Math.min(B, BASE_255)\n            };\n            if (relative_a) {\n                const A = new CalcParser('alpha', relative_a, fromRGBVars).result;\n                rgb.A = Math.min(A, 1);\n            }\n            this._rgb = rgb;\n        }\n        else {\n            this._r = r_legacy ?? r;\n            this._g = g_legacy ?? g;\n            this._b = b_legacy ?? b;\n            this._a = a_legacy ?? a;\n            const rgb = {\n                R: Math.min(getBase255Number(this._r), BASE_255),\n                G: Math.min(getBase255Number(this._g), BASE_255),\n                B: Math.min(getBase255Number(this._b), BASE_255)\n            };\n            if (this._a !== undefined) {\n                rgb.A = normalizeAlpha(this._a);\n            }\n            this._rgb = rgb;\n        }\n    }\n    get hasPercentageValues() {\n        return (PCENT.test(this._r) &&\n            PCENT.test(this._g) &&\n            PCENT.test(this._b));\n    }\n    static test(colorString) {\n        return COLORREGS.RGB.test(colorString);\n    }\n}\n","import { AnglesUnitEnum } from '@types';\nimport { HSL_HUE } from '#constants';\nimport { AlphaBaseClass } from './_AlphaBaseClass';\nexport class HueBaseClass extends AlphaBaseClass {\n    get angleUnit() {\n        if (this._h) {\n            const angleUnitMatch = this._h.match(HSL_HUE);\n            const angleUnit = angleUnitMatch.groups.units;\n            return angleUnit === ''\n                ? AnglesUnitEnum.NONE\n                : angleUnit;\n        }\n        return AnglesUnitEnum.NONE;\n    }\n}\n","import { COLORREGS, MAX_ALPHA, MAX_HUE, MAX_PCENT } from '#constants';\nimport { minmax, normalizeAlpha, normalizeHue, percent } from '#helpers';\nimport { hslToRgb, rgbToHsl } from '#color/translators';\nimport { CalcParser } from './_CalcParser';\nimport { HueBaseClass } from './baseClasses/_HueBaseClass';\nexport class HSLStringParser extends HueBaseClass {\n    constructor(colorString, getRGBObject) {\n        super();\n        const match = colorString.match(COLORREGS.HSL);\n        const groups = match.groups;\n        const { h_legacy, s_legacy, l_legacy, a_legacy, h, s, l, a, from, relative_h, relative_s, relative_l, relative_a } = groups;\n        if (from) {\n            const fromRGB = getRGBObject(from);\n            const fromHSL = rgbToHsl(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n            const fromHSLVars = {\n                h: fromHSL.H,\n                s: fromHSL.S,\n                l: fromHSL.L,\n                alpha: fromHSL.A\n            };\n            const H = new CalcParser('h', relative_h, fromHSLVars).result;\n            const S = new CalcParser('s', relative_s, fromHSLVars).result;\n            const L = new CalcParser('l', relative_l, fromHSLVars).result;\n            const rgb = hslToRgb(minmax(H, 0, MAX_HUE), minmax(S, 0, MAX_PCENT), minmax(L, 0, MAX_PCENT));\n            if (relative_a) {\n                const A = new CalcParser('alpha', relative_a, fromHSLVars).result;\n                rgb.A = minmax(A, 0, MAX_ALPHA);\n            }\n            this._rgb = rgb;\n        }\n        else {\n            this._h = h_legacy ?? h;\n            this._s = s_legacy ?? s;\n            this._l = l_legacy ?? l;\n            this._a = a_legacy ?? a;\n            const rgb = hslToRgb(normalizeHue(this._h), percent(this._s), percent(this._l));\n            if (this._a !== undefined) {\n                rgb.A = normalizeAlpha(this._a);\n            }\n            this._rgb = rgb;\n        }\n    }\n    static test(colorString) {\n        return COLORREGS.HSL.test(colorString);\n    }\n}\n","import { COLORREGS, MAX_ALPHA, MAX_HUE, MAX_PCENT } from '#constants';\nimport { minmax, normalizeAlpha, normalizeHue, percent } from '#helpers';\nimport { hwbToRgb, rgbToHwb } from '#color/translators';\nimport { CalcParser } from './_CalcParser';\nimport { HueBaseClass } from './baseClasses/_HueBaseClass';\nexport class HWBStringParser extends HueBaseClass {\n    constructor(colorString, getRGBObject) {\n        super();\n        const match = colorString.match(COLORREGS.HWB);\n        const groups = match.groups;\n        const { h, w, b, a, from, relative_h, relative_w, relative_b, relative_a } = groups;\n        if (from) {\n            const fromRGB = getRGBObject(from);\n            const fromHWB = rgbToHwb(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n            const fromHWBVars = {\n                h: fromHWB.H,\n                w: fromHWB.W,\n                b: fromHWB.B,\n                alpha: fromHWB.A\n            };\n            const H = new CalcParser('h', relative_h, fromHWBVars).result;\n            const W = new CalcParser('w', relative_w, fromHWBVars).result;\n            const B = new CalcParser('b', relative_b, fromHWBVars).result;\n            const rgb = hwbToRgb(minmax(H, 0, MAX_HUE), minmax(W, 0, MAX_PCENT), minmax(B, 0, MAX_PCENT));\n            if (relative_a) {\n                const A = new CalcParser('alpha', relative_a, fromHWBVars).result;\n                rgb.A = minmax(A, 0, MAX_ALPHA);\n            }\n            this._rgb = rgb;\n        }\n        else {\n            this._h = h;\n            this._w = w;\n            this._b = b;\n            this._a = a;\n            const rgb = hwbToRgb(normalizeHue(this._h), percent(this._w), percent(this._b));\n            if (this._a !== undefined) {\n                rgb.A = normalizeAlpha(this._a);\n            }\n            this._rgb = rgb;\n        }\n    }\n    static test(colorString) {\n        return COLORREGS.HWB.test(colorString);\n    }\n}\n","import { COLORREGS, MAX_ALPHA, MAX_LAB, MAX_PCENT, PCENT } from '#constants';\nimport { getBase125Number, minmax, normalizeAlpha, percent } from '#helpers';\nimport { labToRgb, rgbToLab } from '#color/translators';\nimport { CalcParser } from './_CalcParser';\nimport { AlphaBaseClass } from './baseClasses/_AlphaBaseClass';\nexport class CIELabStringParser extends AlphaBaseClass {\n    constructor(colorString, getRGBObject) {\n        super();\n        const match = colorString.match(COLORREGS.CIELab);\n        const groups = match.groups;\n        const { L, a, b, A, from, relative_L, relative_a, relative_b, relative_A } = groups;\n        if (from) {\n            const fromRGB = getRGBObject(from);\n            const fromLab = rgbToLab(fromRGB.R, fromRGB.G, fromRGB.B);\n            const fromLabVars = {\n                l: fromLab.L,\n                a: fromLab.a,\n                b: fromLab.b,\n                alpha: fromRGB.A ?? 1\n            };\n            const L = new CalcParser('l', relative_L, fromLabVars).result;\n            const a = new CalcParser('a', relative_a, fromLabVars).result;\n            const b = new CalcParser('b', relative_b, fromLabVars).result;\n            const rgb = labToRgb(minmax(L, 0, MAX_PCENT), minmax(a, -MAX_LAB, MAX_LAB), minmax(b, -MAX_LAB, MAX_LAB));\n            if (relative_A) {\n                const A = new CalcParser('alpha', relative_A, fromLabVars).result;\n                rgb.A = minmax(A, 0, MAX_ALPHA);\n            }\n            this._rgb = rgb;\n        }\n        else {\n            this._L = L;\n            this._A = a;\n            this._B = b;\n            this._a = A;\n            const rgb = labToRgb(percent(this._L), getBase125Number(this._A), getBase125Number(this._B));\n            if (this._a !== undefined) {\n                rgb.A = normalizeAlpha(this._a);\n            }\n            this._rgb = rgb;\n        }\n    }\n    get hasPercentageValues() {\n        return (PCENT.test(this._L) &&\n            PCENT.test(this._A) &&\n            PCENT.test(this._B));\n    }\n    static test(colorString) {\n        return COLORREGS.CIELab.test(colorString);\n    }\n}\n","import { COLORREGS, MAX_ALPHA, MAX_LCH_C, MAX_PCENT, PCENT } from '#constants';\nimport { getBase150Number, minmax, normalizeAlpha, normalizeHue, percent } from '#helpers';\nimport { lchToRgb, rgbToLch } from '#color/translators';\nimport { CalcParser } from './_CalcParser';\nimport { HueBaseClass } from './baseClasses/_HueBaseClass';\nexport class LCHStringParser extends HueBaseClass {\n    constructor(colorString, getRGBObject) {\n        super();\n        const match = colorString.match(COLORREGS.LCH);\n        const groups = match.groups;\n        const { l, c, h, a, from, relative_l, relative_c, relative_h, relative_a } = groups;\n        if (from) {\n            const fromRGB = getRGBObject(from);\n            const fromLCH = rgbToLch(fromRGB.R, fromRGB.G, fromRGB.B);\n            const fromLCHVars = {\n                l: fromLCH.L,\n                c: fromLCH.C,\n                h: fromLCH.H,\n                alpha: fromRGB.A ?? 1\n            };\n            const L = new CalcParser('l', relative_l, fromLCHVars).result;\n            const C = new CalcParser('c', relative_c, fromLCHVars).result;\n            const H = new CalcParser('h', relative_h, fromLCHVars).result;\n            const rgb = lchToRgb(minmax(L, 0, MAX_PCENT), minmax(C, -MAX_LCH_C, MAX_LCH_C), normalizeHue(H));\n            if (relative_a) {\n                const A = new CalcParser('alpha', relative_a, fromLCHVars).result;\n                rgb.A = minmax(A, 0, MAX_ALPHA);\n            }\n            this._rgb = rgb;\n        }\n        else {\n            this._l = l;\n            this._c = c;\n            this._h = h;\n            this._a = a;\n            const rgb = lchToRgb(percent(this._l), getBase150Number(this._c), normalizeHue(this._h));\n            if (this._a !== undefined) {\n                rgb.A = normalizeAlpha(this._a);\n            }\n            this._rgb = rgb;\n        }\n    }\n    get hasPercentageValues() {\n        return (PCENT.test(this._l) &&\n            PCENT.test(this._c));\n    }\n    static test(colorString) {\n        return COLORREGS.LCH.test(colorString);\n    }\n}\n","import { COLORREGS, PCENT } from '#constants';\nimport { getCMYKNumber, normalizeAlpha } from '#helpers';\nimport { cmykToRgb } from '#color/translators';\nimport { AlphaBaseClass } from './baseClasses/_AlphaBaseClass';\nexport class CMYKStringParser extends AlphaBaseClass {\n    constructor(colorString) {\n        super();\n        const match = colorString.match(COLORREGS.CMYK);\n        const groups = match.groups;\n        this._c = groups.c_legacy ?? groups.c;\n        this._m = groups.m_legacy ?? groups.m;\n        this._y = groups.y_legacy ?? groups.y;\n        this._k = groups.k_legacy ?? groups.k;\n        this._a = groups.a_legacy ?? groups.a;\n        const rgb = cmykToRgb(getCMYKNumber(this._c), getCMYKNumber(this._m), getCMYKNumber(this._y), getCMYKNumber(this._k));\n        if (this._a !== undefined) {\n            rgb.A = normalizeAlpha(this._a);\n        }\n        this._rgb = rgb;\n    }\n    get hasPercentageValues() {\n        return (PCENT.test(this._c) &&\n            PCENT.test(this._m) &&\n            PCENT.test(this._y) &&\n            PCENT.test(this._k));\n    }\n    static test(colorString) {\n        return COLORREGS.CMYK.test(colorString);\n    }\n}\n","export { HEXStringParser } from './_HEXStringParser';\nexport { RGBStringParser } from './_RGBStringParser';\nexport { HSLStringParser } from './_HSLStringParser';\nexport { HWBStringParser } from './_HWBStringParser';\nexport { CIELabStringParser } from './_CIELabStringParser';\nexport { LCHStringParser } from './_LCHStringParser';\nexport { CMYKStringParser } from './_CMYKStringParser';\n","import { AnglesUnitEnum, CMYKFunctionEnum, ColorUnitEnum } from '@types';\nimport { BASE_255, COLOR_KEYS, ColorKeywords, ColorModel, COLORREGS, COMMAS_AND_NEXT_CHARS, DEFAULT_OPTIONS, ERRORS, HEX, PCENT, SPACES, TypeOf, VALID_COLOR_OBJECTS } from '#constants';\nimport { getBase125Number, getBase150Number, getBase255Number, getCMYKNumber, getOrderedArrayString, hasProp, normalizeAlpha, normalizeHue, percent } from '#helpers';\nimport { CIELabStringParser, CMYKStringParser, HEXStringParser, HSLStringParser, HWBStringParser, LCHStringParser, RGBStringParser } from '#parsers';\nimport { cmykToRgb, hslToRgb, hwbToRgb, labToRgb, lchToRgb } from '#color/translators';\nconst getColorModelFromString = (color) => {\n    let model;\n    Object.keys(ColorModel).some((p) => {\n        const reg = COLORREGS[p];\n        if (reg.test(color)) {\n            model = p;\n            return true;\n        }\n    });\n    if (!model &&\n        !!~COLOR_KEYS.indexOf(color)) {\n        model = ColorModel.HEX;\n    }\n    if (!model) {\n        throw new Error(ERRORS.NOT_ACCEPTED_STRING_INPUT);\n    }\n    return model;\n};\nconst getColorModelFromObject = (color) => {\n    let model;\n    let invalid = false;\n    const props = getOrderedArrayString(Object.keys(color));\n    if (VALID_COLOR_OBJECTS[props]) {\n        model = VALID_COLOR_OBJECTS[props];\n    }\n    if (model && model === ColorModel.RGB) {\n        const hasInvalidHex = Object.entries(color).some((item) => {\n            return !HEX.test(`${item[1]}`);\n        });\n        const hasInvalidRegb = Object.entries(color).some((item) => {\n            return !(PCENT.test(`${item[1]}`) ||\n                (!HEX.test(`${item[1]}`) &&\n                    !isNaN(+item[1]) &&\n                    +item[1] <= BASE_255));\n        });\n        if (hasInvalidHex && hasInvalidRegb) {\n            invalid = true;\n        }\n        if (!hasInvalidHex) {\n            model = ColorModel.HEX;\n        }\n    }\n    if (!model || invalid) {\n        throw new Error(ERRORS.NOT_ACCEPTED_OBJECT_INPUT);\n    }\n    return model;\n};\nexport const getColorModel = (color) => typeof color === 'string'\n    ? getColorModelFromString(color)\n    : getColorModelFromObject(color);\nexport const getRGBObjectFromString = {\n    [ColorModel.HEX](color) {\n        const colorStr = !~COLOR_KEYS.indexOf(color)\n            ? color\n            : ColorKeywords[color];\n        return new HEXStringParser(colorStr).rgb;\n    },\n    [ColorModel.RGB](color) {\n        return new RGBStringParser(color, getRGBObject).rgb;\n    },\n    [ColorModel.HSL](color) {\n        return new HSLStringParser(color, getRGBObject).rgb;\n    },\n    [ColorModel.HWB](color) {\n        return new HWBStringParser(color, getRGBObject).rgb;\n    },\n    [ColorModel.CIELab](color) {\n        return new CIELabStringParser(color, getRGBObject).rgb;\n    },\n    [ColorModel.LCH](color) {\n        return new LCHStringParser(color, getRGBObject).rgb;\n    },\n    [ColorModel.CMYK](color) {\n        return new CMYKStringParser(color).rgb;\n    }\n};\nexport const getRGBObjectFromObject = {\n    [ColorModel.HEX](color) {\n        const object = {\n            R: getBase255Number(`${color.R}`),\n            G: getBase255Number(`${color.G}`),\n            B: getBase255Number(`${color.B}`)\n        };\n        if (hasProp(color, 'A')) {\n            object.A = Math.min(getBase255Number(`${color.A}`, true), 1);\n        }\n        return object;\n    },\n    [ColorModel.RGB](color) {\n        return this.HEX(color);\n    },\n    [ColorModel.HSL](color) {\n        const S = percent(`${color.S}`);\n        const L = percent(`${color.L}`);\n        const RGB = hslToRgb(normalizeHue(color.H), S, L);\n        if (hasProp(color, 'A')) {\n            RGB.A = normalizeAlpha(color.A);\n        }\n        return RGB;\n    },\n    [ColorModel.HWB](color) {\n        const W = percent(`${color.W}`);\n        const B = percent(`${color.B}`);\n        const RGB = hwbToRgb(normalizeHue(color.H), W, B);\n        if (hasProp(color, 'A')) {\n            RGB.A = normalizeAlpha(color.A);\n        }\n        return RGB;\n    },\n    [ColorModel.CIELab](color) {\n        const L = percent(`${color.L}`);\n        const a = getBase125Number(`${color.a}`);\n        const b = getBase125Number(`${color.b}`);\n        const RGB = labToRgb(L, a, b);\n        if (hasProp(color, 'A')) {\n            RGB.A = normalizeAlpha(color.A);\n        }\n        return RGB;\n    },\n    [ColorModel.LCH](color) {\n        const L = percent(`${color.L}`);\n        const C = getBase150Number(`${color.C}`);\n        const H = normalizeHue(`${color.H}`);\n        const RGB = lchToRgb(L, C, H);\n        if (hasProp(color, 'A')) {\n            RGB.A = normalizeAlpha(color.A);\n        }\n        return RGB;\n    },\n    [ColorModel.CMYK](color) {\n        const C = getCMYKNumber(`${color.C}`);\n        const M = getCMYKNumber(`${color.M}`);\n        const Y = getCMYKNumber(`${color.Y}`);\n        const K = getCMYKNumber(`${color.K}`);\n        const RGB = cmykToRgb(C, M, Y, K);\n        if (hasProp(color, 'A')) {\n            RGB.A = normalizeAlpha(color.A);\n        }\n        return RGB;\n    }\n};\nexport const getRGBObject = (color, model = getColorModel(color)) => {\n    return typeof color === 'string'\n        ? getRGBObjectFromString[model](color)\n        : getRGBObjectFromObject[model](color);\n};\nexport const getOptionsFromColorInput = (options, ...colors) => {\n    const cssColors = [];\n    const anglesUnits = [];\n    const rgbColors = [];\n    const labColors = [];\n    const lchColors = [];\n    const cmykColors = [];\n    const alphaValues = [];\n    const anglesUnitValues = Object.values(AnglesUnitEnum);\n    const colorUnitValues = Object.values(ColorUnitEnum);\n    const cmykFunctionValues = Object.values(CMYKFunctionEnum);\n    const matchOptions = {\n        legacyCSS: 0,\n        spacesAfterCommas: 0,\n        cmykFunction: 0\n    };\n    for (const color of colors) {\n        if (typeof color === 'string') {\n            cssColors.push(color);\n            if (color.includes(',')) {\n                matchOptions.legacyCSS++;\n                const commasWithNextCharacter = color.match(COMMAS_AND_NEXT_CHARS);\n                if (new Set(commasWithNextCharacter).size === 1 &&\n                    SPACES.test(commasWithNextCharacter[0].slice(1))) {\n                    matchOptions.spacesAfterCommas++;\n                }\n            }\n            if (HSLStringParser.test(color)) {\n                const parser = new HSLStringParser(color, getRGBObject);\n                anglesUnits.push(parser.angleUnit);\n                alphaValues.push(parser.hasPercentageAlpha);\n                continue;\n            }\n            if (HWBStringParser.test(color)) {\n                const parser = new HWBStringParser(color, getRGBObject);\n                anglesUnits.push(parser.angleUnit);\n                alphaValues.push(parser.hasPercentageAlpha);\n                continue;\n            }\n            if (RGBStringParser.test(color)) {\n                const parser = new RGBStringParser(color, getRGBObject);\n                rgbColors.push(parser.hasPercentageValues);\n                alphaValues.push(parser.hasPercentageAlpha);\n                continue;\n            }\n            if (CIELabStringParser.test(color)) {\n                const parser = new CIELabStringParser(color, getRGBObject);\n                labColors.push(parser.hasPercentageValues);\n                alphaValues.push(parser.hasPercentageAlpha);\n                continue;\n            }\n            if (LCHStringParser.test(color)) {\n                const parser = new LCHStringParser(color, getRGBObject);\n                anglesUnits.push(parser.angleUnit);\n                lchColors.push(parser.hasPercentageValues);\n                alphaValues.push(parser.hasPercentageAlpha);\n                continue;\n            }\n            if (CMYKStringParser.test(color)) {\n                const parser = new CMYKStringParser(color);\n                cmykColors.push(parser.hasPercentageValues);\n                if (color.startsWith('cmyk')) {\n                    matchOptions.cmykFunction++;\n                }\n                alphaValues.push(parser.hasPercentageAlpha);\n            }\n        }\n    }\n    return {\n        decimals: typeof options.decimals === TypeOf.NUMBER\n            ? options.decimals\n            : DEFAULT_OPTIONS.decimals,\n        legacyCSS: typeof options.legacyCSS === TypeOf.BOOLEAN\n            ? options.legacyCSS\n            : Boolean(cssColors.length &&\n                matchOptions.legacyCSS === cssColors.length) || DEFAULT_OPTIONS.legacyCSS,\n        spacesAfterCommas: typeof options.spacesAfterCommas === TypeOf.BOOLEAN\n            ? options.spacesAfterCommas\n            : Boolean(cssColors.length &&\n                matchOptions.spacesAfterCommas === cssColors.length) || DEFAULT_OPTIONS.spacesAfterCommas,\n        anglesUnit: options.anglesUnit && anglesUnitValues.includes(options.anglesUnit)\n            ? options.anglesUnit\n            : (new Set(anglesUnits).size === 1\n                ? anglesUnits[0]\n                : DEFAULT_OPTIONS.anglesUnit),\n        rgbUnit: options.rgbUnit && colorUnitValues.includes(options.rgbUnit)\n            ? options.rgbUnit\n            : (new Set(rgbColors).size === 1 && rgbColors[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.rgbUnit),\n        labUnit: options.labUnit && colorUnitValues.includes(options.labUnit)\n            ? options.labUnit\n            : (new Set(labColors).size === 1 && labColors[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.labUnit),\n        lchUnit: options.lchUnit && colorUnitValues.includes(options.lchUnit)\n            ? options.lchUnit\n            : (new Set(lchColors).size === 1 && lchColors[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.lchUnit),\n        cmykUnit: options.cmykUnit && colorUnitValues.includes(options.cmykUnit)\n            ? options.cmykUnit\n            : (new Set(cmykColors).size === 1 && !cmykColors[0]\n                ? ColorUnitEnum.NONE\n                : DEFAULT_OPTIONS.cmykUnit),\n        alphaUnit: options.alphaUnit && colorUnitValues.includes(options.alphaUnit)\n            ? options.alphaUnit\n            : (new Set(alphaValues).size === 1 && alphaValues[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.alphaUnit),\n        cmykFunction: options.cmykFunction && cmykFunctionValues.includes(options.cmykFunction)\n            ? options.cmykFunction\n            : (cmykColors.length && cmykColors.length === matchOptions.cmykFunction\n                ? CMYKFunctionEnum.CMYK\n                : DEFAULT_OPTIONS.cmykFunction)\n    };\n};\n","import { round } from '#helpers';\nexport const roundHSLObject = (color, decimals) => {\n    return {\n        H: round(color.H, decimals),\n        S: round(color.S, decimals),\n        L: round(color.L, decimals)\n    };\n};\nexport const roundHWBObject = (color, decimals) => {\n    return {\n        H: round(color.H, decimals),\n        W: round(color.W, decimals),\n        B: round(color.B, decimals)\n    };\n};\nexport const roundCIELabObject = (color, decimals) => {\n    return {\n        L: round(color.L, decimals),\n        a: round(color.a, decimals),\n        b: round(color.b, decimals)\n    };\n};\nexport const roundLCHObject = (color, decimals) => {\n    return {\n        L: round(color.L, decimals),\n        C: round(color.C, decimals),\n        H: round(color.H, decimals)\n    };\n};\nexport const roundCMYKObject = (color, decimals) => {\n    return {\n        C: round(color.C, decimals),\n        M: round(color.M, decimals),\n        Y: round(color.Y, decimals),\n        K: round(color.K, decimals)\n    };\n};\n","import { AnglesUnitEnum, ColorUnitEnum } from '@types';\nimport { COLOR_PROPS, ColorModel, TEMPLATE_VAR, VALID_COLOR_OBJECTS } from '#constants';\nimport { from125NumberToPercent, from150NumberToPercent, from255NumberToPercent, getOrderedArrayString, percent, round, toHEX, translateDegrees } from '#helpers';\nconst getComma = (withSpace) => withSpace\n    ? ', '\n    : ',';\nconst prepareColorForCss = (color, transformer) => {\n    const props = getOrderedArrayString(Object.keys(color));\n    const model = VALID_COLOR_OBJECTS[props];\n    const keys = COLOR_PROPS[model];\n    return keys.reduce((result, key, index) => {\n        const value = color[key];\n        if (typeof value !== 'undefined') {\n            result.push(transformer(value, index));\n        }\n        return result;\n    }, []);\n};\nconst getResultFromTemplate = (template, vars) => {\n    return template.replace(TEMPLATE_VAR, (__match, indexStr) => {\n        const index = +indexStr - 1;\n        return `${vars[index]}`;\n    });\n};\nconst getAlpha = (value, options, ignoreLegacy = false) => {\n    const { alphaUnit, legacyCSS, decimals } = options;\n    if (alphaUnit === ColorUnitEnum.PERCENT &&\n        (!legacyCSS ||\n            ignoreLegacy)) {\n        return `${round(value * 100, decimals)}%`;\n    }\n    return round(value, decimals);\n};\nconst buildHueTransformer = (options) => {\n    const { anglesUnit, decimals } = options;\n    return (value, index) => {\n        if (index === 0 &&\n            anglesUnit !== AnglesUnitEnum.NONE) {\n            const translated = round(translateDegrees(value, anglesUnit), decimals);\n            return `${translated}${anglesUnit}`;\n        }\n        return index === 3\n            ? getAlpha(value, options)\n            : round(value, decimals);\n    };\n};\nexport const CSS = {\n    [ColorModel.HEX]: (color) => {\n        const transformer = (value) => toHEX(round(value));\n        const values = prepareColorForCss(color, transformer);\n        const template = values.length === 4\n            ? '#{1}{2}{3}{4}'\n            : '#{1}{2}{3}';\n        return getResultFromTemplate(template, values);\n    },\n    [ColorModel.RGB]: (color, options) => {\n        const { decimals, legacyCSS, spacesAfterCommas, rgbUnit } = options;\n        const comma = getComma(spacesAfterCommas);\n        const transformer = (value, index) => {\n            return rgbUnit === ColorUnitEnum.PERCENT && index < 3\n                ? `${from255NumberToPercent(value, decimals)}%`\n                : (index === 3\n                    ? getAlpha(value, options)\n                    : round(value, decimals));\n        };\n        const values = prepareColorForCss(color, transformer);\n        const template = legacyCSS\n            ? (values.length === 4\n                ? `rgba({1}${comma}{2}${comma}{3}${comma}{4})`\n                : `rgb({1}${comma}{2}${comma}{3})`)\n            : (values.length === 4\n                ? `rgb({1} {2} {3} / {4})`\n                : `rgb({1} {2} {3})`);\n        return getResultFromTemplate(template, values);\n    },\n    [ColorModel.HSL]: (color, options) => {\n        const { legacyCSS, spacesAfterCommas } = options;\n        const comma = getComma(spacesAfterCommas);\n        const transformer = buildHueTransformer(options);\n        const values = prepareColorForCss(color, transformer);\n        const template = legacyCSS\n            ? (values.length === 4\n                ? `hsla({1}${comma}{2}%${comma}{3}%${comma}{4})`\n                : `hsl({1}${comma}{2}%${comma}{3}%)`)\n            : (values.length === 4\n                ? `hsl({1} {2}% {3}% / {4})`\n                : `hsl({1} {2}% {3}%)`);\n        return getResultFromTemplate(template, values);\n    },\n    [ColorModel.HWB]: (color, options) => {\n        const transformer = buildHueTransformer(options);\n        const values = prepareColorForCss(color, transformer);\n        const template = values.length === 4\n            ? `hwb({1} {2}% {3}% / {4})`\n            : `hwb({1} {2}% {3}%)`;\n        return getResultFromTemplate(template, values);\n    },\n    [ColorModel.CIELab]: (color, options) => {\n        const { decimals, labUnit } = options;\n        const transformer = (value, index) => {\n            if (index === 0) {\n                const L = round(percent(value), decimals);\n                return labUnit === ColorUnitEnum.PERCENT\n                    ? `${L}%`\n                    : `${L}`;\n            }\n            if (index < 3) {\n                return labUnit === ColorUnitEnum.PERCENT\n                    ? `${from125NumberToPercent(value, decimals)}%`\n                    : round(value, decimals);\n            }\n            return getAlpha(value, options, true);\n        };\n        const values = prepareColorForCss(color, transformer);\n        const template = values.length === 4\n            ? `lab({1} {2} {3} / {4})`\n            : `lab({1} {2} {3})`;\n        return getResultFromTemplate(template, values);\n    },\n    [ColorModel.LCH]: (color, options) => {\n        const { decimals, lchUnit, anglesUnit } = options;\n        const transformer = (value, index) => {\n            if (index === 0) {\n                const L = round(percent(value), decimals);\n                return lchUnit === ColorUnitEnum.PERCENT\n                    ? `${L}%`\n                    : `${L}`;\n            }\n            if (index === 1) {\n                return lchUnit === ColorUnitEnum.PERCENT\n                    ? `${from150NumberToPercent(value, decimals)}%`\n                    : round(value, decimals);\n            }\n            if (index === 2) {\n                if (anglesUnit !== AnglesUnitEnum.NONE) {\n                    const translated = round(translateDegrees(value, anglesUnit), decimals);\n                    return `${translated}${anglesUnit}`;\n                }\n                return round(value, decimals);\n            }\n            return getAlpha(value, options, true);\n        };\n        const values = prepareColorForCss(color, transformer);\n        const template = values.length === 4\n            ? `lch({1} {2} {3} / {4})`\n            : `lch({1} {2} {3})`;\n        return getResultFromTemplate(template, values);\n    },\n    [ColorModel.CMYK]: (color, options) => {\n        const { decimals, legacyCSS, spacesAfterCommas, cmykUnit, cmykFunction } = options;\n        const comma = getComma(spacesAfterCommas);\n        const transformer = (value, index) => {\n            if (cmykUnit === ColorUnitEnum.PERCENT &&\n                index < 4) {\n                return `${round(value, decimals)}%`;\n            }\n            return index === 4\n                ? getAlpha(value, options)\n                : round(value / 100, decimals);\n        };\n        const values = prepareColorForCss(color, transformer);\n        const template = legacyCSS\n            ? (values.length === 5\n                ? `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4}${comma}{5})`\n                : `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4})`)\n            : (values.length === 5\n                ? `${cmykFunction}({1} {2} {3} {4} / {5})`\n                : `${cmykFunction}({1} {2} {3} {4})`);\n        return getResultFromTemplate(template, values);\n    }\n};\n","import { BASE_255, ColorModel, Mix } from '#constants';\nimport { getHEX, hasProp, minmax, normalizeAlpha, normalizeHue, round } from '#helpers';\nimport { hslToRgb, hueRyb, rgbToCmyk, rgbToHsl, rgbToHwb, rgbToLab, rgbToLch, rgbToRyb, rybToRgb } from '#color/translators';\nimport { getColorModel, getRGBObject } from './extractors';\nimport { roundCIELabObject, roundCMYKObject, roundHSLObject, roundHWBObject, roundLCHObject } from './rounders';\nimport { CSS } from '#color/css';\nconst harmony = (color, angles, mode) => angles.reduce((arr, num) => ([\n    ...arr,\n    {\n        ...color,\n        H: mode === Mix.ADDITIVE\n            ? normalizeHue(color.H + num)\n            : normalizeHue(hueRyb(hueRyb(color.H, false) + num, true))\n    }\n]), [{ ...color }]);\nexport const analogous = (color, mode) => harmony(color, [30, -30], mode);\nexport const complementary = (color, mode) => harmony(color, [180], mode);\nexport const splitComplementary = (color, mode) => harmony(color, [150, -150], mode);\nexport const triadic = (color, mode) => harmony(color, [120, -120], mode);\nexport const tetradic = (color, mode) => harmony(color, [60, -120, 180], mode);\nexport const square = (color, mode) => harmony(color, [90, -90, 180], mode);\nexport const translateColor = {\n    [ColorModel.HEX](color) {\n        return {\n            R: getHEX(color.R),\n            G: getHEX(color.G),\n            B: getHEX(color.B)\n        };\n    },\n    HEXA(color) {\n        const RGB = translateColor.HEX(color);\n        RGB.A = hasProp(color, 'A')\n            ? getHEX(color.A * BASE_255)\n            : '0xFF';\n        return RGB;\n    },\n    [ColorModel.RGB](color, decimals) {\n        const RGB = roundRGBObject(color, decimals);\n        if (hasProp(RGB, 'A')) {\n            delete RGB.A;\n        }\n        return RGB;\n    },\n    RGBA(color, decimals) {\n        const RGB = translateColor.RGB(color, decimals);\n        RGB.A = hasProp(color, 'A')\n            ? round(color.A)\n            : 1;\n        return RGB;\n    },\n    [ColorModel.HSL](color, decimals) {\n        const HSL = rgbToHsl(color.R, color.G, color.B);\n        delete HSL.A;\n        return roundHSLObject(HSL, decimals);\n    },\n    HSLA(color, decimals) {\n        const HSL = translateColor.HSL(color, decimals);\n        HSL.A = hasProp(color, 'A')\n            ? round(color.A, decimals)\n            : 1;\n        return HSL;\n    },\n    [ColorModel.HWB](color, decimals) {\n        const HWB = rgbToHwb(color.R, color.G, color.B);\n        delete HWB.A;\n        return roundHWBObject(HWB, decimals);\n    },\n    HWBA(color, decimals) {\n        const HWB = translateColor.HWB(color, decimals);\n        HWB.A = hasProp(color, 'A')\n            ? round(color.A, decimals)\n            : 1;\n        return HWB;\n    },\n    [ColorModel.CIELab](color, decimals) {\n        const Lab = rgbToLab(color.R, color.G, color.B);\n        return roundCIELabObject(Lab, decimals);\n    },\n    CIELabA(color, decimals) {\n        const Lab = translateColor.CIELab(color, decimals);\n        Lab.A = hasProp(color, 'A')\n            ? round(color.A, decimals)\n            : 1;\n        return Lab;\n    },\n    [ColorModel.LCH](color, decimals) {\n        const lch = rgbToLch(color.R, color.G, color.B);\n        return roundLCHObject(lch, decimals);\n    },\n    LCHA(color, decimals) {\n        const lch = translateColor.LCH(color, decimals);\n        lch.A = hasProp(color, 'A')\n            ? round(color.A, decimals)\n            : 1;\n        return lch;\n    },\n    [ColorModel.CMYK](color, decimals) {\n        return roundCMYKObject(rgbToCmyk(color.R, color.G, color.B), decimals);\n    },\n    CMYKA(color, decimals) {\n        const CMYK = translateColor.CMYK(color, decimals);\n        CMYK.A = hasProp(color, 'A')\n            ? round(color.A, decimals)\n            : 1;\n        return CMYK;\n    }\n};\nexport const blend = (from, to, steps) => {\n    const div = steps - 1;\n    const diffR = (to.R - from.R) / div;\n    const diffG = (to.G - from.G) / div;\n    const diffB = (to.B - from.B) / div;\n    const fromA = normalizeAlpha(from.A);\n    const toA = normalizeAlpha(to.A);\n    const diffA = (toA - fromA) / div;\n    return Array(steps).fill(null).map((__n, i) => {\n        if (i === 0) {\n            return from;\n        }\n        if (i === div) {\n            return to;\n        }\n        return {\n            R: round(from.R + diffR * i),\n            G: round(from.G + diffG * i),\n            B: round(from.B + diffB * i),\n            A: round(fromA + diffA * i)\n        };\n    });\n};\nexport const getColorMixture = (color, steps, shades, options) => {\n    const model = getColorModel(color);\n    const isCSS = typeof color === 'string';\n    const RGB = getRGBObject(color, model);\n    const hasAlpha = ((typeof color === 'string' && hasProp(RGB, 'A')) ||\n        (typeof color !== 'string' &&\n            hasProp(color, 'A')));\n    const HSL = rgbToHsl(RGB.R, RGB.G, RGB.B, RGB.A);\n    if (!hasAlpha)\n        delete HSL.A;\n    const increment = shades\n        ? HSL.L / (steps + 1)\n        : (100 - HSL.L) / (steps + 1);\n    const hslMap = Array(steps).fill(null).map((__n, i) => ({\n        ...HSL,\n        L: HSL.L + increment * (i + 1) * (1 - +shades * 2)\n    }));\n    switch (model) {\n        case ColorModel.HEX:\n        default:\n            return hslMap.map((HSLColor) => {\n                const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n                if (hasAlpha)\n                    RGBColor.A = HSLColor.A;\n                return isCSS\n                    ? hasAlpha\n                        ? CSS.HEX({\n                            ...RGBColor,\n                            A: round(RGBColor.A * BASE_255)\n                        })\n                        : CSS.HEX(RGBColor)\n                    : hasAlpha\n                        ? translateColor.HEXA(RGBColor)\n                        : translateColor.HEX(RGBColor);\n            });\n        case ColorModel.RGB:\n            return hslMap.map((HSLColor) => {\n                const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n                if (hasAlpha)\n                    RGBColor.A = HSLColor.A;\n                return isCSS\n                    ? CSS.RGB(RGBColor, options)\n                    : hasAlpha\n                        ? translateColor.RGBA(RGBColor, options.decimals)\n                        : translateColor.RGB(RGBColor, options.decimals);\n                ;\n            });\n        case ColorModel.HSL:\n            return hslMap.map((HSLColor) => {\n                return isCSS\n                    ? CSS.HSL(HSLColor, options)\n                    : hasAlpha\n                        ? translateColor.HSLA({\n                            ...hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L),\n                            A: HSLColor.A\n                        }, options.decimals)\n                        : translateColor.HSL(hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L), options.decimals);\n            });\n        case ColorModel.HWB:\n            return hslMap.map((HSLColor) => {\n                const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n                if (hasAlpha)\n                    RGBColor.A = HSLColor.A;\n                const hwb = hasAlpha\n                    ? translateColor.HWBA(RGBColor, options.decimals)\n                    : translateColor.HWB(RGBColor, options.decimals);\n                return isCSS\n                    ? CSS.HWB(hwb, options)\n                    : hwb;\n            });\n        case ColorModel.CIELab:\n            return hslMap.map((HSLColor) => {\n                const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n                if (hasAlpha)\n                    RGBColor.A = HSLColor.A;\n                const lab = hasAlpha\n                    ? translateColor.CIELabA(RGBColor, options.decimals)\n                    : translateColor.CIELab(RGBColor, options.decimals);\n                return isCSS\n                    ? CSS.CIELab(lab, options)\n                    : lab;\n            });\n        case ColorModel.LCH:\n            return hslMap.map((HSLColor) => {\n                const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L);\n                const LCHColor = rgbToLch(RGBColor.R, RGBColor.G, RGBColor.B);\n                if (hasAlpha)\n                    LCHColor.A = HSLColor.A;\n                return isCSS\n                    ? CSS.LCH(LCHColor, options)\n                    : hasAlpha\n                        ? translateColor.LCHA({\n                            ...RGBColor,\n                            A: HSLColor.A\n                        }, options.decimals)\n                        : translateColor.LCH(RGBColor, options.decimals);\n            });\n    }\n};\nexport const colorHarmony = {\n    buildHarmony(color, harmonyFunction, mode, options) {\n        const model = getColorModel(color);\n        const RGB = getRGBObject(color, model);\n        const HSL = rgbToHsl(RGB.R, RGB.G, RGB.B, RGB.A);\n        const hasAlpha = ((typeof color === 'string' && hasProp(RGB, 'A')) ||\n            (typeof color !== 'string' &&\n                hasProp(color, 'A')));\n        const isCSS = typeof color === 'string';\n        switch (model) {\n            case ColorModel.HEX:\n            default:\n                return hasAlpha\n                    ? this.HEXA(roundHSLObject(HSL, 0), harmonyFunction, mode, isCSS)\n                    : this.HEX(roundHSLObject(HSL, 0), harmonyFunction, mode, isCSS);\n            case ColorModel.HSL:\n                return hasAlpha\n                    ? this.HSLA(HSL, harmonyFunction, mode, isCSS, options)\n                    : this.HSL(HSL, harmonyFunction, mode, isCSS, options);\n            case ColorModel.HWB:\n                return hasAlpha\n                    ? this.HWBA(HSL, harmonyFunction, mode, isCSS, options)\n                    : this.HWB(HSL, harmonyFunction, mode, isCSS, options);\n            case ColorModel.RGB:\n                return hasAlpha\n                    ? this.RGBA(HSL, harmonyFunction, mode, isCSS, options)\n                    : this.RGB(HSL, harmonyFunction, mode, isCSS, options);\n            case ColorModel.CIELab:\n                return hasAlpha\n                    ? this.CIELabA(HSL, harmonyFunction, mode, isCSS, options)\n                    : this.CIELab(HSL, harmonyFunction, mode, isCSS, options);\n            case ColorModel.LCH:\n                return hasAlpha\n                    ? this.LCHA(HSL, harmonyFunction, mode, isCSS, options)\n                    : this.LCH(HSL, harmonyFunction, mode, isCSS, options);\n        }\n    },\n    [ColorModel.HEX](color, harmonyFunction, mode, css) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => (css\n            ? CSS.HEX(hslToRgb(c.H, c.S, c.L))\n            : translateColor.HEX(hslToRgb(c.H, c.S, c.L))));\n    },\n    HEXA(color, harmonyFunction, mode, css) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => (css\n            ? CSS.HEX({\n                ...hslToRgb(c.H, c.S, c.L),\n                A: normalizeAlpha(c.A) * BASE_255\n            })\n            : translateColor.HEXA({\n                ...hslToRgb(c.H, c.S, c.L),\n                A: normalizeAlpha(c.A)\n            })));\n    },\n    [ColorModel.RGB](color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => (css\n            ? CSS.RGB(hslToRgb(c.H, c.S, c.L), options)\n            : translateColor.RGB(hslToRgb(c.H, c.S, c.L), options.decimals)));\n    },\n    RGBA(color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => (css\n            ? CSS.RGB({\n                ...hslToRgb(c.H, c.S, c.L),\n                A: normalizeAlpha(c.A)\n            }, options)\n            : translateColor.RGBA({\n                ...hslToRgb(c.H, c.S, c.L),\n                A: normalizeAlpha(c.A)\n            }, options.decimals)));\n    },\n    [ColorModel.HSL](color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => (css\n            ? CSS.HSL({\n                H: c.H,\n                S: c.S,\n                L: c.L\n            }, options)\n            : translateColor.HSL(hslToRgb(c.H, c.S, c.L), options.decimals)));\n    },\n    HSLA(color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => (css\n            ? CSS.HSL({\n                ...c,\n                A: normalizeAlpha(c.A)\n            }, options)\n            : translateColor.HSLA({\n                ...hslToRgb(c.H, c.S, c.L),\n                A: normalizeAlpha(c.A)\n            }, options.decimals)));\n    },\n    [ColorModel.HWB](color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => {\n            const rgb = hslToRgb(c.H, c.S, c.L);\n            const hwb = rgbToHwb(rgb.R, rgb.G, rgb.B);\n            return css\n                ? CSS.HWB({\n                    H: hwb.H,\n                    W: hwb.W,\n                    B: hwb.B\n                }, options)\n                : translateColor.HWB(rgb, options.decimals);\n        });\n    },\n    HWBA(color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => {\n            const rgb = hslToRgb(c.H, c.S, c.L);\n            const hwb = rgbToHwb(rgb.R, rgb.G, rgb.B);\n            return css\n                ? CSS.HWB({\n                    ...hwb,\n                    A: normalizeAlpha(c.A)\n                }, options)\n                : translateColor.HWBA({\n                    ...rgb,\n                    A: normalizeAlpha(c.A)\n                }, options.decimals);\n        });\n    },\n    [ColorModel.CIELab](color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => {\n            const RGB = hslToRgb(c.H, c.S, c.L);\n            return (css\n                ? CSS.CIELab(rgbToLab(RGB.R, RGB.G, RGB.B), options)\n                : translateColor.CIELab(RGB, options.decimals));\n        });\n    },\n    CIELabA(color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => {\n            const RGB = hslToRgb(c.H, c.S, c.L);\n            return (css\n                ? CSS.CIELab({\n                    ...rgbToLab(RGB.R, RGB.G, RGB.B),\n                    A: normalizeAlpha(c.A)\n                }, options)\n                : translateColor.CIELabA({\n                    ...RGB,\n                    A: normalizeAlpha(c.A)\n                }, options.decimals));\n        });\n    },\n    [ColorModel.LCH](color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => {\n            const RGB = hslToRgb(c.H, c.S, c.L);\n            return (css\n                ? CSS.LCH(rgbToLch(RGB.R, RGB.G, RGB.B), options)\n                : translateColor.LCH(RGB, options.decimals));\n        });\n    },\n    LCHA(color, harmonyFunction, mode, css, options) {\n        const array = harmonyFunction(color, mode);\n        return array.map((c) => {\n            const RGB = hslToRgb(c.H, c.S, c.L);\n            return (css\n                ? CSS.LCH({\n                    ...rgbToLch(RGB.R, RGB.G, RGB.B),\n                    A: normalizeAlpha(c.A)\n                }, options)\n                : translateColor.LCHA({\n                    ...RGB,\n                    A: normalizeAlpha(c.A)\n                }, options.decimals));\n        });\n    }\n};\nexport const colorMixer = {\n    mix(colors, mode) {\n        const rgbMap = colors.map((color) => {\n            const model = getColorModel(color);\n            return getRGBObject(color, model);\n        });\n        const rybMap = mode === Mix.SUBTRACTIVE\n            ? rgbMap.map((color) => {\n                const RYB = rgbToRyb(color.R, color.G, color.B);\n                if (hasProp(color, 'A')) {\n                    RYB.A = color.A;\n                }\n                return RYB;\n            })\n            : null;\n        function createMix(items) {\n            const initial = mode === Mix.ADDITIVE\n                ? { R: 0, G: 0, B: 0, A: 0 }\n                : { R: 0, Y: 0, B: 0, A: 0 };\n            return items.reduce((mix, color) => {\n                const colorA = hasProp(color, 'A') ? color.A : 1;\n                const common = {\n                    R: Math.min(mix.R + color.R * colorA, BASE_255),\n                    B: Math.min(mix.B + color.B * colorA, BASE_255),\n                    A: 1 - (1 - colorA) * (1 - mix.A)\n                };\n                const mixGY = 'G' in mix\n                    ? mix.G\n                    : mix.Y;\n                const colorGY = 'G' in color\n                    ? color.G\n                    : color.Y;\n                return {\n                    ...common,\n                    ...(mode === Mix.ADDITIVE\n                        ? { G: Math.min(mixGY + colorGY * colorA, BASE_255) }\n                        : { Y: Math.min(mixGY + colorGY * colorA, BASE_255) })\n                };\n            }, initial);\n        }\n        let mix;\n        if (mode === Mix.ADDITIVE) {\n            mix = createMix(rgbMap);\n        }\n        else {\n            const RYB = createMix(rybMap);\n            mix = rybToRgb(RYB.R, RYB.Y, RYB.B);\n            mix.A = RYB.A;\n        }\n        return {\n            R: round(mix.R),\n            G: round(mix.G),\n            B: round(mix.B),\n            A: minmax(mix.A, 0, 1)\n        };\n    },\n    [ColorModel.HEX](colors, mode, css) {\n        const mix = this.mix(colors, mode);\n        delete mix.A;\n        return (css\n            ? CSS.HEX(mix)\n            : translateColor.HEX(mix));\n    },\n    HEXA(colors, mode, css) {\n        const mix = this.mix(colors, mode);\n        mix.A = css\n            ? normalizeAlpha(mix.A) * BASE_255\n            : normalizeAlpha(mix.A);\n        return (css\n            ? CSS.HEX(mix)\n            : translateColor.HEXA(mix));\n    },\n    [ColorModel.RGB](colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        delete mix.A;\n        return (css\n            ? CSS.RGB(mix, options)\n            : translateColor.RGB(mix, options.decimals));\n    },\n    RGBA(colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        return (css\n            ? CSS.RGB(mix, options)\n            : translateColor.RGBA(mix, options.decimals));\n    },\n    [ColorModel.HSL](colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const HSL = rgbToHsl(mix.R, mix.G, mix.B);\n        delete mix.A;\n        delete HSL.A;\n        return (css\n            ? CSS.HSL(HSL, options)\n            : translateColor.HSL(mix, options.decimals));\n    },\n    HSLA(colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const HSL = rgbToHsl(mix.R, mix.G, mix.B, mix.A);\n        return (css\n            ? CSS.HSL(HSL, options)\n            : translateColor.HSLA(mix, options.decimals));\n    },\n    [ColorModel.HWB](colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const HWB = rgbToHwb(mix.R, mix.G, mix.B);\n        delete mix.A;\n        delete HWB.A;\n        return (css\n            ? CSS.HWB(HWB, options)\n            : translateColor.HWB(mix, options.decimals));\n    },\n    HWBA(colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const HWB = rgbToHwb(mix.R, mix.G, mix.B, mix.A);\n        return (css\n            ? CSS.HWB(HWB, options)\n            : translateColor.HWBA(mix, options.decimals));\n    },\n    [ColorModel.CIELab](colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const Lab = rgbToLab(mix.R, mix.G, mix.B);\n        delete mix.A;\n        return (css\n            ? CSS.CIELab(Lab, options)\n            : translateColor.CIELab(mix, options.decimals));\n    },\n    CIELabA(colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const Lab = rgbToLab(mix.R, mix.G, mix.B);\n        Lab.A = mix.A;\n        return (css\n            ? CSS.CIELab(Lab, options)\n            : translateColor.CIELabA(mix, options.decimals));\n    },\n    [ColorModel.LCH](colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const lch = rgbToLch(mix.R, mix.G, mix.B);\n        delete mix.A;\n        return (css\n            ? CSS.LCH(lch, options)\n            : translateColor.LCH(mix, options.decimals));\n    },\n    LCHA(colors, mode, css, options) {\n        const mix = this.mix(colors, mode);\n        const lch = rgbToLch(mix.R, mix.G, mix.B);\n        lch.A = mix.A;\n        return (css\n            ? CSS.LCH(lch, options)\n            : translateColor.LCHA(mix, options.decimals));\n    }\n};\nexport const roundRGBObject = (color, decimals) => {\n    const R = round(color.R, decimals);\n    const G = round(color.G, decimals);\n    const B = round(color.B, decimals);\n    return {\n        R,\n        G,\n        B,\n        ...(hasProp(color, 'A')\n            ? {\n                A: round(color.A, decimals)\n            }\n            : {})\n    };\n};\n","import { DEFAULT_BLEND_STEPS, Harmony, Mix } from '#constants';\nimport * as utils from '#color/utils';\nimport { getOptionsFromColorInput, getRGBObject } from '#color/extractors';\nexport const getColorReturn = (color, model, decimals, translateFunction) => {\n    const rgbObject = getRGBObject(color, model);\n    return translateFunction(rgbObject, decimals);\n};\nexport const getBlendReturn = (from, to, steps, decimals, translateFunction) => {\n    if (steps < 1)\n        steps = DEFAULT_BLEND_STEPS;\n    const fromRGBObject = getRGBObject(from);\n    const toRGBObject = getRGBObject(to);\n    const blendArray = utils.blend(fromRGBObject, toRGBObject, steps);\n    return blendArray.map((color) => {\n        return translateFunction(color, decimals);\n    });\n};\nexport function getBlendReturnWithParameters(params) {\n    const { from, to, thirdParameter, fourthParameter, translateFunction, cssFunction } = params;\n    const result = typeof thirdParameter === 'number'\n        ? getBlendReturn(from, to, thirdParameter, fourthParameter?.decimals, translateFunction)\n        : getBlendReturn(from, to, DEFAULT_BLEND_STEPS, thirdParameter?.decimals, translateFunction);\n    if (cssFunction) {\n        return result.map((color) => cssFunction(color, getOptionsFromColorInput((typeof thirdParameter === 'number'\n            ? fourthParameter\n            : thirdParameter) ?? {}, from, to)));\n    }\n    return result;\n}\nexport function getMixReturn(params) {\n    const { colors, secondParameter, thirdParameter, colorMixerFunction, css } = params;\n    const options = getOptionsFromColorInput((typeof secondParameter === 'string'\n        ? thirdParameter\n        : secondParameter) ?? {}, ...colors);\n    if (typeof secondParameter === 'string') {\n        return colorMixerFunction(colors, secondParameter, css, options);\n    }\n    return colorMixerFunction(colors, Mix.ADDITIVE, css, options);\n}\nexport const getHarmonyReturn = (harmony, color, mode, options) => {\n    return ({\n        [Harmony.ANALOGOUS]: utils.colorHarmony.buildHarmony(color, utils.analogous, mode, options),\n        [Harmony.COMPLEMENTARY]: utils.colorHarmony.buildHarmony(color, utils.complementary, mode, options),\n        [Harmony.SPLIT_COMPLEMENTARY]: utils.colorHarmony.buildHarmony(color, utils.splitComplementary, mode, options),\n        [Harmony.TRIADIC]: utils.colorHarmony.buildHarmony(color, utils.triadic, mode, options),\n        [Harmony.TETRADIC]: utils.colorHarmony.buildHarmony(color, utils.tetradic, mode, options),\n        [Harmony.SQUARE]: utils.colorHarmony.buildHarmony(color, utils.square, mode, options)\n    })[harmony];\n};\n","import { BASE_255, DEFAULT_BLEND_STEPS, DEFAULT_SHADES_TINTS_STEPS, Harmony, MAX_ALPHA, MAX_LAB, MAX_LCH_C, MAX_PCENT, Mix } from '#constants';\nimport { cmykToRgb, hslToRgb, hwbToRgb, labToLch, labToRgb, lchToLab, lchToRgb, rgbToCmyk, rgbToHsl, rgbToHwb, rgbToLab, rgbToLch } from '#color/translators';\nimport * as utils from '#color/utils';\nimport { getColorModel, getOptionsFromColorInput, getRGBObject } from '#color/extractors';\nimport { CSS } from '#color/css';\nimport { isHarmony, isMix, minmax, normalizeHue, round } from '#helpers';\nimport { getBlendReturn, getBlendReturnWithParameters, getColorReturn, getHarmonyReturn, getMixReturn } from '#returns';\nconst bindedMixers = Object.fromEntries(Object.entries(utils.colorMixer).map((entry) => {\n    const [key, fn] = entry;\n    return [key, fn.bind(utils.colorMixer)];\n}));\nexport class ColorTranslator {\n    constructor(color, options = {}) {\n        this._options = getOptionsFromColorInput(options, color);\n        this.rgb = getRGBObject(color);\n        this.update('rgb');\n    }\n    update(...exclude) {\n        if (!exclude.includes('rgb')) {\n            this.updateRGB();\n        }\n        if (!exclude.includes('hsl')) {\n            this.updateHSL();\n        }\n        if (!exclude.includes('hwb')) {\n            this.updateHWB();\n        }\n        if (!exclude.includes('lab')) {\n            this.updateLAB();\n        }\n        if (!exclude.includes('lch')) {\n            this.updateLCH();\n        }\n        if (!exclude.includes('cmyk')) {\n            this.updateCMYK();\n        }\n    }\n    updateRGB() {\n        this.rgb = {\n            ...hslToRgb(this.hsl.H, this.hsl.S, this.hsl.L),\n            A: this.hsl.A\n        };\n    }\n    updateHSL() {\n        this.hsl = rgbToHsl(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n    }\n    updateHWB() {\n        this.hwb = rgbToHwb(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n    }\n    updateLAB() {\n        this.lab = {\n            ...rgbToLab(this.rgb.R, this.rgb.G, this.rgb.B),\n            A: this.rgb.A\n        };\n    }\n    updateLCH() {\n        this.lch = {\n            ...rgbToLch(this.rgb.R, this.rgb.G, this.rgb.B),\n            A: this.rgb.A\n        };\n    }\n    updateCMYK() {\n        this.cmyk = rgbToCmyk(this.rgb.R, this.rgb.G, this.rgb.B);\n    }\n    updateRGBFromHWB() {\n        this.rgb = {\n            ...hwbToRgb(this.hwb.H, this.hwb.W, this.hwb.B),\n            A: this.rgb.A\n        };\n    }\n    updateRGBFromLCH() {\n        this.rgb = {\n            ...lchToRgb(this.lch.L, this.lch.C, this.lch.H),\n            A: this.rgb.A\n        };\n    }\n    updateRGBFromCMYK() {\n        this.rgb = {\n            ...cmykToRgb(this.cmyk.C, this.cmyk.M, this.cmyk.Y, this.cmyk.K),\n            A: this.rgb.A\n        };\n    }\n    updateRGBFromLAB() {\n        this.rgb = {\n            ...labToRgb(this.lab.L, this.lab.a, this.lab.b),\n            A: this.rgb.A\n        };\n    }\n    updateLCHFromLAB() {\n        this.lch = {\n            ...labToLch(this.lab.L, this.lab.a, this.lab.b),\n            A: this.lab.A\n        };\n    }\n    updateLABromLCH() {\n        this.lab = {\n            ...lchToLab(this.lch.L, this.lch.C, this.lch.H),\n            A: this.lch.A\n        };\n    }\n    setOptions(options = {}) {\n        this._options = {\n            ...this._options,\n            ...options\n        };\n        return this;\n    }\n    setR(R) {\n        this.rgb.R = minmax(R, 0, BASE_255);\n        this.update('rgb');\n        return;\n    }\n    setG(G) {\n        this.rgb.G = minmax(G, 0, BASE_255);\n        this.update('rgb');\n        return this;\n    }\n    setB(B) {\n        this.rgb.B = minmax(B, 0, BASE_255);\n        this.update('rgb');\n        return this;\n    }\n    setH(H) {\n        this.hsl.H = normalizeHue(H);\n        this.update('hsl');\n        return this;\n    }\n    setS(S) {\n        this.hsl.S = minmax(S, 0, MAX_PCENT);\n        this.update('hsl');\n        return this;\n    }\n    setL(L) {\n        this.hsl.L = minmax(L, 0, MAX_PCENT);\n        this.update('hsl');\n        return this;\n    }\n    setWhiteness(W) {\n        this.hwb.W = minmax(W, 0, MAX_PCENT);\n        this.updateRGBFromHWB();\n        this.update('rgb', 'hwb');\n        return this;\n    }\n    setBlackness(B) {\n        this.hwb.B = minmax(B, 0, MAX_PCENT);\n        this.updateRGBFromHWB();\n        this.update('rgb', 'hwb');\n        return this;\n    }\n    setCIEL(L) {\n        this.lab.L = minmax(L, 0, MAX_PCENT);\n        this.updateRGBFromLAB();\n        this.updateLCHFromLAB();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setCIEa(a) {\n        this.lab.a = minmax(a, -MAX_LAB, MAX_LAB);\n        this.updateRGBFromLAB();\n        this.updateLCHFromLAB();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setCIEb(b) {\n        this.lab.b = minmax(b, -MAX_LAB, MAX_LAB);\n        this.updateRGBFromLAB();\n        this.updateLCHFromLAB();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setLCHL(l) {\n        this.lch.L = minmax(l, 0, MAX_PCENT);\n        this.updateRGBFromLCH();\n        this.updateLABromLCH();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setLCHC(c) {\n        this.lch.C = minmax(c, 0, MAX_LCH_C);\n        this.updateRGBFromLCH();\n        this.updateLABromLCH();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setLCHH(h) {\n        this.lch.H = normalizeHue(h);\n        this.updateRGBFromLCH();\n        this.updateLABromLCH();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setA(A) {\n        const alpha = minmax(A, 0, MAX_ALPHA);\n        this.rgb.A = alpha;\n        this.hsl.A = alpha;\n        this.hwb.A = alpha;\n        this.lab.A = alpha;\n        this.lch.A = alpha;\n        this.cmyk.A = alpha;\n        return this;\n    }\n    setC(C) {\n        this.cmyk.C = minmax(C, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    setM(M) {\n        this.cmyk.M = minmax(M, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    setY(Y) {\n        this.cmyk.Y = minmax(Y, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    setK(K) {\n        this.cmyk.K = minmax(K, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    get options() {\n        return this._options;\n    }\n    get R() {\n        return round(this.rgb.R, this.options.decimals);\n    }\n    get G() {\n        return round(this.rgb.G, this.options.decimals);\n    }\n    get B() {\n        return round(this.rgb.B, this.options.decimals);\n    }\n    get H() {\n        return round(this.hsl.H, this.options.decimals);\n    }\n    get S() {\n        return round(this.hsl.S, this.options.decimals);\n    }\n    get L() {\n        return round(this.hsl.L, this.options.decimals);\n    }\n    get Whiteness() {\n        return round(this.hwb.W, this.options.decimals);\n    }\n    get Blackness() {\n        return round(this.hwb.B, this.options.decimals);\n    }\n    get CIEL() {\n        return round(this.lab.L, this.options.decimals);\n    }\n    get CIEa() {\n        return round(this.lab.a, this.options.decimals);\n    }\n    get CIEb() {\n        return round(this.lab.b, this.options.decimals);\n    }\n    get LCHL() {\n        return round(this.lch.L, this.options.decimals);\n    }\n    get LCHC() {\n        return round(this.lch.C, this.options.decimals);\n    }\n    get LCHH() {\n        return round(this.lch.H, this.options.decimals);\n    }\n    get A() {\n        return round(this.hsl.A, this.options.decimals);\n    }\n    get C() {\n        return round(this.cmyk.C, this.options.decimals);\n    }\n    get M() {\n        return round(this.cmyk.M, this.options.decimals);\n    }\n    get Y() {\n        return round(this.cmyk.Y, this.options.decimals);\n    }\n    get K() {\n        return round(this.cmyk.K, this.options.decimals);\n    }\n    get HEXObject() {\n        return utils.translateColor.HEX(this.rgb);\n    }\n    get HEXAObject() {\n        return utils.translateColor.HEXA(this.rgb);\n    }\n    get RGBObject() {\n        return {\n            R: this.R,\n            G: this.G,\n            B: this.B\n        };\n    }\n    get RGBAObject() {\n        return {\n            ...this.RGBObject,\n            A: this.A\n        };\n    }\n    get HSLObject() {\n        return {\n            H: this.H,\n            S: this.S,\n            L: this.L\n        };\n    }\n    get HSLAObject() {\n        return {\n            ...this.HSLObject,\n            A: this.A\n        };\n    }\n    get HWBObject() {\n        return {\n            H: this.H,\n            W: this.Whiteness,\n            B: this.Blackness\n        };\n    }\n    get HWBAObject() {\n        return {\n            ...this.HWBObject,\n            A: this.A\n        };\n    }\n    get CIELabObject() {\n        return {\n            L: this.CIEL,\n            a: this.CIEa,\n            b: this.CIEb\n        };\n    }\n    get CIELabAObject() {\n        return {\n            ...this.CIELabObject,\n            A: this.A\n        };\n    }\n    get LCHObject() {\n        return {\n            L: this.LCHL,\n            C: this.LCHC,\n            H: this.LCHH\n        };\n    }\n    get LCHAObject() {\n        return {\n            ...this.LCHObject,\n            A: this.A\n        };\n    }\n    get CMYKObject() {\n        return {\n            C: this.C,\n            M: this.M,\n            Y: this.Y,\n            K: this.K\n        };\n    }\n    get CMYKAObject() {\n        return {\n            ...this.CMYKObject,\n            A: this.A\n        };\n    }\n    get HEX() {\n        return CSS.HEX({\n            R: this.R,\n            G: this.G,\n            B: this.B\n        });\n    }\n    get HEXA() {\n        return CSS.HEX({\n            R: this.R,\n            G: this.G,\n            B: this.B,\n            A: this.A * BASE_255\n        });\n    }\n    get RGB() {\n        return CSS.RGB({\n            R: this.R,\n            G: this.G,\n            B: this.B\n        }, this.options);\n    }\n    get RGBA() {\n        return CSS.RGB({\n            R: this.R,\n            G: this.G,\n            B: this.B,\n            A: this.A\n        }, this.options);\n    }\n    get HSL() {\n        return CSS.HSL({\n            H: this.H,\n            S: this.S,\n            L: this.L\n        }, this.options);\n    }\n    get HSLA() {\n        return CSS.HSL({\n            H: this.H,\n            S: this.S,\n            L: this.L,\n            A: this.A\n        }, this.options);\n    }\n    get HWB() {\n        return CSS.HWB({\n            H: this.H,\n            W: this.Whiteness,\n            B: this.Blackness\n        }, this.options);\n    }\n    get HWBA() {\n        return CSS.HWB({\n            H: this.H,\n            W: this.Whiteness,\n            B: this.Blackness,\n            A: this.A\n        }, this.options);\n    }\n    get CIELab() {\n        return CSS.CIELab({\n            L: this.CIEL,\n            a: this.CIEa,\n            b: this.CIEb\n        }, this.options);\n    }\n    get CIELabA() {\n        return CSS.CIELab({\n            L: this.CIEL,\n            a: this.CIEa,\n            b: this.CIEb,\n            A: this.A\n        }, this.options);\n    }\n    get LCH() {\n        return CSS.LCH({\n            L: this.LCHL,\n            C: this.LCHC,\n            H: this.LCHH\n        }, this.options);\n    }\n    get LCHA() {\n        return CSS.LCH({\n            L: this.LCHL,\n            C: this.LCHC,\n            H: this.LCHH,\n            A: this.A\n        }, this.options);\n    }\n    get CMYK() {\n        return CSS.CMYK({\n            C: this.C,\n            M: this.M,\n            Y: this.Y,\n            K: this.K\n        }, this.options);\n    }\n    get CMYKA() {\n        return CSS.CMYK({\n            C: this.C,\n            M: this.M,\n            Y: this.Y,\n            K: this.K,\n            A: this.A\n        }, this.options);\n    }\n    static toHEXObject(color) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, 0, utils.translateColor.HEX);\n    }\n    static toHEX(color) {\n        return CSS.HEX(ColorTranslator.toHEXObject(color));\n    }\n    static toHEXAObject(color) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, 0, utils.translateColor.HEXA);\n    }\n    static toHEXA(color) {\n        return CSS.HEX(ColorTranslator.toHEXAObject(color));\n    }\n    static toRGBObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.RGB);\n    }\n    static toRGB(color, options = {}) {\n        const rgb = ColorTranslator.toRGBObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.RGB(rgb, detectedOptions);\n    }\n    static toRGBAObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.RGBA);\n    }\n    static toRGBA(color, options = {}) {\n        const rgba = ColorTranslator.toRGBAObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.RGB(rgba, detectedOptions);\n    }\n    static toHSLObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.HSL);\n    }\n    static toHSL(color, options = {}) {\n        const hsl = ColorTranslator.toHSLObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.HSL(hsl, detectedOptions);\n    }\n    static toHSLAObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.HSLA);\n    }\n    static toHSLA(color, options = {}) {\n        const hsla = ColorTranslator.toHSLAObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.HSL(hsla, detectedOptions);\n    }\n    static toHWBObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.HWB);\n    }\n    static toHWB(color, options = {}) {\n        const hwb = ColorTranslator.toHWBObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.HWB(hwb, detectedOptions);\n    }\n    static toHWBAObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.HWBA);\n    }\n    static toHWBA(color, options = {}) {\n        const hwb = ColorTranslator.toHWBAObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.HWB(hwb, detectedOptions);\n    }\n    static toCIELabObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.CIELab);\n    }\n    static toCIELab(color, options = {}) {\n        const lab = ColorTranslator.toCIELabObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.CIELab(lab, detectedOptions);\n    }\n    static toCIELabAObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.CIELabA);\n    }\n    static toCIELabA(color, options = {}) {\n        const lab = ColorTranslator.toCIELabAObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.CIELab(lab, detectedOptions);\n    }\n    static toLCHObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.LCH);\n    }\n    static toLCH(color, options = {}) {\n        const lch = ColorTranslator.toLCHObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.LCH(lch, detectedOptions);\n    }\n    static toLCHAObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.LCHA);\n    }\n    static toLCHA(color, options = {}) {\n        const lch = ColorTranslator.toLCHAObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.LCH(lch, detectedOptions);\n    }\n    static toCMYKObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.CMYK);\n    }\n    static toCMYK(color, options = {}) {\n        const cmyk = ColorTranslator.toCMYKObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.CMYK(cmyk, detectedOptions);\n    }\n    static toCMYKAObject(color, options = {}) {\n        const model = getColorModel(color);\n        return getColorReturn(color, model, options.decimals, utils.translateColor.CMYKA);\n    }\n    static toCMYKA(color, options = {}) {\n        const cmyka = ColorTranslator.toCMYKAObject(color, options);\n        const detectedOptions = getOptionsFromColorInput(options, color);\n        return CSS.CMYK(cmyka, detectedOptions);\n    }\n    static getBlendHEXObject(from, to, steps = DEFAULT_BLEND_STEPS) {\n        return getBlendReturn(from, to, steps, 0, utils.translateColor.HEX);\n    }\n    static getBlendHEX(from, to, steps = DEFAULT_BLEND_STEPS) {\n        return ColorTranslator.getBlendHEXObject(from, to, steps)\n            .map((color) => CSS.HEX(color));\n    }\n    static getBlendHEXAObject(from, to, steps = DEFAULT_BLEND_STEPS) {\n        return getBlendReturn(from, to, steps, 0, utils.translateColor.HEXA);\n    }\n    static getBlendHEXA(from, to, steps = DEFAULT_BLEND_STEPS) {\n        return ColorTranslator.getBlendHEXAObject(from, to, steps)\n            .map((color) => CSS.HEX(color));\n    }\n    static getBlendRGBObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.RGB\n        });\n    }\n    static getBlendRGB(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.RGB,\n            cssFunction: CSS.RGB\n        });\n    }\n    static getBlendRGBAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.RGBA\n        });\n    }\n    static getBlendRGBA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.RGBA,\n            cssFunction: CSS.RGB\n        });\n    }\n    static getBlendHSLObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HSL\n        });\n    }\n    static getBlendHSL(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HSL,\n            cssFunction: CSS.HSL\n        });\n    }\n    static getBlendHSLAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HSLA\n        });\n    }\n    static getBlendHSLA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HSLA,\n            cssFunction: CSS.HSL\n        });\n    }\n    static getBlendHWBObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HWB\n        });\n    }\n    static getBlendHWB(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HWB,\n            cssFunction: CSS.HWB\n        });\n    }\n    static getBlendHWBAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HWBA\n        });\n    }\n    static getBlendHWBA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.HWBA,\n            cssFunction: CSS.HWB\n        });\n    }\n    static getBlendCIELabObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.CIELab\n        });\n    }\n    static getBlendCIELab(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.CIELab,\n            cssFunction: CSS.CIELab\n        });\n    }\n    static getBlendCIELabAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.CIELabA\n        });\n    }\n    static getBlendCIELabA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.CIELabA,\n            cssFunction: CSS.CIELab\n        });\n    }\n    static getBlendLCHObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.LCH\n        });\n    }\n    static getBlendLCH(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.LCH,\n            cssFunction: CSS.LCH\n        });\n    }\n    static getBlendLCHAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.LCHA\n        });\n    }\n    static getBlendLCHA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturnWithParameters({\n            from,\n            to,\n            thirdParameter,\n            fourthParameter,\n            translateFunction: utils.translateColor.LCHA,\n            cssFunction: CSS.LCH\n        });\n    }\n    static getMixHEXObject(colors, mode = Mix.ADDITIVE) {\n        return utils.colorMixer.HEX(colors, mode, false);\n    }\n    static getMixHEX(colors, mode = Mix.ADDITIVE) {\n        return utils.colorMixer.HEX(colors, mode, true);\n    }\n    static getMixHEXAObject(colors, mode = Mix.ADDITIVE) {\n        return utils.colorMixer.HEXA(colors, mode, false);\n    }\n    static getMixHEXA(colors, mode = Mix.ADDITIVE) {\n        return utils.colorMixer.HEXA(colors, mode, true);\n    }\n    static getMixRGBObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.RGB,\n            css: false\n        });\n    }\n    static getMixRGB(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.RGB,\n            css: true\n        });\n    }\n    static getMixRGBAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.RGBA,\n            css: false\n        });\n    }\n    static getMixRGBA(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.RGBA,\n            css: true\n        });\n    }\n    static getMixHSLObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HSL,\n            css: false\n        });\n    }\n    static getMixHSL(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HSL,\n            css: true\n        });\n    }\n    static getMixHSLAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HSLA,\n            css: false\n        });\n    }\n    static getMixHSLA(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HSLA,\n            css: true\n        });\n    }\n    static getMixHWBObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HWB,\n            css: false\n        });\n    }\n    static getMixHWB(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HWB,\n            css: true\n        });\n    }\n    static getMixHWBAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HWBA,\n            css: false\n        });\n    }\n    static getMixHWBA(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.HWBA,\n            css: true\n        });\n    }\n    static getMixCIELabObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.CIELab,\n            css: false\n        });\n    }\n    static getMixCIELab(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.CIELab,\n            css: true\n        });\n    }\n    static getMixCIELabAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.CIELabA,\n            css: false\n        });\n    }\n    static getMixCIELabA(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.CIELabA,\n            css: true\n        });\n    }\n    static getMixLCHObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.LCH,\n            css: false\n        });\n    }\n    static getMixLCH(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.LCH,\n            css: true\n        });\n    }\n    static getMixLCHAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.LCHA,\n            css: false\n        });\n    }\n    static getMixLCHA(colors, secondParameter, thirdParameter) {\n        return getMixReturn({\n            colors,\n            secondParameter,\n            thirdParameter,\n            colorMixerFunction: bindedMixers.LCHA,\n            css: true\n        });\n    }\n    static getShades(color, secondParameter, thirdParameter) {\n        if (typeof secondParameter === 'number') {\n            return utils.getColorMixture(color, secondParameter, true, getOptionsFromColorInput(thirdParameter || {}, color));\n        }\n        return utils.getColorMixture(color, DEFAULT_SHADES_TINTS_STEPS, true, getOptionsFromColorInput(secondParameter || {}, color));\n    }\n    static getTints(color, secondParameter, thirdParameter) {\n        if (typeof secondParameter === 'number') {\n            return utils.getColorMixture(color, secondParameter, false, getOptionsFromColorInput(thirdParameter || {}, color));\n        }\n        return utils.getColorMixture(color, DEFAULT_SHADES_TINTS_STEPS, false, getOptionsFromColorInput(secondParameter || {}, color));\n    }\n    static getHarmony(color, secondParam, thirdParam, fourthParam) {\n        if (isHarmony(secondParam)) {\n            return getHarmonyReturn(secondParam, color, isMix(thirdParam)\n                ? thirdParam\n                : Mix.ADDITIVE, getOptionsFromColorInput(isMix(thirdParam)\n                ? (fourthParam || {})\n                : thirdParam || {}, color));\n        }\n        else if (isMix(secondParam)) {\n            return getHarmonyReturn(Harmony.COMPLEMENTARY, color, secondParam, getOptionsFromColorInput(thirdParam || {}, color));\n        }\n        return getHarmonyReturn(Harmony.COMPLEMENTARY, color, Mix.ADDITIVE, getOptionsFromColorInput(secondParam || {}, color));\n    }\n}\nexport { Harmony, Mix };\n","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const color = new ColorTranslator('hsl(180 100% 50%)', { decimals: 0 });\n\n    for (let row = 0; row < 10; row++) {\n\n        for (let col = 0; col < 10; col++) {\n\n            color\n                .setS(row * 10)\n                .setL(col * 5 + 30);\n\n            const box = document.createElement('div');\n\n            box.classList.add('box');\n            box.style.background = color.HEX;\n\n            box.innerText =\n                `R:${color.R}\n                 G:${color.G}\n                 B:${color.B}`;\n            container.appendChild(box);\n\n        }\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const color = new ColorTranslator({ R: 255, G: 0, B: 0 });\n    const hue = [0, 30, 60, 120, 240, 280, 320, 0];\n    let rainbow;\n\n    for (let r = 0; r < hue.length; r++) {\n\n        color.setH(hue[r]);\n\n        const bow = document.createElement('div');\n\n        bow.classList.add('rainbow');\n        bow.style.background = color.HEX;\n\n        if (rainbow) {\n            rainbow.appendChild(bow);\n        } else {\n            container.appendChild(bow);\n        }\n\n        rainbow = bow;\n    }\n\n    rainbow.style.background = '#333';\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const hsl = { H: 0, S: '90%', L: '50%' };\n    const hue = [undefined, 55, 30, 0, 290, 220, 130];\n    const total = hue.length;\n\n    for (let row = 0; row < total; row++) {\n\n        for (let col = 0; col < total; col++) {\n\n            let index = total - row + col;\n            if (index >= total) {\n                index -= total;\n            }\n            hsl.H = hue[index];\n            const rgb = hue[index] === undefined\n                ? '#FFF'\n                : ColorTranslator.toHEX(hsl);\n            const box = document.createElement('div');\n\n            box.classList.add('flag');\n            box.style.background = rgb;\n\n            container.appendChild(box);\n\n        }\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const hexColors = [\n        '#FE2712', '#FE5409', '#FB9902',\n        '#FABD03', '#FFFE32', '#D1EA2C',\n        '#66B132', '#0392CE', '#0247FE',\n        '#3D00A5', '#8601B0', '#A7194B'\n    ];\n\n    hexColors.forEach((color) => {\n\n        const rgb = ColorTranslator.toRGB(color);\n        const hsl = ColorTranslator.toHSL(color, { decimals: 0 });\n        const hwb = ColorTranslator.toHWB(color, { decimals: 0 });\n        const lab = ColorTranslator.toCIELab(color, { decimals: 0 });\n        const lch = ColorTranslator.toLCH(color, { decimals: 0 });\n\n        const rgbDiv = document.createElement('div');\n        const hslDiv = document.createElement('div');\n        const hwbDiv = document.createElement('div');\n        const labDiv = document.createElement('div');\n        const lchDiv = document.createElement('div');\n\n        rgbDiv.style.backgroundColor = rgb;\n        rgbDiv.textContent = rgb;\n\n        hslDiv.style.backgroundColor = hsl;\n        hslDiv.textContent = hsl;\n\n        hwbDiv.style.backgroundColor = hwb;\n        hwbDiv.textContent = hwb;\n\n        labDiv.style.backgroundColor = lab;\n        labDiv.textContent = lab;\n\n        lchDiv.style.backgroundColor = lch;\n        lchDiv.textContent = lch;\n\n        container.appendChild(rgbDiv);\n        container.appendChild(hslDiv);\n        container.appendChild(hwbDiv);\n        container.appendChild(labDiv);\n        container.appendChild(lchDiv);\n\n    });\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const colors = [\n        'red',\n        'lime',\n        'blue',\n        'aqua',\n        'yellow',\n        'fuchsia'\n    ];\n    const total = colors.length;\n\n    for (let row = 0; row < total; row++) {\n\n        const hsl = ColorTranslator.toHSLObject(colors[row]);\n        const step = hsl.S / (total - 1);\n\n        for (let col = 0; col < total; col++) {\n\n            const rgb = ColorTranslator.toHEX(hsl);\n            const cmyk = ColorTranslator.toCMYKObject(hsl, { decimals: 0 });\n\n            const box = document.createElement('div');\n            box.classList.add('box');\n            box.style.background = rgb;\n            box.innerText = `C:${cmyk.C}\n                             M:${cmyk.M}\n                             Y:${cmyk.Y}\n                             K:${cmyk.K}`;\n\n            container.appendChild(box);\n\n            hsl.S -= step;\n\n        }\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const rows = 11;\n    const mult = 3;\n\n    for (let i = 0; i < rows; i++) {\n\n        const blends = ColorTranslator.getBlendHEX('#F00', '#FF0', mult + i * mult);\n\n        blends.forEach((blend, index) => {\n            const box = document.createElement('div');\n            box.classList.add('box', `file${i}`);\n            box.style.background = blend;\n            box.innerText = index + 1;\n            container.appendChild(box);\n        });\n\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n\n    const colors = ['#F00', '#FF8000', '#FF0', '#0F0', '#00F', '#A0F', '#F0A'];\n\n    const createBox = (color, type) => {\n        const box = document.createElement('div');\n        box.classList.add('box');\n        box.style.backgroundColor = color;\n        if (type) box.dataset.type = type;\n        container.appendChild(box);\n    };\n\n    colors.forEach((color) => {\n        const shades = ColorTranslator.getShades(color, 3).reverse();\n        const tints = ColorTranslator.getTints(color, 3);\n        shades.forEach((shade) => createBox(shade, 'shade'));\n        createBox(color);\n        tints.forEach((tint) => createBox(tint, 'tint'));\n    });\n\n    return container;\n\n};","import './styles.scss';\n\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n\n    const mixes = [\n        '#F00',\n        '#0F0',\n        '#00F',\n        [1, 3],\n        [1, 2],\n        [2, 3],\n        [1, 2, 3]\n    ];\n\n    const fillPlanes = () => {\n        const planes = container.querySelectorAll('#planes path');\n        planes.forEach((plane, index) => {\n            let color = '#CCC';\n            if (typeof mixes[index] === 'string') {\n                color = mixes[index];\n            } else if(mixes[index]) {\n                const colors = mixes[index].map((i) => mixes[i - 1]);\n                color = mixes[index] = ColorTranslator.getMixHEX(colors);\n            }\n            plane.setAttribute('fill', color);\n        });\n    };\n\n    fetch('images/color-mixes.svg')\n        .then(result => result.text())\n        .then((svgCode) => {\n            container.innerHTML = svgCode;\n            fillPlanes();\n        });\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator, { Mix }) => {\n\n    const container = document.createElement('div');\n\n    const mixes = [\n        '#F00',\n        '#FF0',\n        '#00F',\n        [1, 3],\n        [1, 2],\n        [2, 3],\n        [1, 2, 3]\n    ];\n\n    const fillPlanes = () => {\n        const planes = container.querySelectorAll('#planes path');\n        planes.forEach((plane, index) => {\n            let color = '#CCC';\n            if (typeof mixes[index] === 'string') {\n                color = mixes[index];\n            } else if(mixes[index]) {\n                const colors = mixes[index].map((i) => mixes[i - 1]);\n                color = mixes[index] = ColorTranslator.getMixHEX(colors, Mix.SUBTRACTIVE);\n            }\n            plane.setAttribute('fill', color);\n        });\n    };\n\n    fetch('images/color-mixes.svg')\n        .then(result => result.text())\n        .then((svgCode) => {\n            container.innerHTML = svgCode;\n            fillPlanes();\n        });\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator, { Harmony }) => {\n\n    const container = document.createElement('div');\n\n    const harmonies = [\n        { label: 'Complementary',       value: Harmony.COMPLEMENTARY },\n        { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n        { label: 'Analogous',           value: Harmony.ANALOGOUS },\n        { label: 'Triadic',             value: Harmony.TRIADIC },\n        { label: 'Tetradic',            value: Harmony.TETRADIC },\n        { label: 'Square',              value: Harmony.SQUARE }\n    ];\n\n    const baseColor = '#F00';\n\n    const createElement = (className, parent) => {\n        const div = document.createElement('div');\n        div.classList.add(className);\n        parent.appendChild(div);\n        return div;\n    };\n\n    const createHarmony = (item) => {\n\n        const wrapper = createElement('wrapper', container);\n        const wheel = createElement('wheel', wrapper);\n        const harmony = createElement('harmony', wrapper);\n        createElement('label', wrapper).innerText = item.label;\n\n        fetch('images/wheel-additive.svg')\n            .then(result => result.text())\n            .then((svgCode) => {\n                const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value);\n                const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n                wheel.innerHTML = svgCode;\n                harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n                wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n            });\n\n    };\n\n    harmonies.forEach((item) => createHarmony(item));\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator, { Harmony, Mix }) => {\n\n    const container = document.createElement('div');\n\n    const harmonies = [\n        { label: 'Complementary',       value: Harmony.COMPLEMENTARY },\n        { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n        { label: 'Analogous',           value: Harmony.ANALOGOUS },\n        { label: 'Triadic',             value: Harmony.TRIADIC },\n        { label: 'Tetradic',            value: Harmony.TETRADIC },\n        { label: 'Square',              value: Harmony.SQUARE }\n    ];\n\n    const baseColor = '#F00';\n\n    const createElement = (className, parent) => {\n        const div = document.createElement('div');\n        div.classList.add(className);\n        parent.appendChild(div);\n        return div;\n    };\n\n    const createHarmony = (item) => {\n\n        const wrapper = createElement('wrapper', container);\n        const wheel = createElement('wheel', wrapper);\n        const harmony = createElement('harmony', wrapper);\n        createElement('label', wrapper).innerText = item.label;\n\n        fetch('images/wheel-subtractive.svg')\n            .then(result => result.text())\n            .then((svgCode) => {\n                const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value, Mix.SUBTRACTIVE);\n                const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n                wheel.innerHTML = svgCode;\n                harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n                wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n            });\n\n    };\n\n    harmonies.forEach((item) => createHarmony(item));\n\n    return container;\n\n};","import '../../node_modules/google-code-prettify/bin/run_prettify.min';\nimport '../../node_modules/google-code-prettify/bin/prettify.min.css';\nimport '../../node_modules/google-code-prettify/styles/desert.css';\nimport 'whatwg-fetch';\nimport './styles.scss';\nimport { ColorTranslator, Harmony, Mix } from '../';\nimport demo1 from './demo1';\nimport demo2 from './demo2';\nimport demo3 from './demo3';\nimport demo4 from './demo4';\nimport demo5 from './demo5';\nimport demo6 from './demo6';\nimport demo7 from './demo7';\nimport demo8 from './demo8';\nimport demo9 from './demo9';\nimport demo10 from './demo10';\nimport demo11 from './demo11';\n\nconst functioToString = (fn) => {\n    const article = document.createElement('article');\n    const pre = document.createElement('pre');\n    article.classList.add('function-container');\n    pre.classList.add('prettyprint');\n    article.appendChild(pre);\n    pre.innerHTML = fn.toString().replace('(ColorTranslator)', '()');\n    return article;\n};\n\nconst demos = new Map([\n    ['demo1', demo1],\n    ['demo2', demo2],\n    ['demo3', demo3],\n    ['demo4', demo4],\n    ['demo5', demo5],\n    ['demo6', demo6],\n    ['demo7', demo7],\n    ['demo8', demo8],\n    ['demo9', demo9],\n    ['demo10', demo10],\n    ['demo11', demo11]\n]);\n\ndocument.addEventListener('DOMContentLoaded', () => {\n    demos.forEach((module, div) => {\n        const demo = document.getElementById(div);\n        const container = document.createElement('div');\n        const wrapper = document.createElement('div');\n\n        container.classList.add('demo-container');\n        wrapper.classList.add('demo-wrapper');\n\n        wrapper.appendChild(module(ColorTranslator, { Harmony, Mix }));\n        container.appendChild(wrapper);\n        demo.appendChild(container);\n        demo.appendChild(functioToString(module));\n    });\n});"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///967\n\n}")}},__webpack_module_cache__={};function __webpack_require__(I){var g=__webpack_module_cache__[I];if(void 0!==g)return g.exports;var C=__webpack_module_cache__[I]={exports:{}};return __webpack_modules__[I](C,C.exports,__webpack_require__),C.exports}__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(I){if("object"==typeof window)return window}}();var __webpack_exports__=__webpack_require__(967),__webpack_export_target__=window;for(var __webpack_i__ in __webpack_exports__)__webpack_export_target__[__webpack_i__]=__webpack_exports__[__webpack_i__];__webpack_exports__.__esModule&&Object.defineProperty(__webpack_export_target__,"__esModule",{value:!0})})(); \ No newline at end of file +(()=>{var __webpack_modules__={966(module,exports){eval('{var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;!function(){var r=null;\n(function(){function X(e){function j(){try{J.doScroll("left")}catch(e){P(j,50);return}w("poll")}function w(j){if(!(j.type=="readystatechange"&&x.readyState!="complete")&&((j.type=="load"?n:x)[z](i+j.type,w,!1),!m&&(m=!0)))e.call(n,j.type||j)}var Y=x.addEventListener,m=!1,C=!0,t=Y?"addEventListener":"attachEvent",z=Y?"removeEventListener":"detachEvent",i=Y?"":"on";if(x.readyState=="complete")e.call(n,"lazy");else{if(x.createEventObject&&J.doScroll){try{C=!n.frameElement}catch(A){}C&&j()}x[t](i+"DOMContentLoaded",\nw,!1);x[t](i+"readystatechange",w,!1);n[t](i+"load",w,!1)}}function Q(){S&&X(function(){var e=K.length;$(e?function(){for(var j=0;j=0;){var M=A[m],T=M.src.match(/^[^#?]*\\/run_prettify\\.js(\\?[^#]*)?(?:#.*)?$/);if(T){z=T[1]||"";M.parentNode.removeChild(M);break}}var S=!0,D=\n[],N=[],K=[];z.replace(/[&?]([^&=]+)=([^&]+)/g,function(e,j,w){w=decodeURIComponent(w);j=decodeURIComponent(j);j=="autorun"?S=!/^[0fn]/i.test(w):j=="lang"?D.push(w):j=="skin"?N.push(w):j=="callback"&&K.push(w)});m=0;for(z=D.length;m122||(o<65||k>90||f.push([Math.max(65,k)|32,Math.min(o,90)|32]),o<97||k>122||f.push([Math.max(97,k)&-33,Math.min(o,122)&-33]))}}f.sort(function(f,a){return f[0]-\na[0]||a[1]-f[1]});b=[];g=[];for(a=0;ak[0]&&(k[1]+1>k[0]&&c.push("-"),c.push(h(k[1])));c.push("]");return c.join("")}function e(f){for(var a=f.source.match(/\\[(?:[^\\\\\\]]|\\\\[\\S\\s])*]|\\\\u[\\dA-Fa-f]{4}|\\\\x[\\dA-Fa-f]{2}|\\\\\\d+|\\\\[^\\dux]|\\(\\?[!:=]|[()^]|[^()[\\\\^]+/g),c=a.length,d=[],g=0,k=0;g=2&&f==="["?a[g]=b(o):f!=="\\\\"&&(a[g]=o.replace(/[A-Za-z]/g,function(a){a=a.charCodeAt(0);return"["+String.fromCharCode(a&-33,a|32)+"]"}));return a.join("")}for(var j=0,F=!1,l=!1,I=0,c=a.length;I=5&&"lang-"===y.substring(0,5))&&!(u&&typeof u[1]==="string"))g=!1,y="src";g||(m[B]=y)}k=c;c+=B.length;if(g){g=u[1];var o=B.indexOf(g),H=o+g.length;u[2]&&(H=B.length-u[2].length,o=H-g.length);y=y.substring(5);n(l+k,B.substring(0,o),h,j);n(l+k+o,g,A(y,\ng),j);n(l+k+H,B.substring(H),h,j)}else j.push(l+k,y)}a.g=j}var b={},e;(function(){for(var h=a.concat(d),l=[],i={},c=0,p=h.length;c=0;)b[q.charAt(f)]=m;m=m[1];q=""+m;i.hasOwnProperty(q)||(l.push(m),i[q]=r)}l.push(/[\\S\\s]/);e=j(l)})();var i=d.length;return h}function t(a){var d=[],h=[];a.tripleQuotedStrings?d.push(["str",/^(?:\'\'\'(?:[^\'\\\\]|\\\\[\\S\\s]|\'\'?(?=[^\']))*(?:\'\'\'|$)|"""(?:[^"\\\\]|\\\\[\\S\\s]|""?(?=[^"]))*(?:"""|$)|\'(?:[^\'\\\\]|\\\\[\\S\\s])*(?:\'|$)|"(?:[^"\\\\]|\\\\[\\S\\s])*(?:"|$))/,\nr,"\'\\""]):a.multiLineStrings?d.push(["str",/^(?:\'(?:[^\'\\\\]|\\\\[\\S\\s])*(?:\'|$)|"(?:[^"\\\\]|\\\\[\\S\\s])*(?:"|$)|`(?:[^\\\\`]|\\\\[\\S\\s])*(?:`|$))/,r,"\'\\"`"]):d.push(["str",/^(?:\'(?:[^\\n\\r\'\\\\]|\\\\.)*(?:\'|$)|"(?:[^\\n\\r"\\\\]|\\\\.)*(?:"|$))/,r,"\\"\'"]);a.verbatimStrings&&h.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,r]);var b=a.hashComments;b&&(a.cStyleComments?(b>1?d.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,r,"#"]):d.push(["com",/^#(?:(?:define|e(?:l|nd)if|else|error|ifn?def|include|line|pragma|undef|warning)\\b|[^\\n\\r]*)/,\nr,"#"]),h.push(["str",/^<(?:(?:(?:\\.\\.\\/)*|\\/?)(?:[\\w-]+(?:\\/[\\w-]+)+)?[\\w-]+\\.h(?:h|pp|\\+\\+)?|[a-z]\\w*)>/,r])):d.push(["com",/^#[^\\n\\r]*/,r,"#"]));a.cStyleComments&&(h.push(["com",/^\\/\\/[^\\n\\r]*/,r]),h.push(["com",/^\\/\\*[\\S\\s]*?(?:\\*\\/|$)/,r]));if(b=a.regexLiterals){var e=(b=b>1?"":"\\n\\r")?".":"[\\\\S\\\\s]";h.push(["lang-regex",RegExp("^(?:^^\\\\.?|[+-]|[!=]=?=?|\\\\#|%=?|&&?=?|\\\\(|\\\\*=?|[+\\\\-]=|->|\\\\/=?|::?|<>?>?=?|,|;|\\\\?|@|\\\\[|~|{|\\\\^\\\\^?=?|\\\\|\\\\|?=?|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\\\s*("+\n("/(?=[^/*"+b+"])(?:[^/\\\\x5B\\\\x5C"+b+"]|\\\\x5C"+e+"|\\\\x5B(?:[^\\\\x5C\\\\x5D"+b+"]|\\\\x5C"+e+")*(?:\\\\x5D|$))+/")+")")])}(b=a.types)&&h.push(["typ",b]);b=(""+a.keywords).replace(/^ | $/g,"");b.length&&h.push(["kwd",RegExp("^(?:"+b.replace(/[\\s,]+/g,"|")+")\\\\b"),r]);d.push(["pln",/^\\s+/,r," \\r\\n\\t\\u00a0"]);b="^.[^\\\\s\\\\w.$@\'\\"`/\\\\\\\\]*";a.regexLiterals&&(b+="(?!s*/)");h.push(["lit",/^@[$_a-z][\\w$@]*/i,r],["typ",/^(?:[@_]?[A-Z]+[a-z][\\w$@]*|\\w+_t\\b)/,r],["pln",/^[$_a-z][\\w$@]*/i,r],["lit",/^(?:0x[\\da-f]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+-]?\\d+)?)[a-z]*/i,\nr,"0123456789"],["pln",/^\\\\[\\S\\s]?/,r],["pun",RegExp(b),r]);return C(d,h)}function z(a,d,h){function b(a){var c=a.nodeType;if(c==1&&!j.test(a.className))if("br"===a.nodeName)e(a),a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)b(a);else if((c==3||c==4)&&h){var d=a.nodeValue,i=d.match(m);if(i)c=d.substring(0,i.index),a.nodeValue=c,(d=d.substring(i.index+i[0].length))&&a.parentNode.insertBefore(l.createTextNode(d),a.nextSibling),e(a),c||a.parentNode.removeChild(a)}}\nfunction e(a){function b(a,c){var d=c?a.cloneNode(!1):a,f=a.parentNode;if(f){var f=b(f,1),h=a.nextSibling;f.appendChild(d);for(var e=h;e;e=h)h=e.nextSibling,f.appendChild(e)}return d}for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=b(a.nextSibling,0),d;(d=a.parentNode)&&d.nodeType===1;)a=d;c.push(a)}for(var j=/(?:^|\\s)nocode(?:\\s|$)/,m=/\\r\\n?|\\n/,l=a.ownerDocument,i=l.createElement("li");a.firstChild;)i.appendChild(a.firstChild);for(var c=[i],p=0;p=0;){var b=d[h];U.hasOwnProperty(b)?V.console&&console.warn("cannot override language handler %s",b):U[b]=a}}function A(a,d){if(!a||!U.hasOwnProperty(a))a=/^\\s*=o&&(b+=2);h>=H&&(t+=2)}}finally{if(g)g.style.display=k}}catch(v){V.console&&console.log(v&&v.stack||v)}}var V=window,G=["break,continue,do,else,for,if,return,while"],O=[[G,"auto,case,char,const,default,double,enum,extern,float,goto,inline,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],\n"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],J=[O,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,delegate,dynamic_cast,explicit,export,friend,generic,late_check,mutable,namespace,nullptr,property,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],K=[O,"abstract,assert,boolean,byte,extends,final,finally,implements,import,instanceof,interface,null,native,package,strictfp,super,synchronized,throws,transient"],\nL=[K,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,internal,into,is,let,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var,virtual,where"],O=[O,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],M=[G,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],\nN=[G,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],R=[G,"as,assert,const,copy,drop,enum,extern,fail,false,fn,impl,let,log,loop,match,mod,move,mut,priv,pub,pure,ref,self,static,struct,true,trait,type,unsafe,use"],G=[G,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],Q=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\\d*)\\b/,\nS=/\\S/,T=t({keywords:[J,L,O,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",M,N,G],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),U={};i(T,["default-code"]);i(C([],[["pln",/^[^]*(?:>|$)/],["com",/^<\\!--[\\S\\s]*?(?:--\\>|$)/],["lang-",/^<\\?([\\S\\s]+?)(?:\\?>|$)/],["lang-",/^<%([\\S\\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-",\n/^]*>([\\S\\s]+?)<\\/xmp\\b[^>]*>/i],["lang-js",/^]*>([\\S\\s]*?)(<\\/script\\b[^>]*>)/i],["lang-css",/^]*>([\\S\\s]*?)(<\\/style\\b[^>]*>)/i],["lang-in.tag",/^(<\\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);i(C([["pln",/^\\s+/,r," \\t\\r\\n"],["atv",/^(?:"[^"]*"?|\'[^\']*\'?)/,r,"\\"\'"]],[["tag",/^^<\\/?[a-z](?:[\\w-.:]*\\w)?|\\/?>$/i],["atn",/^(?!style[\\s=]|on)[a-z](?:[\\w:-]*\\w)?/i],["lang-uq.val",/^=\\s*([^\\s"\'>]*(?:[^\\s"\'/>]|\\/(?=\\s)))/],["pun",/^[/<->]+/],\n["lang-js",/^on\\w+\\s*=\\s*"([^"]+)"/i],["lang-js",/^on\\w+\\s*=\\s*\'([^\']+)\'/i],["lang-js",/^on\\w+\\s*=\\s*([^\\s"\'>]+)/i],["lang-css",/^style\\s*=\\s*"([^"]+)"/i],["lang-css",/^style\\s*=\\s*\'([^\']+)\'/i],["lang-css",/^style\\s*=\\s*([^\\s"\'>]+)/i]]),["in.tag"]);i(C([],[["atv",/^[\\S\\s]+/]]),["uq.val"]);i(t({keywords:J,hashComments:!0,cStyleComments:!0,types:Q}),["c","cc","cpp","cxx","cyc","m"]);i(t({keywords:"null,true,false"}),["json"]);i(t({keywords:L,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:Q}),\n["cs"]);i(t({keywords:K,cStyleComments:!0}),["java"]);i(t({keywords:G,hashComments:!0,multiLineStrings:!0}),["bash","bsh","csh","sh"]);i(t({keywords:M,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}),["cv","py","python"]);i(t({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:2}),["perl","pl","pm"]);i(t({keywords:N,\nhashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["rb","ruby"]);i(t({keywords:O,cStyleComments:!0,regexLiterals:!0}),["javascript","js"]);i(t({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,throw,true,try,unless,until,when,while,yes",hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);i(t({keywords:R,cStyleComments:!0,multilineStrings:!0}),["rc","rs","rust"]);\ni(C([],[["str",/^[\\S\\s]+/]]),["regex"]);var X=V.PR={createSimpleLexer:C,registerLangHandler:i,sourceDecorator:t,PR_ATTRIB_NAME:"atn",PR_ATTRIB_VALUE:"atv",PR_COMMENT:"com",PR_DECLARATION:"dec",PR_KEYWORD:"kwd",PR_LITERAL:"lit",PR_NOCODE:"nocode",PR_PLAIN:"pln",PR_PUNCTUATION:"pun",PR_SOURCE:"src",PR_STRING:"str",PR_TAG:"tag",PR_TYPE:"typ",prettyPrintOne:function(a,d,e){var b=document.createElement("div");b.innerHTML="
"+a+"
";b=b.firstChild;e&&z(b,e,!0);D({h:d,j:e,c:b,i:1});return b.innerHTML},\nprettyPrint:e=e=function(a,d){function e(){for(var b=V.PR_SHOULD_USE_CONTINUATION?c.now()+250:Infinity;p -1\n }\n}\n\nfunction normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name)\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~!]/i.test(name) || name === '') {\n throw new TypeError('Invalid character in header field name: \"' + name + '\"')\n }\n return name.toLowerCase()\n}\n\nfunction normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value)\n }\n return value\n}\n\n// Build a destructive iterator for the value list\nfunction iteratorFor(items) {\n var iterator = {\n next: function() {\n var value = items.shift()\n return {done: value === undefined, value: value}\n }\n }\n\n if (support.iterable) {\n iterator[Symbol.iterator] = function() {\n return iterator\n }\n }\n\n return iterator\n}\n\nfunction Headers(headers) {\n this.map = {}\n\n if (headers instanceof Headers) {\n headers.forEach(function(value, name) {\n this.append(name, value)\n }, this)\n } else if (Array.isArray(headers)) {\n headers.forEach(function(header) {\n if (header.length != 2) {\n throw new TypeError('Headers constructor: expected name/value pair to be length 2, found' + header.length)\n }\n this.append(header[0], header[1])\n }, this)\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function(name) {\n this.append(name, headers[name])\n }, this)\n }\n}\n\nHeaders.prototype.append = function(name, value) {\n name = normalizeName(name)\n value = normalizeValue(value)\n var oldValue = this.map[name]\n this.map[name] = oldValue ? oldValue + ', ' + value : value\n}\n\nHeaders.prototype['delete'] = function(name) {\n delete this.map[normalizeName(name)]\n}\n\nHeaders.prototype.get = function(name) {\n name = normalizeName(name)\n return this.has(name) ? this.map[name] : null\n}\n\nHeaders.prototype.has = function(name) {\n return this.map.hasOwnProperty(normalizeName(name))\n}\n\nHeaders.prototype.set = function(name, value) {\n this.map[normalizeName(name)] = normalizeValue(value)\n}\n\nHeaders.prototype.forEach = function(callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this)\n }\n }\n}\n\nHeaders.prototype.keys = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push(name)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.values = function() {\n var items = []\n this.forEach(function(value) {\n items.push(value)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.entries = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push([name, value])\n })\n return iteratorFor(items)\n}\n\nif (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n}\n\nfunction consumed(body) {\n if (body._noBody) return\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'))\n }\n body.bodyUsed = true\n}\n\nfunction fileReaderReady(reader) {\n return new Promise(function(resolve, reject) {\n reader.onload = function() {\n resolve(reader.result)\n }\n reader.onerror = function() {\n reject(reader.error)\n }\n })\n}\n\nfunction readBlobAsArrayBuffer(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n reader.readAsArrayBuffer(blob)\n return promise\n}\n\nfunction readBlobAsText(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n var match = /charset=([A-Za-z0-9_-]+)/.exec(blob.type)\n var encoding = match ? match[1] : 'utf-8'\n reader.readAsText(blob, encoding)\n return promise\n}\n\nfunction readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf)\n var chars = new Array(view.length)\n\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i])\n }\n return chars.join('')\n}\n\nfunction bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0)\n } else {\n var view = new Uint8Array(buf.byteLength)\n view.set(new Uint8Array(buf))\n return view.buffer\n }\n}\n\nfunction Body() {\n this.bodyUsed = false\n\n this._initBody = function(body) {\n /*\n fetch-mock wraps the Response object in an ES6 Proxy to\n provide useful test harness features such as flush. However, on\n ES5 browsers without fetch or Proxy support pollyfills must be used;\n the proxy-pollyfill is unable to proxy an attribute unless it exists\n on the object before the Proxy is created. This change ensures\n Response.bodyUsed exists on the instance, while maintaining the\n semantic of setting Request.bodyUsed in the constructor before\n _initBody is called.\n */\n // eslint-disable-next-line no-self-assign\n this.bodyUsed = this.bodyUsed\n this._bodyInit = body\n if (!body) {\n this._noBody = true;\n this._bodyText = ''\n } else if (typeof body === 'string') {\n this._bodyText = body\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString()\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer)\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer])\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body)\n } else {\n this._bodyText = body = Object.prototype.toString.call(body)\n }\n\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8')\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type)\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n }\n }\n }\n\n if (support.blob) {\n this.blob = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob')\n } else {\n return Promise.resolve(new Blob([this._bodyText]))\n }\n }\n }\n\n this.arrayBuffer = function() {\n if (this._bodyArrayBuffer) {\n var isConsumed = consumed(this)\n if (isConsumed) {\n return isConsumed\n } else if (ArrayBuffer.isView(this._bodyArrayBuffer)) {\n return Promise.resolve(\n this._bodyArrayBuffer.buffer.slice(\n this._bodyArrayBuffer.byteOffset,\n this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength\n )\n )\n } else {\n return Promise.resolve(this._bodyArrayBuffer)\n }\n } else if (support.blob) {\n return this.blob().then(readBlobAsArrayBuffer)\n } else {\n throw new Error('could not read as ArrayBuffer')\n }\n }\n\n this.text = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text')\n } else {\n return Promise.resolve(this._bodyText)\n }\n }\n\n if (support.formData) {\n this.formData = function() {\n return this.text().then(decode)\n }\n }\n\n this.json = function() {\n return this.text().then(JSON.parse)\n }\n\n return this\n}\n\n// HTTP methods whose capitalization should be normalized\nvar methods = ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'TRACE']\n\nfunction normalizeMethod(method) {\n var upcased = method.toUpperCase()\n return methods.indexOf(upcased) > -1 ? upcased : method\n}\n\nfunction Request(input, options) {\n if (!(this instanceof Request)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n\n options = options || {}\n var body = options.body\n\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read')\n }\n this.url = input.url\n this.credentials = input.credentials\n if (!options.headers) {\n this.headers = new Headers(input.headers)\n }\n this.method = input.method\n this.mode = input.mode\n this.signal = input.signal\n if (!body && input._bodyInit != null) {\n body = input._bodyInit\n input.bodyUsed = true\n }\n } else {\n this.url = String(input)\n }\n\n this.credentials = options.credentials || this.credentials || 'same-origin'\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers)\n }\n this.method = normalizeMethod(options.method || this.method || 'GET')\n this.mode = options.mode || this.mode || null\n this.signal = options.signal || this.signal || (function () {\n if ('AbortController' in g) {\n var ctrl = new AbortController();\n return ctrl.signal;\n }\n }());\n this.referrer = null\n\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests')\n }\n this._initBody(body)\n\n if (this.method === 'GET' || this.method === 'HEAD') {\n if (options.cache === 'no-store' || options.cache === 'no-cache') {\n // Search for a '_' parameter in the query string\n var reParamSearch = /([?&])_=[^&]*/\n if (reParamSearch.test(this.url)) {\n // If it already exists then set the value with the current time\n this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime())\n } else {\n // Otherwise add a new '_' parameter to the end with the current time\n var reQueryString = /\\?/\n this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime()\n }\n }\n }\n}\n\nRequest.prototype.clone = function() {\n return new Request(this, {body: this._bodyInit})\n}\n\nfunction decode(body) {\n var form = new FormData()\n body\n .trim()\n .split('&')\n .forEach(function(bytes) {\n if (bytes) {\n var split = bytes.split('=')\n var name = split.shift().replace(/\\+/g, ' ')\n var value = split.join('=').replace(/\\+/g, ' ')\n form.append(decodeURIComponent(name), decodeURIComponent(value))\n }\n })\n return form\n}\n\nfunction parseHeaders(rawHeaders) {\n var headers = new Headers()\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ')\n // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill\n // https://github.com/github/fetch/issues/748\n // https://github.com/zloirock/core-js/issues/751\n preProcessedHeaders\n .split('\\r')\n .map(function(header) {\n return header.indexOf('\\n') === 0 ? header.substr(1, header.length) : header\n })\n .forEach(function(line) {\n var parts = line.split(':')\n var key = parts.shift().trim()\n if (key) {\n var value = parts.join(':').trim()\n try {\n headers.append(key, value)\n } catch (error) {\n console.warn('Response ' + error.message)\n }\n }\n })\n return headers\n}\n\nBody.call(Request.prototype)\n\nfunction Response(bodyInit, options) {\n if (!(this instanceof Response)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n if (!options) {\n options = {}\n }\n\n this.type = 'default'\n this.status = options.status === undefined ? 200 : options.status\n if (this.status < 200 || this.status > 599) {\n throw new RangeError(\"Failed to construct 'Response': The status provided (0) is outside the range [200, 599].\")\n }\n this.ok = this.status >= 200 && this.status < 300\n this.statusText = options.statusText === undefined ? '' : '' + options.statusText\n this.headers = new Headers(options.headers)\n this.url = options.url || ''\n this._initBody(bodyInit)\n}\n\nBody.call(Response.prototype)\n\nResponse.prototype.clone = function() {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n })\n}\n\nResponse.error = function() {\n var response = new Response(null, {status: 200, statusText: ''})\n response.ok = false\n response.status = 0\n response.type = 'error'\n return response\n}\n\nvar redirectStatuses = [301, 302, 303, 307, 308]\n\nResponse.redirect = function(url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code')\n }\n\n return new Response(null, {status: status, headers: {location: url}})\n}\n\nvar DOMException = g.DOMException\ntry {\n new DOMException()\n} catch (err) {\n DOMException = function(message, name) {\n this.message = message\n this.name = name\n var error = Error(message)\n this.stack = error.stack\n }\n DOMException.prototype = Object.create(Error.prototype)\n DOMException.prototype.constructor = DOMException\n}\n\nfunction fetch_fetch(input, init) {\n return new Promise(function(resolve, reject) {\n var request = new Request(input, init)\n\n if (request.signal && request.signal.aborted) {\n return reject(new DOMException('Aborted', 'AbortError'))\n }\n\n var xhr = new XMLHttpRequest()\n\n function abortXhr() {\n xhr.abort()\n }\n\n xhr.onload = function() {\n var options = {\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n }\n // This check if specifically for when a user fetches a file locally from the file system\n // Only if the status is out of a normal range\n if (request.url.indexOf('file://') === 0 && (xhr.status < 200 || xhr.status > 599)) {\n options.status = 200;\n } else {\n options.status = xhr.status;\n }\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n var body = 'response' in xhr ? xhr.response : xhr.responseText\n setTimeout(function() {\n resolve(new Response(body, options))\n }, 0)\n }\n\n xhr.onerror = function() {\n setTimeout(function() {\n reject(new TypeError('Network request failed'))\n }, 0)\n }\n\n xhr.ontimeout = function() {\n setTimeout(function() {\n reject(new TypeError('Network request timed out'))\n }, 0)\n }\n\n xhr.onabort = function() {\n setTimeout(function() {\n reject(new DOMException('Aborted', 'AbortError'))\n }, 0)\n }\n\n function fixUrl(url) {\n try {\n return url === '' && g.location.href ? g.location.href : url\n } catch (e) {\n return url\n }\n }\n\n xhr.open(request.method, fixUrl(request.url), true)\n\n if (request.credentials === 'include') {\n xhr.withCredentials = true\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false\n }\n\n if ('responseType' in xhr) {\n if (support.blob) {\n xhr.responseType = 'blob'\n } else if (\n support.arrayBuffer\n ) {\n xhr.responseType = 'arraybuffer'\n }\n }\n\n if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers || (g.Headers && init.headers instanceof g.Headers))) {\n var names = [];\n Object.getOwnPropertyNames(init.headers).forEach(function(name) {\n names.push(normalizeName(name))\n xhr.setRequestHeader(name, normalizeValue(init.headers[name]))\n })\n request.headers.forEach(function(value, name) {\n if (names.indexOf(name) === -1) {\n xhr.setRequestHeader(name, value)\n }\n })\n } else {\n request.headers.forEach(function(value, name) {\n xhr.setRequestHeader(name, value)\n })\n }\n\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr)\n\n xhr.onreadystatechange = function() {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr)\n }\n }\n }\n\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n })\n}\n\nfetch_fetch.polyfill = true\n\nif (!g.fetch) {\n g.fetch = fetch_fetch\n g.Headers = Headers\n g.Request = Request\n g.Response = Response\n}\n\n;// ./src/@types/index.ts\nvar AnglesUnitEnum;\n(function (AnglesUnitEnum) {\n AnglesUnitEnum[\"NONE\"] = \"none\";\n AnglesUnitEnum[\"DEGREES\"] = \"deg\";\n AnglesUnitEnum[\"GRADIANS\"] = \"grad\";\n AnglesUnitEnum[\"RADIANS\"] = \"rad\";\n AnglesUnitEnum[\"TURNS\"] = \"turn\";\n})(AnglesUnitEnum || (AnglesUnitEnum = {}));\nvar ColorUnitEnum;\n(function (ColorUnitEnum) {\n ColorUnitEnum[\"NONE\"] = \"none\";\n ColorUnitEnum[\"PERCENT\"] = \"percent\";\n})(ColorUnitEnum || (ColorUnitEnum = {}));\nvar CMYKFunctionEnum;\n(function (CMYKFunctionEnum) {\n CMYKFunctionEnum[\"DEVICE_CMYK\"] = \"device-cmyk\";\n CMYKFunctionEnum[\"CMYK\"] = \"cmyk\";\n})(CMYKFunctionEnum || (CMYKFunctionEnum = {}));\n\n;// ./src/constants/enums.ts\nvar ColorModel;\n(function (ColorModel) {\n ColorModel[\"HEX\"] = \"HEX\";\n ColorModel[\"RGB\"] = \"RGB\";\n ColorModel[\"HWB\"] = \"HWB\";\n ColorModel[\"HSL\"] = \"HSL\";\n ColorModel[\"CIELab\"] = \"CIELab\";\n ColorModel[\"LCH\"] = \"LCH\";\n ColorModel[\"CMYK\"] = \"CMYK\";\n})(ColorModel || (ColorModel = {}));\nvar Harmony;\n(function (Harmony) {\n Harmony[\"ANALOGOUS\"] = \"ANALOGOUS\";\n Harmony[\"COMPLEMENTARY\"] = \"COMPLEMENTARY\";\n Harmony[\"SPLIT_COMPLEMENTARY\"] = \"SPLIT_COMPLEMENTARY\";\n Harmony[\"TRIADIC\"] = \"TRIADIC\";\n Harmony[\"TETRADIC\"] = \"TETRADIC\";\n Harmony[\"SQUARE\"] = \"SQUARE\";\n})(Harmony || (Harmony = {}));\nvar Mix;\n(function (Mix) {\n Mix[\"ADDITIVE\"] = \"ADDITIVE\";\n Mix[\"SUBTRACTIVE\"] = \"SUBTRACTIVE\";\n})(Mix || (Mix = {}));\nvar ColorKeywords;\n(function (ColorKeywords) {\n ColorKeywords[\"black\"] = \"#000000\";\n ColorKeywords[\"silver\"] = \"#C0C0C0\";\n ColorKeywords[\"gray\"] = \"#808080\";\n ColorKeywords[\"white\"] = \"#FFFFFF\";\n ColorKeywords[\"maroon\"] = \"#800000\";\n ColorKeywords[\"red\"] = \"#FF0000\";\n ColorKeywords[\"purple\"] = \"#800080\";\n ColorKeywords[\"fuchsia\"] = \"#FF00FF\";\n ColorKeywords[\"green\"] = \"#008000\";\n ColorKeywords[\"lime\"] = \"#00FF00\";\n ColorKeywords[\"olive\"] = \"#808000\";\n ColorKeywords[\"yellow\"] = \"#FFFF00\";\n ColorKeywords[\"navy\"] = \"#000080\";\n ColorKeywords[\"blue\"] = \"#0000FF\";\n ColorKeywords[\"teal\"] = \"#008080\";\n ColorKeywords[\"aqua\"] = \"#00FFFF\";\n ColorKeywords[\"orange\"] = \"#FFA500\";\n ColorKeywords[\"aliceblue\"] = \"#F0F8FF\";\n ColorKeywords[\"antiquewhite\"] = \"#FAEBD7\";\n ColorKeywords[\"aquamarine\"] = \"#7FFFD4\";\n ColorKeywords[\"azure\"] = \"#F0FFFF\";\n ColorKeywords[\"beige\"] = \"#F5F5DC\";\n ColorKeywords[\"bisque\"] = \"#FFE4C4\";\n ColorKeywords[\"blanchedalmond\"] = \"#FFEBCD\";\n ColorKeywords[\"blueviolet\"] = \"#8A2BE2\";\n ColorKeywords[\"brown\"] = \"#A52A2A\";\n ColorKeywords[\"burlywood\"] = \"#DEB887\";\n ColorKeywords[\"cadetblue\"] = \"#5F9EA0\";\n ColorKeywords[\"chartreuse\"] = \"#7FFF00\";\n ColorKeywords[\"chocolate\"] = \"#D2691E\";\n ColorKeywords[\"coral\"] = \"#FF7F50\";\n ColorKeywords[\"cornflowerblue\"] = \"#6495ED\";\n ColorKeywords[\"cornsilk\"] = \"#FFF8DC\";\n ColorKeywords[\"crimson\"] = \"#DC143C\";\n ColorKeywords[\"cyan\"] = \"#00FFFF\";\n ColorKeywords[\"darkblue\"] = \"#00008B\";\n ColorKeywords[\"darkcyan\"] = \"#008B8B\";\n ColorKeywords[\"darkgoldenrod\"] = \"#B8860B\";\n ColorKeywords[\"darkgray\"] = \"#A9A9A9\";\n ColorKeywords[\"darkgreen\"] = \"#006400\";\n ColorKeywords[\"darkgrey\"] = \"#A9A9A9\";\n ColorKeywords[\"darkkhaki\"] = \"#BDB76B\";\n ColorKeywords[\"darkmagenta\"] = \"#8B008B\";\n ColorKeywords[\"darkolivegreen\"] = \"#556B2F\";\n ColorKeywords[\"darkorange\"] = \"#FF8C00\";\n ColorKeywords[\"darkorchid\"] = \"#9932CC\";\n ColorKeywords[\"darkred\"] = \"#8B0000\";\n ColorKeywords[\"darksalmon\"] = \"#E9967A\";\n ColorKeywords[\"darkseagreen\"] = \"#8FBC8F\";\n ColorKeywords[\"darkslateblue\"] = \"#483D8B\";\n ColorKeywords[\"darkslategray\"] = \"#2F4F4F\";\n ColorKeywords[\"darkslategrey\"] = \"#2F4F4F\";\n ColorKeywords[\"darkturquoise\"] = \"#00CED1\";\n ColorKeywords[\"darkviolet\"] = \"#9400D3\";\n ColorKeywords[\"deeppink\"] = \"#FF1493\";\n ColorKeywords[\"deepskyblue\"] = \"#00BFFF\";\n ColorKeywords[\"dimgray\"] = \"#696969\";\n ColorKeywords[\"dimgrey\"] = \"#696969\";\n ColorKeywords[\"dodgerblue\"] = \"#1E90FF\";\n ColorKeywords[\"firebrick\"] = \"#B22222\";\n ColorKeywords[\"floralwhite\"] = \"#FFFAF0\";\n ColorKeywords[\"forestgreen\"] = \"#228B22\";\n ColorKeywords[\"gainsboro\"] = \"#DCDCDC\";\n ColorKeywords[\"ghostwhite\"] = \"#F8F8FF\";\n ColorKeywords[\"gold\"] = \"#FFD700\";\n ColorKeywords[\"goldenrod\"] = \"#DAA520\";\n ColorKeywords[\"greenyellow\"] = \"#ADFF2F\";\n ColorKeywords[\"grey\"] = \"#808080\";\n ColorKeywords[\"honeydew\"] = \"#F0FFF0\";\n ColorKeywords[\"hotpink\"] = \"#FF69B4\";\n ColorKeywords[\"indianred\"] = \"#CD5C5C\";\n ColorKeywords[\"indigo\"] = \"#4B0082\";\n ColorKeywords[\"ivory\"] = \"#FFFFF0\";\n ColorKeywords[\"khaki\"] = \"#F0E68C\";\n ColorKeywords[\"lavender\"] = \"#E6E6FA\";\n ColorKeywords[\"lavenderblush\"] = \"#FFF0F5\";\n ColorKeywords[\"lawngreen\"] = \"#7CFC00\";\n ColorKeywords[\"lemonchiffon\"] = \"#FFFACD\";\n ColorKeywords[\"lightblue\"] = \"#ADD8E6\";\n ColorKeywords[\"lightcoral\"] = \"#F08080\";\n ColorKeywords[\"lightcyan\"] = \"#E0FFFF\";\n ColorKeywords[\"lightgoldenrodyellow\"] = \"#FAFAD2\";\n ColorKeywords[\"lightgray\"] = \"#D3D3D3\";\n ColorKeywords[\"lightgreen\"] = \"#90EE90\";\n ColorKeywords[\"lightgrey\"] = \"#D3D3D3\";\n ColorKeywords[\"lightpink\"] = \"#FFB6C1\";\n ColorKeywords[\"lightsalmon\"] = \"#FFA07A\";\n ColorKeywords[\"lightseagreen\"] = \"#20B2AA\";\n ColorKeywords[\"lightskyblue\"] = \"#87CEFA\";\n ColorKeywords[\"lightslategray\"] = \"#778899\";\n ColorKeywords[\"lightslategrey\"] = \"#778899\";\n ColorKeywords[\"lightsteelblue\"] = \"#B0C4DE\";\n ColorKeywords[\"lightyellow\"] = \"#FFFFE0\";\n ColorKeywords[\"limegreen\"] = \"#32CD32\";\n ColorKeywords[\"linen\"] = \"#FAF0E6\";\n ColorKeywords[\"magenta\"] = \"#FF00FF\";\n ColorKeywords[\"mediumaquamarine\"] = \"#66CDAA\";\n ColorKeywords[\"mediumblue\"] = \"#0000CD\";\n ColorKeywords[\"mediumorchid\"] = \"#BA55D3\";\n ColorKeywords[\"mediumpurple\"] = \"#9370DB\";\n ColorKeywords[\"mediumseagreen\"] = \"#3CB371\";\n ColorKeywords[\"mediumslateblue\"] = \"#7B68EE\";\n ColorKeywords[\"mediumspringgreen\"] = \"#00FA9A\";\n ColorKeywords[\"mediumturquoise\"] = \"#48D1CC\";\n ColorKeywords[\"mediumvioletred\"] = \"#C71585\";\n ColorKeywords[\"midnightblue\"] = \"#191970\";\n ColorKeywords[\"mintcream\"] = \"#F5FFFA\";\n ColorKeywords[\"mistyrose\"] = \"#FFE4E1\";\n ColorKeywords[\"moccasin\"] = \"#FFE4B5\";\n ColorKeywords[\"navajowhite\"] = \"#FFDEAD\";\n ColorKeywords[\"oldlace\"] = \"#FDF5E6\";\n ColorKeywords[\"olivedrab\"] = \"#6B8E23\";\n ColorKeywords[\"orangered\"] = \"#FF4500\";\n ColorKeywords[\"orchid\"] = \"#DA70D6\";\n ColorKeywords[\"palegoldenrod\"] = \"#EEE8AA\";\n ColorKeywords[\"palegreen\"] = \"#98FB98\";\n ColorKeywords[\"paleturquoise\"] = \"#AFEEEE\";\n ColorKeywords[\"palevioletred\"] = \"#DB7093\";\n ColorKeywords[\"papayawhip\"] = \"#FFEFD5\";\n ColorKeywords[\"peachpuff\"] = \"#FFDAB9\";\n ColorKeywords[\"peru\"] = \"#CD853F\";\n ColorKeywords[\"pink\"] = \"#FFC0CB\";\n ColorKeywords[\"plum\"] = \"#DDA0DD\";\n ColorKeywords[\"powderblue\"] = \"#B0E0E6\";\n ColorKeywords[\"rosybrown\"] = \"#BC8F8F\";\n ColorKeywords[\"royalblue\"] = \"#4169E1\";\n ColorKeywords[\"saddlebrown\"] = \"#8B4513\";\n ColorKeywords[\"salmon\"] = \"#FA8072\";\n ColorKeywords[\"sandybrown\"] = \"#F4A460\";\n ColorKeywords[\"seagreen\"] = \"#2E8B57\";\n ColorKeywords[\"seashell\"] = \"#FFF5EE\";\n ColorKeywords[\"sienna\"] = \"#A0522D\";\n ColorKeywords[\"skyblue\"] = \"#87CEEB\";\n ColorKeywords[\"slateblue\"] = \"#6A5ACD\";\n ColorKeywords[\"slategray\"] = \"#708090\";\n ColorKeywords[\"slategrey\"] = \"#708090\";\n ColorKeywords[\"snow\"] = \"#FFFAFA\";\n ColorKeywords[\"springgreen\"] = \"#00FF7F\";\n ColorKeywords[\"steelblue\"] = \"#4682B4\";\n ColorKeywords[\"tan\"] = \"#D2B48C\";\n ColorKeywords[\"thistle\"] = \"#D8BFD8\";\n ColorKeywords[\"tomato\"] = \"#FF6347\";\n ColorKeywords[\"turquoise\"] = \"#40E0D0\";\n ColorKeywords[\"violet\"] = \"#EE82EE\";\n ColorKeywords[\"wheat\"] = \"#F5DEB3\";\n ColorKeywords[\"whitesmoke\"] = \"#F5F5F5\";\n ColorKeywords[\"yellowgreen\"] = \"#9ACD32\";\n ColorKeywords[\"rebeccapurple\"] = \"#663399\";\n})(ColorKeywords || (ColorKeywords = {}));\n\n;// ./src/constants/regexps.ts\n\nconst COLORREGS = {\n [ColorModel.HEX]: /^#(?:(?[a-f\\d])(?[a-f\\d])(?[a-f\\d])(?
[a-f\\d])?|(?[a-f\\d]{2})(?[a-f\\d]{2})(?[a-f\\d]{2})(?[a-f\\d]{2})?)$/i,\n [ColorModel.RGB]: /^rgba?\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?(?:\\d*\\.)?\\d+))?|(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.HWB]: /^hwb\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?(?:\\d*\\.)?\\d+)%\\s+(?(?:\\d*\\.)?\\d+)%(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?\\s+(?(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.HSL]: /^hsla?\\s*\\(\\s*(?:(?-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s*,\\s*(?(?:\\d*\\.)?\\d+)%\\s*,\\s*(?(?:\\d*\\.)?\\d+)%(?:\\s*,\\s*(?(?:\\d*\\.)?\\d+))?|(?-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?(?:\\d*\\.)?\\d+)%?\\s+(?(?:\\d*\\.)?\\d+)%?(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?\\s+(?(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.CIELab]: /^lab\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.LCH]: /^lch\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+%?)\\s+(?-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?|from\\s+(?(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n [ColorModel.CMYK]: /^(?:device-cmyk|cmyk)\\s*\\(\\s*(?:(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?(?:\\d*\\.)?\\d+))?|(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)\\s+(?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?(?:\\d*\\.)?\\d+%?))?)\\s*\\)$/\n};\nconst CALC = {\n REGEXP: /^calc\\(\\s*(?[\\d./*+-\\w\\s]+)\\s*\\)$/,\n SCOPED: /\\(\\s*([^()]+)\\s*\\)/g,\n DIVISION: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\/\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n MULTIPLICATION: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\*\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n SUM: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\+\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n REST: /\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*-\\s*(?(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/\n};\nconst HSL_HUE = /^(?-?(?:\\d*\\.)?\\d+)(?(?:deg|grad|rad|turn)?)$/;\nconst PCENT = /^(-?\\d+(?:\\.\\d+)?|-?\\.\\d+)%$/;\nconst HEX = /^0x([a-f\\d]{1,2})$/i;\nconst TEMPLATE_VAR = /\\{(\\d+)\\}/g;\nconst COMMAS_AND_NEXT_CHARS = /,( +|\\d+)/g;\nconst SPACES = / +/;\n\n;// ./src/constants/index.ts\n\n\nconst MAX_DECIMALS = 6;\nconst DEFAULT_BLEND_STEPS = 5;\nconst DEFAULT_SHADES_TINTS_STEPS = 5;\nconst BASE_255 = 255;\nconst MAX_HUE = 360;\nconst MAX_PCENT = 100;\nconst MAX_ALPHA = 1;\nconst MAX_LAB = 125;\nconst MAX_LCH_C = 150;\nconst GRADIANS = 10 / 9;\nconst COLOR_KEYS = Object.keys(ColorKeywords);\nconst COLOR_PROPS = Object.freeze({\n HEX: ['R', 'G', 'B', 'A'],\n RGB: ['R', 'G', 'B', 'A'],\n HSL: ['H', 'S', 'L', 'A'],\n HWB: ['H', 'W', 'B', 'A'],\n CIELab: ['L', 'a', 'b', 'A'],\n LCH: ['L', 'C', 'H', 'A'],\n CMYK: ['C', 'M', 'Y', 'K', 'A']\n});\nconst VALID_COLOR_OBJECTS = Object.freeze({\n ABGR: ColorModel.RGB,\n ABHW: ColorModel.HWB,\n ACHL: ColorModel.LCH,\n ACKMY: ColorModel.CMYK,\n AHLS: ColorModel.HSL,\n ALAB: ColorModel.CIELab,\n BGR: ColorModel.RGB,\n BHW: ColorModel.HWB,\n CHL: ColorModel.LCH,\n CKMY: ColorModel.CMYK,\n HLS: ColorModel.HSL,\n LAB: ColorModel.CIELab\n});\nconst DEFAULT_OPTIONS = Object.freeze({\n decimals: MAX_DECIMALS,\n legacyCSS: false,\n spacesAfterCommas: false,\n anglesUnit: AnglesUnitEnum.NONE,\n rgbUnit: ColorUnitEnum.NONE,\n labUnit: ColorUnitEnum.NONE,\n lchUnit: ColorUnitEnum.NONE,\n cmykUnit: ColorUnitEnum.PERCENT,\n alphaUnit: ColorUnitEnum.NONE,\n cmykFunction: CMYKFunctionEnum.DEVICE_CMYK\n});\nconst ERRORS = Object.freeze({\n NOT_ACCEPTED_INPUT: `The provided string color doesn't have a correct format`,\n NOT_A_VALID_RELATIVE_COLOR: 'is not a valid operation for a relative color'\n});\n\n\n\n;// ./src/utilities/index.ts\n\n\nconst getOrderedArrayString = (keys) => [...keys].sort().join('').toUpperCase();\nconst isString = (input) => typeof input === 'string';\nconst isNumber = (input) => typeof input === 'number';\nconst isBoolean = (input) => typeof input === 'boolean';\nconst isUndefined = (input) => input === undefined;\nconst getColorModel = (color) => {\n return VALID_COLOR_OBJECTS[getOrderedArrayString(Object.keys(color))];\n};\nconst isRGBObject = (color) => getColorModel(color) === ColorModel.RGB;\nconst isHSLObject = (color) => getColorModel(color) === ColorModel.HSL;\nconst isHWBObject = (color) => getColorModel(color) === ColorModel.HWB;\nconst isCIELabObject = (color) => getColorModel(color) === ColorModel.CIELab;\nconst isLCHObject = (color) => getColorModel(color) === ColorModel.LCH;\nconst isCMYKObject = (color) => getColorModel(color) === ColorModel.CMYK;\nconst percentNumber = (percent) => {\n return +`${percent}`.replace(PCENT, '$1');\n};\nconst percent = (percent) => PCENT.test(`${percent}`)\n ? percentNumber(percent)\n : Math.min(+percent, 100);\nconst getDEC = (hex) => {\n if (hex.length === 1) {\n hex += hex;\n }\n return parseInt(hex, 16);\n};\nconst getHEX = (number) => {\n const hex = round(number, 0).toString(16).toUpperCase();\n if (hex.length === 1) {\n return `0x0${hex}`;\n }\n return `0x${hex}`;\n};\nconst toHEX = (h) => {\n let hex = round(h, 0).toString(16).toUpperCase();\n if (hex.length === 1) {\n hex = `0${hex}`;\n }\n return hex;\n};\nconst from255NumberToPercent = (value, decimals) => round(value / BASE_255 * 100, decimals);\nconst from125NumberToPercent = (value, decimals) => round(value / MAX_LAB * 100, decimals);\nconst from150NumberToPercent = (value, decimals) => round(value / MAX_LCH_C * 100, decimals);\nconst getBase255Number = (color, alpha = false) => {\n if (!alpha && PCENT.test(color)) {\n return Math.min(BASE_255 * percentNumber(color) / 100, BASE_255);\n }\n if (HEX.test(color)) {\n if (color.length === 3) {\n color += color.slice(-1);\n }\n return alpha\n ? round(color) / BASE_255\n : round(color);\n }\n return Math.min(+color, alpha ? 1 : BASE_255);\n};\nconst getBase125Number = (color) => {\n if (PCENT.test(color)) {\n return minmax(MAX_LAB * percentNumber(color) / 100, -MAX_LAB, MAX_LAB);\n }\n return minmax(+color, -MAX_LAB, MAX_LAB);\n};\nconst getBase150Number = (color) => {\n if (PCENT.test(color)) {\n return minmax(MAX_LCH_C * percentNumber(color) / 100, -MAX_LCH_C, MAX_LCH_C);\n }\n return minmax(+color, -MAX_LCH_C, MAX_LCH_C);\n};\nconst getCMYKNumber = (color, base100) => {\n const value = PCENT.test(color)\n ? percentNumber(color)\n : +color;\n if (base100) {\n return Math.min(value * 100, 100);\n }\n return Math.min(value, 100);\n};\nconst round = (value, decimals = MAX_DECIMALS) => {\n const exp = Math.pow(10, decimals);\n return Math.round(+value * exp) / exp;\n};\nconst minmax = (n, min, max) => Math.max(min, Math.min(n, max));\nconst degrees = (radian) => radian * 180 / Math.PI;\nconst radians = (degrees) => degrees * Math.PI / 180;\nconst normalizeHue = (hue) => {\n if (isString(hue)) {\n const matches = hue.match(HSL_HUE);\n const groups = matches.groups;\n const value = +groups.number;\n const units = groups.units;\n switch (units) {\n case AnglesUnitEnum.RADIANS:\n hue = round(degrees(value));\n break;\n case AnglesUnitEnum.TURNS:\n hue = round(value * MAX_HUE);\n break;\n case AnglesUnitEnum.GRADIANS:\n hue = round(9 / 10 * value);\n break;\n case AnglesUnitEnum.DEGREES:\n default:\n hue = value;\n }\n }\n if (hue >= MAX_HUE || hue < 0) {\n hue -= Math.floor(hue / MAX_HUE) * MAX_HUE;\n }\n return hue;\n};\nconst normalizeAlpha = (alpha) => {\n if (isString(alpha)) {\n if (PCENT.test(alpha)) {\n alpha = percentNumber(alpha) / 100;\n }\n else {\n alpha = +alpha;\n }\n }\n return (isNaN(+alpha) || alpha > MAX_ALPHA) ? MAX_ALPHA : round(alpha);\n};\nconst translateDegrees = (degrees, units) => {\n let hue;\n switch (units) {\n case AnglesUnitEnum.RADIANS:\n hue = round(radians(degrees));\n break;\n case AnglesUnitEnum.TURNS:\n hue = round(degrees / MAX_HUE);\n break;\n case AnglesUnitEnum.GRADIANS:\n hue = round(GRADIANS * degrees);\n break;\n case AnglesUnitEnum.DEGREES:\n case AnglesUnitEnum.NONE:\n default:\n hue = degrees;\n }\n return hue;\n};\nconst isHarmony = (param) => {\n return `${param}` in Harmony;\n};\nconst isMix = (param) => {\n return `${param}` in Mix;\n};\nconst getAngleUnit = (unit) => {\n if (unit) {\n const angleUnitMatch = unit.match(HSL_HUE);\n const angleUnit = angleUnitMatch.groups.units;\n return angleUnit === ''\n ? AnglesUnitEnum.NONE\n : angleUnit;\n }\n return AnglesUnitEnum.NONE;\n};\n\n;// ./src/color/translators.ts\n\n\nconst MATRIX_LRGB_XYZ_D50 = [\n [0.4360747, 0.3850649, 0.1430804],\n [0.2225045, 0.7168786, 0.0606169],\n [0.0139322, 0.0971045, 0.7141733]\n];\nconst MATRIX_XYZ_D50_LRGB = [\n [3.1338561, -1.6168667, -0.4906146],\n [-0.9787684, 1.9161415, 0.033454],\n [0.0719453, -0.2289914, 1.4052427]\n];\nconst TRISTIMULUS_D50 = MATRIX_LRGB_XYZ_D50.map((matrix) => {\n return matrix.reduce((sum, value) => sum + value, 0);\n});\nconst hueToRgb = (t1, t2, hue) => {\n if (hue < 0) {\n hue += 6;\n }\n if (hue >= 6) {\n hue -= 6;\n }\n if (hue < 1) {\n return round(((t2 - t1) * hue + t1) * BASE_255);\n }\n else if (hue < 3) {\n return round(t2 * BASE_255);\n }\n else if (hue < 4) {\n return round(((t2 - t1) * (4 - hue) + t1) * BASE_255);\n }\n else {\n return round(t1 * BASE_255);\n }\n};\nconst rgbToLinearLightRgb = (value) => {\n return value <= 0.04045\n ? value / 12.92\n : ((value + 0.055) / 1.055) ** 2.4;\n};\nconst linearLightRgbToRgb = (value) => {\n return value <= 0.0031308\n ? 12.92 * value\n : 1.055 * (value ** (1 / 2.4)) - 0.055;\n};\nconst matrixVectorMultiplication = (v1, v2, v3, matrix) => {\n const result = [0, 0, 0];\n const linearRgb = [v1, v2, v3];\n matrix.forEach((array, index) => {\n array.forEach((value, mindex) => {\n result[index] += value * linearRgb[mindex];\n });\n });\n return result;\n};\nconst from_CIE_XYZ_D50_to_CIE_LAB = (x, y, z) => {\n const f = (t) => {\n return t > (6 / 29) ** 3\n ? Math.cbrt(t)\n : t / (3 * (6 / 29) ** 2) + (4 / 29);\n };\n const fx = f(x / TRISTIMULUS_D50[0]);\n const fy = f(y / TRISTIMULUS_D50[1]);\n const fz = f(z / TRISTIMULUS_D50[2]);\n return [\n 116 * fy - 16,\n 500 * (fx - fy),\n 200 * (fy - fz)\n ];\n};\nconst from_CIE_LAB_to_CIE_XYZ_D50 = (L, a, b) => {\n const f = (t) => {\n return t > 6 / 29\n ? t ** 3\n : 3 * (6 / 29) ** 2 * (t - 4 / 29);\n };\n const fl = (L + 16) / 116;\n const fa = a / 500;\n const fb = b / 200;\n return [\n TRISTIMULUS_D50[0] * f(fl + fa),\n TRISTIMULUS_D50[1] * f(fl),\n TRISTIMULUS_D50[2] * f(fl - fb)\n ];\n};\nconst hslToRgb = (H, S, L) => {\n H /= 60;\n S /= 100;\n L /= 100;\n const t2 = (L <= .5)\n ? L * (S + 1)\n : L + S - (L * S);\n const t1 = L * 2 - t2;\n const R = hueToRgb(t1, t2, H + 2);\n const G = hueToRgb(t1, t2, H);\n const B = hueToRgb(t1, t2, H - 2);\n return { R, G, B };\n};\nconst rgbToHsl = (R, G, B, A = 1) => {\n R /= BASE_255;\n G /= BASE_255;\n B /= BASE_255;\n A = Math.min(A, MAX_ALPHA);\n const MAX = Math.max(R, G, B);\n const MIN = Math.min(R, G, B);\n const D = MAX - MIN;\n let H = 0;\n let S = 0;\n const L = (MAX + MIN) / 2;\n if (D !== 0) {\n switch (MAX) {\n case R:\n H = ((G - B) / D) % 6;\n break;\n case G:\n H = (B - R) / D + 2;\n break;\n case B:\n H = (R - G) / D + 4;\n break;\n }\n H = round(H * 60);\n if (H < 0) {\n H += 360;\n }\n S = D / (1 - Math.abs(2 * L - 1));\n }\n return {\n H,\n S: round(S * 100),\n L: round(L * 100),\n A\n };\n};\nconst rgbToLab = (R, G, B) => {\n const LINEAR_LIGHT_RGB = [\n R / BASE_255,\n G / BASE_255,\n B / BASE_255\n ].map(rgbToLinearLightRgb);\n const CIE_XYZ_D50 = matrixVectorMultiplication(LINEAR_LIGHT_RGB[0], LINEAR_LIGHT_RGB[1], LINEAR_LIGHT_RGB[2], MATRIX_LRGB_XYZ_D50);\n const CIE_LAB = from_CIE_XYZ_D50_to_CIE_LAB(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2]);\n return {\n L: CIE_LAB[0],\n a: CIE_LAB[1],\n b: CIE_LAB[2]\n };\n};\nconst labToRgb = (L, a, b) => {\n const CIE_XYZ_D50 = from_CIE_LAB_to_CIE_XYZ_D50(L, a, b);\n const LINEAR_LIGHT_RGB = matrixVectorMultiplication(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2], MATRIX_XYZ_D50_LRGB);\n const rgb = LINEAR_LIGHT_RGB.map(linearLightRgbToRgb);\n return {\n R: minmax(rgb[0] * BASE_255, 0, BASE_255),\n G: minmax(rgb[1] * BASE_255, 0, BASE_255),\n B: minmax(rgb[2] * BASE_255, 0, BASE_255)\n };\n};\nconst labToLch = (L, a, b) => {\n const C = Math.sqrt(a ** 2 + b ** 2);\n const H = degrees(Math.atan2(b, a));\n return {\n L,\n C,\n H: normalizeHue(H)\n };\n};\nconst lchToLab = (L, C, H) => {\n const radH = radians(H);\n const a = C * Math.cos(radH);\n const b = C * Math.sin(radH);\n return {\n L,\n a,\n b\n };\n};\nconst rgbToLch = (R, G, B) => {\n const lab = rgbToLab(R, G, B);\n return labToLch(lab.L, lab.a, lab.b);\n};\nconst lchToRgb = (L, C, H) => {\n const lab = lchToLab(L, C, H);\n return labToRgb(lab.L, lab.a, lab.b);\n};\nconst rgbToHwb = (R, G, B, A = 1) => {\n const hsl = rgbToHsl(R, G, B, A);\n return {\n H: hsl.H,\n W: round(Math.min(R, G, B) / BASE_255 * 100),\n B: round((1 - Math.max(R, G, B) / BASE_255) * 100),\n A\n };\n};\nconst hwbToRgb = (H, W, B) => {\n W /= 100;\n B /= 100;\n const v = 1 - B;\n const c = v - W;\n const x = c * (1 - Math.abs((H / 60) % 2 - 1));\n let rgbR;\n let rgbG;\n let rgbB;\n if (H < 60) {\n rgbR = c;\n rgbG = x;\n rgbB = 0;\n }\n else if (H >= 60 && H < 120) {\n rgbR = x;\n rgbG = c;\n rgbB = 0;\n }\n else if (H >= 120 && H < 180) {\n rgbR = 0;\n rgbG = c;\n rgbB = x;\n }\n else if (H >= 180 && H < 240) {\n rgbR = 0;\n rgbG = x;\n rgbB = c;\n }\n else if (H >= 240 && H < 300) {\n rgbR = x;\n rgbG = 0;\n rgbB = c;\n }\n else {\n rgbR = c;\n rgbG = 0;\n rgbB = x;\n }\n rgbR += W;\n rgbG += W;\n rgbB += W;\n return {\n R: minmax(rgbR * BASE_255, 0, BASE_255),\n G: minmax(rgbG * BASE_255, 0, BASE_255),\n B: minmax(rgbB * BASE_255, 0, BASE_255)\n };\n};\nconst cmykToRgb = (C, M, Y, K) => {\n K = 1 - K;\n return {\n R: minmax(round(BASE_255 * (1 - C) * K), 0, BASE_255),\n G: minmax(round(BASE_255 * (1 - M) * K), 0, BASE_255),\n B: minmax(round(BASE_255 * (1 - Y) * K), 0, BASE_255)\n };\n};\nconst rgbToCmyk = (R, G, B) => {\n R /= BASE_255;\n G /= BASE_255;\n B /= BASE_255;\n const K = 1 - Math.max(R, G, B);\n const K1 = 1 - K;\n const C = K1 && (K1 - R) / K1;\n const M = K1 && (K1 - G) / K1;\n const Y = K1 && (K1 - B) / K1;\n return {\n C: round(C * 100),\n M: round(M * 100),\n Y: round(Y * 100),\n K: round(K * 100)\n };\n};\nconst rgbToRyb = (R, G, B) => {\n const Iw = Math.min(R, G, B);\n const Ib = Math.min(BASE_255 - R, BASE_255 - G, BASE_255 - B);\n const rRgb = R - Iw;\n const gRgb = G - Iw;\n const bRgb = B - Iw;\n const minRg = Math.min(rRgb, gRgb);\n const rRyb = rRgb - minRg;\n const yRyb = (gRgb + minRg) / 2;\n const bRyb = (bRgb + gRgb - minRg) / 2;\n const n = Math.max(rRyb, yRyb, bRyb) / Math.max(rRgb, gRgb, bRgb);\n const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n return {\n R: rRyb / N + Ib,\n Y: yRyb / N + Ib,\n B: bRyb / N + Ib\n };\n};\nconst rybToRgb = (R, Y, B) => {\n const Iw = Math.min(R, Y, B);\n const Ib = Math.min(BASE_255 - R, BASE_255 - Y, BASE_255 - B);\n const rRyb = R - Iw;\n const yRyb = Y - Iw;\n const bRyb = B - Iw;\n const minYb = Math.min(yRyb, bRyb);\n const rRgb = rRyb + yRyb - minYb;\n const gRgb = yRyb + minYb;\n const bRgb = 2 * (bRyb - minYb);\n const n = Math.max(rRgb, gRgb, bRgb) / Math.max(rRyb, yRyb, bRyb);\n const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n return {\n R: rRgb / N + Ib,\n G: gRgb / N + Ib,\n B: bRgb / N + Ib\n };\n};\nconst hueRyb = (hue, toRyb) => {\n if (hue < 0)\n hue += 360;\n if (hue > 360)\n hue -= 360;\n if (hue === 360 || hue === 0)\n return hue;\n const map1 = [\n [0, 120],\n [120, 180],\n [180, 240],\n [240, 360]\n ];\n const map2 = [\n [0, 60],\n [60, 120],\n [120, 240],\n [240, 360]\n ];\n const from = toRyb ? map1 : map2;\n const to = toRyb ? map2 : map1;\n let A = 0;\n let B = 0;\n let C = 0;\n let D = 0;\n from.find((arr, index) => {\n if (hue >= arr[0] && hue < arr[1]) {\n A = arr[0];\n B = arr[1];\n C = to[index][0];\n D = to[index][1];\n return true;\n }\n return false;\n });\n return C + (hue - A) * ((D - C) / (B - A));\n};\n\n;// ./src/classes/ColorParserContext.ts\n\n\nclass ColorParserContext {\n constructor(parsers) {\n this._parsers = parsers;\n }\n getParser(input) {\n const parser = Object.values(this._parsers).find(parser => parser.supports(input));\n if (parser) {\n return parser;\n }\n throw new Error(ERRORS.NOT_ACCEPTED_INPUT);\n }\n parse(input) {\n const parser = this.getParser(input);\n return parser.parse(input, this);\n }\n convert(input, model, decimals = DEFAULT_OPTIONS.decimals, withAlpha = false) {\n const color = this.parse(input);\n const parser = this._parsers[model];\n return parser.convert(color, decimals, withAlpha);\n }\n convertCSS(input, model, options = {}, withAlpha = false) {\n const color = this.parse(input);\n const parser = this._parsers[model];\n return parser.convertCSS(color, options, withAlpha);\n }\n}\nclass ColorParser {\n hasAlpha(input) {\n if (isString(input)) {\n return this.getCSSOptions(input).hasAlpha;\n }\n return !isUndefined(input.A);\n }\n ;\n}\n\n;// ./src/color/rgb.ts\n\n\nconst getAlpha = (color) => {\n if (isUndefined(color.A)) {\n return {};\n }\n return {\n A: +color.A\n };\n};\nconst getRGB = (color) => {\n const alpha = getAlpha(color);\n if (isHSLObject(color)) {\n return {\n ...hslToRgb(color.H, color.S, color.L),\n ...alpha\n };\n }\n if (isHWBObject(color)) {\n return {\n ...hwbToRgb(color.H, color.W, color.B),\n ...alpha\n };\n }\n if (isCIELabObject(color)) {\n return {\n ...labToRgb(color.L, color.a, color.b),\n ...alpha\n };\n }\n if (isLCHObject(color)) {\n return {\n ...lchToRgb(color.L, color.C, color.H),\n ...alpha\n };\n }\n if (isCMYKObject(color)) {\n return {\n ...cmykToRgb(color.C, color.M, color.Y, color.K),\n ...alpha\n };\n }\n return color;\n};\n\n;// ./src/css/index.ts\n\n\n\nconst getCSSComma = (withSpace) => withSpace\n ? ', '\n : ',';\nconst prepareColorForCss = (color, transformer) => {\n const props = getOrderedArrayString(Object.keys(color));\n const model = VALID_COLOR_OBJECTS[props];\n const keys = COLOR_PROPS[model];\n return keys.reduce((result, key, index) => {\n const value = color[key];\n if (typeof value !== 'undefined') {\n result.push(transformer(value, index));\n }\n return result;\n }, []);\n};\nconst getResultFromCSSTemplate = (template, vars) => {\n return template.replace(TEMPLATE_VAR, (__match, indexStr) => {\n const index = +indexStr - 1;\n return `${vars[index]}`;\n });\n};\nconst getCSSAlpha = (value, options, ignoreLegacy = false) => {\n const { alphaUnit, legacyCSS, decimals } = options;\n if (alphaUnit === ColorUnitEnum.PERCENT &&\n (!legacyCSS ||\n ignoreLegacy)) {\n return `${round(value * 100, decimals)}%`;\n }\n return round(value, decimals);\n};\nconst buildCSSHueTransformer = (options) => {\n const { anglesUnit, decimals } = options;\n return (value, index) => {\n if (index === 0 &&\n anglesUnit !== AnglesUnitEnum.NONE) {\n const translated = round(translateDegrees(value, anglesUnit), decimals);\n return `${translated}${anglesUnit}`;\n }\n return index === 3\n ? getCSSAlpha(value, options)\n : round(value, decimals);\n };\n};\n\n;// ./src/classes/HEXParser.ts\n\n\n\n\n\nclass HEXParser extends ColorParser {\n _extract(input) {\n const colorStr = !~COLOR_KEYS.indexOf(input)\n ? input\n : ColorKeywords[input];\n const match = colorStr.match(COLORREGS.HEX);\n return match.groups;\n }\n supports(input) {\n if (isString(input)) {\n return (COLORREGS.HEX.test(input) ||\n !!~COLOR_KEYS.indexOf(input));\n }\n const hasInvalidHex = Object.entries(input).some((item) => {\n return !HEX.test(`${item[1]}`);\n });\n return isRGBObject(input) && !hasInvalidHex;\n }\n parse(input) {\n if (isString(input)) {\n const groups = this._extract(input);\n const r = groups.r ?? groups.rr;\n const g = groups.g ?? groups.gg;\n const b = groups.b ?? groups.bb;\n const a = groups.a ?? groups.aa;\n return {\n R: getDEC(r),\n G: getDEC(g),\n B: getDEC(b),\n ...(isUndefined(a)\n ? {}\n : {\n A: getDEC(a) / BASE_255\n })\n };\n }\n return {\n R: getBase255Number(`${input.R}`),\n G: getBase255Number(`${input.G}`),\n B: getBase255Number(`${input.B}`),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: Math.min(getBase255Number(`${input.A}`, true), 1)\n })\n };\n }\n convert(color, __decimals, withAlpha) {\n const rgb = isRGBObject(color)\n ? color\n : getRGB(color);\n return {\n R: getHEX(rgb.R),\n G: getHEX(rgb.G),\n B: getHEX(rgb.B),\n ...(withAlpha\n ? {\n A: isUndefined(rgb.A)\n ? '0xFF'\n : getHEX(rgb.A * BASE_255)\n }\n : {})\n };\n }\n convertCSS(color, options, withAlpha) {\n const rgb = this.convert(color, options.decimals, withAlpha);\n const transformer = (value) => toHEX(round(value));\n const values = prepareColorForCss(rgb, transformer);\n const template = values.length === 4\n ? '#{1}{2}{3}{4}'\n : '#{1}{2}{3}';\n return getResultFromCSSTemplate(template, values);\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n return {\n hasAlpha: !isUndefined(groups.a ?? groups.aa)\n };\n }\n get model() {\n return ColorModel.HEX;\n }\n}\n\n;// ./src/classes/CalcParser.ts\n\nconst MAX_STACK = 100;\nclass CalcParser {\n constructor(colorIndex, calc, vars) {\n this._operations = new Map([\n [CALC.DIVISION, this._division],\n [CALC.MULTIPLICATION, this._multiplication],\n [CALC.SUM, this._sum],\n [CALC.REST, this._rest]\n ]);\n this._colorIndex = colorIndex;\n let calcString = calc;\n let stack = 0;\n if (!Number.isNaN(+calc)) {\n this._result = +calc;\n }\n else if (calc in vars) {\n this._result = vars[calc];\n }\n else if (CALC.REGEXP.test(calcString)) {\n CALC.REGEXP.lastIndex = 0;\n this._result = this._getCalcValue(calcString, vars);\n }\n else {\n while (CALC.SCOPED.test(calcString) && stack < MAX_STACK) {\n CALC.SCOPED.lastIndex = 0;\n calcString = calcString.replace(CALC.SCOPED, (__match, operation) => {\n return this._calculate(operation, vars).toString();\n });\n if (CALC.REGEXP.test(calcString)) {\n CALC.REGEXP.lastIndex = 0;\n break;\n }\n stack++;\n }\n this._result = this._getCalcValue(calcString, vars);\n }\n }\n _division(left, right) {\n return left / right;\n }\n _multiplication(left, right) {\n return left * right;\n }\n _sum(left, right) {\n return left + right;\n }\n _rest(left, right) {\n return left - right;\n }\n _getCalcValue(calc, vars) {\n const match = calc.match(CALC.REGEXP);\n const operation = match.groups.operation;\n const value = this._calculate(operation, vars);\n if (Number.isNaN(value)) {\n throw new Error(`Invalid value for ${this._colorIndex}. ${operation} ${ERRORS.NOT_A_VALID_RELATIVE_COLOR}`);\n }\n return value;\n }\n _calculate(operation, vars) {\n this._operations.forEach((method, regExp) => {\n let stack = 0;\n while (regExp.test(operation) && stack < MAX_STACK) {\n operation = operation.replace(regExp, (__match, left, right) => {\n return method(vars[left] ?? +left, vars[right] ?? +right).toString();\n });\n stack++;\n }\n });\n return +operation;\n }\n get result() {\n return this._result;\n }\n}\n\n;// ./src/classes/RGBParser.ts\n\n\n\n\n\n\n\nclass RGBParser extends ColorParser {\n _extract(input) {\n const match = input.match(COLORREGS.RGB);\n return match.groups;\n }\n supports(input) {\n if (isString(input)) {\n return COLORREGS.RGB.test(input);\n }\n const hasInvalidRegb = Object.entries(input).some((item) => {\n return !(PCENT.test(`${item[1]}`) ||\n (!HEX.test(`${item[1]}`) &&\n !isNaN(+item[1]) &&\n +item[1] <= BASE_255));\n });\n return isRGBObject(input) && !hasInvalidRegb;\n }\n parse(input, context) {\n if (isString(input)) {\n const groups = this._extract(input);\n const { r_legacy, g_legacy, b_legacy, a_legacy, r, g, b, a, from, relative_r, relative_g, relative_b, relative_a } = groups;\n if (from) {\n const fromColor = context.parse(from);\n const fromRGB = getRGB(fromColor);\n const fromRGBVars = {\n r: fromRGB.R,\n g: fromRGB.G,\n b: fromRGB.B,\n alpha: fromRGB.A ?? 1\n };\n const R = new CalcParser('r', relative_r, fromRGBVars).result;\n const G = new CalcParser('g', relative_g, fromRGBVars).result;\n const B = new CalcParser('b', relative_b, fromRGBVars).result;\n const rgb = {\n R: Math.min(R, BASE_255),\n G: Math.min(G, BASE_255),\n B: Math.min(B, BASE_255)\n };\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromRGBVars).result;\n rgb.A = Math.min(A, 1);\n }\n return rgb;\n }\n else {\n const R = r_legacy ?? r;\n const G = g_legacy ?? g;\n const B = b_legacy ?? b;\n const A = a_legacy ?? a;\n return {\n R: Math.min(getBase255Number(R), BASE_255),\n G: Math.min(getBase255Number(G), BASE_255),\n B: Math.min(getBase255Number(B), BASE_255),\n ...(isUndefined(A)\n ? {}\n : {\n A: normalizeAlpha(A)\n })\n };\n }\n }\n return {\n R: getBase255Number(`${input.R}`),\n G: getBase255Number(`${input.G}`),\n B: getBase255Number(`${input.B}`),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: Math.min(getBase255Number(`${input.A}`, true), 1)\n })\n };\n }\n convert(color, decimals, withAlpha) {\n const rgb = isRGBObject(color)\n ? color\n : getRGB(color);\n return this._roundRGBObject({\n R: rgb.R,\n G: rgb.G,\n B: rgb.B,\n ...(withAlpha\n ? {\n A: rgb.A ?? 1\n }\n : {})\n }, decimals);\n }\n convertCSS(color, options, withAlpha) {\n const { decimals, legacyCSS, spacesAfterCommas, rgbUnit } = options;\n const rgb = this.convert(color, options.decimals, withAlpha);\n const comma = getCSSComma(spacesAfterCommas);\n const transformer = (value, index) => {\n return rgbUnit === ColorUnitEnum.PERCENT && index < 3\n ? `${from255NumberToPercent(value, decimals)}%`\n : (index === 3\n ? getCSSAlpha(value, options)\n : round(value, decimals));\n };\n const values = prepareColorForCss(rgb, transformer);\n const template = legacyCSS\n ? (values.length === 4\n ? `rgba({1}${comma}{2}${comma}{3}${comma}{4})`\n : `rgb({1}${comma}{2}${comma}{3})`)\n : (values.length === 4\n ? `rgb({1} {2} {3} / {4})`\n : `rgb({1} {2} {3})`);\n return getResultFromCSSTemplate(template, values);\n }\n _roundRGBObject(color, decimals) {\n const R = round(color.R, decimals);\n const G = round(color.G, decimals);\n const B = round(color.B, decimals);\n return {\n R,\n G,\n B,\n ...(isUndefined(color.A)\n ? {}\n : {\n A: round(color.A, decimals)\n })\n };\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n const { r_legacy, g_legacy, b_legacy, a_legacy, r, g, b, a } = groups;\n return {\n hasPercentageValues: (PCENT.test(r_legacy ?? r) &&\n PCENT.test(g_legacy ?? g) &&\n PCENT.test(b_legacy ?? b)),\n hasPercentageAlpha: PCENT.test(a_legacy ?? a),\n hasAlpha: !isUndefined(a_legacy ?? a)\n };\n }\n get model() {\n return ColorModel.RGB;\n }\n}\n\n;// ./src/classes/HSLParser.ts\n\n\n\n\n\n\n\nclass HSLParser extends ColorParser {\n _extract(input) {\n const match = input.match(COLORREGS.HSL);\n return match.groups;\n }\n supports(input) {\n if (isString(input)) {\n return COLORREGS.HSL.test(input);\n }\n return isHSLObject(input);\n }\n parse(input, context) {\n if (isString(input)) {\n const groups = this._extract(input);\n const { h_legacy, s_legacy, l_legacy, a_legacy, h, s, l, a, from, relative_h, relative_s, relative_l, relative_a } = groups;\n if (from) {\n const fromColor = context.parse(from);\n const fromRGB = getRGB(fromColor);\n const fromHSL = rgbToHsl(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n const fromHSLVars = {\n h: fromHSL.H,\n s: fromHSL.S,\n l: fromHSL.L,\n alpha: fromHSL.A\n };\n const H = new CalcParser('h', relative_h, fromHSLVars).result;\n const S = new CalcParser('s', relative_s, fromHSLVars).result;\n const L = new CalcParser('l', relative_l, fromHSLVars).result;\n const hsl = {\n H: normalizeHue(H),\n S: percent(S),\n L: percent(L)\n };\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromHSLVars).result;\n hsl.A = minmax(A, 0, MAX_ALPHA);\n }\n return hsl;\n }\n else {\n const H = h_legacy ?? h;\n const S = s_legacy ?? s;\n const L = l_legacy ?? l;\n const A = a_legacy ?? a;\n return {\n H: normalizeHue(H),\n S: percent(S),\n L: percent(L),\n ...(isUndefined(A)\n ? {}\n : {\n A: normalizeAlpha(A)\n })\n };\n }\n }\n return {\n H: normalizeHue(input.H),\n S: percent(`${input.S}`),\n L: percent(`${input.L}`),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: minmax(+input.A, 0, MAX_ALPHA)\n })\n };\n }\n convert(color, decimals, withAlpha) {\n let hsl;\n if (isHSLObject(color)) {\n hsl = color;\n }\n else {\n const rgb = getRGB(color);\n hsl = rgbToHsl(rgb.R, rgb.G, rgb.B, rgb.A);\n }\n return this._roundHSLObject({\n H: hsl.H,\n S: hsl.S,\n L: hsl.L,\n ...(withAlpha\n ? {\n A: hsl.A ?? 1\n }\n : {})\n }, decimals);\n }\n convertCSS(color, options, withAlpha) {\n const { legacyCSS, spacesAfterCommas } = options;\n const comma = getCSSComma(spacesAfterCommas);\n const hsl = this.convert(color, options.decimals, withAlpha);\n const transformer = buildCSSHueTransformer(options);\n const values = prepareColorForCss(hsl, transformer);\n const template = legacyCSS\n ? (values.length === 4\n ? `hsla({1}${comma}{2}%${comma}{3}%${comma}{4})`\n : `hsl({1}${comma}{2}%${comma}{3}%)`)\n : (values.length === 4\n ? `hsl({1} {2}% {3}% / {4})`\n : `hsl({1} {2}% {3}%)`);\n return getResultFromCSSTemplate(template, values);\n }\n _roundHSLObject(color, decimals) {\n return {\n H: round(normalizeHue(color.H), decimals),\n S: round(color.S, decimals),\n L: round(color.L, decimals),\n ...(isUndefined(color.A)\n ? {}\n : {\n A: round(color.A, decimals)\n })\n };\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n const { h_legacy, h, a_legacy, a } = groups;\n return {\n angleUnit: getAngleUnit(h_legacy ?? h),\n hasPercentageAlpha: PCENT.test(a_legacy ?? a),\n hasAlpha: !isUndefined(a_legacy ?? a)\n };\n }\n get model() {\n return ColorModel.HSL;\n }\n}\n\n;// ./src/classes/HWBParser.ts\n\n\n\n\n\n\n\nclass HWBParser extends ColorParser {\n _extract(input) {\n const match = input.match(COLORREGS.HWB);\n return match.groups;\n }\n supports(input) {\n if (isString(input)) {\n return COLORREGS.HWB.test(input);\n }\n return isHWBObject(input);\n }\n parse(input, context) {\n if (isString(input)) {\n const groups = this._extract(input);\n const { h, w, b, a, from, relative_h, relative_w, relative_b, relative_a } = groups;\n if (from) {\n const fromColor = context.parse(from);\n const fromRGB = getRGB(fromColor);\n const fromHWB = rgbToHwb(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n const fromHWBVars = {\n h: fromHWB.H,\n w: fromHWB.W,\n b: fromHWB.B,\n alpha: fromHWB.A\n };\n const H = new CalcParser('h', relative_h, fromHWBVars).result;\n const W = new CalcParser('w', relative_w, fromHWBVars).result;\n const B = new CalcParser('b', relative_b, fromHWBVars).result;\n const hwb = {\n H: minmax(H, 0, MAX_HUE),\n W: minmax(W, 0, MAX_PCENT),\n B: minmax(B, 0, MAX_PCENT)\n };\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromHWBVars).result;\n hwb.A = minmax(A, 0, MAX_ALPHA);\n }\n return hwb;\n }\n else {\n return {\n H: normalizeHue(h),\n W: percent(w),\n B: percent(b),\n ...(isUndefined(a)\n ? {}\n : {\n A: normalizeAlpha(a)\n })\n };\n }\n }\n return {\n H: normalizeHue(input.H),\n W: percent(input.W),\n B: percent(input.B),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: normalizeAlpha(input.A)\n })\n };\n }\n convert(color, decimals, withAlpha) {\n let hwb;\n if (isHWBObject(color)) {\n hwb = color;\n }\n else {\n const rgb = getRGB(color);\n hwb = rgbToHwb(rgb.R, rgb.G, rgb.B, rgb.A);\n }\n return this._roundHWBObject({\n H: hwb.H,\n W: hwb.W,\n B: hwb.B,\n ...(withAlpha\n ? {\n A: hwb.A ?? 1\n }\n : {})\n }, decimals);\n }\n convertCSS(color, options, withAlpha) {\n const hwb = this.convert(color, options.decimals, withAlpha);\n const transformer = buildCSSHueTransformer(options);\n const values = prepareColorForCss(hwb, transformer);\n const template = values.length === 4\n ? `hwb({1} {2}% {3}% / {4})`\n : `hwb({1} {2}% {3}%)`;\n return getResultFromCSSTemplate(template, values);\n }\n _roundHWBObject(color, decimals) {\n return {\n H: round(normalizeHue(color.H), decimals),\n W: round(color.W, decimals),\n B: round(color.B, decimals),\n ...(isUndefined(color.A)\n ? {}\n : {\n A: round(color.A, decimals)\n })\n };\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n return {\n angleUnit: getAngleUnit(groups.h),\n hasPercentageAlpha: PCENT.test(groups.a),\n hasAlpha: !isUndefined(groups.a)\n };\n }\n get model() {\n return ColorModel.HWB;\n }\n}\n\n;// ./src/classes/CIELabParser.ts\n\n\n\n\n\n\n\n\nclass CIELabParser extends ColorParser {\n _extract(input) {\n const match = input.match(COLORREGS.CIELab);\n return match.groups;\n }\n supports(input) {\n if (isString(input)) {\n return COLORREGS.CIELab.test(input);\n }\n return isCIELabObject(input);\n }\n parse(input, context) {\n if (isString(input)) {\n const groups = this._extract(input);\n const { L, a, b, A, from, relative_L, relative_a, relative_b, relative_A } = groups;\n if (from) {\n const fromColor = context.parse(from);\n const fromRGB = getRGB(fromColor);\n const fromCIELab = rgbToLab(fromRGB.R, fromRGB.G, fromRGB.B);\n const fromCIELabVars = {\n l: fromCIELab.L,\n a: fromCIELab.a,\n b: fromCIELab.b,\n alpha: fromRGB.A ?? 1\n };\n const L = new CalcParser('l', relative_L, fromCIELabVars).result;\n const a = new CalcParser('a', relative_a, fromCIELabVars).result;\n const b = new CalcParser('b', relative_b, fromCIELabVars).result;\n const CIELab = {\n L: minmax(L, 0, MAX_PCENT),\n a: minmax(a, -MAX_LAB, MAX_LAB),\n b: minmax(b, -MAX_LAB, MAX_LAB)\n };\n if (relative_A) {\n const A = new CalcParser('alpha', relative_A, fromCIELabVars).result;\n CIELab.A = minmax(A, 0, MAX_ALPHA);\n }\n return CIELab;\n }\n else {\n return {\n L: percent(L),\n a: getBase125Number(a),\n b: getBase125Number(b),\n ...(isUndefined(A)\n ? {}\n : {\n A: normalizeAlpha(A)\n })\n };\n }\n }\n return {\n L: percent(input.L),\n a: getBase125Number(`${input.a}`),\n b: getBase125Number(`${input.b}`),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: normalizeAlpha(input.A)\n })\n };\n }\n convert(color, decimals, withAlpha) {\n let lab;\n if (isCIELabObject(color)) {\n lab = color;\n }\n else {\n const rgb = getRGB(color);\n lab = rgbToLab(rgb.R, rgb.G, rgb.B);\n }\n return this._roundCIELabObject({\n L: lab.L,\n a: lab.a,\n b: lab.b,\n ...(withAlpha\n ? {\n A: +(color.A ?? 1)\n }\n : {})\n }, decimals);\n }\n convertCSS(color, options, withAlpha) {\n const { decimals, labUnit } = options;\n const lab = this.convert(color, options.decimals, withAlpha);\n const transformer = (value, index) => {\n if (index === 0) {\n const L = round(percent(value), decimals);\n return labUnit === ColorUnitEnum.PERCENT\n ? `${L}%`\n : `${L}`;\n }\n if (index < 3) {\n return labUnit === ColorUnitEnum.PERCENT\n ? `${from125NumberToPercent(value, decimals)}%`\n : round(value, decimals);\n }\n return getCSSAlpha(value, options, true);\n };\n const values = prepareColorForCss(lab, transformer);\n const template = values.length === 4\n ? `lab({1} {2} {3} / {4})`\n : `lab({1} {2} {3})`;\n return getResultFromCSSTemplate(template, values);\n }\n _roundCIELabObject(color, decimals) {\n return {\n L: round(color.L, decimals),\n a: round(color.a, decimals),\n b: round(color.b, decimals),\n ...(isUndefined(color.A)\n ? {}\n : {\n A: round(color.A, decimals)\n })\n };\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n const { L, a, b, A } = groups;\n return {\n hasPercentageValues: (PCENT.test(L) &&\n PCENT.test(a) &&\n PCENT.test(b)),\n hasPercentageAlpha: PCENT.test(A),\n hasAlpha: !isUndefined(A)\n };\n }\n get model() {\n return ColorModel.CIELab;\n }\n}\n\n;// ./src/classes/LCHParser.ts\n\n\n\n\n\n\n\n\nclass LCHParser extends ColorParser {\n _extract(input) {\n const match = input.match(COLORREGS.LCH);\n return match.groups;\n }\n supports(input) {\n if (isString(input)) {\n return COLORREGS.LCH.test(input);\n }\n return isLCHObject(input);\n }\n parse(input, context) {\n if (isString(input)) {\n const groups = this._extract(input);\n const { l, c, h, a, from, relative_l, relative_c, relative_h, relative_a } = groups;\n if (from) {\n const fromColor = context.parse(from);\n const fromRGB = getRGB(fromColor);\n const fromLCH = rgbToLch(fromRGB.R, fromRGB.G, fromRGB.B);\n const fromLCHVars = {\n l: fromLCH.L,\n c: fromLCH.C,\n h: fromLCH.H,\n alpha: fromRGB.A ?? 1\n };\n const L = new CalcParser('l', relative_l, fromLCHVars).result;\n const C = new CalcParser('c', relative_c, fromLCHVars).result;\n const H = new CalcParser('h', relative_h, fromLCHVars).result;\n const lch = {\n L: minmax(L, 0, MAX_PCENT),\n C: minmax(C, -MAX_LCH_C, MAX_LCH_C),\n H: normalizeHue(H)\n };\n if (relative_a) {\n const A = new CalcParser('alpha', relative_a, fromLCHVars).result;\n lch.A = minmax(A, 0, MAX_ALPHA);\n }\n return lch;\n }\n else {\n return {\n L: percent(l),\n C: getBase150Number(c),\n H: normalizeHue(h),\n ...(isUndefined(a)\n ? {}\n : {\n A: normalizeAlpha(a)\n })\n };\n }\n }\n return {\n L: percent(input.L),\n C: getBase150Number(`${input.C}`),\n H: normalizeHue(input.H),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: normalizeAlpha(input.A)\n })\n };\n }\n convert(color, decimals, withAlpha) {\n let lch;\n if (isLCHObject(color)) {\n lch = color;\n }\n else {\n const rgb = getRGB(color);\n lch = rgbToLch(rgb.R, rgb.G, rgb.B);\n }\n return this._roundLCHObject({\n L: lch.L,\n C: lch.C,\n H: lch.H,\n ...(withAlpha\n ? {\n A: +(color.A ?? 1)\n }\n : {})\n }, decimals);\n }\n convertCSS(color, options, withAlpha) {\n const { decimals, lchUnit, anglesUnit } = options;\n const lch = this.convert(color, options.decimals, withAlpha);\n const transformer = (value, index) => {\n if (index === 0) {\n const L = round(percent(value), decimals);\n return lchUnit === ColorUnitEnum.PERCENT\n ? `${L}%`\n : `${L}`;\n }\n if (index === 1) {\n return lchUnit === ColorUnitEnum.PERCENT\n ? `${from150NumberToPercent(value, decimals)}%`\n : round(value, decimals);\n }\n if (index === 2) {\n if (anglesUnit !== AnglesUnitEnum.NONE) {\n const translated = round(translateDegrees(value, anglesUnit), decimals);\n return `${translated}${anglesUnit}`;\n }\n return round(value, decimals);\n }\n return getCSSAlpha(value, options, true);\n };\n const values = prepareColorForCss(lch, transformer);\n const template = values.length === 4\n ? `lch({1} {2} {3} / {4})`\n : `lch({1} {2} {3})`;\n return getResultFromCSSTemplate(template, values);\n }\n _roundLCHObject(color, decimals) {\n return {\n L: round(color.L, decimals),\n C: round(color.C, decimals),\n H: round(normalizeHue(color.H), decimals),\n ...(isUndefined(color.A)\n ? {}\n : {\n A: round(color.A, decimals)\n })\n };\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n return {\n angleUnit: getAngleUnit(groups.h),\n hasPercentageValues: (PCENT.test(groups.l) &&\n PCENT.test(groups.c)),\n hasPercentageAlpha: PCENT.test(groups.a),\n hasAlpha: !isUndefined(groups.a)\n };\n }\n get model() {\n return ColorModel.LCH;\n }\n}\n\n;// ./src/classes/CMYKParser.ts\n\n\n\n\n\n\n\nclass CMYKParser extends ColorParser {\n _extract(input) {\n const match = input.match(COLORREGS.CMYK);\n return match.groups;\n }\n _shouldMultiplyBy100(...colors) {\n return !colors.some((color) => +color > 1);\n }\n supports(input) {\n if (isString(input)) {\n return COLORREGS.CMYK.test(input);\n }\n return isCMYKObject(input);\n }\n parse(input) {\n if (isString(input)) {\n const groups = this._extract(input);\n const c = groups.c_legacy ?? groups.c;\n const m = groups.m_legacy ?? groups.m;\n const y = groups.y_legacy ?? groups.y;\n const k = groups.k_legacy ?? groups.k;\n const a = groups.a_legacy ?? groups.a;\n const shouldMultiplyBy100 = this._shouldMultiplyBy100(c, m, y, k);\n return {\n C: getCMYKNumber(c, shouldMultiplyBy100),\n M: getCMYKNumber(m, shouldMultiplyBy100),\n Y: getCMYKNumber(y, shouldMultiplyBy100),\n K: getCMYKNumber(k, shouldMultiplyBy100),\n ...(isUndefined(a)\n ? {}\n : {\n A: normalizeAlpha(a)\n })\n };\n }\n const shouldMultiplyBy100 = this._shouldMultiplyBy100(input.C, input.M, input.Y, input.K);\n return {\n C: getCMYKNumber(`${input.C}`, shouldMultiplyBy100),\n M: getCMYKNumber(`${input.M}`, shouldMultiplyBy100),\n Y: getCMYKNumber(`${input.Y}`, shouldMultiplyBy100),\n K: getCMYKNumber(`${input.K}`, shouldMultiplyBy100),\n ...(isUndefined(input.A)\n ? {}\n : {\n A: normalizeAlpha(input.A)\n })\n };\n }\n convert(color, decimals, withAlpha) {\n let cmyk;\n if (isCMYKObject(color)) {\n cmyk = color;\n }\n else {\n const rgb = getRGB(color);\n cmyk = rgbToCmyk(rgb.R, rgb.G, rgb.B);\n }\n return this._roundCMYKObject({\n C: cmyk.C,\n M: cmyk.M,\n Y: cmyk.Y,\n K: cmyk.K,\n ...(withAlpha\n ? {\n A: +(color.A ?? 1)\n }\n : {})\n }, decimals);\n }\n convertCSS(color, options, withAlpha) {\n const { decimals, legacyCSS, spacesAfterCommas, cmykUnit, cmykFunction } = options;\n const comma = getCSSComma(spacesAfterCommas);\n const cmyk = this.convert(color, options.decimals, withAlpha);\n const transformer = (value, index) => {\n if (cmykUnit === ColorUnitEnum.PERCENT &&\n index < 4) {\n return `${round(value, decimals)}%`;\n }\n return index === 4\n ? getCSSAlpha(value, options)\n : round(value / 100, decimals);\n };\n const values = prepareColorForCss(cmyk, transformer);\n const template = legacyCSS\n ? (values.length === 5\n ? `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4}${comma}{5})`\n : `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4})`)\n : (values.length === 5\n ? `${cmykFunction}({1} {2} {3} {4} / {5})`\n : `${cmykFunction}({1} {2} {3} {4})`);\n return getResultFromCSSTemplate(template, values);\n }\n _roundCMYKObject(color, decimals) {\n return {\n C: round(color.C, decimals),\n M: round(color.M, decimals),\n Y: round(color.Y, decimals),\n K: round(color.K, decimals),\n ...(isUndefined(color.A)\n ? {}\n : {\n A: round(color.A, decimals)\n })\n };\n }\n getCSSOptions(input) {\n const groups = this._extract(input);\n const { c_legacy, m_legacy, y_legacy, k_legacy, a_legacy, c, m, y, k, a } = groups;\n return {\n hasPercentageValues: (PCENT.test(c_legacy ?? c) &&\n PCENT.test(m_legacy ?? m) &&\n PCENT.test(y_legacy ?? y) &&\n PCENT.test(k_legacy ?? k)),\n hasPercentageAlpha: PCENT.test(a_legacy ?? a),\n hasAlpha: !isUndefined(a_legacy ?? a)\n };\n }\n get model() {\n return ColorModel.CMYK;\n }\n}\n\n;// ./src/parsers/index.ts\n\n\n\n\n\n\n\n\n\n\n\nconst hexParser = new HEXParser();\nconst rgbParser = new RGBParser();\nconst hslParser = new HSLParser();\nconst hwbParser = new HWBParser();\nconst cieLabParser = new CIELabParser();\nconst lchParser = new LCHParser();\nconst cmykParser = new CMYKParser();\nconst colorParserContext = new ColorParserContext({\n [ColorModel.HEX]: hexParser,\n [ColorModel.RGB]: rgbParser,\n [ColorModel.HSL]: hslParser,\n [ColorModel.HWB]: hwbParser,\n [ColorModel.CIELab]: cieLabParser,\n [ColorModel.LCH]: lchParser,\n [ColorModel.CMYK]: cmykParser\n});\nconst getOptionsFromColorInput = (options, ...colors) => {\n const cssColors = [];\n const anglesUnits = [];\n const rgbColors = [];\n const labColors = [];\n const lchColors = [];\n const cmykColors = [];\n const alphaValues = [];\n const anglesUnitValues = Object.values(AnglesUnitEnum);\n const colorUnitValues = Object.values(ColorUnitEnum);\n const cmykFunctionValues = Object.values(CMYKFunctionEnum);\n const matchOptions = {\n legacyCSS: 0,\n spacesAfterCommas: 0,\n cmykFunction: 0\n };\n for (const color of colors) {\n if (isString(color)) {\n cssColors.push(color);\n if (color.includes(',')) {\n matchOptions.legacyCSS++;\n const commasWithNextCharacter = color.match(COMMAS_AND_NEXT_CHARS);\n if (new Set(commasWithNextCharacter).size === 1 &&\n SPACES.test(commasWithNextCharacter[0].slice(1))) {\n matchOptions.spacesAfterCommas++;\n }\n }\n if (hslParser.supports(color)) {\n const options = hslParser.getCSSOptions(color);\n anglesUnits.push(options.angleUnit);\n alphaValues.push(options.hasPercentageAlpha);\n continue;\n }\n if (hwbParser.supports(color)) {\n const options = hwbParser.getCSSOptions(color);\n anglesUnits.push(options.angleUnit);\n alphaValues.push(options.hasPercentageAlpha);\n continue;\n }\n if (rgbParser.supports(color)) {\n const options = rgbParser.getCSSOptions(color);\n rgbColors.push(options.hasPercentageValues);\n alphaValues.push(options.hasPercentageAlpha);\n continue;\n }\n if (cieLabParser.supports(color)) {\n const options = cieLabParser.getCSSOptions(color);\n labColors.push(options.hasPercentageValues);\n alphaValues.push(options.hasPercentageAlpha);\n continue;\n }\n if (lchParser.supports(color)) {\n const options = lchParser.getCSSOptions(color);\n anglesUnits.push(options.angleUnit);\n lchColors.push(options.hasPercentageValues);\n alphaValues.push(options.hasPercentageAlpha);\n continue;\n }\n if (cmykParser.supports(color)) {\n const options = cmykParser.getCSSOptions(color);\n cmykColors.push(options.hasPercentageValues);\n if (color.startsWith('cmyk')) {\n matchOptions.cmykFunction++;\n }\n alphaValues.push(options.hasPercentageAlpha);\n }\n }\n }\n return {\n decimals: isNumber(options.decimals)\n ? options.decimals\n : DEFAULT_OPTIONS.decimals,\n legacyCSS: isBoolean(options.legacyCSS)\n ? options.legacyCSS\n : Boolean(cssColors.length &&\n matchOptions.legacyCSS === cssColors.length) || DEFAULT_OPTIONS.legacyCSS,\n spacesAfterCommas: isBoolean(options.spacesAfterCommas)\n ? options.spacesAfterCommas\n : Boolean(cssColors.length &&\n matchOptions.spacesAfterCommas === cssColors.length) || DEFAULT_OPTIONS.spacesAfterCommas,\n anglesUnit: options.anglesUnit && anglesUnitValues.includes(options.anglesUnit)\n ? options.anglesUnit\n : (new Set(anglesUnits).size === 1\n ? anglesUnits[0]\n : DEFAULT_OPTIONS.anglesUnit),\n rgbUnit: options.rgbUnit && colorUnitValues.includes(options.rgbUnit)\n ? options.rgbUnit\n : (new Set(rgbColors).size === 1 && rgbColors[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.rgbUnit),\n labUnit: options.labUnit && colorUnitValues.includes(options.labUnit)\n ? options.labUnit\n : (new Set(labColors).size === 1 && labColors[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.labUnit),\n lchUnit: options.lchUnit && colorUnitValues.includes(options.lchUnit)\n ? options.lchUnit\n : (new Set(lchColors).size === 1 && lchColors[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.lchUnit),\n cmykUnit: options.cmykUnit && colorUnitValues.includes(options.cmykUnit)\n ? options.cmykUnit\n : (new Set(cmykColors).size === 1 && !cmykColors[0]\n ? ColorUnitEnum.NONE\n : DEFAULT_OPTIONS.cmykUnit),\n alphaUnit: options.alphaUnit && colorUnitValues.includes(options.alphaUnit)\n ? options.alphaUnit\n : (new Set(alphaValues).size === 1 && alphaValues[0]\n ? ColorUnitEnum.PERCENT\n : DEFAULT_OPTIONS.alphaUnit),\n cmykFunction: options.cmykFunction && cmykFunctionValues.includes(options.cmykFunction)\n ? options.cmykFunction\n : (cmykColors.length && cmykColors.length === matchOptions.cmykFunction\n ? CMYKFunctionEnum.CMYK\n : DEFAULT_OPTIONS.cmykFunction)\n };\n};\n\n;// ./src/returns/index.ts\n\n\n\n\n\nconst blend = (from, to, steps) => {\n const div = steps - 1;\n const diffR = (to.R - from.R) / div;\n const diffG = (to.G - from.G) / div;\n const diffB = (to.B - from.B) / div;\n const fromA = normalizeAlpha(from.A);\n const toA = normalizeAlpha(to.A);\n const diffA = (toA - fromA) / div;\n return Array(steps).fill(null).map((__n, i) => {\n if (i === 0) {\n return from;\n }\n if (i === div) {\n return to;\n }\n return {\n R: round(from.R + diffR * i),\n G: round(from.G + diffG * i),\n B: round(from.B + diffB * i),\n A: round(fromA + diffA * i)\n };\n });\n};\nfunction getBlendReturn(from, to, model, css, withAlpha, steps = DEFAULT_BLEND_STEPS, options = {}) {\n if (steps < 1)\n steps = DEFAULT_BLEND_STEPS;\n const fromParsed = colorParserContext.parse(from);\n const toParsed = colorParserContext.parse(to);\n const fromRGBObject = getRGB(fromParsed);\n const toRGBObject = getRGB(toParsed);\n const blendArray = blend(fromRGBObject, toRGBObject, steps);\n return blendArray.map((color) => {\n if (css) {\n return colorParserContext.convertCSS(color, model, getOptionsFromColorInput(options, from, to), withAlpha);\n }\n return colorParserContext.convert(color, model, options.decimals, withAlpha);\n });\n}\nconst getBlendReturnParams = (thirdParameter, fourthParameter) => {\n const stepsParameter = isNumber(thirdParameter)\n ? thirdParameter\n : undefined;\n const optionsParameter = isNumber(thirdParameter)\n ? fourthParameter\n : thirdParameter;\n return [\n stepsParameter,\n optionsParameter\n ];\n};\nfunction getMixReturn(colors, model, css, withAlpha, mode = Mix.ADDITIVE, options = {}) {\n const rgbMap = colors.map((color) => {\n return colorParserContext.convert(color, ColorModel.RGB, options.decimals, withAlpha);\n });\n const rybMap = mode === Mix.SUBTRACTIVE\n ? rgbMap.map((color) => {\n const RYB = rgbToRyb(color.R, color.G, color.B);\n if (!isUndefined(color.A)) {\n RYB.A = color.A;\n }\n return RYB;\n })\n : null;\n function createMix(items) {\n const initial = mode === Mix.ADDITIVE\n ? { R: 0, G: 0, B: 0, A: 0 }\n : { R: 0, Y: 0, B: 0, A: 0 };\n return items.reduce((mix, color) => {\n const colorA = isUndefined(color.A)\n ? 1\n : color.A;\n const common = {\n R: Math.min(mix.R + color.R * colorA, BASE_255),\n B: Math.min(mix.B + color.B * colorA, BASE_255),\n A: 1 - (1 - colorA) * (1 - mix.A)\n };\n const mixGY = 'G' in mix\n ? mix.G\n : mix.Y;\n const colorGY = 'G' in color\n ? color.G\n : color.Y;\n return {\n ...common,\n ...(mode === Mix.ADDITIVE\n ? { G: Math.min(mixGY + colorGY * colorA, BASE_255) }\n : { Y: Math.min(mixGY + colorGY * colorA, BASE_255) })\n };\n }, initial);\n }\n let mix;\n if (mode === Mix.ADDITIVE) {\n mix = createMix(rgbMap);\n }\n else {\n const RYB = createMix(rybMap);\n mix = rybToRgb(RYB.R, RYB.Y, RYB.B);\n mix.A = RYB.A;\n }\n if (css) {\n return colorParserContext.convertCSS(mix, model, getOptionsFromColorInput(options, ...colors), withAlpha);\n }\n return colorParserContext.convert(mix, model, options.decimals, withAlpha);\n}\n;\nconst getMixReturnParameters = (secondParameter, thirdParameter) => {\n const modeParam = isString(secondParameter)\n ? secondParameter\n : undefined;\n const optionsParam = isString(secondParameter)\n ? thirdParameter\n : secondParameter;\n return [\n modeParam,\n optionsParam\n ];\n};\nfunction getShadesOrTintsReturn(shades, color, steps = DEFAULT_SHADES_TINTS_STEPS, options = {}) {\n const isCSS = isString(color);\n const parser = colorParserContext.getParser(color);\n const model = parser.model;\n const withAlpha = parser.hasAlpha(color);\n const hsl = colorParserContext.convert(color, ColorModel.HSL, undefined, withAlpha);\n const increment = shades\n ? hsl.L / (steps + 1)\n : (100 - hsl.L) / (steps + 1);\n const hslMap = Array.from(Array(steps)).map((__n, i) => ({\n ...hsl,\n L: hsl.L + increment * (i + 1) * (1 - +shades * 2)\n }));\n if (isCSS) {\n return hslMap.map((hslColor) => {\n return colorParserContext.convertCSS(hslColor, model, getOptionsFromColorInput(options, color), withAlpha);\n });\n }\n return hslMap.map((hslColor) => {\n return colorParserContext.convert(hslColor, model, options.decimals, withAlpha);\n });\n}\nconst getShadesOrTintsReturnParameters = (secondParameter, thirdParameter) => {\n const stepsParam = isNumber(secondParameter)\n ? secondParameter\n : undefined;\n const optionsParam = isNumber(secondParameter)\n ? thirdParameter\n : secondParameter;\n return [\n stepsParam,\n optionsParam\n ];\n};\nconst harmony = (color, angles, mode) => angles.reduce((arr, num) => {\n return [\n ...arr,\n {\n ...color,\n H: mode === Mix.ADDITIVE\n ? normalizeHue(color.H + num)\n : normalizeHue(hueRyb(hueRyb(color.H, false) + num, true))\n }\n ];\n}, [{ ...color }]);\nconst HARMONIES = new Map([\n [\n Harmony.ANALOGOUS,\n (color, mode) => harmony(color, [30, -30], mode)\n ],\n [\n Harmony.COMPLEMENTARY,\n (color, mode) => harmony(color, [180], mode)\n ],\n [\n Harmony.SPLIT_COMPLEMENTARY,\n (color, mode) => harmony(color, [150, -150], mode)\n ],\n [\n Harmony.TRIADIC,\n (color, mode) => harmony(color, [120, -120], mode)\n ],\n [\n Harmony.TETRADIC,\n (color, mode) => harmony(color, [60, -120, 180], mode)\n ],\n [\n Harmony.SQUARE,\n (color, mode) => harmony(color, [90, -90, 180], mode)\n ]\n]);\nconst getHarmonyReturn = (color, harmony, mode, options = {}) => {\n const harmonyFunction = HARMONIES.get(harmony);\n const isCSS = isString(color);\n const parser = colorParserContext.getParser(color);\n const model = parser.model;\n const withAlpha = parser.hasAlpha(color);\n const hsl = colorParserContext.convert(color, ColorModel.HSL);\n const array = harmonyFunction(hsl, mode);\n if (isCSS) {\n return array.map((harmonyColor) => {\n return colorParserContext.convertCSS(harmonyColor, model, getOptionsFromColorInput(options, color), withAlpha);\n });\n }\n return array.map((harmonyColor) => {\n return colorParserContext.convert(harmonyColor, model, options.decimals, withAlpha);\n });\n};\nconst getHarmonyReturnParameters = (secondParam, thirdParam, fourthParam) => {\n if (isHarmony(secondParam)) {\n return [\n secondParam,\n isMix(thirdParam)\n ? thirdParam\n : Mix.ADDITIVE,\n isMix(thirdParam)\n ? fourthParam\n : thirdParam\n ];\n }\n if (isMix(secondParam)) {\n return [\n Harmony.COMPLEMENTARY,\n secondParam,\n thirdParam\n ];\n }\n return [\n Harmony.COMPLEMENTARY,\n Mix.ADDITIVE,\n secondParam\n ];\n};\n\n;// ./src/classes/ColorTranslator.ts\n\n\n\n\n\nclass ColorTranslator {\n constructor(color, options = {}) {\n this._options = getOptionsFromColorInput(options, color);\n const parsedColor = colorParserContext.parse(color);\n const model = getColorModel(parsedColor);\n switch (model) {\n case ColorModel.HSL:\n this.hsl = parsedColor;\n this.update('hsl');\n break;\n case ColorModel.HWB:\n this.hwb = parsedColor;\n this.updateRGBFromHWB();\n this.update('hwb', 'rgb');\n break;\n case ColorModel.CIELab:\n this.lab = parsedColor;\n this.updateRGBFromLAB();\n this.update('lab', 'rgb');\n break;\n case ColorModel.LCH:\n this.lch = parsedColor;\n this.updateRGBFromLCH();\n this.update('lch', 'rgb');\n break;\n case ColorModel.CMYK:\n this.cmyk = parsedColor;\n this.updateRGBFromCMYK();\n this.update('cmyk', 'rgb');\n break;\n default:\n this.rgb = parsedColor;\n this.update('rgb');\n }\n }\n update(...exclude) {\n if (!exclude.includes('rgb')) {\n this.updateRGB();\n }\n if (!exclude.includes('hsl')) {\n this.updateHSL();\n }\n if (!exclude.includes('hwb')) {\n this.updateHWB();\n }\n if (!exclude.includes('lab')) {\n this.updateLAB();\n }\n if (!exclude.includes('lch')) {\n this.updateLCH();\n }\n if (!exclude.includes('cmyk')) {\n this.updateCMYK();\n }\n }\n updateRGB() {\n this.rgb = {\n ...hslToRgb(this.hsl.H, this.hsl.S, this.hsl.L),\n A: this.hsl.A ?? 1\n };\n }\n updateHSL() {\n this.hsl = rgbToHsl(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n }\n updateHWB() {\n this.hwb = rgbToHwb(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n }\n updateLAB() {\n this.lab = {\n ...rgbToLab(this.rgb.R, this.rgb.G, this.rgb.B),\n A: this.rgb.A ?? 1\n };\n }\n updateLCH() {\n this.lch = {\n ...rgbToLch(this.rgb.R, this.rgb.G, this.rgb.B),\n A: this.rgb.A ?? 1\n };\n }\n updateCMYK() {\n this.cmyk = {\n ...rgbToCmyk(this.rgb.R, this.rgb.G, this.rgb.B),\n A: this.rgb.A ?? 1\n };\n }\n updateRGBFromHWB() {\n this.rgb = {\n ...hwbToRgb(this.hwb.H, this.hwb.W, this.hwb.B),\n A: this.hwb?.A ?? 1\n };\n }\n updateRGBFromLCH() {\n this.rgb = {\n ...lchToRgb(this.lch.L, this.lch.C, this.lch.H),\n A: this.lch.A ?? 1\n };\n }\n updateRGBFromCMYK() {\n this.rgb = {\n ...cmykToRgb(this.cmyk.C, this.cmyk.M, this.cmyk.Y, this.cmyk.K),\n A: this.cmyk.A ?? 1\n };\n }\n updateRGBFromLAB() {\n this.rgb = {\n ...labToRgb(this.lab.L, this.lab.a, this.lab.b),\n A: this.lab.A ?? 1\n };\n }\n updateLCHFromLAB() {\n this.lch = {\n ...labToLch(this.lab.L, this.lab.a, this.lab.b),\n A: this.lab.A\n };\n }\n updateLABromLCH() {\n this.lab = {\n ...lchToLab(this.lch.L, this.lch.C, this.lch.H),\n A: this.lch.A\n };\n }\n setOptions(options = {}) {\n this._options = {\n ...this._options,\n ...options\n };\n return this;\n }\n setR(R) {\n this.rgb.R = minmax(R, 0, BASE_255);\n this.update('rgb');\n return;\n }\n setG(G) {\n this.rgb.G = minmax(G, 0, BASE_255);\n this.update('rgb');\n return this;\n }\n setB(B) {\n this.rgb.B = minmax(B, 0, BASE_255);\n this.update('rgb');\n return this;\n }\n setH(H) {\n this.hsl.H = normalizeHue(H);\n this.update('hsl');\n return this;\n }\n setS(S) {\n this.hsl.S = minmax(S, 0, MAX_PCENT);\n this.update('hsl');\n return this;\n }\n setL(L) {\n this.hsl.L = minmax(L, 0, MAX_PCENT);\n this.update('hsl');\n return this;\n }\n setWhiteness(W) {\n this.hwb.W = minmax(W, 0, MAX_PCENT);\n this.updateRGBFromHWB();\n this.update('rgb', 'hwb');\n return this;\n }\n setBlackness(B) {\n this.hwb.B = minmax(B, 0, MAX_PCENT);\n this.updateRGBFromHWB();\n this.update('rgb', 'hwb');\n return this;\n }\n setCIEL(L) {\n this.lab.L = minmax(L, 0, MAX_PCENT);\n this.updateRGBFromLAB();\n this.updateLCHFromLAB();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setCIEa(a) {\n this.lab.a = minmax(a, -MAX_LAB, MAX_LAB);\n this.updateRGBFromLAB();\n this.updateLCHFromLAB();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setCIEb(b) {\n this.lab.b = minmax(b, -MAX_LAB, MAX_LAB);\n this.updateRGBFromLAB();\n this.updateLCHFromLAB();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setLCHL(l) {\n this.lch.L = minmax(l, 0, MAX_PCENT);\n this.updateRGBFromLCH();\n this.updateLABromLCH();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setLCHC(c) {\n this.lch.C = minmax(c, 0, MAX_LCH_C);\n this.updateRGBFromLCH();\n this.updateLABromLCH();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setLCHH(h) {\n this.lch.H = normalizeHue(h);\n this.updateRGBFromLCH();\n this.updateLABromLCH();\n this.update('rgb', 'lab', 'lch');\n return this;\n }\n setA(A) {\n const alpha = minmax(A, 0, MAX_ALPHA);\n this.rgb.A = alpha;\n this.hsl.A = alpha;\n this.hwb.A = alpha;\n this.lab.A = alpha;\n this.lch.A = alpha;\n this.cmyk.A = alpha;\n return this;\n }\n setC(C) {\n this.cmyk.C = minmax(C, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n setM(M) {\n this.cmyk.M = minmax(M, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n setY(Y) {\n this.cmyk.Y = minmax(Y, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n setK(K) {\n this.cmyk.K = minmax(K, 0, 100);\n this.updateRGBFromCMYK();\n this.update('cmyk');\n return this;\n }\n get options() {\n return this._options;\n }\n get R() {\n return round(this.rgb.R, this.options.decimals);\n }\n get G() {\n return round(this.rgb.G, this.options.decimals);\n }\n get B() {\n return round(this.rgb.B, this.options.decimals);\n }\n get H() {\n return round(this.hsl.H, this.options.decimals);\n }\n get S() {\n return round(this.hsl.S, this.options.decimals);\n }\n get L() {\n return round(this.hsl.L, this.options.decimals);\n }\n get Whiteness() {\n return round(this.hwb.W, this.options.decimals);\n }\n get Blackness() {\n return round(this.hwb.B, this.options.decimals);\n }\n get CIEL() {\n return round(this.lab.L, this.options.decimals);\n }\n get CIEa() {\n return round(this.lab.a, this.options.decimals);\n }\n get CIEb() {\n return round(this.lab.b, this.options.decimals);\n }\n get LCHL() {\n return round(this.lch.L, this.options.decimals);\n }\n get LCHC() {\n return round(this.lch.C, this.options.decimals);\n }\n get LCHH() {\n return round(this.lch.H, this.options.decimals);\n }\n get A() {\n return round(this.hsl.A, this.options.decimals);\n }\n get C() {\n return round(this.cmyk.C, this.options.decimals);\n }\n get M() {\n return round(this.cmyk.M, this.options.decimals);\n }\n get Y() {\n return round(this.cmyk.Y, this.options.decimals);\n }\n get K() {\n return round(this.cmyk.K, this.options.decimals);\n }\n get HEXObject() {\n return colorParserContext.convert(this.rgb, ColorModel.HEX);\n }\n get HEXAObject() {\n return colorParserContext.convert(this.rgb, ColorModel.HEX, 0, true);\n }\n get RGBObject() {\n return colorParserContext.convert(this.rgb, ColorModel.RGB, this.options.decimals);\n }\n get RGBAObject() {\n return colorParserContext.convert(this.rgb, ColorModel.RGB, this.options.decimals, true);\n }\n get HSLObject() {\n return colorParserContext.convert(this.hsl, ColorModel.HSL, this.options.decimals);\n }\n get HSLAObject() {\n return colorParserContext.convert(this.hsl, ColorModel.HSL, this.options.decimals, true);\n }\n get HWBObject() {\n return colorParserContext.convert(this.hwb, ColorModel.HWB, this.options.decimals);\n }\n get HWBAObject() {\n return colorParserContext.convert(this.hwb, ColorModel.HWB, this.options.decimals, true);\n }\n get CIELabObject() {\n return colorParserContext.convert(this.lab, ColorModel.CIELab, this.options.decimals);\n }\n get CIELabAObject() {\n return colorParserContext.convert(this.lab, ColorModel.CIELab, this.options.decimals, true);\n }\n get LCHObject() {\n return colorParserContext.convert(this.lch, ColorModel.LCH, this.options.decimals);\n }\n get LCHAObject() {\n return colorParserContext.convert(this.lch, ColorModel.LCH, this.options.decimals, true);\n }\n get CMYKObject() {\n return colorParserContext.convert(this.cmyk, ColorModel.CMYK, this.options.decimals);\n }\n get CMYKAObject() {\n return colorParserContext.convert(this.cmyk, ColorModel.CMYK, this.options.decimals, true);\n }\n get HEX() {\n return colorParserContext.convertCSS(this.rgb, ColorModel.HEX);\n }\n get HEXA() {\n return colorParserContext.convertCSS(this.rgb, ColorModel.HEX, {}, true);\n }\n get RGB() {\n return colorParserContext.convertCSS(this.rgb, ColorModel.RGB, this.options);\n }\n get RGBA() {\n return colorParserContext.convertCSS(this.rgb, ColorModel.RGB, this.options, true);\n }\n get HSL() {\n return colorParserContext.convertCSS(this.hsl, ColorModel.HSL, this.options);\n }\n get HSLA() {\n return colorParserContext.convertCSS(this.hsl, ColorModel.HSL, this.options, true);\n }\n get HWB() {\n return colorParserContext.convertCSS(this.hwb, ColorModel.HWB, this.options);\n }\n get HWBA() {\n return colorParserContext.convertCSS(this.hwb, ColorModel.HWB, this.options, true);\n }\n get CIELab() {\n return colorParserContext.convertCSS(this.lab, ColorModel.CIELab, this.options);\n }\n get CIELabA() {\n return colorParserContext.convertCSS(this.lab, ColorModel.CIELab, this.options, true);\n }\n get LCH() {\n return colorParserContext.convertCSS(this.lch, ColorModel.LCH, this.options);\n }\n get LCHA() {\n return colorParserContext.convertCSS(this.lch, ColorModel.LCH, this.options, true);\n }\n get CMYK() {\n return colorParserContext.convertCSS(this.cmyk, ColorModel.CMYK, this.options);\n }\n get CMYKA() {\n return colorParserContext.convertCSS(this.cmyk, ColorModel.CMYK, this.options, true);\n }\n static toHEXObject(color) {\n return colorParserContext.convert(color, ColorModel.HEX);\n }\n static toHEX(color) {\n return colorParserContext.convertCSS(color, ColorModel.HEX);\n }\n static toHEXAObject(color) {\n return colorParserContext.convert(color, ColorModel.HEX, undefined, true);\n }\n static toHEXA(color) {\n return colorParserContext.convertCSS(color, ColorModel.HEX, undefined, true);\n }\n static toRGBObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.RGB, options.decimals);\n }\n static toRGB(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.RGB, getOptionsFromColorInput(options, color));\n }\n static toRGBAObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.RGB, options.decimals, true);\n }\n static toRGBA(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.RGB, getOptionsFromColorInput(options, color), true);\n }\n static toHSLObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.HSL, options.decimals);\n }\n static toHSL(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.HSL, getOptionsFromColorInput(options, color));\n }\n static toHSLAObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.HSL, options.decimals, true);\n }\n static toHSLA(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.HSL, getOptionsFromColorInput(options, color), true);\n }\n static toHWBObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.HWB, options.decimals);\n }\n static toHWB(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.HWB, getOptionsFromColorInput(options, color));\n }\n static toHWBAObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.HWB, options.decimals, true);\n }\n static toHWBA(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.HWB, getOptionsFromColorInput(options, color), true);\n }\n static toCIELabObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.CIELab, options.decimals);\n }\n static toCIELab(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.CIELab, getOptionsFromColorInput(options, color));\n }\n static toCIELabAObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.CIELab, options.decimals, true);\n }\n static toCIELabA(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.CIELab, getOptionsFromColorInput(options, color), true);\n }\n static toLCHObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.LCH, options.decimals);\n }\n static toLCH(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.LCH, getOptionsFromColorInput(options, color));\n }\n static toLCHAObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.LCH, options.decimals, true);\n }\n static toLCHA(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.LCH, getOptionsFromColorInput(options, color), true);\n }\n static toCMYKObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.CMYK, options.decimals);\n }\n static toCMYK(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.CMYK, getOptionsFromColorInput(options, color));\n }\n static toCMYKAObject(color, options = {}) {\n return colorParserContext.convert(color, ColorModel.CMYK, options.decimals, true);\n }\n static toCMYKA(color, options = {}) {\n return colorParserContext.convertCSS(color, ColorModel.CMYK, getOptionsFromColorInput(options, color), true);\n }\n static getBlendHEXObject(from, to, steps) {\n return getBlendReturn(from, to, ColorModel.HEX, false, false, steps);\n }\n static getBlendHEX(from, to, steps) {\n return getBlendReturn(from, to, ColorModel.HEX, true, false, steps);\n }\n static getBlendHEXAObject(from, to, steps) {\n return getBlendReturn(from, to, ColorModel.HEX, false, true, steps);\n }\n static getBlendHEXA(from, to, steps) {\n return getBlendReturn(from, to, ColorModel.HEX, true, true, steps);\n }\n static getBlendRGBObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.RGB, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendRGB(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.RGB, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendRGBAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.RGB, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendRGBA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.RGB, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHSLObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HSL, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHSL(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HSL, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHSLAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HSL, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHSLA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HSL, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHWBObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HWB, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHWB(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HWB, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHWBAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HWB, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendHWBA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.HWB, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendCIELabObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.CIELab, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendCIELab(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.CIELab, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendCIELabAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.CIELab, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendCIELabA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.CIELab, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendLCHObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.LCH, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendLCH(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.LCH, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendLCHAObject(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.LCH, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getBlendLCHA(from, to, thirdParameter, fourthParameter) {\n return getBlendReturn(from, to, ColorModel.LCH, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n }\n static getMixHEXObject(colors, mode) {\n return getMixReturn(colors, ColorModel.HEX, false, false, mode);\n }\n static getMixHEX(colors, mode = Mix.ADDITIVE) {\n return getMixReturn(colors, ColorModel.HEX, true, false, mode);\n }\n static getMixHEXAObject(colors, mode = Mix.ADDITIVE) {\n return getMixReturn(colors, ColorModel.HEX, false, true, mode);\n }\n static getMixHEXA(colors, mode = Mix.ADDITIVE) {\n return getMixReturn(colors, ColorModel.HEX, true, true, mode);\n }\n static getMixRGBObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.RGB, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixRGB(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.RGB, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixRGBAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.RGB, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixRGBA(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.RGB, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHSLObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HSL, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHSL(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HSL, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHSLAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HSL, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHSLA(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HSL, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHWBObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HWB, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHWB(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HWB, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHWBAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HWB, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixHWBA(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.HWB, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixCIELabObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.CIELab, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixCIELab(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.CIELab, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixCIELabAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.CIELab, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixCIELabA(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.CIELab, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixLCHObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.LCH, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixLCH(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.LCH, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixLCHAObject(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.LCH, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getMixLCHA(colors, secondParameter, thirdParameter) {\n return getMixReturn(colors, ColorModel.LCH, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n }\n static getShades(color, secondParameter, thirdParameter) {\n return getShadesOrTintsReturn(true, color, ...getShadesOrTintsReturnParameters(secondParameter, thirdParameter));\n }\n static getTints(color, secondParameter, thirdParameter) {\n return getShadesOrTintsReturn(false, color, ...getShadesOrTintsReturnParameters(secondParameter, thirdParameter));\n }\n static getHarmony(color, secondParam, thirdParam, fourthParam) {\n return getHarmonyReturn(color, ...getHarmonyReturnParameters(secondParam, thirdParam, fourthParam));\n }\n}\n\n;// ./src/index.ts\n\n\n\n;// ./src/@demo/demo1/index.js\n\n\n/* harmony default export */ const demo1 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const color = new ColorTranslator('hsl(180 100% 50%)', { decimals: 0 });\n\n for (let row = 0; row < 10; row++) {\n\n for (let col = 0; col < 10; col++) {\n\n color\n .setS(row * 10)\n .setL(col * 5 + 30);\n\n const box = document.createElement('div');\n\n box.classList.add('box');\n box.style.background = color.HEX;\n\n box.innerText =\n `R:${color.R}\n G:${color.G}\n B:${color.B}`;\n container.appendChild(box);\n\n }\n }\n\n return container;\n\n});\n;// ./src/@demo/demo2/index.js\n\n\n/* harmony default export */ const demo2 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const color = new ColorTranslator({ R: 255, G: 0, B: 0 });\n const hue = [0, 30, 60, 120, 240, 280, 320, 0];\n let rainbow;\n\n for (let r = 0; r < hue.length; r++) {\n\n color.setH(hue[r]);\n\n const bow = document.createElement('div');\n\n bow.classList.add('rainbow');\n bow.style.background = color.HEX;\n\n if (rainbow) {\n rainbow.appendChild(bow);\n } else {\n container.appendChild(bow);\n }\n\n rainbow = bow;\n }\n\n rainbow.style.background = '#333';\n\n return container;\n\n});\n;// ./src/@demo/demo3/index.js\n\n\n/* harmony default export */ const demo3 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const hsl = { H: 0, S: '90%', L: '50%' };\n const hue = [undefined, 55, 30, 0, 290, 220, 130];\n const total = hue.length;\n\n for (let row = 0; row < total; row++) {\n\n for (let col = 0; col < total; col++) {\n\n let index = total - row + col;\n if (index >= total) {\n index -= total;\n }\n hsl.H = hue[index];\n const rgb = hue[index] === undefined\n ? '#FFF'\n : ColorTranslator.toHEX(hsl);\n const box = document.createElement('div');\n\n box.classList.add('flag');\n box.style.background = rgb;\n\n container.appendChild(box);\n\n }\n }\n\n return container;\n\n});\n;// ./src/@demo/demo4/index.js\n\n\n/* harmony default export */ const demo4 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const hexColors = [\n '#FE2712', '#FE5409', '#FB9902',\n '#FABD03', '#FFFE32', '#D1EA2C',\n '#66B132', '#0392CE', '#0247FE',\n '#3D00A5', '#8601B0', '#A7194B'\n ];\n\n hexColors.forEach((color) => {\n\n const rgb = ColorTranslator.toRGB(color);\n const hsl = ColorTranslator.toHSL(color, { decimals: 0 });\n const hwb = ColorTranslator.toHWB(color, { decimals: 0 });\n const lab = ColorTranslator.toCIELab(color, { decimals: 0 });\n const lch = ColorTranslator.toLCH(color, { decimals: 0 });\n\n const rgbDiv = document.createElement('div');\n const hslDiv = document.createElement('div');\n const hwbDiv = document.createElement('div');\n const labDiv = document.createElement('div');\n const lchDiv = document.createElement('div');\n\n rgbDiv.style.backgroundColor = rgb;\n rgbDiv.textContent = rgb;\n\n hslDiv.style.backgroundColor = hsl;\n hslDiv.textContent = hsl;\n\n hwbDiv.style.backgroundColor = hwb;\n hwbDiv.textContent = hwb;\n\n labDiv.style.backgroundColor = lab;\n labDiv.textContent = lab;\n\n lchDiv.style.backgroundColor = lch;\n lchDiv.textContent = lch;\n\n container.appendChild(rgbDiv);\n container.appendChild(hslDiv);\n container.appendChild(hwbDiv);\n container.appendChild(labDiv);\n container.appendChild(lchDiv);\n\n });\n\n return container;\n\n});\n;// ./src/@demo/demo5/index.js\n\n\n/* harmony default export */ const demo5 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const colors = [\n 'red',\n 'lime',\n 'blue',\n 'aqua',\n 'yellow',\n 'fuchsia'\n ];\n const total = colors.length;\n\n for (let row = 0; row < total; row++) {\n\n const hsl = ColorTranslator.toHSLObject(colors[row]);\n const step = hsl.S / (total - 1);\n\n for (let col = 0; col < total; col++) {\n\n const rgb = ColorTranslator.toHEX(hsl);\n const cmyk = ColorTranslator.toCMYKObject(hsl, { decimals: 0 });\n\n const box = document.createElement('div');\n box.classList.add('box');\n box.style.background = rgb;\n box.innerText = `C:${cmyk.C}\n M:${cmyk.M}\n Y:${cmyk.Y}\n K:${cmyk.K}`;\n\n container.appendChild(box);\n\n hsl.S -= step;\n\n }\n }\n\n return container;\n\n});\n;// ./src/@demo/demo6/index.js\n\n\n/* harmony default export */ const demo6 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n const rows = 11;\n const mult = 3;\n\n for (let i = 0; i < rows; i++) {\n\n const blends = ColorTranslator.getBlendHEX('#F00', '#FF0', mult + i * mult);\n\n blends.forEach((blend, index) => {\n const box = document.createElement('div');\n box.classList.add('box', `file${i}`);\n box.style.background = blend;\n box.innerText = index + 1;\n container.appendChild(box);\n });\n\n }\n\n return container;\n\n});\n;// ./src/@demo/demo7/index.js\n\n\n/* harmony default export */ const demo7 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n\n const colors = ['#F00', '#FF8000', '#FF0', '#0F0', '#00F', '#A0F', '#F0A'];\n\n const createBox = (color, type) => {\n const box = document.createElement('div');\n box.classList.add('box');\n box.style.backgroundColor = color;\n if (type) box.dataset.type = type;\n container.appendChild(box);\n };\n\n colors.forEach((color) => {\n const shades = ColorTranslator.getShades(color, 3).reverse();\n const tints = ColorTranslator.getTints(color, 3);\n shades.forEach((shade) => createBox(shade, 'shade'));\n createBox(color);\n tints.forEach((tint) => createBox(tint, 'tint'));\n });\n\n return container;\n\n});\n;// ./src/@demo/demo8/index.js\n\n\n\n/* harmony default export */ const demo8 = ((ColorTranslator) => {\n\n const container = document.createElement('div');\n\n const mixes = [\n '#F00',\n '#0F0',\n '#00F',\n [1, 3],\n [1, 2],\n [2, 3],\n [1, 2, 3]\n ];\n\n const fillPlanes = () => {\n const planes = container.querySelectorAll('#planes path');\n planes.forEach((plane, index) => {\n let color = '#CCC';\n if (typeof mixes[index] === 'string') {\n color = mixes[index];\n } else if(mixes[index]) {\n const colors = mixes[index].map((i) => mixes[i - 1]);\n color = mixes[index] = ColorTranslator.getMixHEX(colors);\n }\n plane.setAttribute('fill', color);\n });\n };\n\n fetch('images/color-mixes.svg')\n .then(result => result.text())\n .then((svgCode) => {\n container.innerHTML = svgCode;\n fillPlanes();\n });\n\n return container;\n\n});\n;// ./src/@demo/demo9/index.js\n\n\n/* harmony default export */ const demo9 = ((ColorTranslator, { Mix }) => {\n\n const container = document.createElement('div');\n\n const mixes = [\n '#F00',\n '#FF0',\n '#00F',\n [1, 3],\n [1, 2],\n [2, 3],\n [1, 2, 3]\n ];\n\n const fillPlanes = () => {\n const planes = container.querySelectorAll('#planes path');\n planes.forEach((plane, index) => {\n let color = '#CCC';\n if (typeof mixes[index] === 'string') {\n color = mixes[index];\n } else if(mixes[index]) {\n const colors = mixes[index].map((i) => mixes[i - 1]);\n color = mixes[index] = ColorTranslator.getMixHEX(colors, Mix.SUBTRACTIVE);\n }\n plane.setAttribute('fill', color);\n });\n };\n\n fetch('images/color-mixes.svg')\n .then(result => result.text())\n .then((svgCode) => {\n container.innerHTML = svgCode;\n fillPlanes();\n });\n\n return container;\n\n});\n;// ./src/@demo/demo10/index.js\n\n\n/* harmony default export */ const demo10 = ((ColorTranslator, { Harmony }) => {\n\n const container = document.createElement('div');\n\n const harmonies = [\n { label: 'Complementary', value: Harmony.COMPLEMENTARY },\n { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n { label: 'Analogous', value: Harmony.ANALOGOUS },\n { label: 'Triadic', value: Harmony.TRIADIC },\n { label: 'Tetradic', value: Harmony.TETRADIC },\n { label: 'Square', value: Harmony.SQUARE }\n ];\n\n const baseColor = '#F00';\n\n const createElement = (className, parent) => {\n const div = document.createElement('div');\n div.classList.add(className);\n parent.appendChild(div);\n return div;\n };\n\n const createHarmony = (item) => {\n\n const wrapper = createElement('wrapper', container);\n const wheel = createElement('wheel', wrapper);\n const harmony = createElement('harmony', wrapper);\n createElement('label', wrapper).innerText = item.label;\n\n fetch('images/wheel-additive.svg')\n .then(result => result.text())\n .then((svgCode) => {\n const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value);\n const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n wheel.innerHTML = svgCode;\n harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n });\n\n };\n\n harmonies.forEach((item) => createHarmony(item));\n\n return container;\n\n});\n;// ./src/@demo/demo11/index.js\n\n\n/* harmony default export */ const demo11 = ((ColorTranslator, { Harmony, Mix }) => {\n\n const container = document.createElement('div');\n\n const harmonies = [\n { label: 'Complementary', value: Harmony.COMPLEMENTARY },\n { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n { label: 'Analogous', value: Harmony.ANALOGOUS },\n { label: 'Triadic', value: Harmony.TRIADIC },\n { label: 'Tetradic', value: Harmony.TETRADIC },\n { label: 'Square', value: Harmony.SQUARE }\n ];\n\n const baseColor = '#F00';\n\n const createElement = (className, parent) => {\n const div = document.createElement('div');\n div.classList.add(className);\n parent.appendChild(div);\n return div;\n };\n\n const createHarmony = (item) => {\n\n const wrapper = createElement('wrapper', container);\n const wheel = createElement('wheel', wrapper);\n const harmony = createElement('harmony', wrapper);\n createElement('label', wrapper).innerText = item.label;\n\n fetch('images/wheel-subtractive.svg')\n .then(result => result.text())\n .then((svgCode) => {\n const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value, Mix.SUBTRACTIVE);\n const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n wheel.innerHTML = svgCode;\n harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n });\n\n };\n\n harmonies.forEach((item) => createHarmony(item));\n\n return container;\n\n});\n;// ./src/@demo/demo.js\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst functioToString = (fn) => {\n const article = document.createElement('article');\n const pre = document.createElement('pre');\n article.classList.add('function-container');\n pre.classList.add('prettyprint');\n article.appendChild(pre);\n pre.innerHTML = fn.toString().replace('(ColorTranslator)', '()');\n return article;\n};\n\nconst demos = new Map([\n ['demo1', demo1],\n ['demo2', demo2],\n ['demo3', demo3],\n ['demo4', demo4],\n ['demo5', demo5],\n ['demo6', demo6],\n ['demo7', demo7],\n ['demo8', demo8],\n ['demo9', demo9],\n ['demo10', demo10],\n ['demo11', demo11]\n]);\n\ndocument.addEventListener('DOMContentLoaded', () => {\n demos.forEach((module, div) => {\n const demo = document.getElementById(div);\n const container = document.createElement('div');\n const wrapper = document.createElement('div');\n\n container.classList.add('demo-container');\n wrapper.classList.add('demo-wrapper');\n\n wrapper.appendChild(module(ColorTranslator, { Harmony: Harmony, Mix: Mix }));\n container.appendChild(wrapper);\n demo.appendChild(container);\n demo.appendChild(functioToString(module));\n });\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"117.js","mappings":";;;;AAAA;AACA;AACA;AACA;AACA;AACA,UAAU,qBAAM,oBAAoB,qBAAM;AAC1C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEO;AACP;;AAEA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,kBAAkB,iBAAiB;AACnC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA,qDAAqD;AACrD,QAAQ;AACR;AACA,QAAQ;AACR,4EAA4E;AAC5E;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEO;AACP;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4BAA4B,qBAAqB;AACjD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;;AAEO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA,qCAAqC,4BAA4B;AACjE;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA,6BAA6B,0BAA0B,eAAe;AACtE;;AAEO;AACP;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEO,SAAS,WAAK;AACrB;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA,WAAK;;AAEL;AACA,YAAY,WAAK;AACjB;AACA;AACA;AACA;;;ACjoBO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,wCAAwC;AAClC;AACP;AACA;AACA;AACA,CAAC,sCAAsC;AAChC;AACP;AACA;AACA;AACA,CAAC,4CAA4C;;;ACjBtC;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,gCAAgC;AAC1B;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,0BAA0B;AACpB;AACP;AACA;AACA;AACA,CAAC,kBAAkB;AACZ;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,sCAAsC;;;AC9KF;AAC9B;AACP,KAAK,UAAU,iFAAiF,EAAE,eAAe,EAAE,eAAe,EAAE,eAAe,EAAE;AACrJ,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACA;AACA,yBAAyB,IAAI;AAC7B,wBAAwB,OAAO;AAC/B;AACA;;;ACvBkE;AACrB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,aAAa;AAC5C;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACM;AACP,UAAU,UAAU;AACpB,UAAU,UAAU;AACpB,UAAU,UAAU;AACpB,WAAW,UAAU;AACrB,UAAU,UAAU;AACpB,UAAU,UAAU;AACpB,SAAS,UAAU;AACnB,SAAS,UAAU;AACnB,SAAS,UAAU;AACnB,UAAU,UAAU;AACpB,SAAS,UAAU;AACnB,SAAS,UAAU;AACnB,CAAC;AACM;AACP;AACA;AACA;AACA,gBAAgB,cAAc;AAC9B,aAAa,aAAa;AAC1B,aAAa,aAAa;AAC1B,aAAa,aAAa;AAC1B,cAAc,aAAa;AAC3B,eAAe,aAAa;AAC5B,kBAAkB,gBAAgB;AAClC,CAAC;AACM;AACP;AACA;AACA,CAAC;AACyB;AACF;;;ACrDgB;AACkI;AACnK;AACA;AACA;AACA;AACA;AACA;AACP,WAAW,mBAAmB;AAC9B;AACO,wDAAwD,UAAU;AAClE,wDAAwD,UAAU;AAClE,wDAAwD,UAAU;AAClE,2DAA2D,UAAU;AACrE,wDAAwD,UAAU;AAClE,yDAAyD,UAAU;AACnE;AACP,eAAe,QAAQ,UAAU,KAAK;AACtC;AACO,6BAA6B,KAAK,SAAS,QAAQ;AAC1D;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA,qBAAqB,IAAI;AACzB;AACA,gBAAgB,IAAI;AACpB;AACO;AACP;AACA;AACA,kBAAkB,IAAI;AACtB;AACA;AACA;AACO,kEAAkE,QAAQ;AAC1E,kEAAkE,OAAO;AACzE,kEAAkE,SAAS;AAC3E;AACP,kBAAkB,KAAK;AACvB,wBAAwB,QAAQ,+BAA+B,QAAQ;AACvE;AACA,QAAQ,GAAG;AACX;AACA;AACA;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA,wCAAwC,QAAQ;AAChD;AACO;AACP,QAAQ,KAAK;AACb,sBAAsB,OAAO,gCAAgC,OAAO,EAAE,OAAO;AAC7E;AACA,2BAA2B,OAAO,EAAE,OAAO;AAC3C;AACO;AACP,QAAQ,KAAK;AACb,sBAAsB,SAAS,gCAAgC,SAAS,EAAE,SAAS;AACnF;AACA,2BAA2B,SAAS,EAAE,SAAS;AAC/C;AACO;AACP,kBAAkB,KAAK;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACO,iCAAiC,YAAY;AACpD;AACA;AACA;AACO;AACA;AACA;AACA;AACP;AACA,kCAAkC,OAAO;AACzC;AACA;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA,iBAAiB,cAAc;AAC/B,oCAAoC,OAAO;AAC3C;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA;AACA;AACA,eAAe,OAAO;AACtB,gCAAgC,OAAO,IAAI,OAAO;AAClD;AACA;AACA;AACO;AACP;AACA,YAAY,KAAK;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,SAAS,IAAI,SAAS;AAC3D;AACO;AACP;AACA;AACA,aAAa,cAAc;AAC3B;AACA;AACA,aAAa,cAAc;AAC3B,kCAAkC,OAAO;AACzC;AACA,aAAa,cAAc;AAC3B,wBAAwB,QAAQ;AAChC;AACA,aAAa,cAAc;AAC3B,aAAa,cAAc;AAC3B;AACA;AACA;AACA;AACA;AACO;AACP,cAAc,MAAM,KAAK,OAAO;AAChC;AACO;AACP,cAAc,MAAM,KAAK,GAAG;AAC5B;AACO;AACP;AACA,0CAA0C,OAAO;AACjD;AACA;AACA,cAAc,cAAc;AAC5B;AACA;AACA,WAAW,cAAc;AACzB;;;AC9JiD;AAC0B;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK,0BAA0B,QAAQ;AACtD;AACA;AACA,eAAe,KAAK,MAAM,QAAQ;AAClC;AACA;AACA,eAAe,KAAK,gCAAgC,QAAQ;AAC5D;AACA;AACA,eAAe,KAAK,MAAM,QAAQ;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB,oBAAoB,SAAS;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,KAAK;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACA;AACO;AACP;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,WAAW,MAAM,UAAU,QAAQ,KAAK,QAAQ;AAChD,WAAW,MAAM,UAAU,QAAQ,KAAK,QAAQ;AAChD,WAAW,MAAM,UAAU,QAAQ,KAAK,QAAQ;AAChD;AACA;AACO;AACP;AACA,cAAc,OAAO;AACrB;AACA;AACA;AACA,WAAW,YAAY;AACvB;AACA;AACO;AACP,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA,WAAW,KAAK,qBAAqB,QAAQ;AAC7C,WAAW,KAAK,0BAA0B,QAAQ;AAClD;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,MAAM,QAAQ,QAAQ,KAAK,QAAQ;AAC9C,WAAW,MAAM,QAAQ,QAAQ,KAAK,QAAQ;AAC9C,WAAW,MAAM,QAAQ,QAAQ,KAAK,QAAQ;AAC9C;AACA;AACO;AACP;AACA;AACA,WAAW,MAAM,CAAC,KAAK,CAAC,QAAQ,oBAAoB,QAAQ;AAC5D,WAAW,MAAM,CAAC,KAAK,CAAC,QAAQ,oBAAoB,QAAQ;AAC5D,WAAW,MAAM,CAAC,KAAK,CAAC,QAAQ,oBAAoB,QAAQ;AAC5D;AACA;AACO;AACP,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB,SAAS,QAAQ;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB,WAAW,KAAK;AAChB;AACA;AACO;AACP;AACA,wBAAwB,QAAQ,MAAM,QAAQ,MAAM,QAAQ;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,wBAAwB,QAAQ,MAAM,QAAQ,MAAM,QAAQ;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;;AClVqD;AACF;AAC5C;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B;AACA;AACA;AACA;AACA;AACA,qCAAqC,eAAe;AACpD;AACA;AACA;AACA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;AACA;AACO;AACP;AACA,YAAY,QAAQ;AACpB;AACA;AACA,gBAAgB,WAAW;AAC3B;AACA;AACA;;;ACpCuF;AACuB;AAC9G;AACA,QAAQ,WAAW;AACnB;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,QAAQ,WAAW;AACnB;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA,QAAQ,WAAW;AACnB;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA,QAAQ,cAAc;AACtB;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA,QAAQ,WAAW;AACnB;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA,QAAQ,YAAY;AACpB;AACA,eAAe,SAAS;AACxB;AACA;AACA;AACA;AACA;;;AC3CuD;AACqB;AACA;AACrE;AACP;AACA;AACO;AACP,kBAAkB,qBAAqB;AACvC,kBAAkB,mBAAmB;AACrC,iBAAiB,WAAW;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP,4BAA4B,YAAY;AACxC;AACA,kBAAkB,YAAY;AAC9B,KAAK;AACL;AACO;AACP,YAAY,iCAAiC;AAC7C,sBAAsB,aAAa;AACnC;AACA;AACA,kBAAkB,KAAK,wBAAwB;AAC/C;AACA,WAAW,KAAK;AAChB;AACO;AACP,YAAY,uBAAuB;AACnC;AACA;AACA,2BAA2B,cAAc;AACzC,+BAA+B,KAAK,CAAC,gBAAgB;AACrD,sBAAsB,WAAW,EAAE,WAAW;AAC9C;AACA;AACA;AACA,cAAc,KAAK;AACnB;AACA;;;AC7C6F;AACzD;AACgC;AAC4C;AAC7D;AAC5C,wBAAwB,WAAW;AAC1C;AACA,2BAA2B,UAAU;AACrC;AACA,cAAc,aAAa;AAC3B,qCAAqC,SAAS;AAC9C;AACA;AACA;AACA,YAAY,QAAQ;AACpB,oBAAoB,SAAS;AAC7B,mBAAmB,UAAU;AAC7B;AACA;AACA,oBAAoB,GAAG,SAAS,QAAQ;AACxC,SAAS;AACT,eAAe,WAAW;AAC1B;AACA;AACA,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,MAAM;AACzB,mBAAmB,MAAM;AACzB,mBAAmB,MAAM;AACzB,oBAAoB,WAAW;AAC/B;AACA;AACA,2BAA2B,MAAM,MAAM,QAAQ;AAC/C,qBAAqB;AACrB;AACA;AACA;AACA,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,gBAAgB,WAAW;AAC3B;AACA;AACA,gCAAgC,gBAAgB,IAAI,QAAQ;AAC5D,iBAAiB;AACjB;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA,cAAc,MAAM;AACpB;AACA,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB;AACA;AACA,uBAAuB,WAAW;AAClC;AACA,0BAA0B,MAAM,SAAS,QAAQ;AACjD;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA,uCAAuC,KAAK,CAAC,KAAK;AAClD,uBAAuB,kBAAkB;AACzC;AACA,iBAAiB,GAAG,GAAG,GAAG,EAAE;AAC5B,iBAAiB,GAAG,GAAG,EAAE;AACzB,eAAe,wBAAwB;AACvC;AACA;AACA;AACA;AACA,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;ACvF0C;AAC1C;AACO;AACP;AACA;AACA,aAAa,IAAI;AACjB,aAAa,IAAI;AACjB,aAAa,IAAI;AACjB,aAAa,IAAI;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,IAAI;AACrB,YAAY,IAAI;AAChB;AACA;AACA;AACA,mBAAmB,IAAI;AACvB,gBAAgB,IAAI;AACpB,gDAAgD,IAAI;AACpD;AACA,iBAAiB;AACjB,oBAAoB,IAAI;AACxB,oBAAoB,IAAI;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,IAAI;AACrC;AACA;AACA;AACA,iDAAiD,iBAAiB,IAAI,WAAW,EAAE,MAAM,4BAA4B;AACrH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;;AC1EuC;AACkC;AACwD;AACnC;AAC1D;AACM;AACS;AAC5C,wBAAwB,WAAW;AAC1C;AACA,kCAAkC,SAAS;AAC3C;AACA;AACA;AACA,YAAY,QAAQ;AACpB,mBAAmB,SAAS;AAC5B;AACA;AACA,qBAAqB,KAAK,SAAS,QAAQ;AAC3C,kBAAkB,GAAG,SAAS,QAAQ;AACtC;AACA,gCAAgC,QAAQ;AACxC,SAAS;AACT,eAAe,WAAW;AAC1B;AACA;AACA,YAAY,QAAQ;AACpB;AACA,oBAAoB,2GAA2G;AAC/H;AACA;AACA,gCAAgC,MAAM;AACtC;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC;AACA,mCAAmC,QAAQ;AAC3C,mCAAmC,QAAQ;AAC3C,mCAAmC,QAAQ;AAC3C;AACA;AACA,kCAAkC,UAAU;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,gBAAgB,KAAK,QAAQ;AAC7D,gCAAgC,gBAAgB,KAAK,QAAQ;AAC7D,gCAAgC,gBAAgB,KAAK,QAAQ;AAC7D,wBAAwB,WAAW;AACnC;AACA;AACA,+BAA+B,cAAc;AAC7C,yBAAyB;AACzB;AACA;AACA;AACA;AACA,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,gBAAgB,WAAW;AAC3B;AACA;AACA,gCAAgC,gBAAgB,IAAI,QAAQ;AAC5D,iBAAiB;AACjB;AACA;AACA;AACA,oBAAoB,WAAW;AAC/B;AACA,cAAc,MAAM;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB,SAAS;AACT;AACA;AACA,gBAAgB,kDAAkD;AAClE;AACA,sBAAsB,WAAW;AACjC;AACA,+BAA+B,aAAa;AAC5C,qBAAqB,sBAAsB,kBAAkB;AAC7D;AACA,sBAAsB,WAAW;AACjC,sBAAsB,KAAK;AAC3B;AACA,uBAAuB,kBAAkB;AACzC;AACA;AACA,yBAAyB,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AAC5D,wBAAwB,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AAChD;AACA,wBAAwB,IAAI,IAAI,GAAG,GAAG,EAAE;AACxC,wBAAwB,IAAI,IAAI,EAAE;AAClC,eAAe,wBAAwB;AACvC;AACA;AACA,kBAAkB,KAAK;AACvB,kBAAkB,KAAK;AACvB,kBAAkB,KAAK;AACvB;AACA;AACA;AACA;AACA,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,KAAK;AAC5B,iBAAiB;AACjB;AACA;AACA;AACA;AACA,gBAAgB,qDAAqD;AACrE;AACA,kCAAkC,KAAK;AACvC,gBAAgB,KAAK;AACrB,gBAAgB,KAAK;AACrB,gCAAgC,KAAK;AACrC,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;AChJqE;AAC+D;AAC3B;AACrE;AACU;AACJ;AACS;AAC5C,wBAAwB,WAAW;AAC1C;AACA,kCAAkC,SAAS;AAC3C;AACA;AACA;AACA,YAAY,QAAQ;AACpB,mBAAmB,SAAS;AAC5B;AACA,eAAe,WAAW;AAC1B;AACA;AACA,YAAY,QAAQ;AACpB;AACA,oBAAoB,2GAA2G;AAC/H;AACA;AACA,gCAAgC,MAAM;AACtC,gCAAgC,QAAQ;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC;AACA,uBAAuB,YAAY;AACnC,uBAAuB,OAAO;AAC9B,uBAAuB,OAAO;AAC9B;AACA;AACA,kCAAkC,UAAU;AAC5C,4BAA4B,MAAM,OAAO,SAAS;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,YAAY;AACnC,uBAAuB,OAAO;AAC9B,uBAAuB,OAAO;AAC9B,wBAAwB,WAAW;AACnC;AACA;AACA,+BAA+B,cAAc;AAC7C,yBAAyB;AACzB;AACA;AACA;AACA;AACA,eAAe,YAAY;AAC3B,eAAe,OAAO,IAAI,QAAQ;AAClC,eAAe,OAAO,IAAI,QAAQ;AAClC,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,MAAM,cAAc,SAAS;AACpD,iBAAiB;AACjB;AACA;AACA;AACA;AACA,YAAY,WAAW;AACvB;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB,SAAS;AACT;AACA;AACA,gBAAgB,+BAA+B;AAC/C,sBAAsB,WAAW;AACjC;AACA,4BAA4B,sBAAsB;AAClD,uBAAuB,kBAAkB;AACzC;AACA;AACA,yBAAyB,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,GAAG,OAAO,EAAE;AAC9D,wBAAwB,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE;AACjD;AACA,wBAAwB,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE;AAC1C,wBAAwB,IAAI,EAAE,GAAG,EAAE;AACnC,eAAe,wBAAwB;AACvC;AACA;AACA;AACA,eAAe,KAAK,CAAC,YAAY;AACjC,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,KAAK;AAC5B,iBAAiB;AACjB;AACA;AACA;AACA;AACA,gBAAgB,2BAA2B;AAC3C;AACA,uBAAuB,YAAY;AACnC,gCAAgC,KAAK;AACrC,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;ACrIyF;AAC2C;AACxC;AACxD;AACU;AACJ;AACS;AAC5C,wBAAwB,WAAW;AAC1C;AACA,kCAAkC,SAAS;AAC3C;AACA;AACA;AACA,YAAY,QAAQ;AACpB,mBAAmB,SAAS;AAC5B;AACA,eAAe,WAAW;AAC1B;AACA;AACA,YAAY,QAAQ;AACpB;AACA,oBAAoB,mEAAmE;AACvF;AACA;AACA,gCAAgC,MAAM;AACtC,gCAAgC,QAAQ;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC;AACA,uBAAuB,MAAM,OAAO,OAAO;AAC3C,uBAAuB,MAAM,OAAO,SAAS;AAC7C,uBAAuB,MAAM,OAAO,SAAS;AAC7C;AACA;AACA,kCAAkC,UAAU;AAC5C,4BAA4B,MAAM,OAAO,SAAS;AAClD;AACA;AACA;AACA;AACA;AACA,uBAAuB,YAAY;AACnC,uBAAuB,OAAO;AAC9B,uBAAuB,OAAO;AAC9B,wBAAwB,WAAW;AACnC;AACA;AACA,+BAA+B,cAAc;AAC7C,yBAAyB;AACzB;AACA;AACA;AACA;AACA,eAAe,YAAY;AAC3B,eAAe,OAAO;AACtB,eAAe,OAAO;AACtB,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA;AACA;AACA,YAAY,WAAW;AACvB;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB,SAAS;AACT;AACA;AACA;AACA,4BAA4B,sBAAsB;AAClD,uBAAuB,kBAAkB;AACzC;AACA,oBAAoB,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE;AACtC,oBAAoB,IAAI,EAAE,GAAG,EAAE;AAC/B,eAAe,wBAAwB;AACvC;AACA;AACA;AACA,eAAe,KAAK,CAAC,YAAY;AACjC,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,KAAK;AAC5B,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,uBAAuB,YAAY;AACnC,gCAAgC,KAAK;AACrC,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;AC1HuC;AACkD;AAC4D;AACpE;AAC7C;AACU;AACJ;AACS;AAC5C,2BAA2B,WAAW;AAC7C;AACA,kCAAkC,SAAS;AAC3C;AACA;AACA;AACA,YAAY,QAAQ;AACpB,mBAAmB,SAAS;AAC5B;AACA,eAAe,cAAc;AAC7B;AACA;AACA,YAAY,QAAQ;AACpB;AACA,oBAAoB,mEAAmE;AACvF;AACA;AACA,gCAAgC,MAAM;AACtC,mCAAmC,QAAQ;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC;AACA,uBAAuB,MAAM,OAAO,SAAS;AAC7C,uBAAuB,MAAM,KAAK,OAAO,EAAE,OAAO;AAClD,uBAAuB,MAAM,KAAK,OAAO,EAAE,OAAO;AAClD;AACA;AACA,kCAAkC,UAAU;AAC5C,+BAA+B,MAAM,OAAO,SAAS;AACrD;AACA;AACA;AACA;AACA;AACA,uBAAuB,OAAO;AAC9B,uBAAuB,gBAAgB;AACvC,uBAAuB,gBAAgB;AACvC,wBAAwB,WAAW;AACnC;AACA;AACA,+BAA+B,cAAc;AAC7C,yBAAyB;AACzB;AACA;AACA;AACA;AACA,eAAe,OAAO;AACtB,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA;AACA;AACA,YAAY,cAAc;AAC1B;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB,SAAS;AACT;AACA;AACA,gBAAgB,oBAAoB;AACpC;AACA;AACA;AACA,0BAA0B,KAAK,CAAC,OAAO;AACvC,mCAAmC,aAAa;AAChD,yBAAyB,EAAE;AAC3B,yBAAyB,EAAE;AAC3B;AACA;AACA,mCAAmC,aAAa;AAChD,yBAAyB,sBAAsB,kBAAkB;AACjE,sBAAsB,KAAK;AAC3B;AACA,mBAAmB,WAAW;AAC9B;AACA,uBAAuB,kBAAkB;AACzC;AACA,oBAAoB,IAAI,IAAI,GAAG,GAAG,EAAE;AACpC,oBAAoB,IAAI,IAAI,EAAE;AAC9B,eAAe,wBAAwB;AACvC;AACA;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,KAAK;AAC5B,iBAAiB;AACjB;AACA;AACA;AACA;AACA,gBAAgB,aAAa;AAC7B;AACA,kCAAkC,KAAK;AACvC,gBAAgB,KAAK;AACrB,gBAAgB,KAAK;AACrB,gCAAgC,KAAK;AACrC,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;AC5IuD;AACoC;AACqG;AAC/G;AAC7C;AACU;AACJ;AACS;AAC5C,wBAAwB,WAAW;AAC1C;AACA,kCAAkC,SAAS;AAC3C;AACA;AACA;AACA,YAAY,QAAQ;AACpB,mBAAmB,SAAS;AAC5B;AACA,eAAe,WAAW;AAC1B;AACA;AACA,YAAY,QAAQ;AACpB;AACA,oBAAoB,mEAAmE;AACvF;AACA;AACA,gCAAgC,MAAM;AACtC,gCAAgC,QAAQ;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC,8BAA8B,UAAU;AACxC;AACA,uBAAuB,MAAM,OAAO,SAAS;AAC7C,uBAAuB,MAAM,KAAK,SAAS,EAAE,SAAS;AACtD,uBAAuB,YAAY;AACnC;AACA;AACA,kCAAkC,UAAU;AAC5C,4BAA4B,MAAM,OAAO,SAAS;AAClD;AACA;AACA;AACA;AACA;AACA,uBAAuB,OAAO;AAC9B,uBAAuB,gBAAgB;AACvC,uBAAuB,YAAY;AACnC,wBAAwB,WAAW;AACnC;AACA;AACA,+BAA+B,cAAc;AAC7C,yBAAyB;AACzB;AACA;AACA;AACA;AACA,eAAe,OAAO;AACtB,eAAe,gBAAgB,IAAI,QAAQ;AAC3C,eAAe,YAAY;AAC3B,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA;AACA;AACA,YAAY,WAAW;AACvB;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB,SAAS;AACT;AACA;AACA,gBAAgB,gCAAgC;AAChD;AACA;AACA;AACA,0BAA0B,KAAK,CAAC,OAAO;AACvC,mCAAmC,aAAa;AAChD,yBAAyB,EAAE;AAC3B,yBAAyB,EAAE;AAC3B;AACA;AACA,mCAAmC,aAAa;AAChD,yBAAyB,sBAAsB,kBAAkB;AACjE,sBAAsB,KAAK;AAC3B;AACA;AACA,mCAAmC,cAAc;AACjD,uCAAuC,KAAK,CAAC,gBAAgB;AAC7D,8BAA8B,WAAW,EAAE,WAAW;AACtD;AACA,uBAAuB,KAAK;AAC5B;AACA,mBAAmB,WAAW;AAC9B;AACA,uBAAuB,kBAAkB;AACzC;AACA,oBAAoB,IAAI,IAAI,GAAG,GAAG,EAAE;AACpC,oBAAoB,IAAI,IAAI,EAAE;AAC9B,eAAe,wBAAwB;AACvC;AACA;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK,CAAC,YAAY;AACjC,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,KAAK;AAC5B,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,uBAAuB,YAAY;AACnC,kCAAkC,KAAK;AACvC,gBAAgB,KAAK;AACrB,gCAAgC,KAAK;AACrC,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;AClJuC;AACmB;AAC6C;AACT;AAC1D;AACW;AACI;AAC5C,yBAAyB,WAAW;AAC3C;AACA,kCAAkC,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,mBAAmB,SAAS;AAC5B;AACA,eAAe,YAAY;AAC3B;AACA;AACA,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,aAAa;AAChC,mBAAmB,aAAa;AAChC,mBAAmB,aAAa;AAChC,mBAAmB,aAAa;AAChC,oBAAoB,WAAW;AAC/B;AACA;AACA,2BAA2B,cAAc;AACzC,qBAAqB;AACrB;AACA;AACA;AACA;AACA,eAAe,aAAa,IAAI,QAAQ;AACxC,eAAe,aAAa,IAAI,QAAQ;AACxC,eAAe,aAAa,IAAI,QAAQ;AACxC,eAAe,aAAa,IAAI,QAAQ;AACxC,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,cAAc;AACrC,iBAAiB;AACjB;AACA;AACA;AACA;AACA,YAAY,YAAY;AACxB;AACA;AACA;AACA,wBAAwB,MAAM;AAC9B,mBAAmB,SAAS;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB,SAAS;AACT;AACA;AACA,gBAAgB,iEAAiE;AACjF,sBAAsB,WAAW;AACjC;AACA;AACA,6BAA6B,aAAa;AAC1C;AACA,0BAA0B,KAAK,kBAAkB;AACjD;AACA;AACA,kBAAkB,WAAW;AAC7B,kBAAkB,KAAK;AACvB;AACA,uBAAuB,kBAAkB;AACzC;AACA;AACA,qBAAqB,aAAa,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AAClF,qBAAqB,aAAa,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE;AACvE;AACA,qBAAqB,aAAa,EAAE,IAAI,IAAI,IAAI,GAAG,GAAG,EAAE;AACxD,qBAAqB,aAAa,EAAE,IAAI,IAAI,IAAI,EAAE;AAClD,eAAe,wBAAwB;AACvC;AACA;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,gBAAgB,WAAW;AAC3B;AACA;AACA,uBAAuB,KAAK;AAC5B,iBAAiB;AACjB;AACA;AACA;AACA;AACA,gBAAgB,kEAAkE;AAClF;AACA,kCAAkC,KAAK;AACvC,gBAAgB,KAAK;AACrB,gBAAgB,KAAK;AACrB,gBAAgB,KAAK;AACrB,gCAAgC,KAAK;AACrC,uBAAuB,WAAW;AAClC;AACA;AACA;AACA,eAAe,UAAU;AACzB;AACA;;;AC/HyE;AACe;AAC7B;AACM;AAClB;AACA;AACA;AACA;AACM;AACN;AACE;AAC1C,sBAAsB,SAAS;AAC/B,sBAAsB,SAAS;AAC/B,sBAAsB,SAAS;AAC/B,sBAAsB,SAAS;AAC/B,yBAAyB,YAAY;AACrC,sBAAsB,SAAS;AAC/B,uBAAuB,UAAU;AACjC,+BAA+B,kBAAkB;AACxD,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,KAAK,UAAU;AACf,CAAC;AACM;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,cAAc;AACzD,0CAA0C,aAAa;AACvD,6CAA6C,gBAAgB;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB;AACA;AACA;AACA,4DAA4D,qBAAqB;AACjF;AACA,oBAAoB,MAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA,cAAc,eAAe;AAC7B,mBAAmB,SAAS;AAC5B;AACA;AACA,gEAAgE,eAAe;AAC/E,2BAA2B,SAAS;AACpC;AACA;AACA,wEAAwE,eAAe;AACvF;AACA;AACA;AACA;AACA,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,aAAa;AAC/B,kBAAkB,eAAe;AACjC;AACA;AACA;AACA,kBAAkB,gBAAgB;AAClC,kBAAkB,eAAe;AACjC;AACA;;;AC/IiH;AACG;AACpD;AAC5B;AACoC;AACxE;AACA;AACA;AACA;AACA;AACA,kBAAkB,cAAc;AAChC,gBAAgB,cAAc;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB;AACA,KAAK;AACL;AACO,iEAAiE,mBAAmB,cAAc;AACzG;AACA,gBAAgB,mBAAmB;AACnC,uBAAuB,kBAAkB;AACzC,qBAAqB,kBAAkB;AACvC,0BAA0B,MAAM;AAChC,wBAAwB,MAAM;AAC9B;AACA;AACA;AACA,mBAAmB,kBAAkB,0BAA0B,wBAAwB;AACvF;AACA,eAAe,kBAAkB;AACjC,KAAK;AACL;AACO;AACP,2BAA2B,QAAQ;AACnC;AACA;AACA,6BAA6B,QAAQ;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACO,4DAA4D,GAAG,uBAAuB;AAC7F;AACA,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D,KAAK;AACL,4BAA4B,GAAG;AAC/B;AACA,wBAAwB,QAAQ;AAChC,iBAAiB,WAAW;AAC5B;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,iCAAiC,GAAG;AACpC,gBAAgB;AAChB,gBAAgB;AAChB;AACA,2BAA2B,WAAW;AACtC;AACA;AACA;AACA,sDAAsD,QAAQ;AAC9D,sDAAsD,QAAQ;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,GAAG;AAChC,wBAAwB,sCAAsC,QAAQ;AACtE,wBAAwB,sCAAsC,QAAQ,GAAG;AACzE;AACA,SAAS;AACT;AACA;AACA,iBAAiB,GAAG;AACpB;AACA;AACA;AACA;AACA,cAAc,QAAQ;AACtB;AACA;AACA;AACA,eAAe,kBAAkB,wBAAwB,wBAAwB;AACjF;AACA,WAAW,kBAAkB;AAC7B;AACA;AACO;AACP,sBAAsB,QAAQ;AAC9B;AACA;AACA,yBAAyB,QAAQ;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACO,uDAAuD,0BAA0B,cAAc;AACtG,kBAAkB,QAAQ;AAC1B,mBAAmB,kBAAkB;AACrC;AACA;AACA,gBAAgB,kBAAkB,gBAAgB,UAAU;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kBAAkB,6BAA6B,wBAAwB;AAC1F,SAAS;AACT;AACA;AACA,eAAe,kBAAkB;AACjC,KAAK;AACL;AACO;AACP,uBAAuB,QAAQ;AAC/B;AACA;AACA,yBAAyB,QAAQ;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,GAAG;AAC3B,kBAAkB,YAAY;AAC9B,kBAAkB,YAAY,CAAC,MAAM,CAAC,MAAM;AAC5C;AACA;AACA,CAAC,KAAK,UAAU;AAChB;AACA;AACA,QAAQ,OAAO;AACf;AACA;AACA;AACA,QAAQ,OAAO;AACf;AACA;AACA;AACA,QAAQ,OAAO;AACf;AACA;AACA;AACA,QAAQ,OAAO;AACf;AACA;AACA;AACA,QAAQ,OAAO;AACf;AACA;AACA;AACA,QAAQ,OAAO;AACf;AACA;AACA;AACO,4DAA4D;AACnE;AACA,kBAAkB,QAAQ;AAC1B,mBAAmB,kBAAkB;AACrC;AACA;AACA,gBAAgB,kBAAkB,gBAAgB,UAAU;AAC5D;AACA;AACA;AACA,mBAAmB,kBAAkB,iCAAiC,wBAAwB;AAC9F,SAAS;AACT;AACA;AACA,eAAe,kBAAkB;AACjC,KAAK;AACL;AACO;AACP,QAAQ,SAAS;AACjB;AACA;AACA,YAAY,KAAK;AACjB;AACA,kBAAkB,GAAG;AACrB,YAAY,KAAK;AACjB;AACA;AACA;AACA;AACA,QAAQ,KAAK;AACb;AACA,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;AACA,QAAQ,OAAO;AACf,QAAQ,GAAG;AACX;AACA;AACA;;;AC1OiG;AAC6D;AACtF;AACA;AACsI;AACvM;AACP,mCAAmC;AACnC,wBAAwB,wBAAwB;AAChD,4BAA4B,kBAAkB;AAC9C,sBAAsB,aAAa;AACnC;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA,mBAAmB,QAAQ;AAC3B;AACA;AACA,mBAAmB,QAAQ;AAC3B;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,QAAQ;AAC1C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,QAAQ;AAC1C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,QAAQ;AAC1C;AACA;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,KAAK,OAAO,EAAE,OAAO;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,KAAK,OAAO,EAAE,OAAO;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,MAAM,OAAO,SAAS;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM,OAAO,SAAS;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA,sBAAsB,MAAM;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,KAAK;AACpB;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,oBAAoB,UAAU;AAC/D;AACA;AACA,eAAe,kBAAkB,oBAAoB,UAAU;AAC/D;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU,QAAQ;AACzE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,sBAAsB,UAAU;AACjE;AACA;AACA,eAAe,kBAAkB,uBAAuB,UAAU;AAClE;AACA;AACA,eAAe,kBAAkB,uBAAuB,UAAU;AAClE;AACA;AACA,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA;AACA,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA;AACA,eAAe,kBAAkB,mBAAmB,UAAU;AAC9D;AACA,0CAA0C;AAC1C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,oCAAoC;AACpC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,2CAA2C;AAC3C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,qCAAqC;AACrC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,0CAA0C;AAC1C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,oCAAoC;AACpC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,2CAA2C;AAC3C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,qCAAqC;AACrC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,0CAA0C;AAC1C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,oCAAoC;AACpC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,2CAA2C;AAC3C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,qCAAqC;AACrC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,6CAA6C;AAC7C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,uCAAuC;AACvC,eAAe,kBAAkB,mBAAmB,UAAU,SAAS,wBAAwB;AAC/F;AACA,8CAA8C;AAC9C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,wCAAwC;AACxC,eAAe,kBAAkB,mBAAmB,UAAU,SAAS,wBAAwB;AAC/F;AACA,0CAA0C;AAC1C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,oCAAoC;AACpC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,2CAA2C;AAC3C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,qCAAqC;AACrC,eAAe,kBAAkB,mBAAmB,UAAU,MAAM,wBAAwB;AAC5F;AACA,2CAA2C;AAC3C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,qCAAqC;AACrC,eAAe,kBAAkB,mBAAmB,UAAU,OAAO,wBAAwB;AAC7F;AACA,4CAA4C;AAC5C,eAAe,kBAAkB,gBAAgB,UAAU;AAC3D;AACA,sCAAsC;AACtC,eAAe,kBAAkB,mBAAmB,UAAU,OAAO,wBAAwB;AAC7F;AACA;AACA,eAAe,cAAc,WAAW,UAAU;AAClD;AACA;AACA,eAAe,cAAc,WAAW,UAAU;AAClD;AACA;AACA,eAAe,cAAc,WAAW,UAAU;AAClD;AACA;AACA,eAAe,cAAc,WAAW,UAAU;AAClD;AACA;AACA,eAAe,cAAc,WAAW,UAAU,uBAAuB,oBAAoB;AAC7F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,qBAAqB,oBAAoB;AAC3F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,uBAAuB,oBAAoB;AAC7F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,qBAAqB,oBAAoB;AAC3F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,uBAAuB,oBAAoB;AAC7F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,qBAAqB,oBAAoB;AAC3F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,0BAA0B,oBAAoB;AAChG;AACA;AACA,eAAe,cAAc,WAAW,UAAU,yBAAyB,oBAAoB;AAC/F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,yBAAyB,oBAAoB;AAC/F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,wBAAwB,oBAAoB;AAC9F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,uBAAuB,oBAAoB;AAC7F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,sBAAsB,oBAAoB;AAC5F;AACA;AACA,eAAe,cAAc,WAAW,UAAU,qBAAqB,oBAAoB;AAC3F;AACA;AACA,eAAe,YAAY,SAAS,UAAU;AAC9C;AACA,oCAAoC,GAAG;AACvC,eAAe,YAAY,SAAS,UAAU;AAC9C;AACA,2CAA2C,GAAG;AAC9C,eAAe,YAAY,SAAS,UAAU;AAC9C;AACA,qCAAqC,GAAG;AACxC,eAAe,YAAY,SAAS,UAAU;AAC9C;AACA;AACA,eAAe,YAAY,SAAS,UAAU,uBAAuB,sBAAsB;AAC3F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,qBAAqB,sBAAsB;AACzF;AACA;AACA,eAAe,YAAY,SAAS,UAAU,uBAAuB,sBAAsB;AAC3F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,qBAAqB,sBAAsB;AACzF;AACA;AACA,eAAe,YAAY,SAAS,UAAU,uBAAuB,sBAAsB;AAC3F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,qBAAqB,sBAAsB;AACzF;AACA;AACA,eAAe,YAAY,SAAS,UAAU,0BAA0B,sBAAsB;AAC9F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,yBAAyB,sBAAsB;AAC7F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,yBAAyB,sBAAsB;AAC7F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,wBAAwB,sBAAsB;AAC5F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,uBAAuB,sBAAsB;AAC3F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,sBAAsB,sBAAsB;AAC1F;AACA;AACA,eAAe,YAAY,SAAS,UAAU,qBAAqB,sBAAsB;AACzF;AACA;AACA,eAAe,sBAAsB,iBAAiB,gCAAgC;AACtF;AACA;AACA,eAAe,sBAAsB,kBAAkB,gCAAgC;AACvF;AACA;AACA,eAAe,gBAAgB,WAAW,0BAA0B;AACpE;AACA;;;ACxnB0C;AACiB;;;ACDpC;;AAEvB,4CAAe;;AAEf;AACA,6DAA6D,aAAa;;AAE1E,sBAAsB,UAAU;;AAEhC,0BAA0B,UAAU;;AAEpC;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,qBAAqB;AACrB,qBAAqB;AACrB,qBAAqB,QAAQ;AAC7B;;AAEA;AACA;;AAEA;;AAEA,CAAC,E;;AC/BsB;;AAEvB,4CAAe;;AAEf;AACA,wCAAwC,oBAAoB;AAC5D;AACA;;AAEA,oBAAoB,gBAAgB;;AAEpC;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,E;;AC/BsB;;AAEvB,4CAAe;;AAEf;AACA,kBAAkB;AAClB;AACA;;AAEA,sBAAsB,aAAa;;AAEnC,0BAA0B,aAAa;;AAEvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,CAAC,E;;ACjCsB;;AAEvB,4CAAe;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,mDAAmD,aAAa;AAChE,mDAAmD,aAAa;AAChE,sDAAsD,aAAa;AACnE,mDAAmD,aAAa;;AAEhE;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,KAAK;;AAEL;;AAEA,CAAC,E;;ACnDsB;;AAEvB,4CAAe;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,aAAa;;AAEnC;AACA;;AAEA,0BAA0B,aAAa;;AAEvC;AACA,6DAA6D,aAAa;;AAE1E;AACA;AACA;AACA,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC,OAAO;;AAExC;;AAEA;;AAEA;AACA;;AAEA;;AAEA,CAAC,E;;AC1CsB;;AAEvB,4CAAe;;AAEf;AACA;AACA;;AAEA,oBAAoB,UAAU;;AAE9B;;AAEA;AACA;AACA,4CAA4C,EAAE;AAC9C;AACA;AACA;AACA,SAAS;;AAET;;AAEA;;AAEA,CAAC,E;;ACxBsB;;AAEvB,4CAAe;;AAEf;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA,CAAC,E;;AC1BsB;;;AAGvB,4CAAe;;AAEf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA,CAAC,E;;ACxCsB;;AAEvB,4CAAe,oBAAoB,KAAK;;AAExC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA,CAAC,E;;ACvCsB;;AAEvB,6CAAe,oBAAoB,SAAS;;AAE5C;;AAEA;AACA,UAAU,4DAA4D;AACtE,UAAU,kEAAkE;AAC5E,UAAU,wDAAwD;AAClE,UAAU,sDAAsD;AAChE,UAAU,uDAAuD;AACjE,UAAU;AACV;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sFAAsF,MAAM;AAC5F;AACA;AACA;AACA,aAAa;;AAEb;;AAEA;;AAEA;;AAEA,CAAC,E;;AC/CsB;;AAEvB,6CAAe,oBAAoB,cAAc;;AAEjD;;AAEA;AACA,UAAU,4DAA4D;AACtE,UAAU,kEAAkE;AAC5E,UAAU,wDAAwD;AAClE,UAAU,sDAAsD;AAChE,UAAU,uDAAuD;AACjE,UAAU;AACV;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sFAAsF,MAAM;AAC5F;AACA;AACA;AACA,aAAa;;AAEb;;AAEA;;AAEA;;AAEA,CAAC,E;;AC/CqE;AACA;AACH;AAC7C;AACC;AAC6B;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACE;AACA;;AAE9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,cAAc,KAAK;AACnB,eAAe,MAAM;AACrB,eAAe,MAAM;AACrB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,mCAAmC,eAAe,IAAI,OAAO,cAAK,OAAE;AACpE;AACA;AACA;AACA,KAAK;AACL,CAAC","sources":["webpack://colortranslator/./node_modules/.pnpm/whatwg-fetch@3.6.20/node_modules/whatwg-fetch/fetch.js?d4cb","webpack://colortranslator/./src/@types/index.ts?e4bd","webpack://colortranslator/./src/constants/enums.ts?64fb","webpack://colortranslator/./src/constants/regexps.ts?856e","webpack://colortranslator/./src/constants/index.ts?661c","webpack://colortranslator/./src/utilities/index.ts?d12e","webpack://colortranslator/./src/color/translators.ts?2559","webpack://colortranslator/./src/classes/ColorParserContext.ts?1db4","webpack://colortranslator/./src/color/rgb.ts?3e26","webpack://colortranslator/./src/css/index.ts?208f","webpack://colortranslator/./src/classes/HEXParser.ts?66ea","webpack://colortranslator/./src/classes/CalcParser.ts?37ac","webpack://colortranslator/./src/classes/RGBParser.ts?7359","webpack://colortranslator/./src/classes/HSLParser.ts?0a9f","webpack://colortranslator/./src/classes/HWBParser.ts?d176","webpack://colortranslator/./src/classes/CIELabParser.ts?649d","webpack://colortranslator/./src/classes/LCHParser.ts?a54d","webpack://colortranslator/./src/classes/CMYKParser.ts?8b73","webpack://colortranslator/./src/parsers/index.ts?4014","webpack://colortranslator/./src/returns/index.ts?17d4","webpack://colortranslator/./src/classes/ColorTranslator.ts?16e3","webpack://colortranslator/./src/index.ts?a58f","webpack://colortranslator/./src/@demo/demo1/index.js?3965","webpack://colortranslator/./src/@demo/demo2/index.js?d8dc","webpack://colortranslator/./src/@demo/demo3/index.js?d386","webpack://colortranslator/./src/@demo/demo4/index.js?619f","webpack://colortranslator/./src/@demo/demo5/index.js?d8cc","webpack://colortranslator/./src/@demo/demo6/index.js?3a32","webpack://colortranslator/./src/@demo/demo7/index.js?8343","webpack://colortranslator/./src/@demo/demo8/index.js?7725","webpack://colortranslator/./src/@demo/demo9/index.js?8532","webpack://colortranslator/./src/@demo/demo10/index.js?4f67","webpack://colortranslator/./src/@demo/demo11/index.js?dbe6","webpack://colortranslator/./src/@demo/demo.js?9b7d"],"sourcesContent":["/* eslint-disable no-prototype-builtins */\nvar g =\n  (typeof globalThis !== 'undefined' && globalThis) ||\n  (typeof self !== 'undefined' && self) ||\n  // eslint-disable-next-line no-undef\n  (typeof global !== 'undefined' && global) ||\n  {}\n\nvar support = {\n  searchParams: 'URLSearchParams' in g,\n  iterable: 'Symbol' in g && 'iterator' in Symbol,\n  blob:\n    'FileReader' in g &&\n    'Blob' in g &&\n    (function() {\n      try {\n        new Blob()\n        return true\n      } catch (e) {\n        return false\n      }\n    })(),\n  formData: 'FormData' in g,\n  arrayBuffer: 'ArrayBuffer' in g\n}\n\nfunction isDataView(obj) {\n  return obj && DataView.prototype.isPrototypeOf(obj)\n}\n\nif (support.arrayBuffer) {\n  var viewClasses = [\n    '[object Int8Array]',\n    '[object Uint8Array]',\n    '[object Uint8ClampedArray]',\n    '[object Int16Array]',\n    '[object Uint16Array]',\n    '[object Int32Array]',\n    '[object Uint32Array]',\n    '[object Float32Array]',\n    '[object Float64Array]'\n  ]\n\n  var isArrayBufferView =\n    ArrayBuffer.isView ||\n    function(obj) {\n      return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n    }\n}\n\nfunction normalizeName(name) {\n  if (typeof name !== 'string') {\n    name = String(name)\n  }\n  if (/[^a-z0-9\\-#$%&'*+.^_`|~!]/i.test(name) || name === '') {\n    throw new TypeError('Invalid character in header field name: \"' + name + '\"')\n  }\n  return name.toLowerCase()\n}\n\nfunction normalizeValue(value) {\n  if (typeof value !== 'string') {\n    value = String(value)\n  }\n  return value\n}\n\n// Build a destructive iterator for the value list\nfunction iteratorFor(items) {\n  var iterator = {\n    next: function() {\n      var value = items.shift()\n      return {done: value === undefined, value: value}\n    }\n  }\n\n  if (support.iterable) {\n    iterator[Symbol.iterator] = function() {\n      return iterator\n    }\n  }\n\n  return iterator\n}\n\nexport function Headers(headers) {\n  this.map = {}\n\n  if (headers instanceof Headers) {\n    headers.forEach(function(value, name) {\n      this.append(name, value)\n    }, this)\n  } else if (Array.isArray(headers)) {\n    headers.forEach(function(header) {\n      if (header.length != 2) {\n        throw new TypeError('Headers constructor: expected name/value pair to be length 2, found' + header.length)\n      }\n      this.append(header[0], header[1])\n    }, this)\n  } else if (headers) {\n    Object.getOwnPropertyNames(headers).forEach(function(name) {\n      this.append(name, headers[name])\n    }, this)\n  }\n}\n\nHeaders.prototype.append = function(name, value) {\n  name = normalizeName(name)\n  value = normalizeValue(value)\n  var oldValue = this.map[name]\n  this.map[name] = oldValue ? oldValue + ', ' + value : value\n}\n\nHeaders.prototype['delete'] = function(name) {\n  delete this.map[normalizeName(name)]\n}\n\nHeaders.prototype.get = function(name) {\n  name = normalizeName(name)\n  return this.has(name) ? this.map[name] : null\n}\n\nHeaders.prototype.has = function(name) {\n  return this.map.hasOwnProperty(normalizeName(name))\n}\n\nHeaders.prototype.set = function(name, value) {\n  this.map[normalizeName(name)] = normalizeValue(value)\n}\n\nHeaders.prototype.forEach = function(callback, thisArg) {\n  for (var name in this.map) {\n    if (this.map.hasOwnProperty(name)) {\n      callback.call(thisArg, this.map[name], name, this)\n    }\n  }\n}\n\nHeaders.prototype.keys = function() {\n  var items = []\n  this.forEach(function(value, name) {\n    items.push(name)\n  })\n  return iteratorFor(items)\n}\n\nHeaders.prototype.values = function() {\n  var items = []\n  this.forEach(function(value) {\n    items.push(value)\n  })\n  return iteratorFor(items)\n}\n\nHeaders.prototype.entries = function() {\n  var items = []\n  this.forEach(function(value, name) {\n    items.push([name, value])\n  })\n  return iteratorFor(items)\n}\n\nif (support.iterable) {\n  Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n}\n\nfunction consumed(body) {\n  if (body._noBody) return\n  if (body.bodyUsed) {\n    return Promise.reject(new TypeError('Already read'))\n  }\n  body.bodyUsed = true\n}\n\nfunction fileReaderReady(reader) {\n  return new Promise(function(resolve, reject) {\n    reader.onload = function() {\n      resolve(reader.result)\n    }\n    reader.onerror = function() {\n      reject(reader.error)\n    }\n  })\n}\n\nfunction readBlobAsArrayBuffer(blob) {\n  var reader = new FileReader()\n  var promise = fileReaderReady(reader)\n  reader.readAsArrayBuffer(blob)\n  return promise\n}\n\nfunction readBlobAsText(blob) {\n  var reader = new FileReader()\n  var promise = fileReaderReady(reader)\n  var match = /charset=([A-Za-z0-9_-]+)/.exec(blob.type)\n  var encoding = match ? match[1] : 'utf-8'\n  reader.readAsText(blob, encoding)\n  return promise\n}\n\nfunction readArrayBufferAsText(buf) {\n  var view = new Uint8Array(buf)\n  var chars = new Array(view.length)\n\n  for (var i = 0; i < view.length; i++) {\n    chars[i] = String.fromCharCode(view[i])\n  }\n  return chars.join('')\n}\n\nfunction bufferClone(buf) {\n  if (buf.slice) {\n    return buf.slice(0)\n  } else {\n    var view = new Uint8Array(buf.byteLength)\n    view.set(new Uint8Array(buf))\n    return view.buffer\n  }\n}\n\nfunction Body() {\n  this.bodyUsed = false\n\n  this._initBody = function(body) {\n    /*\n      fetch-mock wraps the Response object in an ES6 Proxy to\n      provide useful test harness features such as flush. However, on\n      ES5 browsers without fetch or Proxy support pollyfills must be used;\n      the proxy-pollyfill is unable to proxy an attribute unless it exists\n      on the object before the Proxy is created. This change ensures\n      Response.bodyUsed exists on the instance, while maintaining the\n      semantic of setting Request.bodyUsed in the constructor before\n      _initBody is called.\n    */\n    // eslint-disable-next-line no-self-assign\n    this.bodyUsed = this.bodyUsed\n    this._bodyInit = body\n    if (!body) {\n      this._noBody = true;\n      this._bodyText = ''\n    } else if (typeof body === 'string') {\n      this._bodyText = body\n    } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n      this._bodyBlob = body\n    } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n      this._bodyFormData = body\n    } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n      this._bodyText = body.toString()\n    } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n      this._bodyArrayBuffer = bufferClone(body.buffer)\n      // IE 10-11 can't handle a DataView body.\n      this._bodyInit = new Blob([this._bodyArrayBuffer])\n    } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n      this._bodyArrayBuffer = bufferClone(body)\n    } else {\n      this._bodyText = body = Object.prototype.toString.call(body)\n    }\n\n    if (!this.headers.get('content-type')) {\n      if (typeof body === 'string') {\n        this.headers.set('content-type', 'text/plain;charset=UTF-8')\n      } else if (this._bodyBlob && this._bodyBlob.type) {\n        this.headers.set('content-type', this._bodyBlob.type)\n      } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n        this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n      }\n    }\n  }\n\n  if (support.blob) {\n    this.blob = function() {\n      var rejected = consumed(this)\n      if (rejected) {\n        return rejected\n      }\n\n      if (this._bodyBlob) {\n        return Promise.resolve(this._bodyBlob)\n      } else if (this._bodyArrayBuffer) {\n        return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n      } else if (this._bodyFormData) {\n        throw new Error('could not read FormData body as blob')\n      } else {\n        return Promise.resolve(new Blob([this._bodyText]))\n      }\n    }\n  }\n\n  this.arrayBuffer = function() {\n    if (this._bodyArrayBuffer) {\n      var isConsumed = consumed(this)\n      if (isConsumed) {\n        return isConsumed\n      } else if (ArrayBuffer.isView(this._bodyArrayBuffer)) {\n        return Promise.resolve(\n          this._bodyArrayBuffer.buffer.slice(\n            this._bodyArrayBuffer.byteOffset,\n            this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength\n          )\n        )\n      } else {\n        return Promise.resolve(this._bodyArrayBuffer)\n      }\n    } else if (support.blob) {\n      return this.blob().then(readBlobAsArrayBuffer)\n    } else {\n      throw new Error('could not read as ArrayBuffer')\n    }\n  }\n\n  this.text = function() {\n    var rejected = consumed(this)\n    if (rejected) {\n      return rejected\n    }\n\n    if (this._bodyBlob) {\n      return readBlobAsText(this._bodyBlob)\n    } else if (this._bodyArrayBuffer) {\n      return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n    } else if (this._bodyFormData) {\n      throw new Error('could not read FormData body as text')\n    } else {\n      return Promise.resolve(this._bodyText)\n    }\n  }\n\n  if (support.formData) {\n    this.formData = function() {\n      return this.text().then(decode)\n    }\n  }\n\n  this.json = function() {\n    return this.text().then(JSON.parse)\n  }\n\n  return this\n}\n\n// HTTP methods whose capitalization should be normalized\nvar methods = ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'TRACE']\n\nfunction normalizeMethod(method) {\n  var upcased = method.toUpperCase()\n  return methods.indexOf(upcased) > -1 ? upcased : method\n}\n\nexport function Request(input, options) {\n  if (!(this instanceof Request)) {\n    throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n  }\n\n  options = options || {}\n  var body = options.body\n\n  if (input instanceof Request) {\n    if (input.bodyUsed) {\n      throw new TypeError('Already read')\n    }\n    this.url = input.url\n    this.credentials = input.credentials\n    if (!options.headers) {\n      this.headers = new Headers(input.headers)\n    }\n    this.method = input.method\n    this.mode = input.mode\n    this.signal = input.signal\n    if (!body && input._bodyInit != null) {\n      body = input._bodyInit\n      input.bodyUsed = true\n    }\n  } else {\n    this.url = String(input)\n  }\n\n  this.credentials = options.credentials || this.credentials || 'same-origin'\n  if (options.headers || !this.headers) {\n    this.headers = new Headers(options.headers)\n  }\n  this.method = normalizeMethod(options.method || this.method || 'GET')\n  this.mode = options.mode || this.mode || null\n  this.signal = options.signal || this.signal || (function () {\n    if ('AbortController' in g) {\n      var ctrl = new AbortController();\n      return ctrl.signal;\n    }\n  }());\n  this.referrer = null\n\n  if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n    throw new TypeError('Body not allowed for GET or HEAD requests')\n  }\n  this._initBody(body)\n\n  if (this.method === 'GET' || this.method === 'HEAD') {\n    if (options.cache === 'no-store' || options.cache === 'no-cache') {\n      // Search for a '_' parameter in the query string\n      var reParamSearch = /([?&])_=[^&]*/\n      if (reParamSearch.test(this.url)) {\n        // If it already exists then set the value with the current time\n        this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime())\n      } else {\n        // Otherwise add a new '_' parameter to the end with the current time\n        var reQueryString = /\\?/\n        this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime()\n      }\n    }\n  }\n}\n\nRequest.prototype.clone = function() {\n  return new Request(this, {body: this._bodyInit})\n}\n\nfunction decode(body) {\n  var form = new FormData()\n  body\n    .trim()\n    .split('&')\n    .forEach(function(bytes) {\n      if (bytes) {\n        var split = bytes.split('=')\n        var name = split.shift().replace(/\\+/g, ' ')\n        var value = split.join('=').replace(/\\+/g, ' ')\n        form.append(decodeURIComponent(name), decodeURIComponent(value))\n      }\n    })\n  return form\n}\n\nfunction parseHeaders(rawHeaders) {\n  var headers = new Headers()\n  // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n  // https://tools.ietf.org/html/rfc7230#section-3.2\n  var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ')\n  // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill\n  // https://github.com/github/fetch/issues/748\n  // https://github.com/zloirock/core-js/issues/751\n  preProcessedHeaders\n    .split('\\r')\n    .map(function(header) {\n      return header.indexOf('\\n') === 0 ? header.substr(1, header.length) : header\n    })\n    .forEach(function(line) {\n      var parts = line.split(':')\n      var key = parts.shift().trim()\n      if (key) {\n        var value = parts.join(':').trim()\n        try {\n          headers.append(key, value)\n        } catch (error) {\n          console.warn('Response ' + error.message)\n        }\n      }\n    })\n  return headers\n}\n\nBody.call(Request.prototype)\n\nexport function Response(bodyInit, options) {\n  if (!(this instanceof Response)) {\n    throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n  }\n  if (!options) {\n    options = {}\n  }\n\n  this.type = 'default'\n  this.status = options.status === undefined ? 200 : options.status\n  if (this.status < 200 || this.status > 599) {\n    throw new RangeError(\"Failed to construct 'Response': The status provided (0) is outside the range [200, 599].\")\n  }\n  this.ok = this.status >= 200 && this.status < 300\n  this.statusText = options.statusText === undefined ? '' : '' + options.statusText\n  this.headers = new Headers(options.headers)\n  this.url = options.url || ''\n  this._initBody(bodyInit)\n}\n\nBody.call(Response.prototype)\n\nResponse.prototype.clone = function() {\n  return new Response(this._bodyInit, {\n    status: this.status,\n    statusText: this.statusText,\n    headers: new Headers(this.headers),\n    url: this.url\n  })\n}\n\nResponse.error = function() {\n  var response = new Response(null, {status: 200, statusText: ''})\n  response.ok = false\n  response.status = 0\n  response.type = 'error'\n  return response\n}\n\nvar redirectStatuses = [301, 302, 303, 307, 308]\n\nResponse.redirect = function(url, status) {\n  if (redirectStatuses.indexOf(status) === -1) {\n    throw new RangeError('Invalid status code')\n  }\n\n  return new Response(null, {status: status, headers: {location: url}})\n}\n\nexport var DOMException = g.DOMException\ntry {\n  new DOMException()\n} catch (err) {\n  DOMException = function(message, name) {\n    this.message = message\n    this.name = name\n    var error = Error(message)\n    this.stack = error.stack\n  }\n  DOMException.prototype = Object.create(Error.prototype)\n  DOMException.prototype.constructor = DOMException\n}\n\nexport function fetch(input, init) {\n  return new Promise(function(resolve, reject) {\n    var request = new Request(input, init)\n\n    if (request.signal && request.signal.aborted) {\n      return reject(new DOMException('Aborted', 'AbortError'))\n    }\n\n    var xhr = new XMLHttpRequest()\n\n    function abortXhr() {\n      xhr.abort()\n    }\n\n    xhr.onload = function() {\n      var options = {\n        statusText: xhr.statusText,\n        headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n      }\n      // This check if specifically for when a user fetches a file locally from the file system\n      // Only if the status is out of a normal range\n      if (request.url.indexOf('file://') === 0 && (xhr.status < 200 || xhr.status > 599)) {\n        options.status = 200;\n      } else {\n        options.status = xhr.status;\n      }\n      options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n      var body = 'response' in xhr ? xhr.response : xhr.responseText\n      setTimeout(function() {\n        resolve(new Response(body, options))\n      }, 0)\n    }\n\n    xhr.onerror = function() {\n      setTimeout(function() {\n        reject(new TypeError('Network request failed'))\n      }, 0)\n    }\n\n    xhr.ontimeout = function() {\n      setTimeout(function() {\n        reject(new TypeError('Network request timed out'))\n      }, 0)\n    }\n\n    xhr.onabort = function() {\n      setTimeout(function() {\n        reject(new DOMException('Aborted', 'AbortError'))\n      }, 0)\n    }\n\n    function fixUrl(url) {\n      try {\n        return url === '' && g.location.href ? g.location.href : url\n      } catch (e) {\n        return url\n      }\n    }\n\n    xhr.open(request.method, fixUrl(request.url), true)\n\n    if (request.credentials === 'include') {\n      xhr.withCredentials = true\n    } else if (request.credentials === 'omit') {\n      xhr.withCredentials = false\n    }\n\n    if ('responseType' in xhr) {\n      if (support.blob) {\n        xhr.responseType = 'blob'\n      } else if (\n        support.arrayBuffer\n      ) {\n        xhr.responseType = 'arraybuffer'\n      }\n    }\n\n    if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers || (g.Headers && init.headers instanceof g.Headers))) {\n      var names = [];\n      Object.getOwnPropertyNames(init.headers).forEach(function(name) {\n        names.push(normalizeName(name))\n        xhr.setRequestHeader(name, normalizeValue(init.headers[name]))\n      })\n      request.headers.forEach(function(value, name) {\n        if (names.indexOf(name) === -1) {\n          xhr.setRequestHeader(name, value)\n        }\n      })\n    } else {\n      request.headers.forEach(function(value, name) {\n        xhr.setRequestHeader(name, value)\n      })\n    }\n\n    if (request.signal) {\n      request.signal.addEventListener('abort', abortXhr)\n\n      xhr.onreadystatechange = function() {\n        // DONE (success or failure)\n        if (xhr.readyState === 4) {\n          request.signal.removeEventListener('abort', abortXhr)\n        }\n      }\n    }\n\n    xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n  })\n}\n\nfetch.polyfill = true\n\nif (!g.fetch) {\n  g.fetch = fetch\n  g.Headers = Headers\n  g.Request = Request\n  g.Response = Response\n}\n","export var AnglesUnitEnum;\n(function (AnglesUnitEnum) {\n    AnglesUnitEnum[\"NONE\"] = \"none\";\n    AnglesUnitEnum[\"DEGREES\"] = \"deg\";\n    AnglesUnitEnum[\"GRADIANS\"] = \"grad\";\n    AnglesUnitEnum[\"RADIANS\"] = \"rad\";\n    AnglesUnitEnum[\"TURNS\"] = \"turn\";\n})(AnglesUnitEnum || (AnglesUnitEnum = {}));\nexport var ColorUnitEnum;\n(function (ColorUnitEnum) {\n    ColorUnitEnum[\"NONE\"] = \"none\";\n    ColorUnitEnum[\"PERCENT\"] = \"percent\";\n})(ColorUnitEnum || (ColorUnitEnum = {}));\nexport var CMYKFunctionEnum;\n(function (CMYKFunctionEnum) {\n    CMYKFunctionEnum[\"DEVICE_CMYK\"] = \"device-cmyk\";\n    CMYKFunctionEnum[\"CMYK\"] = \"cmyk\";\n})(CMYKFunctionEnum || (CMYKFunctionEnum = {}));\n","export var ColorModel;\n(function (ColorModel) {\n    ColorModel[\"HEX\"] = \"HEX\";\n    ColorModel[\"RGB\"] = \"RGB\";\n    ColorModel[\"HWB\"] = \"HWB\";\n    ColorModel[\"HSL\"] = \"HSL\";\n    ColorModel[\"CIELab\"] = \"CIELab\";\n    ColorModel[\"LCH\"] = \"LCH\";\n    ColorModel[\"CMYK\"] = \"CMYK\";\n})(ColorModel || (ColorModel = {}));\nexport var Harmony;\n(function (Harmony) {\n    Harmony[\"ANALOGOUS\"] = \"ANALOGOUS\";\n    Harmony[\"COMPLEMENTARY\"] = \"COMPLEMENTARY\";\n    Harmony[\"SPLIT_COMPLEMENTARY\"] = \"SPLIT_COMPLEMENTARY\";\n    Harmony[\"TRIADIC\"] = \"TRIADIC\";\n    Harmony[\"TETRADIC\"] = \"TETRADIC\";\n    Harmony[\"SQUARE\"] = \"SQUARE\";\n})(Harmony || (Harmony = {}));\nexport var Mix;\n(function (Mix) {\n    Mix[\"ADDITIVE\"] = \"ADDITIVE\";\n    Mix[\"SUBTRACTIVE\"] = \"SUBTRACTIVE\";\n})(Mix || (Mix = {}));\nexport var ColorKeywords;\n(function (ColorKeywords) {\n    ColorKeywords[\"black\"] = \"#000000\";\n    ColorKeywords[\"silver\"] = \"#C0C0C0\";\n    ColorKeywords[\"gray\"] = \"#808080\";\n    ColorKeywords[\"white\"] = \"#FFFFFF\";\n    ColorKeywords[\"maroon\"] = \"#800000\";\n    ColorKeywords[\"red\"] = \"#FF0000\";\n    ColorKeywords[\"purple\"] = \"#800080\";\n    ColorKeywords[\"fuchsia\"] = \"#FF00FF\";\n    ColorKeywords[\"green\"] = \"#008000\";\n    ColorKeywords[\"lime\"] = \"#00FF00\";\n    ColorKeywords[\"olive\"] = \"#808000\";\n    ColorKeywords[\"yellow\"] = \"#FFFF00\";\n    ColorKeywords[\"navy\"] = \"#000080\";\n    ColorKeywords[\"blue\"] = \"#0000FF\";\n    ColorKeywords[\"teal\"] = \"#008080\";\n    ColorKeywords[\"aqua\"] = \"#00FFFF\";\n    ColorKeywords[\"orange\"] = \"#FFA500\";\n    ColorKeywords[\"aliceblue\"] = \"#F0F8FF\";\n    ColorKeywords[\"antiquewhite\"] = \"#FAEBD7\";\n    ColorKeywords[\"aquamarine\"] = \"#7FFFD4\";\n    ColorKeywords[\"azure\"] = \"#F0FFFF\";\n    ColorKeywords[\"beige\"] = \"#F5F5DC\";\n    ColorKeywords[\"bisque\"] = \"#FFE4C4\";\n    ColorKeywords[\"blanchedalmond\"] = \"#FFEBCD\";\n    ColorKeywords[\"blueviolet\"] = \"#8A2BE2\";\n    ColorKeywords[\"brown\"] = \"#A52A2A\";\n    ColorKeywords[\"burlywood\"] = \"#DEB887\";\n    ColorKeywords[\"cadetblue\"] = \"#5F9EA0\";\n    ColorKeywords[\"chartreuse\"] = \"#7FFF00\";\n    ColorKeywords[\"chocolate\"] = \"#D2691E\";\n    ColorKeywords[\"coral\"] = \"#FF7F50\";\n    ColorKeywords[\"cornflowerblue\"] = \"#6495ED\";\n    ColorKeywords[\"cornsilk\"] = \"#FFF8DC\";\n    ColorKeywords[\"crimson\"] = \"#DC143C\";\n    ColorKeywords[\"cyan\"] = \"#00FFFF\";\n    ColorKeywords[\"darkblue\"] = \"#00008B\";\n    ColorKeywords[\"darkcyan\"] = \"#008B8B\";\n    ColorKeywords[\"darkgoldenrod\"] = \"#B8860B\";\n    ColorKeywords[\"darkgray\"] = \"#A9A9A9\";\n    ColorKeywords[\"darkgreen\"] = \"#006400\";\n    ColorKeywords[\"darkgrey\"] = \"#A9A9A9\";\n    ColorKeywords[\"darkkhaki\"] = \"#BDB76B\";\n    ColorKeywords[\"darkmagenta\"] = \"#8B008B\";\n    ColorKeywords[\"darkolivegreen\"] = \"#556B2F\";\n    ColorKeywords[\"darkorange\"] = \"#FF8C00\";\n    ColorKeywords[\"darkorchid\"] = \"#9932CC\";\n    ColorKeywords[\"darkred\"] = \"#8B0000\";\n    ColorKeywords[\"darksalmon\"] = \"#E9967A\";\n    ColorKeywords[\"darkseagreen\"] = \"#8FBC8F\";\n    ColorKeywords[\"darkslateblue\"] = \"#483D8B\";\n    ColorKeywords[\"darkslategray\"] = \"#2F4F4F\";\n    ColorKeywords[\"darkslategrey\"] = \"#2F4F4F\";\n    ColorKeywords[\"darkturquoise\"] = \"#00CED1\";\n    ColorKeywords[\"darkviolet\"] = \"#9400D3\";\n    ColorKeywords[\"deeppink\"] = \"#FF1493\";\n    ColorKeywords[\"deepskyblue\"] = \"#00BFFF\";\n    ColorKeywords[\"dimgray\"] = \"#696969\";\n    ColorKeywords[\"dimgrey\"] = \"#696969\";\n    ColorKeywords[\"dodgerblue\"] = \"#1E90FF\";\n    ColorKeywords[\"firebrick\"] = \"#B22222\";\n    ColorKeywords[\"floralwhite\"] = \"#FFFAF0\";\n    ColorKeywords[\"forestgreen\"] = \"#228B22\";\n    ColorKeywords[\"gainsboro\"] = \"#DCDCDC\";\n    ColorKeywords[\"ghostwhite\"] = \"#F8F8FF\";\n    ColorKeywords[\"gold\"] = \"#FFD700\";\n    ColorKeywords[\"goldenrod\"] = \"#DAA520\";\n    ColorKeywords[\"greenyellow\"] = \"#ADFF2F\";\n    ColorKeywords[\"grey\"] = \"#808080\";\n    ColorKeywords[\"honeydew\"] = \"#F0FFF0\";\n    ColorKeywords[\"hotpink\"] = \"#FF69B4\";\n    ColorKeywords[\"indianred\"] = \"#CD5C5C\";\n    ColorKeywords[\"indigo\"] = \"#4B0082\";\n    ColorKeywords[\"ivory\"] = \"#FFFFF0\";\n    ColorKeywords[\"khaki\"] = \"#F0E68C\";\n    ColorKeywords[\"lavender\"] = \"#E6E6FA\";\n    ColorKeywords[\"lavenderblush\"] = \"#FFF0F5\";\n    ColorKeywords[\"lawngreen\"] = \"#7CFC00\";\n    ColorKeywords[\"lemonchiffon\"] = \"#FFFACD\";\n    ColorKeywords[\"lightblue\"] = \"#ADD8E6\";\n    ColorKeywords[\"lightcoral\"] = \"#F08080\";\n    ColorKeywords[\"lightcyan\"] = \"#E0FFFF\";\n    ColorKeywords[\"lightgoldenrodyellow\"] = \"#FAFAD2\";\n    ColorKeywords[\"lightgray\"] = \"#D3D3D3\";\n    ColorKeywords[\"lightgreen\"] = \"#90EE90\";\n    ColorKeywords[\"lightgrey\"] = \"#D3D3D3\";\n    ColorKeywords[\"lightpink\"] = \"#FFB6C1\";\n    ColorKeywords[\"lightsalmon\"] = \"#FFA07A\";\n    ColorKeywords[\"lightseagreen\"] = \"#20B2AA\";\n    ColorKeywords[\"lightskyblue\"] = \"#87CEFA\";\n    ColorKeywords[\"lightslategray\"] = \"#778899\";\n    ColorKeywords[\"lightslategrey\"] = \"#778899\";\n    ColorKeywords[\"lightsteelblue\"] = \"#B0C4DE\";\n    ColorKeywords[\"lightyellow\"] = \"#FFFFE0\";\n    ColorKeywords[\"limegreen\"] = \"#32CD32\";\n    ColorKeywords[\"linen\"] = \"#FAF0E6\";\n    ColorKeywords[\"magenta\"] = \"#FF00FF\";\n    ColorKeywords[\"mediumaquamarine\"] = \"#66CDAA\";\n    ColorKeywords[\"mediumblue\"] = \"#0000CD\";\n    ColorKeywords[\"mediumorchid\"] = \"#BA55D3\";\n    ColorKeywords[\"mediumpurple\"] = \"#9370DB\";\n    ColorKeywords[\"mediumseagreen\"] = \"#3CB371\";\n    ColorKeywords[\"mediumslateblue\"] = \"#7B68EE\";\n    ColorKeywords[\"mediumspringgreen\"] = \"#00FA9A\";\n    ColorKeywords[\"mediumturquoise\"] = \"#48D1CC\";\n    ColorKeywords[\"mediumvioletred\"] = \"#C71585\";\n    ColorKeywords[\"midnightblue\"] = \"#191970\";\n    ColorKeywords[\"mintcream\"] = \"#F5FFFA\";\n    ColorKeywords[\"mistyrose\"] = \"#FFE4E1\";\n    ColorKeywords[\"moccasin\"] = \"#FFE4B5\";\n    ColorKeywords[\"navajowhite\"] = \"#FFDEAD\";\n    ColorKeywords[\"oldlace\"] = \"#FDF5E6\";\n    ColorKeywords[\"olivedrab\"] = \"#6B8E23\";\n    ColorKeywords[\"orangered\"] = \"#FF4500\";\n    ColorKeywords[\"orchid\"] = \"#DA70D6\";\n    ColorKeywords[\"palegoldenrod\"] = \"#EEE8AA\";\n    ColorKeywords[\"palegreen\"] = \"#98FB98\";\n    ColorKeywords[\"paleturquoise\"] = \"#AFEEEE\";\n    ColorKeywords[\"palevioletred\"] = \"#DB7093\";\n    ColorKeywords[\"papayawhip\"] = \"#FFEFD5\";\n    ColorKeywords[\"peachpuff\"] = \"#FFDAB9\";\n    ColorKeywords[\"peru\"] = \"#CD853F\";\n    ColorKeywords[\"pink\"] = \"#FFC0CB\";\n    ColorKeywords[\"plum\"] = \"#DDA0DD\";\n    ColorKeywords[\"powderblue\"] = \"#B0E0E6\";\n    ColorKeywords[\"rosybrown\"] = \"#BC8F8F\";\n    ColorKeywords[\"royalblue\"] = \"#4169E1\";\n    ColorKeywords[\"saddlebrown\"] = \"#8B4513\";\n    ColorKeywords[\"salmon\"] = \"#FA8072\";\n    ColorKeywords[\"sandybrown\"] = \"#F4A460\";\n    ColorKeywords[\"seagreen\"] = \"#2E8B57\";\n    ColorKeywords[\"seashell\"] = \"#FFF5EE\";\n    ColorKeywords[\"sienna\"] = \"#A0522D\";\n    ColorKeywords[\"skyblue\"] = \"#87CEEB\";\n    ColorKeywords[\"slateblue\"] = \"#6A5ACD\";\n    ColorKeywords[\"slategray\"] = \"#708090\";\n    ColorKeywords[\"slategrey\"] = \"#708090\";\n    ColorKeywords[\"snow\"] = \"#FFFAFA\";\n    ColorKeywords[\"springgreen\"] = \"#00FF7F\";\n    ColorKeywords[\"steelblue\"] = \"#4682B4\";\n    ColorKeywords[\"tan\"] = \"#D2B48C\";\n    ColorKeywords[\"thistle\"] = \"#D8BFD8\";\n    ColorKeywords[\"tomato\"] = \"#FF6347\";\n    ColorKeywords[\"turquoise\"] = \"#40E0D0\";\n    ColorKeywords[\"violet\"] = \"#EE82EE\";\n    ColorKeywords[\"wheat\"] = \"#F5DEB3\";\n    ColorKeywords[\"whitesmoke\"] = \"#F5F5F5\";\n    ColorKeywords[\"yellowgreen\"] = \"#9ACD32\";\n    ColorKeywords[\"rebeccapurple\"] = \"#663399\";\n})(ColorKeywords || (ColorKeywords = {}));\n","import { ColorModel } from './enums';\nexport const COLORREGS = {\n    [ColorModel.HEX]: /^#(?:(?<r>[a-f\\d])(?<g>[a-f\\d])(?<b>[a-f\\d])(?<a>[a-f\\d])?|(?<rr>[a-f\\d]{2})(?<gg>[a-f\\d]{2})(?<bb>[a-f\\d]{2})(?<aa>[a-f\\d]{2})?)$/i,\n    [ColorModel.RGB]: /^rgba?\\s*\\(\\s*(?:(?<r_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<g_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<b_legacy>(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?<a_legacy>(?:\\d*\\.)?\\d+))?|(?<r>(?:\\d*\\.)?\\d+%?)\\s+(?<g>(?:\\d*\\.)?\\d+%?)\\s+(?<b>(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_r>(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_g>(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_b>(?:[rgb]|(?:\\d*\\.)?\\d+|calc\\([rgb()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.HWB]: /^hwb\\s*\\(\\s*(?:(?<h>(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?<w>(?:\\d*\\.)?\\d+)%\\s+(?<b>(?:\\d*\\.)?\\d+)%(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_h>(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_w>(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?\\s+(?<relative_b>(?:[hwb]|(?:\\d*\\.)?\\d+|calc\\([hwb()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.HSL]: /^hsla?\\s*\\(\\s*(?:(?<h_legacy>-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s*,\\s*(?<s_legacy>(?:\\d*\\.)?\\d+)%\\s*,\\s*(?<l_legacy>(?:\\d*\\.)?\\d+)%(?:\\s*,\\s*(?<a_legacy>(?:\\d*\\.)?\\d+))?|(?<h>-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)\\s+(?<s>(?:\\d*\\.)?\\d+)%?\\s+(?<l>(?:\\d*\\.)?\\d+)%?(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_h>(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_s>(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?\\s+(?<relative_l>(?:[hsl]|(?:\\d*\\.)?\\d+|calc\\([hsl()/*\\-+\\d.\\s]+\\)))%?(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.CIELab]: /^lab\\s*\\(\\s*(?:(?<L>(?:\\d*\\.)?\\d+%?)\\s+(?<a>-?(?:\\d*\\.)?\\d+%?)\\s+(?<b>-?(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?<A>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_L>(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_a>(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_b>(?:[lab]|(?:\\d*\\.)?\\d+|calc\\([lab()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?<relative_A>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.LCH]: /^lch\\s*\\(\\s*(?:(?<l>(?:\\d*\\.)?\\d+%?)\\s+(?<c>-?(?:\\d*\\.)?\\d+%?)\\s+(?<h>-?(?:\\d*\\.)?\\d+(?:deg|grad|rad|turn)?)(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?|from\\s+(?<from>(?:\\w+|\\w+\\(\\s*[^())]+\\s*\\)|\\w+\\(from\\s+\\w+\\(.*\\)\\s*\\)|#[a-fA-F\\d]+))\\s+(?<relative_l>(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_c>(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))\\s+(?<relative_h>(?:[lch]|(?:\\d*\\.)?\\d+|calc\\([lch()/*\\-+\\d.\\s]+\\)))(?:\\s*\\/\\s*(?<relative_a>(?:(?:\\d*\\.)?\\d+%?|calc\\([()/*\\-+\\d.\\s\\w]*(?:alpha)?[()/*\\-+\\d.\\s\\w]*\\)|alpha)))?)\\s*\\)$/,\n    [ColorModel.CMYK]: /^(?:device-cmyk|cmyk)\\s*\\(\\s*(?:(?<c_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<m_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<y_legacy>(?:\\d*\\.)?\\d+%?)\\s*,\\s*(?<k_legacy>(?:\\d*\\.)?\\d+%?)(?:\\s*,\\s*(?<a_legacy>(?:\\d*\\.)?\\d+))?|(?<c>(?:\\d*\\.)?\\d+%?)\\s+(?<m>(?:\\d*\\.)?\\d+%?)\\s+(?<y>(?:\\d*\\.)?\\d+%?)\\s+(?<k>(?:\\d*\\.)?\\d+%?)(?:\\s*\\/\\s*(?<a>(?:\\d*\\.)?\\d+%?))?)\\s*\\)$/\n};\nexport const CALC = {\n    REGEXP: /^calc\\(\\s*(?<operation>[\\d./*+-\\w\\s]+)\\s*\\)$/,\n    SCOPED: /\\(\\s*([^()]+)\\s*\\)/g,\n    DIVISION: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\/\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n    MULTIPLICATION: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\*\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n    SUM: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*\\+\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/,\n    REST: /\\s*(?<left>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*-\\s*(?<right>(?:(?:\\d*\\.)?\\d+|\\w+))\\s*/\n};\nexport const HSL_HUE = /^(?<number>-?(?:\\d*\\.)?\\d+)(?<units>(?:deg|grad|rad|turn)?)$/;\nexport const PCENT = /^(-?\\d+(?:\\.\\d+)?|-?\\.\\d+)%$/;\nexport const HEX = /^0x([a-f\\d]{1,2})$/i;\nexport const TEMPLATE_VAR = /\\{(\\d+)\\}/g;\nexport const COMMAS_AND_NEXT_CHARS = /,( +|\\d+)/g;\nexport const SPACES = / +/;\n","import { AnglesUnitEnum, CMYKFunctionEnum, ColorUnitEnum } from '@types';\nimport { ColorKeywords, ColorModel } from './enums';\nexport const MAX_DECIMALS = 6;\nexport const DEFAULT_BLEND_STEPS = 5;\nexport const DEFAULT_SHADES_TINTS_STEPS = 5;\nexport const BASE_255 = 255;\nexport const MAX_HUE = 360;\nexport const MAX_PCENT = 100;\nexport const MAX_ALPHA = 1;\nexport const MAX_LAB = 125;\nexport const MAX_LCH_C = 150;\nexport const GRADIANS = 10 / 9;\nexport const COLOR_KEYS = Object.keys(ColorKeywords);\nexport const COLOR_PROPS = Object.freeze({\n    HEX: ['R', 'G', 'B', 'A'],\n    RGB: ['R', 'G', 'B', 'A'],\n    HSL: ['H', 'S', 'L', 'A'],\n    HWB: ['H', 'W', 'B', 'A'],\n    CIELab: ['L', 'a', 'b', 'A'],\n    LCH: ['L', 'C', 'H', 'A'],\n    CMYK: ['C', 'M', 'Y', 'K', 'A']\n});\nexport const VALID_COLOR_OBJECTS = Object.freeze({\n    ABGR: ColorModel.RGB,\n    ABHW: ColorModel.HWB,\n    ACHL: ColorModel.LCH,\n    ACKMY: ColorModel.CMYK,\n    AHLS: ColorModel.HSL,\n    ALAB: ColorModel.CIELab,\n    BGR: ColorModel.RGB,\n    BHW: ColorModel.HWB,\n    CHL: ColorModel.LCH,\n    CKMY: ColorModel.CMYK,\n    HLS: ColorModel.HSL,\n    LAB: ColorModel.CIELab\n});\nexport const DEFAULT_OPTIONS = Object.freeze({\n    decimals: MAX_DECIMALS,\n    legacyCSS: false,\n    spacesAfterCommas: false,\n    anglesUnit: AnglesUnitEnum.NONE,\n    rgbUnit: ColorUnitEnum.NONE,\n    labUnit: ColorUnitEnum.NONE,\n    lchUnit: ColorUnitEnum.NONE,\n    cmykUnit: ColorUnitEnum.PERCENT,\n    alphaUnit: ColorUnitEnum.NONE,\n    cmykFunction: CMYKFunctionEnum.DEVICE_CMYK\n});\nexport const ERRORS = Object.freeze({\n    NOT_ACCEPTED_INPUT: `The provided string color doesn't have a correct format`,\n    NOT_A_VALID_RELATIVE_COLOR: 'is not a valid operation for a relative color'\n});\nexport * from './regexps';\nexport * from './enums';\n","import { AnglesUnitEnum } from '@types';\nimport { BASE_255, ColorModel, GRADIANS, Harmony, HEX, HSL_HUE, MAX_ALPHA, MAX_DECIMALS, MAX_HUE, MAX_LAB, MAX_LCH_C, Mix, PCENT, VALID_COLOR_OBJECTS } from '#constants';\nexport const getOrderedArrayString = (keys) => [...keys].sort().join('').toUpperCase();\nexport const isString = (input) => typeof input === 'string';\nexport const isNumber = (input) => typeof input === 'number';\nexport const isBoolean = (input) => typeof input === 'boolean';\nexport const isUndefined = (input) => input === undefined;\nexport const getColorModel = (color) => {\n    return VALID_COLOR_OBJECTS[getOrderedArrayString(Object.keys(color))];\n};\nexport const isRGBObject = (color) => getColorModel(color) === ColorModel.RGB;\nexport const isHSLObject = (color) => getColorModel(color) === ColorModel.HSL;\nexport const isHWBObject = (color) => getColorModel(color) === ColorModel.HWB;\nexport const isCIELabObject = (color) => getColorModel(color) === ColorModel.CIELab;\nexport const isLCHObject = (color) => getColorModel(color) === ColorModel.LCH;\nexport const isCMYKObject = (color) => getColorModel(color) === ColorModel.CMYK;\nexport const percentNumber = (percent) => {\n    return +`${percent}`.replace(PCENT, '$1');\n};\nexport const percent = (percent) => PCENT.test(`${percent}`)\n    ? percentNumber(percent)\n    : Math.min(+percent, 100);\nexport const getDEC = (hex) => {\n    if (hex.length === 1) {\n        hex += hex;\n    }\n    return parseInt(hex, 16);\n};\nexport const getHEX = (number) => {\n    const hex = round(number, 0).toString(16).toUpperCase();\n    if (hex.length === 1) {\n        return `0x0${hex}`;\n    }\n    return `0x${hex}`;\n};\nexport const toHEX = (h) => {\n    let hex = round(h, 0).toString(16).toUpperCase();\n    if (hex.length === 1) {\n        hex = `0${hex}`;\n    }\n    return hex;\n};\nexport const from255NumberToPercent = (value, decimals) => round(value / BASE_255 * 100, decimals);\nexport const from125NumberToPercent = (value, decimals) => round(value / MAX_LAB * 100, decimals);\nexport const from150NumberToPercent = (value, decimals) => round(value / MAX_LCH_C * 100, decimals);\nexport const getBase255Number = (color, alpha = false) => {\n    if (!alpha && PCENT.test(color)) {\n        return Math.min(BASE_255 * percentNumber(color) / 100, BASE_255);\n    }\n    if (HEX.test(color)) {\n        if (color.length === 3) {\n            color += color.slice(-1);\n        }\n        return alpha\n            ? round(color) / BASE_255\n            : round(color);\n    }\n    return Math.min(+color, alpha ? 1 : BASE_255);\n};\nexport const getBase125Number = (color) => {\n    if (PCENT.test(color)) {\n        return minmax(MAX_LAB * percentNumber(color) / 100, -MAX_LAB, MAX_LAB);\n    }\n    return minmax(+color, -MAX_LAB, MAX_LAB);\n};\nexport const getBase150Number = (color) => {\n    if (PCENT.test(color)) {\n        return minmax(MAX_LCH_C * percentNumber(color) / 100, -MAX_LCH_C, MAX_LCH_C);\n    }\n    return minmax(+color, -MAX_LCH_C, MAX_LCH_C);\n};\nexport const getCMYKNumber = (color, base100) => {\n    const value = PCENT.test(color)\n        ? percentNumber(color)\n        : +color;\n    if (base100) {\n        return Math.min(value * 100, 100);\n    }\n    return Math.min(value, 100);\n};\nexport const round = (value, decimals = MAX_DECIMALS) => {\n    const exp = Math.pow(10, decimals);\n    return Math.round(+value * exp) / exp;\n};\nexport const minmax = (n, min, max) => Math.max(min, Math.min(n, max));\nexport const degrees = (radian) => radian * 180 / Math.PI;\nexport const radians = (degrees) => degrees * Math.PI / 180;\nexport const normalizeHue = (hue) => {\n    if (isString(hue)) {\n        const matches = hue.match(HSL_HUE);\n        const groups = matches.groups;\n        const value = +groups.number;\n        const units = groups.units;\n        switch (units) {\n            case AnglesUnitEnum.RADIANS:\n                hue = round(degrees(value));\n                break;\n            case AnglesUnitEnum.TURNS:\n                hue = round(value * MAX_HUE);\n                break;\n            case AnglesUnitEnum.GRADIANS:\n                hue = round(9 / 10 * value);\n                break;\n            case AnglesUnitEnum.DEGREES:\n            default:\n                hue = value;\n        }\n    }\n    if (hue >= MAX_HUE || hue < 0) {\n        hue -= Math.floor(hue / MAX_HUE) * MAX_HUE;\n    }\n    return hue;\n};\nexport const normalizeAlpha = (alpha) => {\n    if (isString(alpha)) {\n        if (PCENT.test(alpha)) {\n            alpha = percentNumber(alpha) / 100;\n        }\n        else {\n            alpha = +alpha;\n        }\n    }\n    return (isNaN(+alpha) || alpha > MAX_ALPHA) ? MAX_ALPHA : round(alpha);\n};\nexport const translateDegrees = (degrees, units) => {\n    let hue;\n    switch (units) {\n        case AnglesUnitEnum.RADIANS:\n            hue = round(radians(degrees));\n            break;\n        case AnglesUnitEnum.TURNS:\n            hue = round(degrees / MAX_HUE);\n            break;\n        case AnglesUnitEnum.GRADIANS:\n            hue = round(GRADIANS * degrees);\n            break;\n        case AnglesUnitEnum.DEGREES:\n        case AnglesUnitEnum.NONE:\n        default:\n            hue = degrees;\n    }\n    return hue;\n};\nexport const isHarmony = (param) => {\n    return `${param}` in Harmony;\n};\nexport const isMix = (param) => {\n    return `${param}` in Mix;\n};\nexport const getAngleUnit = (unit) => {\n    if (unit) {\n        const angleUnitMatch = unit.match(HSL_HUE);\n        const angleUnit = angleUnitMatch.groups.units;\n        return angleUnit === ''\n            ? AnglesUnitEnum.NONE\n            : angleUnit;\n    }\n    return AnglesUnitEnum.NONE;\n};\n","import { BASE_255, MAX_ALPHA } from '#constants';\nimport { degrees, minmax, normalizeHue, radians, round } from '#utilities';\nconst MATRIX_LRGB_XYZ_D50 = [\n    [0.4360747, 0.3850649, 0.1430804],\n    [0.2225045, 0.7168786, 0.0606169],\n    [0.0139322, 0.0971045, 0.7141733]\n];\nconst MATRIX_XYZ_D50_LRGB = [\n    [3.1338561, -1.6168667, -0.4906146],\n    [-0.9787684, 1.9161415, 0.033454],\n    [0.0719453, -0.2289914, 1.4052427]\n];\nconst TRISTIMULUS_D50 = MATRIX_LRGB_XYZ_D50.map((matrix) => {\n    return matrix.reduce((sum, value) => sum + value, 0);\n});\nconst hueToRgb = (t1, t2, hue) => {\n    if (hue < 0) {\n        hue += 6;\n    }\n    if (hue >= 6) {\n        hue -= 6;\n    }\n    if (hue < 1) {\n        return round(((t2 - t1) * hue + t1) * BASE_255);\n    }\n    else if (hue < 3) {\n        return round(t2 * BASE_255);\n    }\n    else if (hue < 4) {\n        return round(((t2 - t1) * (4 - hue) + t1) * BASE_255);\n    }\n    else {\n        return round(t1 * BASE_255);\n    }\n};\nconst rgbToLinearLightRgb = (value) => {\n    return value <= 0.04045\n        ? value / 12.92\n        : ((value + 0.055) / 1.055) ** 2.4;\n};\nconst linearLightRgbToRgb = (value) => {\n    return value <= 0.0031308\n        ? 12.92 * value\n        : 1.055 * (value ** (1 / 2.4)) - 0.055;\n};\nconst matrixVectorMultiplication = (v1, v2, v3, matrix) => {\n    const result = [0, 0, 0];\n    const linearRgb = [v1, v2, v3];\n    matrix.forEach((array, index) => {\n        array.forEach((value, mindex) => {\n            result[index] += value * linearRgb[mindex];\n        });\n    });\n    return result;\n};\nconst from_CIE_XYZ_D50_to_CIE_LAB = (x, y, z) => {\n    const f = (t) => {\n        return t > (6 / 29) ** 3\n            ? Math.cbrt(t)\n            : t / (3 * (6 / 29) ** 2) + (4 / 29);\n    };\n    const fx = f(x / TRISTIMULUS_D50[0]);\n    const fy = f(y / TRISTIMULUS_D50[1]);\n    const fz = f(z / TRISTIMULUS_D50[2]);\n    return [\n        116 * fy - 16,\n        500 * (fx - fy),\n        200 * (fy - fz)\n    ];\n};\nconst from_CIE_LAB_to_CIE_XYZ_D50 = (L, a, b) => {\n    const f = (t) => {\n        return t > 6 / 29\n            ? t ** 3\n            : 3 * (6 / 29) ** 2 * (t - 4 / 29);\n    };\n    const fl = (L + 16) / 116;\n    const fa = a / 500;\n    const fb = b / 200;\n    return [\n        TRISTIMULUS_D50[0] * f(fl + fa),\n        TRISTIMULUS_D50[1] * f(fl),\n        TRISTIMULUS_D50[2] * f(fl - fb)\n    ];\n};\nexport const hslToRgb = (H, S, L) => {\n    H /= 60;\n    S /= 100;\n    L /= 100;\n    const t2 = (L <= .5)\n        ? L * (S + 1)\n        : L + S - (L * S);\n    const t1 = L * 2 - t2;\n    const R = hueToRgb(t1, t2, H + 2);\n    const G = hueToRgb(t1, t2, H);\n    const B = hueToRgb(t1, t2, H - 2);\n    return { R, G, B };\n};\nexport const rgbToHsl = (R, G, B, A = 1) => {\n    R /= BASE_255;\n    G /= BASE_255;\n    B /= BASE_255;\n    A = Math.min(A, MAX_ALPHA);\n    const MAX = Math.max(R, G, B);\n    const MIN = Math.min(R, G, B);\n    const D = MAX - MIN;\n    let H = 0;\n    let S = 0;\n    const L = (MAX + MIN) / 2;\n    if (D !== 0) {\n        switch (MAX) {\n            case R:\n                H = ((G - B) / D) % 6;\n                break;\n            case G:\n                H = (B - R) / D + 2;\n                break;\n            case B:\n                H = (R - G) / D + 4;\n                break;\n        }\n        H = round(H * 60);\n        if (H < 0) {\n            H += 360;\n        }\n        S = D / (1 - Math.abs(2 * L - 1));\n    }\n    return {\n        H,\n        S: round(S * 100),\n        L: round(L * 100),\n        A\n    };\n};\nexport const rgbToLab = (R, G, B) => {\n    const LINEAR_LIGHT_RGB = [\n        R / BASE_255,\n        G / BASE_255,\n        B / BASE_255\n    ].map(rgbToLinearLightRgb);\n    const CIE_XYZ_D50 = matrixVectorMultiplication(LINEAR_LIGHT_RGB[0], LINEAR_LIGHT_RGB[1], LINEAR_LIGHT_RGB[2], MATRIX_LRGB_XYZ_D50);\n    const CIE_LAB = from_CIE_XYZ_D50_to_CIE_LAB(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2]);\n    return {\n        L: CIE_LAB[0],\n        a: CIE_LAB[1],\n        b: CIE_LAB[2]\n    };\n};\nexport const labToRgb = (L, a, b) => {\n    const CIE_XYZ_D50 = from_CIE_LAB_to_CIE_XYZ_D50(L, a, b);\n    const LINEAR_LIGHT_RGB = matrixVectorMultiplication(CIE_XYZ_D50[0], CIE_XYZ_D50[1], CIE_XYZ_D50[2], MATRIX_XYZ_D50_LRGB);\n    const rgb = LINEAR_LIGHT_RGB.map(linearLightRgbToRgb);\n    return {\n        R: minmax(rgb[0] * BASE_255, 0, BASE_255),\n        G: minmax(rgb[1] * BASE_255, 0, BASE_255),\n        B: minmax(rgb[2] * BASE_255, 0, BASE_255)\n    };\n};\nexport const labToLch = (L, a, b) => {\n    const C = Math.sqrt(a ** 2 + b ** 2);\n    const H = degrees(Math.atan2(b, a));\n    return {\n        L,\n        C,\n        H: normalizeHue(H)\n    };\n};\nexport const lchToLab = (L, C, H) => {\n    const radH = radians(H);\n    const a = C * Math.cos(radH);\n    const b = C * Math.sin(radH);\n    return {\n        L,\n        a,\n        b\n    };\n};\nexport const rgbToLch = (R, G, B) => {\n    const lab = rgbToLab(R, G, B);\n    return labToLch(lab.L, lab.a, lab.b);\n};\nexport const lchToRgb = (L, C, H) => {\n    const lab = lchToLab(L, C, H);\n    return labToRgb(lab.L, lab.a, lab.b);\n};\nexport const rgbToHwb = (R, G, B, A = 1) => {\n    const hsl = rgbToHsl(R, G, B, A);\n    return {\n        H: hsl.H,\n        W: round(Math.min(R, G, B) / BASE_255 * 100),\n        B: round((1 - Math.max(R, G, B) / BASE_255) * 100),\n        A\n    };\n};\nexport const hwbToRgb = (H, W, B) => {\n    W /= 100;\n    B /= 100;\n    const v = 1 - B;\n    const c = v - W;\n    const x = c * (1 - Math.abs((H / 60) % 2 - 1));\n    let rgbR;\n    let rgbG;\n    let rgbB;\n    if (H < 60) {\n        rgbR = c;\n        rgbG = x;\n        rgbB = 0;\n    }\n    else if (H >= 60 && H < 120) {\n        rgbR = x;\n        rgbG = c;\n        rgbB = 0;\n    }\n    else if (H >= 120 && H < 180) {\n        rgbR = 0;\n        rgbG = c;\n        rgbB = x;\n    }\n    else if (H >= 180 && H < 240) {\n        rgbR = 0;\n        rgbG = x;\n        rgbB = c;\n    }\n    else if (H >= 240 && H < 300) {\n        rgbR = x;\n        rgbG = 0;\n        rgbB = c;\n    }\n    else {\n        rgbR = c;\n        rgbG = 0;\n        rgbB = x;\n    }\n    rgbR += W;\n    rgbG += W;\n    rgbB += W;\n    return {\n        R: minmax(rgbR * BASE_255, 0, BASE_255),\n        G: minmax(rgbG * BASE_255, 0, BASE_255),\n        B: minmax(rgbB * BASE_255, 0, BASE_255)\n    };\n};\nexport const cmykToRgb = (C, M, Y, K) => {\n    K = 1 - K;\n    return {\n        R: minmax(round(BASE_255 * (1 - C) * K), 0, BASE_255),\n        G: minmax(round(BASE_255 * (1 - M) * K), 0, BASE_255),\n        B: minmax(round(BASE_255 * (1 - Y) * K), 0, BASE_255)\n    };\n};\nexport const rgbToCmyk = (R, G, B) => {\n    R /= BASE_255;\n    G /= BASE_255;\n    B /= BASE_255;\n    const K = 1 - Math.max(R, G, B);\n    const K1 = 1 - K;\n    const C = K1 && (K1 - R) / K1;\n    const M = K1 && (K1 - G) / K1;\n    const Y = K1 && (K1 - B) / K1;\n    return {\n        C: round(C * 100),\n        M: round(M * 100),\n        Y: round(Y * 100),\n        K: round(K * 100)\n    };\n};\nexport const rgbToRyb = (R, G, B) => {\n    const Iw = Math.min(R, G, B);\n    const Ib = Math.min(BASE_255 - R, BASE_255 - G, BASE_255 - B);\n    const rRgb = R - Iw;\n    const gRgb = G - Iw;\n    const bRgb = B - Iw;\n    const minRg = Math.min(rRgb, gRgb);\n    const rRyb = rRgb - minRg;\n    const yRyb = (gRgb + minRg) / 2;\n    const bRyb = (bRgb + gRgb - minRg) / 2;\n    const n = Math.max(rRyb, yRyb, bRyb) / Math.max(rRgb, gRgb, bRgb);\n    const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n    return {\n        R: rRyb / N + Ib,\n        Y: yRyb / N + Ib,\n        B: bRyb / N + Ib\n    };\n};\nexport const rybToRgb = (R, Y, B) => {\n    const Iw = Math.min(R, Y, B);\n    const Ib = Math.min(BASE_255 - R, BASE_255 - Y, BASE_255 - B);\n    const rRyb = R - Iw;\n    const yRyb = Y - Iw;\n    const bRyb = B - Iw;\n    const minYb = Math.min(yRyb, bRyb);\n    const rRgb = rRyb + yRyb - minYb;\n    const gRgb = yRyb + minYb;\n    const bRgb = 2 * (bRyb - minYb);\n    const n = Math.max(rRgb, gRgb, bRgb) / Math.max(rRyb, yRyb, bRyb);\n    const N = isNaN(n) || n === Infinity || n <= 0 ? 1 : n;\n    return {\n        R: rRgb / N + Ib,\n        G: gRgb / N + Ib,\n        B: bRgb / N + Ib\n    };\n};\nexport const hueRyb = (hue, toRyb) => {\n    if (hue < 0)\n        hue += 360;\n    if (hue > 360)\n        hue -= 360;\n    if (hue === 360 || hue === 0)\n        return hue;\n    const map1 = [\n        [0, 120],\n        [120, 180],\n        [180, 240],\n        [240, 360]\n    ];\n    const map2 = [\n        [0, 60],\n        [60, 120],\n        [120, 240],\n        [240, 360]\n    ];\n    const from = toRyb ? map1 : map2;\n    const to = toRyb ? map2 : map1;\n    let A = 0;\n    let B = 0;\n    let C = 0;\n    let D = 0;\n    from.find((arr, index) => {\n        if (hue >= arr[0] && hue < arr[1]) {\n            A = arr[0];\n            B = arr[1];\n            C = to[index][0];\n            D = to[index][1];\n            return true;\n        }\n        return false;\n    });\n    return C + (hue - A) * ((D - C) / (B - A));\n};\n","import { DEFAULT_OPTIONS, ERRORS } from '#constants';\nimport { isString, isUndefined } from '#utilities';\nexport class ColorParserContext {\n    constructor(parsers) {\n        this._parsers = parsers;\n    }\n    getParser(input) {\n        const parser = Object.values(this._parsers).find(parser => parser.supports(input));\n        if (parser) {\n            return parser;\n        }\n        throw new Error(ERRORS.NOT_ACCEPTED_INPUT);\n    }\n    parse(input) {\n        const parser = this.getParser(input);\n        return parser.parse(input, this);\n    }\n    convert(input, model, decimals = DEFAULT_OPTIONS.decimals, withAlpha = false) {\n        const color = this.parse(input);\n        const parser = this._parsers[model];\n        return parser.convert(color, decimals, withAlpha);\n    }\n    convertCSS(input, model, options = {}, withAlpha = false) {\n        const color = this.parse(input);\n        const parser = this._parsers[model];\n        return parser.convertCSS(color, options, withAlpha);\n    }\n}\nexport class ColorParser {\n    hasAlpha(input) {\n        if (isString(input)) {\n            return this.getCSSOptions(input).hasAlpha;\n        }\n        return !isUndefined(input.A);\n    }\n    ;\n}\n","import { cmykToRgb, hslToRgb, hwbToRgb, labToRgb, lchToRgb } from '#color/translators';\nimport { isCIELabObject, isCMYKObject, isHSLObject, isHWBObject, isLCHObject, isUndefined } from '#utilities';\nconst getAlpha = (color) => {\n    if (isUndefined(color.A)) {\n        return {};\n    }\n    return {\n        A: +color.A\n    };\n};\nexport const getRGB = (color) => {\n    const alpha = getAlpha(color);\n    if (isHSLObject(color)) {\n        return {\n            ...hslToRgb(color.H, color.S, color.L),\n            ...alpha\n        };\n    }\n    if (isHWBObject(color)) {\n        return {\n            ...hwbToRgb(color.H, color.W, color.B),\n            ...alpha\n        };\n    }\n    if (isCIELabObject(color)) {\n        return {\n            ...labToRgb(color.L, color.a, color.b),\n            ...alpha\n        };\n    }\n    if (isLCHObject(color)) {\n        return {\n            ...lchToRgb(color.L, color.C, color.H),\n            ...alpha\n        };\n    }\n    if (isCMYKObject(color)) {\n        return {\n            ...cmykToRgb(color.C, color.M, color.Y, color.K),\n            ...alpha\n        };\n    }\n    return color;\n};\n","import { AnglesUnitEnum, ColorUnitEnum } from '@types';\nimport { COLOR_PROPS, TEMPLATE_VAR, VALID_COLOR_OBJECTS } from '#constants';\nimport { getOrderedArrayString, round, translateDegrees } from '#utilities';\nexport const getCSSComma = (withSpace) => withSpace\n    ? ', '\n    : ',';\nexport const prepareColorForCss = (color, transformer) => {\n    const props = getOrderedArrayString(Object.keys(color));\n    const model = VALID_COLOR_OBJECTS[props];\n    const keys = COLOR_PROPS[model];\n    return keys.reduce((result, key, index) => {\n        const value = color[key];\n        if (typeof value !== 'undefined') {\n            result.push(transformer(value, index));\n        }\n        return result;\n    }, []);\n};\nexport const getResultFromCSSTemplate = (template, vars) => {\n    return template.replace(TEMPLATE_VAR, (__match, indexStr) => {\n        const index = +indexStr - 1;\n        return `${vars[index]}`;\n    });\n};\nexport const getCSSAlpha = (value, options, ignoreLegacy = false) => {\n    const { alphaUnit, legacyCSS, decimals } = options;\n    if (alphaUnit === ColorUnitEnum.PERCENT &&\n        (!legacyCSS ||\n            ignoreLegacy)) {\n        return `${round(value * 100, decimals)}%`;\n    }\n    return round(value, decimals);\n};\nexport const buildCSSHueTransformer = (options) => {\n    const { anglesUnit, decimals } = options;\n    return (value, index) => {\n        if (index === 0 &&\n            anglesUnit !== AnglesUnitEnum.NONE) {\n            const translated = round(translateDegrees(value, anglesUnit), decimals);\n            return `${translated}${anglesUnit}`;\n        }\n        return index === 3\n            ? getCSSAlpha(value, options)\n            : round(value, decimals);\n    };\n};\n","import { BASE_255, COLOR_KEYS, ColorKeywords, ColorModel, COLORREGS, HEX } from '#constants';\nimport { getRGB } from '#color/rgb';\nimport { getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getDEC, getHEX, getBase255Number, isString, isUndefined, isRGBObject, round, toHEX } from '#utilities';\nimport { ColorParser } from './ColorParserContext';\nexport class HEXParser extends ColorParser {\n    _extract(input) {\n        const colorStr = !~COLOR_KEYS.indexOf(input)\n            ? input\n            : ColorKeywords[input];\n        const match = colorStr.match(COLORREGS.HEX);\n        return match.groups;\n    }\n    supports(input) {\n        if (isString(input)) {\n            return (COLORREGS.HEX.test(input) ||\n                !!~COLOR_KEYS.indexOf(input));\n        }\n        const hasInvalidHex = Object.entries(input).some((item) => {\n            return !HEX.test(`${item[1]}`);\n        });\n        return isRGBObject(input) && !hasInvalidHex;\n    }\n    parse(input) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const r = groups.r ?? groups.rr;\n            const g = groups.g ?? groups.gg;\n            const b = groups.b ?? groups.bb;\n            const a = groups.a ?? groups.aa;\n            return {\n                R: getDEC(r),\n                G: getDEC(g),\n                B: getDEC(b),\n                ...(isUndefined(a)\n                    ? {}\n                    : {\n                        A: getDEC(a) / BASE_255\n                    })\n            };\n        }\n        return {\n            R: getBase255Number(`${input.R}`),\n            G: getBase255Number(`${input.G}`),\n            B: getBase255Number(`${input.B}`),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: Math.min(getBase255Number(`${input.A}`, true), 1)\n                })\n        };\n    }\n    convert(color, __decimals, withAlpha) {\n        const rgb = isRGBObject(color)\n            ? color\n            : getRGB(color);\n        return {\n            R: getHEX(rgb.R),\n            G: getHEX(rgb.G),\n            B: getHEX(rgb.B),\n            ...(withAlpha\n                ? {\n                    A: isUndefined(rgb.A)\n                        ? '0xFF'\n                        : getHEX(rgb.A * BASE_255)\n                }\n                : {})\n        };\n    }\n    convertCSS(color, options, withAlpha) {\n        const rgb = this.convert(color, options.decimals, withAlpha);\n        const transformer = (value) => toHEX(round(value));\n        const values = prepareColorForCss(rgb, transformer);\n        const template = values.length === 4\n            ? '#{1}{2}{3}{4}'\n            : '#{1}{2}{3}';\n        return getResultFromCSSTemplate(template, values);\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        return {\n            hasAlpha: !isUndefined(groups.a ?? groups.aa)\n        };\n    }\n    get model() {\n        return ColorModel.HEX;\n    }\n}\n","import { CALC, ERRORS } from '#constants';\nconst MAX_STACK = 100;\nexport class CalcParser {\n    constructor(colorIndex, calc, vars) {\n        this._operations = new Map([\n            [CALC.DIVISION, this._division],\n            [CALC.MULTIPLICATION, this._multiplication],\n            [CALC.SUM, this._sum],\n            [CALC.REST, this._rest]\n        ]);\n        this._colorIndex = colorIndex;\n        let calcString = calc;\n        let stack = 0;\n        if (!Number.isNaN(+calc)) {\n            this._result = +calc;\n        }\n        else if (calc in vars) {\n            this._result = vars[calc];\n        }\n        else if (CALC.REGEXP.test(calcString)) {\n            CALC.REGEXP.lastIndex = 0;\n            this._result = this._getCalcValue(calcString, vars);\n        }\n        else {\n            while (CALC.SCOPED.test(calcString) && stack < MAX_STACK) {\n                CALC.SCOPED.lastIndex = 0;\n                calcString = calcString.replace(CALC.SCOPED, (__match, operation) => {\n                    return this._calculate(operation, vars).toString();\n                });\n                if (CALC.REGEXP.test(calcString)) {\n                    CALC.REGEXP.lastIndex = 0;\n                    break;\n                }\n                stack++;\n            }\n            this._result = this._getCalcValue(calcString, vars);\n        }\n    }\n    _division(left, right) {\n        return left / right;\n    }\n    _multiplication(left, right) {\n        return left * right;\n    }\n    _sum(left, right) {\n        return left + right;\n    }\n    _rest(left, right) {\n        return left - right;\n    }\n    _getCalcValue(calc, vars) {\n        const match = calc.match(CALC.REGEXP);\n        const operation = match.groups.operation;\n        const value = this._calculate(operation, vars);\n        if (Number.isNaN(value)) {\n            throw new Error(`Invalid value for ${this._colorIndex}. ${operation} ${ERRORS.NOT_A_VALID_RELATIVE_COLOR}`);\n        }\n        return value;\n    }\n    _calculate(operation, vars) {\n        this._operations.forEach((method, regExp) => {\n            let stack = 0;\n            while (regExp.test(operation) && stack < MAX_STACK) {\n                operation = operation.replace(regExp, (__match, left, right) => {\n                    return method(vars[left] ?? +left, vars[right] ?? +right).toString();\n                });\n                stack++;\n            }\n        });\n        return +operation;\n    }\n    get result() {\n        return this._result;\n    }\n}\n","import { ColorUnitEnum } from '@types';\nimport { BASE_255, COLORREGS, ColorModel, HEX, PCENT } from '#constants';\nimport { from255NumberToPercent, getBase255Number, isString, isRGBObject, isUndefined, normalizeAlpha, round } from '#utilities';\nimport { getCSSAlpha, getCSSComma, getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getRGB } from '#color/rgb';\nimport { CalcParser } from './CalcParser';\nimport { ColorParser } from './ColorParserContext';\nexport class RGBParser extends ColorParser {\n    _extract(input) {\n        const match = input.match(COLORREGS.RGB);\n        return match.groups;\n    }\n    supports(input) {\n        if (isString(input)) {\n            return COLORREGS.RGB.test(input);\n        }\n        const hasInvalidRegb = Object.entries(input).some((item) => {\n            return !(PCENT.test(`${item[1]}`) ||\n                (!HEX.test(`${item[1]}`) &&\n                    !isNaN(+item[1]) &&\n                    +item[1] <= BASE_255));\n        });\n        return isRGBObject(input) && !hasInvalidRegb;\n    }\n    parse(input, context) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const { r_legacy, g_legacy, b_legacy, a_legacy, r, g, b, a, from, relative_r, relative_g, relative_b, relative_a } = groups;\n            if (from) {\n                const fromColor = context.parse(from);\n                const fromRGB = getRGB(fromColor);\n                const fromRGBVars = {\n                    r: fromRGB.R,\n                    g: fromRGB.G,\n                    b: fromRGB.B,\n                    alpha: fromRGB.A ?? 1\n                };\n                const R = new CalcParser('r', relative_r, fromRGBVars).result;\n                const G = new CalcParser('g', relative_g, fromRGBVars).result;\n                const B = new CalcParser('b', relative_b, fromRGBVars).result;\n                const rgb = {\n                    R: Math.min(R, BASE_255),\n                    G: Math.min(G, BASE_255),\n                    B: Math.min(B, BASE_255)\n                };\n                if (relative_a) {\n                    const A = new CalcParser('alpha', relative_a, fromRGBVars).result;\n                    rgb.A = Math.min(A, 1);\n                }\n                return rgb;\n            }\n            else {\n                const R = r_legacy ?? r;\n                const G = g_legacy ?? g;\n                const B = b_legacy ?? b;\n                const A = a_legacy ?? a;\n                return {\n                    R: Math.min(getBase255Number(R), BASE_255),\n                    G: Math.min(getBase255Number(G), BASE_255),\n                    B: Math.min(getBase255Number(B), BASE_255),\n                    ...(isUndefined(A)\n                        ? {}\n                        : {\n                            A: normalizeAlpha(A)\n                        })\n                };\n            }\n        }\n        return {\n            R: getBase255Number(`${input.R}`),\n            G: getBase255Number(`${input.G}`),\n            B: getBase255Number(`${input.B}`),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: Math.min(getBase255Number(`${input.A}`, true), 1)\n                })\n        };\n    }\n    convert(color, decimals, withAlpha) {\n        const rgb = isRGBObject(color)\n            ? color\n            : getRGB(color);\n        return this._roundRGBObject({\n            R: rgb.R,\n            G: rgb.G,\n            B: rgb.B,\n            ...(withAlpha\n                ? {\n                    A: rgb.A ?? 1\n                }\n                : {})\n        }, decimals);\n    }\n    convertCSS(color, options, withAlpha) {\n        const { decimals, legacyCSS, spacesAfterCommas, rgbUnit } = options;\n        const rgb = this.convert(color, options.decimals, withAlpha);\n        const comma = getCSSComma(spacesAfterCommas);\n        const transformer = (value, index) => {\n            return rgbUnit === ColorUnitEnum.PERCENT && index < 3\n                ? `${from255NumberToPercent(value, decimals)}%`\n                : (index === 3\n                    ? getCSSAlpha(value, options)\n                    : round(value, decimals));\n        };\n        const values = prepareColorForCss(rgb, transformer);\n        const template = legacyCSS\n            ? (values.length === 4\n                ? `rgba({1}${comma}{2}${comma}{3}${comma}{4})`\n                : `rgb({1}${comma}{2}${comma}{3})`)\n            : (values.length === 4\n                ? `rgb({1} {2} {3} / {4})`\n                : `rgb({1} {2} {3})`);\n        return getResultFromCSSTemplate(template, values);\n    }\n    _roundRGBObject(color, decimals) {\n        const R = round(color.R, decimals);\n        const G = round(color.G, decimals);\n        const B = round(color.B, decimals);\n        return {\n            R,\n            G,\n            B,\n            ...(isUndefined(color.A)\n                ? {}\n                : {\n                    A: round(color.A, decimals)\n                })\n        };\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        const { r_legacy, g_legacy, b_legacy, a_legacy, r, g, b, a } = groups;\n        return {\n            hasPercentageValues: (PCENT.test(r_legacy ?? r) &&\n                PCENT.test(g_legacy ?? g) &&\n                PCENT.test(b_legacy ?? b)),\n            hasPercentageAlpha: PCENT.test(a_legacy ?? a),\n            hasAlpha: !isUndefined(a_legacy ?? a)\n        };\n    }\n    get model() {\n        return ColorModel.RGB;\n    }\n}\n","import { COLORREGS, ColorModel, MAX_ALPHA, PCENT } from '#constants';\nimport { getAngleUnit, isHSLObject, isString, isUndefined, minmax, normalizeAlpha, normalizeHue, percent, round } from '#utilities';\nimport { buildCSSHueTransformer, getCSSComma, getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getRGB } from '#color/rgb';\nimport { rgbToHsl } from '#color/translators';\nimport { CalcParser } from './CalcParser';\nimport { ColorParser } from './ColorParserContext';\nexport class HSLParser extends ColorParser {\n    _extract(input) {\n        const match = input.match(COLORREGS.HSL);\n        return match.groups;\n    }\n    supports(input) {\n        if (isString(input)) {\n            return COLORREGS.HSL.test(input);\n        }\n        return isHSLObject(input);\n    }\n    parse(input, context) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const { h_legacy, s_legacy, l_legacy, a_legacy, h, s, l, a, from, relative_h, relative_s, relative_l, relative_a } = groups;\n            if (from) {\n                const fromColor = context.parse(from);\n                const fromRGB = getRGB(fromColor);\n                const fromHSL = rgbToHsl(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n                const fromHSLVars = {\n                    h: fromHSL.H,\n                    s: fromHSL.S,\n                    l: fromHSL.L,\n                    alpha: fromHSL.A\n                };\n                const H = new CalcParser('h', relative_h, fromHSLVars).result;\n                const S = new CalcParser('s', relative_s, fromHSLVars).result;\n                const L = new CalcParser('l', relative_l, fromHSLVars).result;\n                const hsl = {\n                    H: normalizeHue(H),\n                    S: percent(S),\n                    L: percent(L)\n                };\n                if (relative_a) {\n                    const A = new CalcParser('alpha', relative_a, fromHSLVars).result;\n                    hsl.A = minmax(A, 0, MAX_ALPHA);\n                }\n                return hsl;\n            }\n            else {\n                const H = h_legacy ?? h;\n                const S = s_legacy ?? s;\n                const L = l_legacy ?? l;\n                const A = a_legacy ?? a;\n                return {\n                    H: normalizeHue(H),\n                    S: percent(S),\n                    L: percent(L),\n                    ...(isUndefined(A)\n                        ? {}\n                        : {\n                            A: normalizeAlpha(A)\n                        })\n                };\n            }\n        }\n        return {\n            H: normalizeHue(input.H),\n            S: percent(`${input.S}`),\n            L: percent(`${input.L}`),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: minmax(+input.A, 0, MAX_ALPHA)\n                })\n        };\n    }\n    convert(color, decimals, withAlpha) {\n        let hsl;\n        if (isHSLObject(color)) {\n            hsl = color;\n        }\n        else {\n            const rgb = getRGB(color);\n            hsl = rgbToHsl(rgb.R, rgb.G, rgb.B, rgb.A);\n        }\n        return this._roundHSLObject({\n            H: hsl.H,\n            S: hsl.S,\n            L: hsl.L,\n            ...(withAlpha\n                ? {\n                    A: hsl.A ?? 1\n                }\n                : {})\n        }, decimals);\n    }\n    convertCSS(color, options, withAlpha) {\n        const { legacyCSS, spacesAfterCommas } = options;\n        const comma = getCSSComma(spacesAfterCommas);\n        const hsl = this.convert(color, options.decimals, withAlpha);\n        const transformer = buildCSSHueTransformer(options);\n        const values = prepareColorForCss(hsl, transformer);\n        const template = legacyCSS\n            ? (values.length === 4\n                ? `hsla({1}${comma}{2}%${comma}{3}%${comma}{4})`\n                : `hsl({1}${comma}{2}%${comma}{3}%)`)\n            : (values.length === 4\n                ? `hsl({1} {2}% {3}% / {4})`\n                : `hsl({1} {2}% {3}%)`);\n        return getResultFromCSSTemplate(template, values);\n    }\n    _roundHSLObject(color, decimals) {\n        return {\n            H: round(normalizeHue(color.H), decimals),\n            S: round(color.S, decimals),\n            L: round(color.L, decimals),\n            ...(isUndefined(color.A)\n                ? {}\n                : {\n                    A: round(color.A, decimals)\n                })\n        };\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        const { h_legacy, h, a_legacy, a } = groups;\n        return {\n            angleUnit: getAngleUnit(h_legacy ?? h),\n            hasPercentageAlpha: PCENT.test(a_legacy ?? a),\n            hasAlpha: !isUndefined(a_legacy ?? a)\n        };\n    }\n    get model() {\n        return ColorModel.HSL;\n    }\n}\n","import { COLORREGS, ColorModel, MAX_ALPHA, MAX_HUE, MAX_PCENT, PCENT } from '#constants';\nimport { getAngleUnit, isHWBObject, isString, isUndefined, minmax, normalizeAlpha, normalizeHue, percent, round } from '#utilities';\nimport { buildCSSHueTransformer, getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getRGB } from '#color/rgb';\nimport { rgbToHwb } from '#color/translators';\nimport { CalcParser } from './CalcParser';\nimport { ColorParser } from './ColorParserContext';\nexport class HWBParser extends ColorParser {\n    _extract(input) {\n        const match = input.match(COLORREGS.HWB);\n        return match.groups;\n    }\n    supports(input) {\n        if (isString(input)) {\n            return COLORREGS.HWB.test(input);\n        }\n        return isHWBObject(input);\n    }\n    parse(input, context) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const { h, w, b, a, from, relative_h, relative_w, relative_b, relative_a } = groups;\n            if (from) {\n                const fromColor = context.parse(from);\n                const fromRGB = getRGB(fromColor);\n                const fromHWB = rgbToHwb(fromRGB.R, fromRGB.G, fromRGB.B, fromRGB.A);\n                const fromHWBVars = {\n                    h: fromHWB.H,\n                    w: fromHWB.W,\n                    b: fromHWB.B,\n                    alpha: fromHWB.A\n                };\n                const H = new CalcParser('h', relative_h, fromHWBVars).result;\n                const W = new CalcParser('w', relative_w, fromHWBVars).result;\n                const B = new CalcParser('b', relative_b, fromHWBVars).result;\n                const hwb = {\n                    H: minmax(H, 0, MAX_HUE),\n                    W: minmax(W, 0, MAX_PCENT),\n                    B: minmax(B, 0, MAX_PCENT)\n                };\n                if (relative_a) {\n                    const A = new CalcParser('alpha', relative_a, fromHWBVars).result;\n                    hwb.A = minmax(A, 0, MAX_ALPHA);\n                }\n                return hwb;\n            }\n            else {\n                return {\n                    H: normalizeHue(h),\n                    W: percent(w),\n                    B: percent(b),\n                    ...(isUndefined(a)\n                        ? {}\n                        : {\n                            A: normalizeAlpha(a)\n                        })\n                };\n            }\n        }\n        return {\n            H: normalizeHue(input.H),\n            W: percent(input.W),\n            B: percent(input.B),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: normalizeAlpha(input.A)\n                })\n        };\n    }\n    convert(color, decimals, withAlpha) {\n        let hwb;\n        if (isHWBObject(color)) {\n            hwb = color;\n        }\n        else {\n            const rgb = getRGB(color);\n            hwb = rgbToHwb(rgb.R, rgb.G, rgb.B, rgb.A);\n        }\n        return this._roundHWBObject({\n            H: hwb.H,\n            W: hwb.W,\n            B: hwb.B,\n            ...(withAlpha\n                ? {\n                    A: hwb.A ?? 1\n                }\n                : {})\n        }, decimals);\n    }\n    convertCSS(color, options, withAlpha) {\n        const hwb = this.convert(color, options.decimals, withAlpha);\n        const transformer = buildCSSHueTransformer(options);\n        const values = prepareColorForCss(hwb, transformer);\n        const template = values.length === 4\n            ? `hwb({1} {2}% {3}% / {4})`\n            : `hwb({1} {2}% {3}%)`;\n        return getResultFromCSSTemplate(template, values);\n    }\n    _roundHWBObject(color, decimals) {\n        return {\n            H: round(normalizeHue(color.H), decimals),\n            W: round(color.W, decimals),\n            B: round(color.B, decimals),\n            ...(isUndefined(color.A)\n                ? {}\n                : {\n                    A: round(color.A, decimals)\n                })\n        };\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        return {\n            angleUnit: getAngleUnit(groups.h),\n            hasPercentageAlpha: PCENT.test(groups.a),\n            hasAlpha: !isUndefined(groups.a)\n        };\n    }\n    get model() {\n        return ColorModel.HWB;\n    }\n}\n","import { ColorUnitEnum } from '@types';\nimport { ColorModel, COLORREGS, MAX_ALPHA, MAX_LAB, MAX_PCENT, PCENT } from '#constants';\nimport { from125NumberToPercent, getBase125Number, isCIELabObject, isString, isUndefined, minmax, normalizeAlpha, percent, round } from '#utilities';\nimport { getCSSAlpha, getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getRGB } from '#color/rgb';\nimport { rgbToLab } from '#color/translators';\nimport { CalcParser } from './CalcParser';\nimport { ColorParser } from './ColorParserContext';\nexport class CIELabParser extends ColorParser {\n    _extract(input) {\n        const match = input.match(COLORREGS.CIELab);\n        return match.groups;\n    }\n    supports(input) {\n        if (isString(input)) {\n            return COLORREGS.CIELab.test(input);\n        }\n        return isCIELabObject(input);\n    }\n    parse(input, context) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const { L, a, b, A, from, relative_L, relative_a, relative_b, relative_A } = groups;\n            if (from) {\n                const fromColor = context.parse(from);\n                const fromRGB = getRGB(fromColor);\n                const fromCIELab = rgbToLab(fromRGB.R, fromRGB.G, fromRGB.B);\n                const fromCIELabVars = {\n                    l: fromCIELab.L,\n                    a: fromCIELab.a,\n                    b: fromCIELab.b,\n                    alpha: fromRGB.A ?? 1\n                };\n                const L = new CalcParser('l', relative_L, fromCIELabVars).result;\n                const a = new CalcParser('a', relative_a, fromCIELabVars).result;\n                const b = new CalcParser('b', relative_b, fromCIELabVars).result;\n                const CIELab = {\n                    L: minmax(L, 0, MAX_PCENT),\n                    a: minmax(a, -MAX_LAB, MAX_LAB),\n                    b: minmax(b, -MAX_LAB, MAX_LAB)\n                };\n                if (relative_A) {\n                    const A = new CalcParser('alpha', relative_A, fromCIELabVars).result;\n                    CIELab.A = minmax(A, 0, MAX_ALPHA);\n                }\n                return CIELab;\n            }\n            else {\n                return {\n                    L: percent(L),\n                    a: getBase125Number(a),\n                    b: getBase125Number(b),\n                    ...(isUndefined(A)\n                        ? {}\n                        : {\n                            A: normalizeAlpha(A)\n                        })\n                };\n            }\n        }\n        return {\n            L: percent(input.L),\n            a: getBase125Number(`${input.a}`),\n            b: getBase125Number(`${input.b}`),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: normalizeAlpha(input.A)\n                })\n        };\n    }\n    convert(color, decimals, withAlpha) {\n        let lab;\n        if (isCIELabObject(color)) {\n            lab = color;\n        }\n        else {\n            const rgb = getRGB(color);\n            lab = rgbToLab(rgb.R, rgb.G, rgb.B);\n        }\n        return this._roundCIELabObject({\n            L: lab.L,\n            a: lab.a,\n            b: lab.b,\n            ...(withAlpha\n                ? {\n                    A: +(color.A ?? 1)\n                }\n                : {})\n        }, decimals);\n    }\n    convertCSS(color, options, withAlpha) {\n        const { decimals, labUnit } = options;\n        const lab = this.convert(color, options.decimals, withAlpha);\n        const transformer = (value, index) => {\n            if (index === 0) {\n                const L = round(percent(value), decimals);\n                return labUnit === ColorUnitEnum.PERCENT\n                    ? `${L}%`\n                    : `${L}`;\n            }\n            if (index < 3) {\n                return labUnit === ColorUnitEnum.PERCENT\n                    ? `${from125NumberToPercent(value, decimals)}%`\n                    : round(value, decimals);\n            }\n            return getCSSAlpha(value, options, true);\n        };\n        const values = prepareColorForCss(lab, transformer);\n        const template = values.length === 4\n            ? `lab({1} {2} {3} / {4})`\n            : `lab({1} {2} {3})`;\n        return getResultFromCSSTemplate(template, values);\n    }\n    _roundCIELabObject(color, decimals) {\n        return {\n            L: round(color.L, decimals),\n            a: round(color.a, decimals),\n            b: round(color.b, decimals),\n            ...(isUndefined(color.A)\n                ? {}\n                : {\n                    A: round(color.A, decimals)\n                })\n        };\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        const { L, a, b, A } = groups;\n        return {\n            hasPercentageValues: (PCENT.test(L) &&\n                PCENT.test(a) &&\n                PCENT.test(b)),\n            hasPercentageAlpha: PCENT.test(A),\n            hasAlpha: !isUndefined(A)\n        };\n    }\n    get model() {\n        return ColorModel.CIELab;\n    }\n}\n","import { AnglesUnitEnum, ColorUnitEnum } from '@types';\nimport { COLORREGS, ColorModel, MAX_ALPHA, MAX_LCH_C, MAX_PCENT, PCENT } from '#constants';\nimport { from150NumberToPercent, getAngleUnit, getBase150Number, isLCHObject, isString, isUndefined, minmax, normalizeAlpha, normalizeHue, percent, round, translateDegrees } from '#utilities';\nimport { getCSSAlpha, getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getRGB } from '#color/rgb';\nimport { rgbToLch } from '#color/translators';\nimport { CalcParser } from './CalcParser';\nimport { ColorParser } from './ColorParserContext';\nexport class LCHParser extends ColorParser {\n    _extract(input) {\n        const match = input.match(COLORREGS.LCH);\n        return match.groups;\n    }\n    supports(input) {\n        if (isString(input)) {\n            return COLORREGS.LCH.test(input);\n        }\n        return isLCHObject(input);\n    }\n    parse(input, context) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const { l, c, h, a, from, relative_l, relative_c, relative_h, relative_a } = groups;\n            if (from) {\n                const fromColor = context.parse(from);\n                const fromRGB = getRGB(fromColor);\n                const fromLCH = rgbToLch(fromRGB.R, fromRGB.G, fromRGB.B);\n                const fromLCHVars = {\n                    l: fromLCH.L,\n                    c: fromLCH.C,\n                    h: fromLCH.H,\n                    alpha: fromRGB.A ?? 1\n                };\n                const L = new CalcParser('l', relative_l, fromLCHVars).result;\n                const C = new CalcParser('c', relative_c, fromLCHVars).result;\n                const H = new CalcParser('h', relative_h, fromLCHVars).result;\n                const lch = {\n                    L: minmax(L, 0, MAX_PCENT),\n                    C: minmax(C, -MAX_LCH_C, MAX_LCH_C),\n                    H: normalizeHue(H)\n                };\n                if (relative_a) {\n                    const A = new CalcParser('alpha', relative_a, fromLCHVars).result;\n                    lch.A = minmax(A, 0, MAX_ALPHA);\n                }\n                return lch;\n            }\n            else {\n                return {\n                    L: percent(l),\n                    C: getBase150Number(c),\n                    H: normalizeHue(h),\n                    ...(isUndefined(a)\n                        ? {}\n                        : {\n                            A: normalizeAlpha(a)\n                        })\n                };\n            }\n        }\n        return {\n            L: percent(input.L),\n            C: getBase150Number(`${input.C}`),\n            H: normalizeHue(input.H),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: normalizeAlpha(input.A)\n                })\n        };\n    }\n    convert(color, decimals, withAlpha) {\n        let lch;\n        if (isLCHObject(color)) {\n            lch = color;\n        }\n        else {\n            const rgb = getRGB(color);\n            lch = rgbToLch(rgb.R, rgb.G, rgb.B);\n        }\n        return this._roundLCHObject({\n            L: lch.L,\n            C: lch.C,\n            H: lch.H,\n            ...(withAlpha\n                ? {\n                    A: +(color.A ?? 1)\n                }\n                : {})\n        }, decimals);\n    }\n    convertCSS(color, options, withAlpha) {\n        const { decimals, lchUnit, anglesUnit } = options;\n        const lch = this.convert(color, options.decimals, withAlpha);\n        const transformer = (value, index) => {\n            if (index === 0) {\n                const L = round(percent(value), decimals);\n                return lchUnit === ColorUnitEnum.PERCENT\n                    ? `${L}%`\n                    : `${L}`;\n            }\n            if (index === 1) {\n                return lchUnit === ColorUnitEnum.PERCENT\n                    ? `${from150NumberToPercent(value, decimals)}%`\n                    : round(value, decimals);\n            }\n            if (index === 2) {\n                if (anglesUnit !== AnglesUnitEnum.NONE) {\n                    const translated = round(translateDegrees(value, anglesUnit), decimals);\n                    return `${translated}${anglesUnit}`;\n                }\n                return round(value, decimals);\n            }\n            return getCSSAlpha(value, options, true);\n        };\n        const values = prepareColorForCss(lch, transformer);\n        const template = values.length === 4\n            ? `lch({1} {2} {3} / {4})`\n            : `lch({1} {2} {3})`;\n        return getResultFromCSSTemplate(template, values);\n    }\n    _roundLCHObject(color, decimals) {\n        return {\n            L: round(color.L, decimals),\n            C: round(color.C, decimals),\n            H: round(normalizeHue(color.H), decimals),\n            ...(isUndefined(color.A)\n                ? {}\n                : {\n                    A: round(color.A, decimals)\n                })\n        };\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        return {\n            angleUnit: getAngleUnit(groups.h),\n            hasPercentageValues: (PCENT.test(groups.l) &&\n                PCENT.test(groups.c)),\n            hasPercentageAlpha: PCENT.test(groups.a),\n            hasAlpha: !isUndefined(groups.a)\n        };\n    }\n    get model() {\n        return ColorModel.LCH;\n    }\n}\n","import { ColorUnitEnum } from '@types';\nimport { ColorModel, COLORREGS, PCENT } from '#constants';\nimport { getCMYKNumber, isCMYKObject, isString, isUndefined, normalizeAlpha, round } from '#utilities';\nimport { getCSSAlpha, getCSSComma, getResultFromCSSTemplate, prepareColorForCss } from '#css';\nimport { getRGB } from '#color/rgb';\nimport { rgbToCmyk } from '#color/translators';\nimport { ColorParser } from './ColorParserContext';\nexport class CMYKParser extends ColorParser {\n    _extract(input) {\n        const match = input.match(COLORREGS.CMYK);\n        return match.groups;\n    }\n    _shouldMultiplyBy100(...colors) {\n        return !colors.some((color) => +color > 1);\n    }\n    supports(input) {\n        if (isString(input)) {\n            return COLORREGS.CMYK.test(input);\n        }\n        return isCMYKObject(input);\n    }\n    parse(input) {\n        if (isString(input)) {\n            const groups = this._extract(input);\n            const c = groups.c_legacy ?? groups.c;\n            const m = groups.m_legacy ?? groups.m;\n            const y = groups.y_legacy ?? groups.y;\n            const k = groups.k_legacy ?? groups.k;\n            const a = groups.a_legacy ?? groups.a;\n            const shouldMultiplyBy100 = this._shouldMultiplyBy100(c, m, y, k);\n            return {\n                C: getCMYKNumber(c, shouldMultiplyBy100),\n                M: getCMYKNumber(m, shouldMultiplyBy100),\n                Y: getCMYKNumber(y, shouldMultiplyBy100),\n                K: getCMYKNumber(k, shouldMultiplyBy100),\n                ...(isUndefined(a)\n                    ? {}\n                    : {\n                        A: normalizeAlpha(a)\n                    })\n            };\n        }\n        const shouldMultiplyBy100 = this._shouldMultiplyBy100(input.C, input.M, input.Y, input.K);\n        return {\n            C: getCMYKNumber(`${input.C}`, shouldMultiplyBy100),\n            M: getCMYKNumber(`${input.M}`, shouldMultiplyBy100),\n            Y: getCMYKNumber(`${input.Y}`, shouldMultiplyBy100),\n            K: getCMYKNumber(`${input.K}`, shouldMultiplyBy100),\n            ...(isUndefined(input.A)\n                ? {}\n                : {\n                    A: normalizeAlpha(input.A)\n                })\n        };\n    }\n    convert(color, decimals, withAlpha) {\n        let cmyk;\n        if (isCMYKObject(color)) {\n            cmyk = color;\n        }\n        else {\n            const rgb = getRGB(color);\n            cmyk = rgbToCmyk(rgb.R, rgb.G, rgb.B);\n        }\n        return this._roundCMYKObject({\n            C: cmyk.C,\n            M: cmyk.M,\n            Y: cmyk.Y,\n            K: cmyk.K,\n            ...(withAlpha\n                ? {\n                    A: +(color.A ?? 1)\n                }\n                : {})\n        }, decimals);\n    }\n    convertCSS(color, options, withAlpha) {\n        const { decimals, legacyCSS, spacesAfterCommas, cmykUnit, cmykFunction } = options;\n        const comma = getCSSComma(spacesAfterCommas);\n        const cmyk = this.convert(color, options.decimals, withAlpha);\n        const transformer = (value, index) => {\n            if (cmykUnit === ColorUnitEnum.PERCENT &&\n                index < 4) {\n                return `${round(value, decimals)}%`;\n            }\n            return index === 4\n                ? getCSSAlpha(value, options)\n                : round(value / 100, decimals);\n        };\n        const values = prepareColorForCss(cmyk, transformer);\n        const template = legacyCSS\n            ? (values.length === 5\n                ? `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4}${comma}{5})`\n                : `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4})`)\n            : (values.length === 5\n                ? `${cmykFunction}({1} {2} {3} {4} / {5})`\n                : `${cmykFunction}({1} {2} {3} {4})`);\n        return getResultFromCSSTemplate(template, values);\n    }\n    _roundCMYKObject(color, decimals) {\n        return {\n            C: round(color.C, decimals),\n            M: round(color.M, decimals),\n            Y: round(color.Y, decimals),\n            K: round(color.K, decimals),\n            ...(isUndefined(color.A)\n                ? {}\n                : {\n                    A: round(color.A, decimals)\n                })\n        };\n    }\n    getCSSOptions(input) {\n        const groups = this._extract(input);\n        const { c_legacy, m_legacy, y_legacy, k_legacy, a_legacy, c, m, y, k, a } = groups;\n        return {\n            hasPercentageValues: (PCENT.test(c_legacy ?? c) &&\n                PCENT.test(m_legacy ?? m) &&\n                PCENT.test(y_legacy ?? y) &&\n                PCENT.test(k_legacy ?? k)),\n            hasPercentageAlpha: PCENT.test(a_legacy ?? a),\n            hasAlpha: !isUndefined(a_legacy ?? a)\n        };\n    }\n    get model() {\n        return ColorModel.CMYK;\n    }\n}\n","import { AnglesUnitEnum, CMYKFunctionEnum, ColorUnitEnum } from '@types';\nimport { ColorModel, COMMAS_AND_NEXT_CHARS, DEFAULT_OPTIONS, SPACES } from '#constants';\nimport { isBoolean, isNumber, isString } from '#utilities';\nimport { ColorParserContext } from '#classes/ColorParserContext';\nimport { HEXParser } from '#classes/HEXParser';\nimport { RGBParser } from '#classes/RGBParser';\nimport { HSLParser } from '#classes/HSLParser';\nimport { HWBParser } from '#classes/HWBParser';\nimport { CIELabParser } from '#classes/CIELabParser';\nimport { LCHParser } from '#classes/LCHParser';\nimport { CMYKParser } from '#classes/CMYKParser';\nexport const hexParser = new HEXParser();\nexport const rgbParser = new RGBParser();\nexport const hslParser = new HSLParser();\nexport const hwbParser = new HWBParser();\nexport const cieLabParser = new CIELabParser();\nexport const lchParser = new LCHParser();\nexport const cmykParser = new CMYKParser();\nexport const colorParserContext = new ColorParserContext({\n    [ColorModel.HEX]: hexParser,\n    [ColorModel.RGB]: rgbParser,\n    [ColorModel.HSL]: hslParser,\n    [ColorModel.HWB]: hwbParser,\n    [ColorModel.CIELab]: cieLabParser,\n    [ColorModel.LCH]: lchParser,\n    [ColorModel.CMYK]: cmykParser\n});\nexport const getOptionsFromColorInput = (options, ...colors) => {\n    const cssColors = [];\n    const anglesUnits = [];\n    const rgbColors = [];\n    const labColors = [];\n    const lchColors = [];\n    const cmykColors = [];\n    const alphaValues = [];\n    const anglesUnitValues = Object.values(AnglesUnitEnum);\n    const colorUnitValues = Object.values(ColorUnitEnum);\n    const cmykFunctionValues = Object.values(CMYKFunctionEnum);\n    const matchOptions = {\n        legacyCSS: 0,\n        spacesAfterCommas: 0,\n        cmykFunction: 0\n    };\n    for (const color of colors) {\n        if (isString(color)) {\n            cssColors.push(color);\n            if (color.includes(',')) {\n                matchOptions.legacyCSS++;\n                const commasWithNextCharacter = color.match(COMMAS_AND_NEXT_CHARS);\n                if (new Set(commasWithNextCharacter).size === 1 &&\n                    SPACES.test(commasWithNextCharacter[0].slice(1))) {\n                    matchOptions.spacesAfterCommas++;\n                }\n            }\n            if (hslParser.supports(color)) {\n                const options = hslParser.getCSSOptions(color);\n                anglesUnits.push(options.angleUnit);\n                alphaValues.push(options.hasPercentageAlpha);\n                continue;\n            }\n            if (hwbParser.supports(color)) {\n                const options = hwbParser.getCSSOptions(color);\n                anglesUnits.push(options.angleUnit);\n                alphaValues.push(options.hasPercentageAlpha);\n                continue;\n            }\n            if (rgbParser.supports(color)) {\n                const options = rgbParser.getCSSOptions(color);\n                rgbColors.push(options.hasPercentageValues);\n                alphaValues.push(options.hasPercentageAlpha);\n                continue;\n            }\n            if (cieLabParser.supports(color)) {\n                const options = cieLabParser.getCSSOptions(color);\n                labColors.push(options.hasPercentageValues);\n                alphaValues.push(options.hasPercentageAlpha);\n                continue;\n            }\n            if (lchParser.supports(color)) {\n                const options = lchParser.getCSSOptions(color);\n                anglesUnits.push(options.angleUnit);\n                lchColors.push(options.hasPercentageValues);\n                alphaValues.push(options.hasPercentageAlpha);\n                continue;\n            }\n            if (cmykParser.supports(color)) {\n                const options = cmykParser.getCSSOptions(color);\n                cmykColors.push(options.hasPercentageValues);\n                if (color.startsWith('cmyk')) {\n                    matchOptions.cmykFunction++;\n                }\n                alphaValues.push(options.hasPercentageAlpha);\n            }\n        }\n    }\n    return {\n        decimals: isNumber(options.decimals)\n            ? options.decimals\n            : DEFAULT_OPTIONS.decimals,\n        legacyCSS: isBoolean(options.legacyCSS)\n            ? options.legacyCSS\n            : Boolean(cssColors.length &&\n                matchOptions.legacyCSS === cssColors.length) || DEFAULT_OPTIONS.legacyCSS,\n        spacesAfterCommas: isBoolean(options.spacesAfterCommas)\n            ? options.spacesAfterCommas\n            : Boolean(cssColors.length &&\n                matchOptions.spacesAfterCommas === cssColors.length) || DEFAULT_OPTIONS.spacesAfterCommas,\n        anglesUnit: options.anglesUnit && anglesUnitValues.includes(options.anglesUnit)\n            ? options.anglesUnit\n            : (new Set(anglesUnits).size === 1\n                ? anglesUnits[0]\n                : DEFAULT_OPTIONS.anglesUnit),\n        rgbUnit: options.rgbUnit && colorUnitValues.includes(options.rgbUnit)\n            ? options.rgbUnit\n            : (new Set(rgbColors).size === 1 && rgbColors[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.rgbUnit),\n        labUnit: options.labUnit && colorUnitValues.includes(options.labUnit)\n            ? options.labUnit\n            : (new Set(labColors).size === 1 && labColors[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.labUnit),\n        lchUnit: options.lchUnit && colorUnitValues.includes(options.lchUnit)\n            ? options.lchUnit\n            : (new Set(lchColors).size === 1 && lchColors[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.lchUnit),\n        cmykUnit: options.cmykUnit && colorUnitValues.includes(options.cmykUnit)\n            ? options.cmykUnit\n            : (new Set(cmykColors).size === 1 && !cmykColors[0]\n                ? ColorUnitEnum.NONE\n                : DEFAULT_OPTIONS.cmykUnit),\n        alphaUnit: options.alphaUnit && colorUnitValues.includes(options.alphaUnit)\n            ? options.alphaUnit\n            : (new Set(alphaValues).size === 1 && alphaValues[0]\n                ? ColorUnitEnum.PERCENT\n                : DEFAULT_OPTIONS.alphaUnit),\n        cmykFunction: options.cmykFunction && cmykFunctionValues.includes(options.cmykFunction)\n            ? options.cmykFunction\n            : (cmykColors.length && cmykColors.length === matchOptions.cmykFunction\n                ? CMYKFunctionEnum.CMYK\n                : DEFAULT_OPTIONS.cmykFunction)\n    };\n};\n","import { BASE_255, ColorModel, DEFAULT_BLEND_STEPS, DEFAULT_SHADES_TINTS_STEPS, Harmony, Mix } from '#constants';\nimport { isHarmony, isNumber, isString, isMix, isUndefined, normalizeAlpha, normalizeHue, round } from '#utilities';\nimport { hueRyb, rgbToRyb, rybToRgb } from '#color/translators';\nimport { getRGB } from '#color/rgb';\nimport { colorParserContext, getOptionsFromColorInput } from '#parsers';\nconst blend = (from, to, steps) => {\n    const div = steps - 1;\n    const diffR = (to.R - from.R) / div;\n    const diffG = (to.G - from.G) / div;\n    const diffB = (to.B - from.B) / div;\n    const fromA = normalizeAlpha(from.A);\n    const toA = normalizeAlpha(to.A);\n    const diffA = (toA - fromA) / div;\n    return Array(steps).fill(null).map((__n, i) => {\n        if (i === 0) {\n            return from;\n        }\n        if (i === div) {\n            return to;\n        }\n        return {\n            R: round(from.R + diffR * i),\n            G: round(from.G + diffG * i),\n            B: round(from.B + diffB * i),\n            A: round(fromA + diffA * i)\n        };\n    });\n};\nexport function getBlendReturn(from, to, model, css, withAlpha, steps = DEFAULT_BLEND_STEPS, options = {}) {\n    if (steps < 1)\n        steps = DEFAULT_BLEND_STEPS;\n    const fromParsed = colorParserContext.parse(from);\n    const toParsed = colorParserContext.parse(to);\n    const fromRGBObject = getRGB(fromParsed);\n    const toRGBObject = getRGB(toParsed);\n    const blendArray = blend(fromRGBObject, toRGBObject, steps);\n    return blendArray.map((color) => {\n        if (css) {\n            return colorParserContext.convertCSS(color, model, getOptionsFromColorInput(options, from, to), withAlpha);\n        }\n        return colorParserContext.convert(color, model, options.decimals, withAlpha);\n    });\n}\nexport const getBlendReturnParams = (thirdParameter, fourthParameter) => {\n    const stepsParameter = isNumber(thirdParameter)\n        ? thirdParameter\n        : undefined;\n    const optionsParameter = isNumber(thirdParameter)\n        ? fourthParameter\n        : thirdParameter;\n    return [\n        stepsParameter,\n        optionsParameter\n    ];\n};\nexport function getMixReturn(colors, model, css, withAlpha, mode = Mix.ADDITIVE, options = {}) {\n    const rgbMap = colors.map((color) => {\n        return colorParserContext.convert(color, ColorModel.RGB, options.decimals, withAlpha);\n    });\n    const rybMap = mode === Mix.SUBTRACTIVE\n        ? rgbMap.map((color) => {\n            const RYB = rgbToRyb(color.R, color.G, color.B);\n            if (!isUndefined(color.A)) {\n                RYB.A = color.A;\n            }\n            return RYB;\n        })\n        : null;\n    function createMix(items) {\n        const initial = mode === Mix.ADDITIVE\n            ? { R: 0, G: 0, B: 0, A: 0 }\n            : { R: 0, Y: 0, B: 0, A: 0 };\n        return items.reduce((mix, color) => {\n            const colorA = isUndefined(color.A)\n                ? 1\n                : color.A;\n            const common = {\n                R: Math.min(mix.R + color.R * colorA, BASE_255),\n                B: Math.min(mix.B + color.B * colorA, BASE_255),\n                A: 1 - (1 - colorA) * (1 - mix.A)\n            };\n            const mixGY = 'G' in mix\n                ? mix.G\n                : mix.Y;\n            const colorGY = 'G' in color\n                ? color.G\n                : color.Y;\n            return {\n                ...common,\n                ...(mode === Mix.ADDITIVE\n                    ? { G: Math.min(mixGY + colorGY * colorA, BASE_255) }\n                    : { Y: Math.min(mixGY + colorGY * colorA, BASE_255) })\n            };\n        }, initial);\n    }\n    let mix;\n    if (mode === Mix.ADDITIVE) {\n        mix = createMix(rgbMap);\n    }\n    else {\n        const RYB = createMix(rybMap);\n        mix = rybToRgb(RYB.R, RYB.Y, RYB.B);\n        mix.A = RYB.A;\n    }\n    if (css) {\n        return colorParserContext.convertCSS(mix, model, getOptionsFromColorInput(options, ...colors), withAlpha);\n    }\n    return colorParserContext.convert(mix, model, options.decimals, withAlpha);\n}\n;\nexport const getMixReturnParameters = (secondParameter, thirdParameter) => {\n    const modeParam = isString(secondParameter)\n        ? secondParameter\n        : undefined;\n    const optionsParam = isString(secondParameter)\n        ? thirdParameter\n        : secondParameter;\n    return [\n        modeParam,\n        optionsParam\n    ];\n};\nexport function getShadesOrTintsReturn(shades, color, steps = DEFAULT_SHADES_TINTS_STEPS, options = {}) {\n    const isCSS = isString(color);\n    const parser = colorParserContext.getParser(color);\n    const model = parser.model;\n    const withAlpha = parser.hasAlpha(color);\n    const hsl = colorParserContext.convert(color, ColorModel.HSL, undefined, withAlpha);\n    const increment = shades\n        ? hsl.L / (steps + 1)\n        : (100 - hsl.L) / (steps + 1);\n    const hslMap = Array.from(Array(steps)).map((__n, i) => ({\n        ...hsl,\n        L: hsl.L + increment * (i + 1) * (1 - +shades * 2)\n    }));\n    if (isCSS) {\n        return hslMap.map((hslColor) => {\n            return colorParserContext.convertCSS(hslColor, model, getOptionsFromColorInput(options, color), withAlpha);\n        });\n    }\n    return hslMap.map((hslColor) => {\n        return colorParserContext.convert(hslColor, model, options.decimals, withAlpha);\n    });\n}\nexport const getShadesOrTintsReturnParameters = (secondParameter, thirdParameter) => {\n    const stepsParam = isNumber(secondParameter)\n        ? secondParameter\n        : undefined;\n    const optionsParam = isNumber(secondParameter)\n        ? thirdParameter\n        : secondParameter;\n    return [\n        stepsParam,\n        optionsParam\n    ];\n};\nconst harmony = (color, angles, mode) => angles.reduce((arr, num) => {\n    return [\n        ...arr,\n        {\n            ...color,\n            H: mode === Mix.ADDITIVE\n                ? normalizeHue(color.H + num)\n                : normalizeHue(hueRyb(hueRyb(color.H, false) + num, true))\n        }\n    ];\n}, [{ ...color }]);\nconst HARMONIES = new Map([\n    [\n        Harmony.ANALOGOUS,\n        (color, mode) => harmony(color, [30, -30], mode)\n    ],\n    [\n        Harmony.COMPLEMENTARY,\n        (color, mode) => harmony(color, [180], mode)\n    ],\n    [\n        Harmony.SPLIT_COMPLEMENTARY,\n        (color, mode) => harmony(color, [150, -150], mode)\n    ],\n    [\n        Harmony.TRIADIC,\n        (color, mode) => harmony(color, [120, -120], mode)\n    ],\n    [\n        Harmony.TETRADIC,\n        (color, mode) => harmony(color, [60, -120, 180], mode)\n    ],\n    [\n        Harmony.SQUARE,\n        (color, mode) => harmony(color, [90, -90, 180], mode)\n    ]\n]);\nexport const getHarmonyReturn = (color, harmony, mode, options = {}) => {\n    const harmonyFunction = HARMONIES.get(harmony);\n    const isCSS = isString(color);\n    const parser = colorParserContext.getParser(color);\n    const model = parser.model;\n    const withAlpha = parser.hasAlpha(color);\n    const hsl = colorParserContext.convert(color, ColorModel.HSL);\n    const array = harmonyFunction(hsl, mode);\n    if (isCSS) {\n        return array.map((harmonyColor) => {\n            return colorParserContext.convertCSS(harmonyColor, model, getOptionsFromColorInput(options, color), withAlpha);\n        });\n    }\n    return array.map((harmonyColor) => {\n        return colorParserContext.convert(harmonyColor, model, options.decimals, withAlpha);\n    });\n};\nexport const getHarmonyReturnParameters = (secondParam, thirdParam, fourthParam) => {\n    if (isHarmony(secondParam)) {\n        return [\n            secondParam,\n            isMix(thirdParam)\n                ? thirdParam\n                : Mix.ADDITIVE,\n            isMix(thirdParam)\n                ? fourthParam\n                : thirdParam\n        ];\n    }\n    if (isMix(secondParam)) {\n        return [\n            Harmony.COMPLEMENTARY,\n            secondParam,\n            thirdParam\n        ];\n    }\n    return [\n        Harmony.COMPLEMENTARY,\n        Mix.ADDITIVE,\n        secondParam\n    ];\n};\n","import { BASE_255, ColorModel, MAX_ALPHA, MAX_LAB, MAX_LCH_C, MAX_PCENT, Mix } from '#constants';\nimport { cmykToRgb, hslToRgb, hwbToRgb, labToLch, labToRgb, lchToLab, lchToRgb, rgbToCmyk, rgbToHsl, rgbToHwb, rgbToLab, rgbToLch } from '#color/translators';\nimport { getColorModel, minmax, normalizeHue, round } from '#utilities';\nimport { colorParserContext, getOptionsFromColorInput } from '#parsers';\nimport { getBlendReturn, getBlendReturnParams, getMixReturn, getMixReturnParameters, getShadesOrTintsReturn, getShadesOrTintsReturnParameters, getHarmonyReturn, getHarmonyReturnParameters } from '#returns';\nexport class ColorTranslator {\n    constructor(color, options = {}) {\n        this._options = getOptionsFromColorInput(options, color);\n        const parsedColor = colorParserContext.parse(color);\n        const model = getColorModel(parsedColor);\n        switch (model) {\n            case ColorModel.HSL:\n                this.hsl = parsedColor;\n                this.update('hsl');\n                break;\n            case ColorModel.HWB:\n                this.hwb = parsedColor;\n                this.updateRGBFromHWB();\n                this.update('hwb', 'rgb');\n                break;\n            case ColorModel.CIELab:\n                this.lab = parsedColor;\n                this.updateRGBFromLAB();\n                this.update('lab', 'rgb');\n                break;\n            case ColorModel.LCH:\n                this.lch = parsedColor;\n                this.updateRGBFromLCH();\n                this.update('lch', 'rgb');\n                break;\n            case ColorModel.CMYK:\n                this.cmyk = parsedColor;\n                this.updateRGBFromCMYK();\n                this.update('cmyk', 'rgb');\n                break;\n            default:\n                this.rgb = parsedColor;\n                this.update('rgb');\n        }\n    }\n    update(...exclude) {\n        if (!exclude.includes('rgb')) {\n            this.updateRGB();\n        }\n        if (!exclude.includes('hsl')) {\n            this.updateHSL();\n        }\n        if (!exclude.includes('hwb')) {\n            this.updateHWB();\n        }\n        if (!exclude.includes('lab')) {\n            this.updateLAB();\n        }\n        if (!exclude.includes('lch')) {\n            this.updateLCH();\n        }\n        if (!exclude.includes('cmyk')) {\n            this.updateCMYK();\n        }\n    }\n    updateRGB() {\n        this.rgb = {\n            ...hslToRgb(this.hsl.H, this.hsl.S, this.hsl.L),\n            A: this.hsl.A ?? 1\n        };\n    }\n    updateHSL() {\n        this.hsl = rgbToHsl(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n    }\n    updateHWB() {\n        this.hwb = rgbToHwb(this.rgb.R, this.rgb.G, this.rgb.B, this.rgb.A);\n    }\n    updateLAB() {\n        this.lab = {\n            ...rgbToLab(this.rgb.R, this.rgb.G, this.rgb.B),\n            A: this.rgb.A ?? 1\n        };\n    }\n    updateLCH() {\n        this.lch = {\n            ...rgbToLch(this.rgb.R, this.rgb.G, this.rgb.B),\n            A: this.rgb.A ?? 1\n        };\n    }\n    updateCMYK() {\n        this.cmyk = {\n            ...rgbToCmyk(this.rgb.R, this.rgb.G, this.rgb.B),\n            A: this.rgb.A ?? 1\n        };\n    }\n    updateRGBFromHWB() {\n        this.rgb = {\n            ...hwbToRgb(this.hwb.H, this.hwb.W, this.hwb.B),\n            A: this.hwb?.A ?? 1\n        };\n    }\n    updateRGBFromLCH() {\n        this.rgb = {\n            ...lchToRgb(this.lch.L, this.lch.C, this.lch.H),\n            A: this.lch.A ?? 1\n        };\n    }\n    updateRGBFromCMYK() {\n        this.rgb = {\n            ...cmykToRgb(this.cmyk.C, this.cmyk.M, this.cmyk.Y, this.cmyk.K),\n            A: this.cmyk.A ?? 1\n        };\n    }\n    updateRGBFromLAB() {\n        this.rgb = {\n            ...labToRgb(this.lab.L, this.lab.a, this.lab.b),\n            A: this.lab.A ?? 1\n        };\n    }\n    updateLCHFromLAB() {\n        this.lch = {\n            ...labToLch(this.lab.L, this.lab.a, this.lab.b),\n            A: this.lab.A\n        };\n    }\n    updateLABromLCH() {\n        this.lab = {\n            ...lchToLab(this.lch.L, this.lch.C, this.lch.H),\n            A: this.lch.A\n        };\n    }\n    setOptions(options = {}) {\n        this._options = {\n            ...this._options,\n            ...options\n        };\n        return this;\n    }\n    setR(R) {\n        this.rgb.R = minmax(R, 0, BASE_255);\n        this.update('rgb');\n        return;\n    }\n    setG(G) {\n        this.rgb.G = minmax(G, 0, BASE_255);\n        this.update('rgb');\n        return this;\n    }\n    setB(B) {\n        this.rgb.B = minmax(B, 0, BASE_255);\n        this.update('rgb');\n        return this;\n    }\n    setH(H) {\n        this.hsl.H = normalizeHue(H);\n        this.update('hsl');\n        return this;\n    }\n    setS(S) {\n        this.hsl.S = minmax(S, 0, MAX_PCENT);\n        this.update('hsl');\n        return this;\n    }\n    setL(L) {\n        this.hsl.L = minmax(L, 0, MAX_PCENT);\n        this.update('hsl');\n        return this;\n    }\n    setWhiteness(W) {\n        this.hwb.W = minmax(W, 0, MAX_PCENT);\n        this.updateRGBFromHWB();\n        this.update('rgb', 'hwb');\n        return this;\n    }\n    setBlackness(B) {\n        this.hwb.B = minmax(B, 0, MAX_PCENT);\n        this.updateRGBFromHWB();\n        this.update('rgb', 'hwb');\n        return this;\n    }\n    setCIEL(L) {\n        this.lab.L = minmax(L, 0, MAX_PCENT);\n        this.updateRGBFromLAB();\n        this.updateLCHFromLAB();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setCIEa(a) {\n        this.lab.a = minmax(a, -MAX_LAB, MAX_LAB);\n        this.updateRGBFromLAB();\n        this.updateLCHFromLAB();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setCIEb(b) {\n        this.lab.b = minmax(b, -MAX_LAB, MAX_LAB);\n        this.updateRGBFromLAB();\n        this.updateLCHFromLAB();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setLCHL(l) {\n        this.lch.L = minmax(l, 0, MAX_PCENT);\n        this.updateRGBFromLCH();\n        this.updateLABromLCH();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setLCHC(c) {\n        this.lch.C = minmax(c, 0, MAX_LCH_C);\n        this.updateRGBFromLCH();\n        this.updateLABromLCH();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setLCHH(h) {\n        this.lch.H = normalizeHue(h);\n        this.updateRGBFromLCH();\n        this.updateLABromLCH();\n        this.update('rgb', 'lab', 'lch');\n        return this;\n    }\n    setA(A) {\n        const alpha = minmax(A, 0, MAX_ALPHA);\n        this.rgb.A = alpha;\n        this.hsl.A = alpha;\n        this.hwb.A = alpha;\n        this.lab.A = alpha;\n        this.lch.A = alpha;\n        this.cmyk.A = alpha;\n        return this;\n    }\n    setC(C) {\n        this.cmyk.C = minmax(C, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    setM(M) {\n        this.cmyk.M = minmax(M, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    setY(Y) {\n        this.cmyk.Y = minmax(Y, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    setK(K) {\n        this.cmyk.K = minmax(K, 0, 100);\n        this.updateRGBFromCMYK();\n        this.update('cmyk');\n        return this;\n    }\n    get options() {\n        return this._options;\n    }\n    get R() {\n        return round(this.rgb.R, this.options.decimals);\n    }\n    get G() {\n        return round(this.rgb.G, this.options.decimals);\n    }\n    get B() {\n        return round(this.rgb.B, this.options.decimals);\n    }\n    get H() {\n        return round(this.hsl.H, this.options.decimals);\n    }\n    get S() {\n        return round(this.hsl.S, this.options.decimals);\n    }\n    get L() {\n        return round(this.hsl.L, this.options.decimals);\n    }\n    get Whiteness() {\n        return round(this.hwb.W, this.options.decimals);\n    }\n    get Blackness() {\n        return round(this.hwb.B, this.options.decimals);\n    }\n    get CIEL() {\n        return round(this.lab.L, this.options.decimals);\n    }\n    get CIEa() {\n        return round(this.lab.a, this.options.decimals);\n    }\n    get CIEb() {\n        return round(this.lab.b, this.options.decimals);\n    }\n    get LCHL() {\n        return round(this.lch.L, this.options.decimals);\n    }\n    get LCHC() {\n        return round(this.lch.C, this.options.decimals);\n    }\n    get LCHH() {\n        return round(this.lch.H, this.options.decimals);\n    }\n    get A() {\n        return round(this.hsl.A, this.options.decimals);\n    }\n    get C() {\n        return round(this.cmyk.C, this.options.decimals);\n    }\n    get M() {\n        return round(this.cmyk.M, this.options.decimals);\n    }\n    get Y() {\n        return round(this.cmyk.Y, this.options.decimals);\n    }\n    get K() {\n        return round(this.cmyk.K, this.options.decimals);\n    }\n    get HEXObject() {\n        return colorParserContext.convert(this.rgb, ColorModel.HEX);\n    }\n    get HEXAObject() {\n        return colorParserContext.convert(this.rgb, ColorModel.HEX, 0, true);\n    }\n    get RGBObject() {\n        return colorParserContext.convert(this.rgb, ColorModel.RGB, this.options.decimals);\n    }\n    get RGBAObject() {\n        return colorParserContext.convert(this.rgb, ColorModel.RGB, this.options.decimals, true);\n    }\n    get HSLObject() {\n        return colorParserContext.convert(this.hsl, ColorModel.HSL, this.options.decimals);\n    }\n    get HSLAObject() {\n        return colorParserContext.convert(this.hsl, ColorModel.HSL, this.options.decimals, true);\n    }\n    get HWBObject() {\n        return colorParserContext.convert(this.hwb, ColorModel.HWB, this.options.decimals);\n    }\n    get HWBAObject() {\n        return colorParserContext.convert(this.hwb, ColorModel.HWB, this.options.decimals, true);\n    }\n    get CIELabObject() {\n        return colorParserContext.convert(this.lab, ColorModel.CIELab, this.options.decimals);\n    }\n    get CIELabAObject() {\n        return colorParserContext.convert(this.lab, ColorModel.CIELab, this.options.decimals, true);\n    }\n    get LCHObject() {\n        return colorParserContext.convert(this.lch, ColorModel.LCH, this.options.decimals);\n    }\n    get LCHAObject() {\n        return colorParserContext.convert(this.lch, ColorModel.LCH, this.options.decimals, true);\n    }\n    get CMYKObject() {\n        return colorParserContext.convert(this.cmyk, ColorModel.CMYK, this.options.decimals);\n    }\n    get CMYKAObject() {\n        return colorParserContext.convert(this.cmyk, ColorModel.CMYK, this.options.decimals, true);\n    }\n    get HEX() {\n        return colorParserContext.convertCSS(this.rgb, ColorModel.HEX);\n    }\n    get HEXA() {\n        return colorParserContext.convertCSS(this.rgb, ColorModel.HEX, {}, true);\n    }\n    get RGB() {\n        return colorParserContext.convertCSS(this.rgb, ColorModel.RGB, this.options);\n    }\n    get RGBA() {\n        return colorParserContext.convertCSS(this.rgb, ColorModel.RGB, this.options, true);\n    }\n    get HSL() {\n        return colorParserContext.convertCSS(this.hsl, ColorModel.HSL, this.options);\n    }\n    get HSLA() {\n        return colorParserContext.convertCSS(this.hsl, ColorModel.HSL, this.options, true);\n    }\n    get HWB() {\n        return colorParserContext.convertCSS(this.hwb, ColorModel.HWB, this.options);\n    }\n    get HWBA() {\n        return colorParserContext.convertCSS(this.hwb, ColorModel.HWB, this.options, true);\n    }\n    get CIELab() {\n        return colorParserContext.convertCSS(this.lab, ColorModel.CIELab, this.options);\n    }\n    get CIELabA() {\n        return colorParserContext.convertCSS(this.lab, ColorModel.CIELab, this.options, true);\n    }\n    get LCH() {\n        return colorParserContext.convertCSS(this.lch, ColorModel.LCH, this.options);\n    }\n    get LCHA() {\n        return colorParserContext.convertCSS(this.lch, ColorModel.LCH, this.options, true);\n    }\n    get CMYK() {\n        return colorParserContext.convertCSS(this.cmyk, ColorModel.CMYK, this.options);\n    }\n    get CMYKA() {\n        return colorParserContext.convertCSS(this.cmyk, ColorModel.CMYK, this.options, true);\n    }\n    static toHEXObject(color) {\n        return colorParserContext.convert(color, ColorModel.HEX);\n    }\n    static toHEX(color) {\n        return colorParserContext.convertCSS(color, ColorModel.HEX);\n    }\n    static toHEXAObject(color) {\n        return colorParserContext.convert(color, ColorModel.HEX, undefined, true);\n    }\n    static toHEXA(color) {\n        return colorParserContext.convertCSS(color, ColorModel.HEX, undefined, true);\n    }\n    static toRGBObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.RGB, options.decimals);\n    }\n    static toRGB(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.RGB, getOptionsFromColorInput(options, color));\n    }\n    static toRGBAObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.RGB, options.decimals, true);\n    }\n    static toRGBA(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.RGB, getOptionsFromColorInput(options, color), true);\n    }\n    static toHSLObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.HSL, options.decimals);\n    }\n    static toHSL(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.HSL, getOptionsFromColorInput(options, color));\n    }\n    static toHSLAObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.HSL, options.decimals, true);\n    }\n    static toHSLA(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.HSL, getOptionsFromColorInput(options, color), true);\n    }\n    static toHWBObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.HWB, options.decimals);\n    }\n    static toHWB(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.HWB, getOptionsFromColorInput(options, color));\n    }\n    static toHWBAObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.HWB, options.decimals, true);\n    }\n    static toHWBA(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.HWB, getOptionsFromColorInput(options, color), true);\n    }\n    static toCIELabObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.CIELab, options.decimals);\n    }\n    static toCIELab(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.CIELab, getOptionsFromColorInput(options, color));\n    }\n    static toCIELabAObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.CIELab, options.decimals, true);\n    }\n    static toCIELabA(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.CIELab, getOptionsFromColorInput(options, color), true);\n    }\n    static toLCHObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.LCH, options.decimals);\n    }\n    static toLCH(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.LCH, getOptionsFromColorInput(options, color));\n    }\n    static toLCHAObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.LCH, options.decimals, true);\n    }\n    static toLCHA(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.LCH, getOptionsFromColorInput(options, color), true);\n    }\n    static toCMYKObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.CMYK, options.decimals);\n    }\n    static toCMYK(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.CMYK, getOptionsFromColorInput(options, color));\n    }\n    static toCMYKAObject(color, options = {}) {\n        return colorParserContext.convert(color, ColorModel.CMYK, options.decimals, true);\n    }\n    static toCMYKA(color, options = {}) {\n        return colorParserContext.convertCSS(color, ColorModel.CMYK, getOptionsFromColorInput(options, color), true);\n    }\n    static getBlendHEXObject(from, to, steps) {\n        return getBlendReturn(from, to, ColorModel.HEX, false, false, steps);\n    }\n    static getBlendHEX(from, to, steps) {\n        return getBlendReturn(from, to, ColorModel.HEX, true, false, steps);\n    }\n    static getBlendHEXAObject(from, to, steps) {\n        return getBlendReturn(from, to, ColorModel.HEX, false, true, steps);\n    }\n    static getBlendHEXA(from, to, steps) {\n        return getBlendReturn(from, to, ColorModel.HEX, true, true, steps);\n    }\n    static getBlendRGBObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.RGB, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendRGB(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.RGB, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendRGBAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.RGB, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendRGBA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.RGB, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHSLObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HSL, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHSL(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HSL, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHSLAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HSL, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHSLA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HSL, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHWBObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HWB, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHWB(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HWB, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHWBAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HWB, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendHWBA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.HWB, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendCIELabObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.CIELab, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendCIELab(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.CIELab, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendCIELabAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.CIELab, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendCIELabA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.CIELab, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendLCHObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.LCH, false, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendLCH(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.LCH, true, false, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendLCHAObject(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.LCH, false, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getBlendLCHA(from, to, thirdParameter, fourthParameter) {\n        return getBlendReturn(from, to, ColorModel.LCH, true, true, ...getBlendReturnParams(thirdParameter, fourthParameter));\n    }\n    static getMixHEXObject(colors, mode) {\n        return getMixReturn(colors, ColorModel.HEX, false, false, mode);\n    }\n    static getMixHEX(colors, mode = Mix.ADDITIVE) {\n        return getMixReturn(colors, ColorModel.HEX, true, false, mode);\n    }\n    static getMixHEXAObject(colors, mode = Mix.ADDITIVE) {\n        return getMixReturn(colors, ColorModel.HEX, false, true, mode);\n    }\n    static getMixHEXA(colors, mode = Mix.ADDITIVE) {\n        return getMixReturn(colors, ColorModel.HEX, true, true, mode);\n    }\n    static getMixRGBObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.RGB, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixRGB(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.RGB, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixRGBAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.RGB, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixRGBA(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.RGB, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHSLObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HSL, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHSL(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HSL, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHSLAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HSL, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHSLA(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HSL, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHWBObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HWB, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHWB(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HWB, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHWBAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HWB, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixHWBA(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.HWB, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixCIELabObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.CIELab, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixCIELab(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.CIELab, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixCIELabAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.CIELab, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixCIELabA(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.CIELab, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixLCHObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.LCH, false, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixLCH(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.LCH, true, false, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixLCHAObject(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.LCH, false, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getMixLCHA(colors, secondParameter, thirdParameter) {\n        return getMixReturn(colors, ColorModel.LCH, true, true, ...getMixReturnParameters(secondParameter, thirdParameter));\n    }\n    static getShades(color, secondParameter, thirdParameter) {\n        return getShadesOrTintsReturn(true, color, ...getShadesOrTintsReturnParameters(secondParameter, thirdParameter));\n    }\n    static getTints(color, secondParameter, thirdParameter) {\n        return getShadesOrTintsReturn(false, color, ...getShadesOrTintsReturnParameters(secondParameter, thirdParameter));\n    }\n    static getHarmony(color, secondParam, thirdParam, fourthParam) {\n        return getHarmonyReturn(color, ...getHarmonyReturnParameters(secondParam, thirdParam, fourthParam));\n    }\n}\n","export { Harmony, Mix } from '#constants';\nexport { ColorTranslator } from '#classes/ColorTranslator';\n","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const color = new ColorTranslator('hsl(180 100% 50%)', { decimals: 0 });\n\n    for (let row = 0; row < 10; row++) {\n\n        for (let col = 0; col < 10; col++) {\n\n            color\n                .setS(row * 10)\n                .setL(col * 5 + 30);\n\n            const box = document.createElement('div');\n\n            box.classList.add('box');\n            box.style.background = color.HEX;\n\n            box.innerText =\n                `R:${color.R}\n                 G:${color.G}\n                 B:${color.B}`;\n            container.appendChild(box);\n\n        }\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const color = new ColorTranslator({ R: 255, G: 0, B: 0 });\n    const hue = [0, 30, 60, 120, 240, 280, 320, 0];\n    let rainbow;\n\n    for (let r = 0; r < hue.length; r++) {\n\n        color.setH(hue[r]);\n\n        const bow = document.createElement('div');\n\n        bow.classList.add('rainbow');\n        bow.style.background = color.HEX;\n\n        if (rainbow) {\n            rainbow.appendChild(bow);\n        } else {\n            container.appendChild(bow);\n        }\n\n        rainbow = bow;\n    }\n\n    rainbow.style.background = '#333';\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const hsl = { H: 0, S: '90%', L: '50%' };\n    const hue = [undefined, 55, 30, 0, 290, 220, 130];\n    const total = hue.length;\n\n    for (let row = 0; row < total; row++) {\n\n        for (let col = 0; col < total; col++) {\n\n            let index = total - row + col;\n            if (index >= total) {\n                index -= total;\n            }\n            hsl.H = hue[index];\n            const rgb = hue[index] === undefined\n                ? '#FFF'\n                : ColorTranslator.toHEX(hsl);\n            const box = document.createElement('div');\n\n            box.classList.add('flag');\n            box.style.background = rgb;\n\n            container.appendChild(box);\n\n        }\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const hexColors = [\n        '#FE2712', '#FE5409', '#FB9902',\n        '#FABD03', '#FFFE32', '#D1EA2C',\n        '#66B132', '#0392CE', '#0247FE',\n        '#3D00A5', '#8601B0', '#A7194B'\n    ];\n\n    hexColors.forEach((color) => {\n\n        const rgb = ColorTranslator.toRGB(color);\n        const hsl = ColorTranslator.toHSL(color, { decimals: 0 });\n        const hwb = ColorTranslator.toHWB(color, { decimals: 0 });\n        const lab = ColorTranslator.toCIELab(color, { decimals: 0 });\n        const lch = ColorTranslator.toLCH(color, { decimals: 0 });\n\n        const rgbDiv = document.createElement('div');\n        const hslDiv = document.createElement('div');\n        const hwbDiv = document.createElement('div');\n        const labDiv = document.createElement('div');\n        const lchDiv = document.createElement('div');\n\n        rgbDiv.style.backgroundColor = rgb;\n        rgbDiv.textContent = rgb;\n\n        hslDiv.style.backgroundColor = hsl;\n        hslDiv.textContent = hsl;\n\n        hwbDiv.style.backgroundColor = hwb;\n        hwbDiv.textContent = hwb;\n\n        labDiv.style.backgroundColor = lab;\n        labDiv.textContent = lab;\n\n        lchDiv.style.backgroundColor = lch;\n        lchDiv.textContent = lch;\n\n        container.appendChild(rgbDiv);\n        container.appendChild(hslDiv);\n        container.appendChild(hwbDiv);\n        container.appendChild(labDiv);\n        container.appendChild(lchDiv);\n\n    });\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const colors = [\n        'red',\n        'lime',\n        'blue',\n        'aqua',\n        'yellow',\n        'fuchsia'\n    ];\n    const total = colors.length;\n\n    for (let row = 0; row < total; row++) {\n\n        const hsl = ColorTranslator.toHSLObject(colors[row]);\n        const step = hsl.S / (total - 1);\n\n        for (let col = 0; col < total; col++) {\n\n            const rgb = ColorTranslator.toHEX(hsl);\n            const cmyk = ColorTranslator.toCMYKObject(hsl, { decimals: 0 });\n\n            const box = document.createElement('div');\n            box.classList.add('box');\n            box.style.background = rgb;\n            box.innerText = `C:${cmyk.C}\n                             M:${cmyk.M}\n                             Y:${cmyk.Y}\n                             K:${cmyk.K}`;\n\n            container.appendChild(box);\n\n            hsl.S -= step;\n\n        }\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n    const rows = 11;\n    const mult = 3;\n\n    for (let i = 0; i < rows; i++) {\n\n        const blends = ColorTranslator.getBlendHEX('#F00', '#FF0', mult + i * mult);\n\n        blends.forEach((blend, index) => {\n            const box = document.createElement('div');\n            box.classList.add('box', `file${i}`);\n            box.style.background = blend;\n            box.innerText = index + 1;\n            container.appendChild(box);\n        });\n\n    }\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n\n    const colors = ['#F00', '#FF8000', '#FF0', '#0F0', '#00F', '#A0F', '#F0A'];\n\n    const createBox = (color, type) => {\n        const box = document.createElement('div');\n        box.classList.add('box');\n        box.style.backgroundColor = color;\n        if (type) box.dataset.type = type;\n        container.appendChild(box);\n    };\n\n    colors.forEach((color) => {\n        const shades = ColorTranslator.getShades(color, 3).reverse();\n        const tints = ColorTranslator.getTints(color, 3);\n        shades.forEach((shade) => createBox(shade, 'shade'));\n        createBox(color);\n        tints.forEach((tint) => createBox(tint, 'tint'));\n    });\n\n    return container;\n\n};","import './styles.scss';\n\n\nexport default (ColorTranslator) => {\n\n    const container = document.createElement('div');\n\n    const mixes = [\n        '#F00',\n        '#0F0',\n        '#00F',\n        [1, 3],\n        [1, 2],\n        [2, 3],\n        [1, 2, 3]\n    ];\n\n    const fillPlanes = () => {\n        const planes = container.querySelectorAll('#planes path');\n        planes.forEach((plane, index) => {\n            let color = '#CCC';\n            if (typeof mixes[index] === 'string') {\n                color = mixes[index];\n            } else if(mixes[index]) {\n                const colors = mixes[index].map((i) => mixes[i - 1]);\n                color = mixes[index] = ColorTranslator.getMixHEX(colors);\n            }\n            plane.setAttribute('fill', color);\n        });\n    };\n\n    fetch('images/color-mixes.svg')\n        .then(result => result.text())\n        .then((svgCode) => {\n            container.innerHTML = svgCode;\n            fillPlanes();\n        });\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator, { Mix }) => {\n\n    const container = document.createElement('div');\n\n    const mixes = [\n        '#F00',\n        '#FF0',\n        '#00F',\n        [1, 3],\n        [1, 2],\n        [2, 3],\n        [1, 2, 3]\n    ];\n\n    const fillPlanes = () => {\n        const planes = container.querySelectorAll('#planes path');\n        planes.forEach((plane, index) => {\n            let color = '#CCC';\n            if (typeof mixes[index] === 'string') {\n                color = mixes[index];\n            } else if(mixes[index]) {\n                const colors = mixes[index].map((i) => mixes[i - 1]);\n                color = mixes[index] = ColorTranslator.getMixHEX(colors, Mix.SUBTRACTIVE);\n            }\n            plane.setAttribute('fill', color);\n        });\n    };\n\n    fetch('images/color-mixes.svg')\n        .then(result => result.text())\n        .then((svgCode) => {\n            container.innerHTML = svgCode;\n            fillPlanes();\n        });\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator, { Harmony }) => {\n\n    const container = document.createElement('div');\n\n    const harmonies = [\n        { label: 'Complementary',       value: Harmony.COMPLEMENTARY },\n        { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n        { label: 'Analogous',           value: Harmony.ANALOGOUS },\n        { label: 'Triadic',             value: Harmony.TRIADIC },\n        { label: 'Tetradic',            value: Harmony.TETRADIC },\n        { label: 'Square',              value: Harmony.SQUARE }\n    ];\n\n    const baseColor = '#F00';\n\n    const createElement = (className, parent) => {\n        const div = document.createElement('div');\n        div.classList.add(className);\n        parent.appendChild(div);\n        return div;\n    };\n\n    const createHarmony = (item) => {\n\n        const wrapper = createElement('wrapper', container);\n        const wheel = createElement('wheel', wrapper);\n        const harmony = createElement('harmony', wrapper);\n        createElement('label', wrapper).innerText = item.label;\n\n        fetch('images/wheel-additive.svg')\n            .then(result => result.text())\n            .then((svgCode) => {\n                const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value);\n                const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n                wheel.innerHTML = svgCode;\n                harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n                wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n            });\n\n    };\n\n    harmonies.forEach((item) => createHarmony(item));\n\n    return container;\n\n};","import './styles.scss';\n\nexport default (ColorTranslator, { Harmony, Mix }) => {\n\n    const container = document.createElement('div');\n\n    const harmonies = [\n        { label: 'Complementary',       value: Harmony.COMPLEMENTARY },\n        { label: 'Split Complementary', value: Harmony.SPLIT_COMPLEMENTARY },\n        { label: 'Analogous',           value: Harmony.ANALOGOUS },\n        { label: 'Triadic',             value: Harmony.TRIADIC },\n        { label: 'Tetradic',            value: Harmony.TETRADIC },\n        { label: 'Square',              value: Harmony.SQUARE }\n    ];\n\n    const baseColor = '#F00';\n\n    const createElement = (className, parent) => {\n        const div = document.createElement('div');\n        div.classList.add(className);\n        parent.appendChild(div);\n        return div;\n    };\n\n    const createHarmony = (item) => {\n\n        const wrapper = createElement('wrapper', container);\n        const wheel = createElement('wheel', wrapper);\n        const harmony = createElement('harmony', wrapper);\n        createElement('label', wrapper).innerText = item.label;\n\n        fetch('images/wheel-subtractive.svg')\n            .then(result => result.text())\n            .then((svgCode) => {\n                const harmonyColors = ColorTranslator.getHarmony(baseColor, item.value, Mix.SUBTRACTIVE);\n                const selector = 'path' + harmonyColors.map((color) => `:not([fill=\"${color}\"])`).join('');\n                wheel.innerHTML = svgCode;\n                harmonyColors.forEach((hex) => createElement('box', harmony).style.background = hex);\n                wheel.querySelectorAll(selector).forEach((path) => path.setAttribute('fill-opacity', '0.25'));\n            });\n\n    };\n\n    harmonies.forEach((item) => createHarmony(item));\n\n    return container;\n\n};","import '../../node_modules/google-code-prettify/bin/run_prettify.min';\nimport '../../node_modules/google-code-prettify/bin/prettify.min.css';\nimport '../../node_modules/google-code-prettify/styles/desert.css';\nimport 'whatwg-fetch';\nimport './styles.scss';\nimport { ColorTranslator, Harmony, Mix } from '../';\nimport demo1 from './demo1';\nimport demo2 from './demo2';\nimport demo3 from './demo3';\nimport demo4 from './demo4';\nimport demo5 from './demo5';\nimport demo6 from './demo6';\nimport demo7 from './demo7';\nimport demo8 from './demo8';\nimport demo9 from './demo9';\nimport demo10 from './demo10';\nimport demo11 from './demo11';\n\nconst functioToString = (fn) => {\n    const article = document.createElement('article');\n    const pre = document.createElement('pre');\n    article.classList.add('function-container');\n    pre.classList.add('prettyprint');\n    article.appendChild(pre);\n    pre.innerHTML = fn.toString().replace('(ColorTranslator)', '()');\n    return article;\n};\n\nconst demos = new Map([\n    ['demo1', demo1],\n    ['demo2', demo2],\n    ['demo3', demo3],\n    ['demo4', demo4],\n    ['demo5', demo5],\n    ['demo6', demo6],\n    ['demo7', demo7],\n    ['demo8', demo8],\n    ['demo9', demo9],\n    ['demo10', demo10],\n    ['demo11', demo11]\n]);\n\ndocument.addEventListener('DOMContentLoaded', () => {\n    demos.forEach((module, div) => {\n        const demo = document.getElementById(div);\n        const container = document.createElement('div');\n        const wrapper = document.createElement('div');\n\n        container.classList.add('demo-container');\n        wrapper.classList.add('demo-wrapper');\n\n        wrapper.appendChild(module(ColorTranslator, { Harmony, Mix }));\n        container.appendChild(wrapper);\n        demo.appendChild(container);\n        demo.appendChild(functioToString(module));\n    });\n});"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///117\n\n}")}},__webpack_module_cache__={};function __webpack_require__(I){var g=__webpack_module_cache__[I];if(void 0!==g)return g.exports;var C=__webpack_module_cache__[I]={exports:{}};return __webpack_modules__[I](C,C.exports,__webpack_require__),C.exports}__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(I){if("object"==typeof window)return window}}();var __webpack_exports__=__webpack_require__(117),__webpack_export_target__=window;for(var __webpack_i__ in __webpack_exports__)__webpack_export_target__[__webpack_i__]=__webpack_exports__[__webpack_i__];__webpack_exports__.__esModule&&Object.defineProperty(__webpack_export_target__,"__esModule",{value:!0})})(); \ No newline at end of file diff --git a/package.json b/package.json index 144f0c3..61ed953 100644 --- a/package.json +++ b/package.json @@ -26,6 +26,7 @@ "scripts": { "test:ts": "tsc --noEmit", "test": "jest --verbose", + "test:tag": "jest -t @testing", "lint": "eslint \"src/**/*.{js,ts}\" \"tests/**/*.ts\"", "clean": "./scripts/clean.sh", "finish": "./scripts/finish.sh", diff --git a/src/@types/index.ts b/src/@types/index.ts index 8765277..3802cc3 100644 --- a/src/@types/index.ts +++ b/src/@types/index.ts @@ -104,6 +104,15 @@ export interface RYBObject { export type RGYBObject = RGBObject | RYBObject; +export type ColorObject = + | HEXObject + | RGBObject + | HSLObject + | HWBObject + | CIELabObject + | LCHObject + | CMYKObject; + export type Color = | RGBObjectGeneric | HSLObjectGeneric @@ -302,4 +311,6 @@ export type MatchOptions = { [K in keyof Pick]: number; }; -export type ParserGetRgbObject = (color: string) => RGBObject; \ No newline at end of file +export interface CSSOptionsBase { + hasAlpha: boolean; +} diff --git a/src/classes/CIELabParser.ts b/src/classes/CIELabParser.ts new file mode 100644 index 0000000..00fba7c --- /dev/null +++ b/src/classes/CIELabParser.ts @@ -0,0 +1,252 @@ +import { + CIELabObject, + CIELabObjectGeneric, + CIELabRegExpMatchArray, + ColorInput, + ColorObject, + ColorUnitEnum, + CSSOptionsBase, + NumberOrString, + Options +} from '@types'; +import { + ColorModel, + COLORREGS, + MAX_ALPHA, + MAX_LAB, + MAX_PCENT, + PCENT +} from '#constants'; +import { + from125NumberToPercent, + getBase125Number, + isCIELabObject, + isString, + isUndefined, + minmax, + normalizeAlpha, + percent, + round +} from '#utilities'; +import { + getCSSAlpha, + getResultFromCSSTemplate, + prepareColorForCss +} from '#css'; +import { getRGB } from '#color/rgb'; +import { rgbToLab } from '#color/translators'; +import { CalcParser } from './CalcParser'; +import { ColorParserContext, ColorParser } from './ColorParserContext'; + +interface CSSOptions extends CSSOptionsBase { + hasPercentageValues: boolean; + hasPercentageAlpha: boolean; +} + +export class CIELabParser extends ColorParser { + + private _extract(input: string): CIELabRegExpMatchArray['groups'] { + const match = input.match(COLORREGS.CIELab) as CIELabRegExpMatchArray; + return match.groups; + } + + supports(input: ColorInput): boolean { + if (isString(input)) { + return COLORREGS.CIELab.test(input); + } + return isCIELabObject(input); + } + + parse(input: string | CIELabObjectGeneric, context: ColorParserContext): CIELabObject { + + if (isString(input)) { + + const groups = this._extract(input); + + const { + // Lab values + L, + a, + b, + A, + // Relative values + from, + relative_L, + relative_a, + relative_b, + relative_A + } = groups; + + if (from) { + + const fromColor = context.parse(from); + const fromRGB = getRGB(fromColor); + const fromCIELab = rgbToLab( + fromRGB.R, + fromRGB.G, + fromRGB.B + ); + const fromCIELabVars = { + l: fromCIELab.L, + a: fromCIELab.a, + b: fromCIELab.b, + alpha: fromRGB.A ?? 1 + }; + + const L = new CalcParser('l', relative_L, fromCIELabVars).result; + const a = new CalcParser('a', relative_a, fromCIELabVars).result; + const b = new CalcParser('b', relative_b, fromCIELabVars).result; + + const CIELab: CIELabObject = { + L: minmax(L, 0, MAX_PCENT), + a: minmax(a, - MAX_LAB, MAX_LAB), + b: minmax(b, - MAX_LAB, MAX_LAB) + }; + + if (relative_A) { + const A = new CalcParser('alpha', relative_A, fromCIELabVars).result; + CIELab.A = minmax(A, 0, MAX_ALPHA); + } + + return CIELab; + + } else { + + return { + L: percent(L), + a: getBase125Number(a), + b: getBase125Number(b), + ...( + isUndefined(A) + ? {} + : { + A: normalizeAlpha(A) + } + ) + }; + + } + + } + + return { + L: percent(input.L), + a: getBase125Number(`${input.a}`), + b: getBase125Number(`${input.b}`), + ...( + isUndefined(input.A) + ? {} + : { + A: normalizeAlpha(input.A) + } + ) + }; + + } + + convert( + color: ColorObject, + decimals: number, + withAlpha: boolean + ): CIELabObject { + let lab: CIELabObject; + if (isCIELabObject(color)) { + lab = color as CIELabObject; + } else { + const rgb = getRGB(color); + lab = rgbToLab( + rgb.R, + rgb.G, + rgb.B + ); + } + return this._roundCIELabObject( + { + L: lab.L, + a: lab.a, + b: lab.b, + ...( + withAlpha + ? { + A: +(color.A ?? 1) + } + : {} + ) + }, + decimals + ); + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const { + decimals, + labUnit + } = options; + const lab = this.convert(color, options.decimals, withAlpha); + const transformer = (value: number, index: number): NumberOrString => { + if (index === 0) { + const L = round( + percent(value), + decimals + ); + return labUnit === ColorUnitEnum.PERCENT + ? `${L}%` + : `${L}`; + } + if (index < 3) { + return labUnit === ColorUnitEnum.PERCENT + ? `${from125NumberToPercent(value, decimals)}%` + : round(value, decimals); + } + return getCSSAlpha(value, options, true); + }; + const values = prepareColorForCss(lab, transformer); + const template = values.length === 4 + ? `lab({1} {2} {3} / {4})` + : `lab({1} {2} {3})`; + return getResultFromCSSTemplate(template, values); + } + + private _roundCIELabObject(color: CIELabObject, decimals: number): CIELabObject { + return { + L: round(color.L, decimals), + a: round(color.a, decimals), + b: round(color.b, decimals), + ...( + isUndefined(color.A) + ? {} + : { + A: round(color.A, decimals) + } + ) + }; + } + + public getCSSOptions(input: string): CSSOptions { + const groups = this._extract(input); + const { + L, + a, + b, + A + } = groups; + return { + hasPercentageValues: ( + PCENT.test(L) && + PCENT.test(a) && + PCENT.test(b) + ), + hasPercentageAlpha: PCENT.test(A), + hasAlpha: !isUndefined(A) + }; + } + + public get model(): ColorModel { + return ColorModel.CIELab; + } + +} \ No newline at end of file diff --git a/src/classes/CMYKParser.ts b/src/classes/CMYKParser.ts new file mode 100644 index 0000000..93dec17 --- /dev/null +++ b/src/classes/CMYKParser.ts @@ -0,0 +1,235 @@ +import { + CMYKObject, + CMYKObjectGeneric, + CMYKRegExpMatchArray, + ColorInput, + ColorUnitEnum, + ColorObject, + CSSOptionsBase, + NumberOrString, + Options +} from '@types'; +import { + ColorModel, + COLORREGS, + PCENT +} from '#constants'; +import { + getCMYKNumber, + isCMYKObject, + isString, + isUndefined, + normalizeAlpha, + round +} from '#utilities'; +import { + getCSSAlpha, + getCSSComma, + getResultFromCSSTemplate, + prepareColorForCss +} from '#css'; +import { getRGB } from '#color/rgb'; +import { rgbToCmyk } from '#color/translators'; +import { ColorParser } from './ColorParserContext'; + +interface CSSOptions extends CSSOptionsBase { + hasPercentageValues: boolean; + hasPercentageAlpha: boolean; +} + +export class CMYKParser extends ColorParser { + + private _extract(input: string): CMYKRegExpMatchArray['groups'] { + const match = input.match(COLORREGS.CMYK) as CMYKRegExpMatchArray; + return match.groups; + } + + private _shouldMultiplyBy100(...colors: NumberOrString[]): boolean { + return !colors.some((color: string) => +color > 1); + } + + supports(input: ColorInput): boolean { + if (isString(input)) { + return COLORREGS.CMYK.test(input); + } + return isCMYKObject(input); + } + + parse(input: string | CMYKObjectGeneric): CMYKObject { + + if (isString(input)) { + + const groups = this._extract(input); + + const c = groups.c_legacy ?? groups.c; + const m = groups.m_legacy ?? groups.m; + const y = groups.y_legacy ?? groups.y; + const k = groups.k_legacy ?? groups.k; + const a = groups.a_legacy ?? groups.a; + const shouldMultiplyBy100 = this._shouldMultiplyBy100(c, m, y, k); + + return { + C: getCMYKNumber(c, shouldMultiplyBy100), + M: getCMYKNumber(m, shouldMultiplyBy100), + Y: getCMYKNumber(y, shouldMultiplyBy100), + K: getCMYKNumber(k, shouldMultiplyBy100), + ...( + isUndefined(a) + ? {} + : { + A: normalizeAlpha(a) + } + ) + }; + + } + + const shouldMultiplyBy100 = this._shouldMultiplyBy100( + input.C, + input.M, + input.Y, + input.K + ); + + return { + C: getCMYKNumber(`${input.C}`, shouldMultiplyBy100), + M: getCMYKNumber(`${input.M}`, shouldMultiplyBy100), + Y: getCMYKNumber(`${input.Y}`, shouldMultiplyBy100), + K: getCMYKNumber(`${input.K}`, shouldMultiplyBy100), + ...( + isUndefined(input.A) + ? {} + : { + A: normalizeAlpha(input.A) + } + ) + }; + + } + + convert( + color: ColorObject, + decimals: number, + withAlpha: boolean + ): CMYKObject { + let cmyk: CMYKObject; + if (isCMYKObject(color)) { + cmyk = color as CMYKObject; + } else { + const rgb = getRGB(color); + cmyk = rgbToCmyk( + rgb.R, + rgb.G, + rgb.B + ); + } + return this._roundCMYKObject( + { + C: cmyk.C, + M: cmyk.M, + Y: cmyk.Y, + K: cmyk.K, + ...( + withAlpha + ? { + A: +(color.A ?? 1) + } + : {} + ) + }, + decimals + ); + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const { + decimals, + legacyCSS, + spacesAfterCommas, + cmykUnit, + cmykFunction + } = options; + const comma = getCSSComma(spacesAfterCommas); + const cmyk = this.convert(color, options.decimals, withAlpha); + const transformer = (value: number, index: number): NumberOrString => { + if ( + cmykUnit === ColorUnitEnum.PERCENT && + index < 4 + ) { + return `${round(value, decimals)}%`; + } + return index === 4 + ? getCSSAlpha(value, options) + : round(value / 100, decimals); + }; + const values = prepareColorForCss(cmyk, transformer); + const template = legacyCSS + ? ( + values.length === 5 + ? `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4}${comma}{5})` + : `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4})` + ) + : ( + values.length === 5 + ? `${cmykFunction}({1} {2} {3} {4} / {5})` + : `${cmykFunction}({1} {2} {3} {4})` + ); + return getResultFromCSSTemplate(template, values); + } + + private _roundCMYKObject(color: CMYKObject, decimals: number): CMYKObject { + return { + C: round(color.C, decimals), + M: round(color.M, decimals), + Y: round(color.Y, decimals), + K: round(color.K, decimals), + ...( + isUndefined(color.A) + ? {} + : { + A: round(color.A, decimals) + } + ) + }; + } + + public getCSSOptions(input: string): CSSOptions { + const groups = this._extract(input); + const { + c_legacy, + m_legacy, + y_legacy, + k_legacy, + a_legacy, + c, + m, + y, + k, + a + } = groups; + + return { + hasPercentageValues: ( + PCENT.test(c_legacy ?? c) && + PCENT.test(m_legacy ?? m) && + PCENT.test(y_legacy ?? y) && + PCENT.test(k_legacy ?? k) + ), + hasPercentageAlpha: PCENT.test(a_legacy ?? a), + hasAlpha: !isUndefined(a_legacy ?? a) + }; + } + + /* the getter is here to comply with the abstract class but it is not used for CMYK */ + /* istanbul ignore next */ + public get model(): ColorModel { + /* the getter is here to comply with the abstract class but it is not used for CMYK */ + /* istanbul ignore next */ + return ColorModel.CMYK; + } + +} \ No newline at end of file diff --git a/src/parsers/_CalcParser.ts b/src/classes/CalcParser.ts similarity index 100% rename from src/parsers/_CalcParser.ts rename to src/classes/CalcParser.ts diff --git a/src/classes/ColorParserContext.ts b/src/classes/ColorParserContext.ts new file mode 100644 index 0000000..9a2462f --- /dev/null +++ b/src/classes/ColorParserContext.ts @@ -0,0 +1,72 @@ +import { + ColorInput, + ColorObject, + CSSOptionsBase, + InputOptions +} from '@types'; +import { + ColorModel, + DEFAULT_OPTIONS, + ERRORS +} from '#constants'; +import { isString, isUndefined } from '#utilities'; + +export class ColorParserContext { + + constructor(parsers: Record) { + this._parsers = parsers; + } + + private _parsers: Record; + + getParser(input: ColorInput): ColorParser { + const parser = Object.values(this._parsers).find(parser => parser.supports(input)); + if (parser) { + return parser; + } + throw new Error(ERRORS.NOT_ACCEPTED_INPUT); + } + + parse(input: ColorInput): ColorObject { + const parser = this.getParser(input); + return parser.parse(input, this); + } + + convert( + input: ColorInput, + model: ColorModel, + decimals: number = DEFAULT_OPTIONS.decimals, + withAlpha = false + ): T { + const color = this.parse(input); + const parser = this._parsers[model]; + return parser.convert(color, decimals, withAlpha) as T; + } + + convertCSS( + input: ColorInput, + model: ColorModel, + options: InputOptions = {}, + withAlpha = false + ): string { + const color = this.parse(input); + const parser = this._parsers[model]; + return parser.convertCSS(color, options, withAlpha); + } + +} + +export abstract class ColorParser { + public abstract supports(input: ColorInput): boolean + public abstract parse(input: ColorInput, context: ColorParserContext): ColorObject; + public abstract convert(input: ColorObject, decimals: number, withAlpha: boolean): ColorObject; + public abstract convertCSS(input: ColorObject, options: InputOptions, withAlpha: boolean): string; + public abstract getCSSOptions(input: ColorInput): CSSOptionsBase; + public abstract get model(): ColorModel; + public hasAlpha(input: ColorInput): boolean { + if (isString(input)) { + return this.getCSSOptions(input).hasAlpha; + } + return !isUndefined(input.A); + }; +} \ No newline at end of file diff --git a/src/classes/ColorTranslator.ts b/src/classes/ColorTranslator.ts new file mode 100644 index 0000000..17f35e9 --- /dev/null +++ b/src/classes/ColorTranslator.ts @@ -0,0 +1,2311 @@ +import { + CIELabObject, + CIELabObjectGeneric, + CMYKObject, + ColorInput, + ColorInputWithoutCMYK, + ColorOutput, + HEXObject, + HSLObject, + HSLObjectGeneric, + HWBObject, + HWBObjectGeneric, + InputOptions, + LCHObject, + LCHObjectGeneric, + Options, + RGBObject +} from '@types'; +import { + BASE_255, + ColorModel, + Harmony, + HarmonyString, + MAX_ALPHA, + MAX_LAB, + MAX_LCH_C, + MAX_PCENT, + Mix, + MixString +} from '#constants'; +import { + cmykToRgb, + hslToRgb, + hwbToRgb, + labToLch, + labToRgb, + lchToLab, + lchToRgb, + rgbToCmyk, + rgbToHsl, + rgbToHwb, + rgbToLab, + rgbToLch +} from '#color/translators'; +import { + getColorModel, + minmax, + normalizeHue, + round +} from '#utilities'; +import { colorParserContext, getOptionsFromColorInput } from '#parsers'; +import { + getBlendReturn, + getBlendReturnParams, + getMixReturn, + getMixReturnParameters, + getShadesOrTintsReturn, + getShadesOrTintsReturnParameters, + getHarmonyReturn, + getHarmonyReturnParameters +} from '#returns'; + +export class ColorTranslator { + + // Constructor + public constructor(color: ColorInput, options: InputOptions = {}) { + this._options = getOptionsFromColorInput(options, color); + const parsedColor = colorParserContext.parse(color); + const model = getColorModel(parsedColor); + switch (model) { + case ColorModel.HSL: + this.hsl = parsedColor as HSLObject; + this.update('hsl'); + break; + case ColorModel.HWB: + this.hwb = parsedColor as HWBObject; + this.updateRGBFromHWB(); + this.update('hwb', 'rgb'); + break; + case ColorModel.CIELab: + this.lab = parsedColor as CIELabObject; + this.updateRGBFromLAB(); + this.update('lab', 'rgb'); + break; + case ColorModel.LCH: + this.lch = parsedColor as LCHObject; + this.updateRGBFromLCH(); + this.update('lch', 'rgb'); + break; + case ColorModel.CMYK: + this.cmyk = parsedColor as CMYKObject; + this.updateRGBFromCMYK(); + this.update('cmyk', 'rgb'); + break; + default: + this.rgb = parsedColor as RGBObject; + this.update('rgb'); + } + } + + // Private properties + private _options: Options; + private rgb: RGBObject; + private hsl: HSLObject; + private hwb: HWBObject; + private lab: CIELabObject; + private lch: LCHObject; + private cmyk: CMYKObject; + + // Private methods + private update(...exclude: ('rgb' | 'hsl' | 'hwb' | 'lab' | 'lch' | 'cmyk')[]): void { + if (!exclude.includes('rgb')) { + this.updateRGB(); + } + if (!exclude.includes('hsl')) { + this.updateHSL(); + } + if (!exclude.includes('hwb')) { + this.updateHWB(); + } + if (!exclude.includes('lab')) { + this.updateLAB(); + } + if (!exclude.includes('lch')) { + this.updateLCH(); + } + if (!exclude.includes('cmyk')) { + this.updateCMYK(); + } + } + + private updateRGB(): void { + this.rgb = { + ...hslToRgb( + this.hsl.H, + this.hsl.S, + this.hsl.L + ), + A: this.hsl.A ?? 1 + }; + } + + private updateHSL(): void { + this.hsl = rgbToHsl( + this.rgb.R, + this.rgb.G, + this.rgb.B, + this.rgb.A + ); + } + + private updateHWB(): void { + this.hwb = rgbToHwb( + this.rgb.R, + this.rgb.G, + this.rgb.B, + this.rgb.A + ); + } + + private updateLAB(): void { + this.lab = { + ...rgbToLab( + this.rgb.R, + this.rgb.G, + this.rgb.B + ), + A: this.rgb.A ?? 1 + }; + } + + private updateLCH(): void { + this.lch = { + ...rgbToLch( + this.rgb.R, + this.rgb.G, + this.rgb.B + ), + A: this.rgb.A ?? 1 + }; + } + + private updateCMYK(): void { + this.cmyk = { + ...rgbToCmyk( + this.rgb.R, + this.rgb.G, + this.rgb.B + ), + A: this.rgb.A ?? 1 + }; + } + + private updateRGBFromHWB(): void { + this.rgb = { + ...hwbToRgb( + this.hwb.H, + this.hwb.W, + this.hwb.B + ), + A: this.hwb?.A ?? 1 + }; + } + + private updateRGBFromLCH(): void { + this.rgb = { + ...lchToRgb( + this.lch.L, + this.lch.C, + this.lch.H + ), + A: this.lch.A ?? 1 + }; + } + + private updateRGBFromCMYK(): void { + this.rgb = { + ...cmykToRgb( + this.cmyk.C, + this.cmyk.M, + this.cmyk.Y, + this.cmyk.K + ), + A: this.cmyk.A ?? 1 + }; + } + + private updateRGBFromLAB(): void { + this.rgb = { + ...labToRgb( + this.lab.L, + this.lab.a, + this.lab.b + ), + A: this.lab.A ?? 1 + }; + } + + private updateLCHFromLAB(): void { + this.lch = { + ...labToLch( + this.lab.L, + this.lab.a, + this.lab.b + ), + A: this.lab.A + }; + } + + private updateLABromLCH(): void { + this.lab = { + ...lchToLab( + this.lch.L, + this.lch.C, + this.lch.H + ), + A: this.lch.A + }; + } + + // Public options method + public setOptions(options: InputOptions = {}): ColorTranslator { + this._options = { + ...this._options, + ...options + } as Options; + return this; + } + + // Public RGB methods + public setR(R: number): ColorTranslator { + this.rgb.R = minmax(R, 0, BASE_255); + this.update('rgb'); + return; + } + + public setG(G: number): ColorTranslator { + this.rgb.G = minmax(G, 0, BASE_255); + this.update('rgb'); + return this; + } + + public setB(B: number): ColorTranslator { + this.rgb.B = minmax(B, 0, BASE_255); + this.update('rgb'); + return this; + } + + // Public HSL methods + public setH(H: number): ColorTranslator { + this.hsl.H = normalizeHue(H); + this.update('hsl'); + return this; + } + + public setS(S: number): ColorTranslator { + this.hsl.S = minmax(S, 0, MAX_PCENT); + this.update('hsl'); + return this; + } + + public setL(L: number): ColorTranslator { + this.hsl.L = minmax(L, 0, MAX_PCENT); + this.update('hsl'); + return this; + } + + // Public HWB methods + public setWhiteness(W: number): ColorTranslator { + this.hwb.W = minmax(W, 0, MAX_PCENT); + this.updateRGBFromHWB(); + this.update('rgb', 'hwb'); + return this; + } + + public setBlackness(B: number): ColorTranslator { + this.hwb.B = minmax(B, 0, MAX_PCENT); + this.updateRGBFromHWB(); + this.update('rgb', 'hwb'); + return this; + } + + // Public Lab methods + public setCIEL(L: number): ColorTranslator { + this.lab.L = minmax(L, 0, MAX_PCENT); + this.updateRGBFromLAB(); + this.updateLCHFromLAB(); + this.update('rgb', 'lab', 'lch'); + return this; + } + + public setCIEa(a: number): ColorTranslator { + this.lab.a = minmax(a, -MAX_LAB, MAX_LAB); + this.updateRGBFromLAB(); + this.updateLCHFromLAB(); + this.update('rgb', 'lab', 'lch'); + return this; + } + + public setCIEb(b: number): ColorTranslator { + this.lab.b = minmax(b, -MAX_LAB, MAX_LAB); + this.updateRGBFromLAB(); + this.updateLCHFromLAB(); + this.update('rgb', 'lab', 'lch'); + return this; + } + + // Puclic LCH methods + public setLCHL(l: number): ColorTranslator { + this.lch.L = minmax(l, 0, MAX_PCENT); + this.updateRGBFromLCH(); + this.updateLABromLCH(); + this.update('rgb', 'lab', 'lch'); + return this; + } + + public setLCHC(c: number): ColorTranslator { + this.lch.C = minmax(c, 0, MAX_LCH_C); + this.updateRGBFromLCH(); + this.updateLABromLCH(); + this.update('rgb', 'lab', 'lch'); + return this; + } + + public setLCHH(h: number): ColorTranslator { + this.lch.H = normalizeHue(h); + this.updateRGBFromLCH(); + this.updateLABromLCH(); + this.update('rgb', 'lab', 'lch'); + return this; + } + + // Public alpha method + public setA(A: number): ColorTranslator { + const alpha = minmax(A, 0, MAX_ALPHA); + this.rgb.A = alpha; + this.hsl.A = alpha; + this.hwb.A = alpha; + this.lab.A = alpha; + this.lch.A = alpha; + this.cmyk.A = alpha; + return this; + } + + // Public CMYK methods + public setC(C: number): ColorTranslator { + this.cmyk.C = minmax(C, 0, 100); + this.updateRGBFromCMYK(); + this.update('cmyk'); + return this; + } + + public setM(M: number): ColorTranslator { + this.cmyk.M = minmax(M, 0, 100); + this.updateRGBFromCMYK(); + this.update('cmyk'); + return this; + } + + public setY(Y: number): ColorTranslator { + this.cmyk.Y = minmax(Y, 0, 100); + this.updateRGBFromCMYK(); + this.update('cmyk'); + return this; + } + + public setK(K: number): ColorTranslator { + this.cmyk.K = minmax(K, 0, 100); + this.updateRGBFromCMYK(); + this.update('cmyk'); + return this; + } + + // Public options property + public get options(): Options { + return this._options; + } + + // Public RGB properties + public get R(): number { + return round(this.rgb.R, this.options.decimals); + } + + public get G(): number { + return round(this.rgb.G, this.options.decimals); + } + + public get B(): number { + return round(this.rgb.B, this.options.decimals); + } + + // Public HSL properties + public get H(): number { + return round(this.hsl.H, this.options.decimals); + } + + public get S(): number { + return round(this.hsl.S, this.options.decimals); + } + + public get L(): number { + return round(this.hsl.L, this.options.decimals); + } + + // Public HWB properties + public get Whiteness(): number { + return round(this.hwb.W, this.options.decimals); + } + + public get Blackness(): number { + return round(this.hwb.B, this.options.decimals); + } + + // Public Lab properties + public get CIEL(): number { + return round(this.lab.L, this.options.decimals); + } + + public get CIEa(): number { + return round(this.lab.a, this.options.decimals); + } + + public get CIEb(): number { + return round(this.lab.b, this.options.decimals); + } + + // Pulic LCH properties + public get LCHL(): number { + return round(this.lch.L, this.options.decimals); + } + + public get LCHC(): number { + return round(this.lch.C, this.options.decimals); + } + + public get LCHH(): number { + return round(this.lch.H, this.options.decimals); + } + + // Public alpha property + public get A(): number { + return round(this.hsl.A, this.options.decimals); + } + + // Public CMYK properties + public get C(): number { + return round(this.cmyk.C, this.options.decimals); + } + + public get M(): number { + return round(this.cmyk.M, this.options.decimals); + } + + public get Y(): number { + return round(this.cmyk.Y, this.options.decimals); + } + + public get K(): number { + return round(this.cmyk.K, this.options.decimals); + } + + // Object public properties + public get HEXObject(): HEXObject { + return colorParserContext.convert( + this.rgb, + ColorModel.HEX + ); + } + + public get HEXAObject(): HEXObject { + return colorParserContext.convert( + this.rgb, + ColorModel.HEX, + 0, + true + ); + } + + public get RGBObject(): RGBObject { + return colorParserContext.convert( + this.rgb, + ColorModel.RGB, + this.options.decimals + ); + } + + public get RGBAObject(): RGBObject { + return colorParserContext.convert( + this.rgb, + ColorModel.RGB, + this.options.decimals, + true + ); + } + + public get HSLObject(): HSLObject { + return colorParserContext.convert( + this.hsl, + ColorModel.HSL, + this.options.decimals + ); + } + + public get HSLAObject(): HSLObject { + return colorParserContext.convert( + this.hsl, + ColorModel.HSL, + this.options.decimals, + true + ); + } + + public get HWBObject(): HWBObject { + return colorParserContext.convert( + this.hwb, + ColorModel.HWB, + this.options.decimals + ); + } + + public get HWBAObject(): HWBObject { + return colorParserContext.convert( + this.hwb, + ColorModel.HWB, + this.options.decimals, + true + ); + } + + public get CIELabObject(): CIELabObject { + return colorParserContext.convert( + this.lab, + ColorModel.CIELab, + this.options.decimals + ); + } + + public get CIELabAObject(): CIELabObject { + return colorParserContext.convert( + this.lab, + ColorModel.CIELab, + this.options.decimals, + true + ); + } + + public get LCHObject(): LCHObject { + return colorParserContext.convert( + this.lch, + ColorModel.LCH, + this.options.decimals + ); + } + + public get LCHAObject(): LCHObject { + return colorParserContext.convert( + this.lch, + ColorModel.LCH, + this.options.decimals, + true + ); + } + + public get CMYKObject(): CMYKObject { + return colorParserContext.convert( + this.cmyk, + ColorModel.CMYK, + this.options.decimals + ); + } + + public get CMYKAObject(): CMYKObject { + return colorParserContext.convert( + this.cmyk, + ColorModel.CMYK, + this.options.decimals, + true + ); + } + + // CSS public properties + public get HEX(): string { + return colorParserContext.convertCSS( + this.rgb, + ColorModel.HEX + ); + } + + public get HEXA(): string { + return colorParserContext.convertCSS( + this.rgb, + ColorModel.HEX, + {}, + true + ); + } + + public get RGB(): string { + return colorParserContext.convertCSS( + this.rgb, + ColorModel.RGB, + this.options + ); + } + + public get RGBA(): string { + return colorParserContext.convertCSS( + this.rgb, + ColorModel.RGB, + this.options, + true + ); + } + + public get HSL(): string { + return colorParserContext.convertCSS( + this.hsl, + ColorModel.HSL, + this.options + ); + } + + public get HSLA(): string { + return colorParserContext.convertCSS( + this.hsl, + ColorModel.HSL, + this.options, + true + ); + } + + public get HWB(): string { + return colorParserContext.convertCSS( + this.hwb, + ColorModel.HWB, + this.options + ); + } + + public get HWBA(): string { + return colorParserContext.convertCSS( + this.hwb, + ColorModel.HWB, + this.options, + true + ); + } + + public get CIELab(): string { + return colorParserContext.convertCSS( + this.lab, + ColorModel.CIELab, + this.options + ); + } + + public get CIELabA(): string { + return colorParserContext.convertCSS( + this.lab, + ColorModel.CIELab, + this.options, + true + ); + } + + public get LCH(): string { + return colorParserContext.convertCSS( + this.lch, + ColorModel.LCH, + this.options + ); + } + + public get LCHA(): string { + return colorParserContext.convertCSS( + this.lch, + ColorModel.LCH, + this.options, + true + ); + } + + public get CMYK(): string { + return colorParserContext.convertCSS( + this.cmyk, + ColorModel.CMYK, + this.options + ); + } + + public get CMYKA(): string { + return colorParserContext.convertCSS( + this.cmyk, + ColorModel.CMYK, + this.options, + true + ); + } + + // Color Conversion Static Methods + public static toHEXObject(color: ColorInput): HEXObject { + return colorParserContext.convert( + color, + ColorModel.HEX + ); + } + + public static toHEX(color: ColorInput): string { + return colorParserContext.convertCSS( + color, + ColorModel.HEX + ); + } + + public static toHEXAObject(color: ColorInput): HEXObject { + return colorParserContext.convert( + color, + ColorModel.HEX, + undefined, + true + ); + } + + public static toHEXA(color: ColorInput): string { + return colorParserContext.convertCSS( + color, + ColorModel.HEX, + undefined, + true + ); + } + + public static toRGBObject(color: ColorInput, options: InputOptions = {}): RGBObject { + return colorParserContext.convert( + color, + ColorModel.RGB, + options.decimals + ); + } + + public static toRGB(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.RGB, + getOptionsFromColorInput(options, color) + ); + } + + public static toRGBAObject(color: ColorInput, options: InputOptions = {}): RGBObject { + return colorParserContext.convert( + color, + ColorModel.RGB, + options.decimals, + true + ); + } + + public static toRGBA(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.RGB, + getOptionsFromColorInput(options, color), + true + ); + } + + public static toHSLObject(color: ColorInput, options: InputOptions = {}): HSLObject { + return colorParserContext.convert( + color, + ColorModel.HSL, + options.decimals + ); + } + + public static toHSL(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.HSL, + getOptionsFromColorInput(options, color) + ); + } + + public static toHSLAObject(color: ColorInput, options: InputOptions = {}): HSLObject { + return colorParserContext.convert( + color, + ColorModel.HSL, + options.decimals, + true + ); + } + + public static toHSLA(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.HSL, + getOptionsFromColorInput(options, color), + true + ); + } + + public static toHWBObject(color: ColorInput, options: InputOptions = {}): HWBObject { + return colorParserContext.convert( + color, + ColorModel.HWB, + options.decimals + ); + } + + public static toHWB(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.HWB, + getOptionsFromColorInput(options, color) + ); + } + + public static toHWBAObject(color: ColorInput, options: InputOptions = {}): HWBObject { + return colorParserContext.convert( + color, + ColorModel.HWB, + options.decimals, + true + ); + } + + public static toHWBA(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.HWB, + getOptionsFromColorInput(options, color), + true + ); + } + + public static toCIELabObject(color: ColorInput, options: InputOptions = {}): CIELabObject { + return colorParserContext.convert( + color, + ColorModel.CIELab, + options.decimals + ); + } + + public static toCIELab(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.CIELab, + getOptionsFromColorInput(options, color) + ); + } + + public static toCIELabAObject(color: ColorInput, options: InputOptions = {}): CIELabObject { + return colorParserContext.convert( + color, + ColorModel.CIELab, + options.decimals, + true + ); + } + + public static toCIELabA(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.CIELab, + getOptionsFromColorInput(options, color), + true + ); + } + + public static toLCHObject(color: ColorInput, options: InputOptions = {}): LCHObject { + return colorParserContext.convert( + color, + ColorModel.LCH, + options.decimals + ); + } + + public static toLCH(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.LCH, + getOptionsFromColorInput(options, color) + ); + } + + public static toLCHAObject(color: ColorInput, options: InputOptions = {}): LCHObject { + return colorParserContext.convert( + color, + ColorModel.LCH, + options.decimals, + true + ); + } + + public static toLCHA(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.LCH, + getOptionsFromColorInput(options, color), + true + ); + } + + public static toCMYKObject(color: ColorInput, options: InputOptions = {}): CMYKObject { + return colorParserContext.convert( + color, + ColorModel.CMYK, + options.decimals + ); + } + + public static toCMYK(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.CMYK, + getOptionsFromColorInput(options, color) + ); + } + + public static toCMYKAObject(color: ColorInput, options: InputOptions = {}): CMYKObject { + return colorParserContext.convert( + color, + ColorModel.CMYK, + options.decimals, + true + ); + } + + public static toCMYKA(color: ColorInput, options: InputOptions = {}): string { + return colorParserContext.convertCSS( + color, + ColorModel.CMYK, + getOptionsFromColorInput(options, color), + true + ); + } + + // Color Blending Static Methods + public static getBlendHEXObject( + from: ColorInput, + to: ColorInput, + steps?: number + ): RGBObject[] { + return getBlendReturn( + from, + to, + ColorModel.HEX, + false, + false, + steps + ); + } + + public static getBlendHEX( + from: ColorInput, + to: ColorInput, + steps?: number + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.HEX, + true, + false, + steps + ); + } + + public static getBlendHEXAObject( + from: ColorInput, + to: ColorInput, + steps?: number + ): RGBObject[] { + return getBlendReturn( + from, + to, + ColorModel.HEX, + false, + true, + steps + ); + } + + public static getBlendHEXA( + from: ColorInput, + to: ColorInput, + steps?: number + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.HEX, + true, + true, + steps + ); + } + + public static getBlendRGBObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): RGBObject[]; + public static getBlendRGBObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): RGBObject[]; + public static getBlendRGBObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): RGBObject[] { + return getBlendReturn( + from, + to, + ColorModel.RGB, + false, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendRGB( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendRGB( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendRGB( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.RGB, + true, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendRGBAObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): RGBObject[]; + public static getBlendRGBAObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): RGBObject[]; + public static getBlendRGBAObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): RGBObject[] { + return getBlendReturn( + from, + to, + ColorModel.RGB, + false, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendRGBA( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendRGBA( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendRGBA( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.RGB, + true, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHSLObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): HSLObject[]; + public static getBlendHSLObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): HSLObject[]; + public static getBlendHSLObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): HSLObject[] { + return getBlendReturn( + from, + to, + ColorModel.HSL, + false, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHSL( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendHSL( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendHSL( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.HSL, + true, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHSLAObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): HSLObject[]; + public static getBlendHSLAObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): HSLObject[]; + public static getBlendHSLAObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): HSLObject[] { + return getBlendReturn( + from, + to, + ColorModel.HSL, + false, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHSLA( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendHSLA( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendHSLA( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.HSL, + true, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHWBObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): HWBObject[]; + public static getBlendHWBObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): HWBObject[]; + public static getBlendHWBObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): HWBObject[] { + return getBlendReturn( + from, + to, + ColorModel.HWB, + false, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHWB( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendHWB( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendHWB( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.HWB, + true, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHWBAObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): HWBObject[]; + public static getBlendHWBAObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): HWBObject[]; + public static getBlendHWBAObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): HWBObject[] { + return getBlendReturn( + from, + to, + ColorModel.HWB, + false, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendHWBA( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendHWBA( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendHWBA( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.HWB, + true, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendCIELabObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): CIELabObject[]; + public static getBlendCIELabObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): CIELabObject[]; + public static getBlendCIELabObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): CIELabObject[] { + return getBlendReturn( + from, + to, + ColorModel.CIELab, + false, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendCIELab( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendCIELab( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendCIELab( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.CIELab, + true, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendCIELabAObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): CIELabObject[]; + public static getBlendCIELabAObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): CIELabObject[]; + public static getBlendCIELabAObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): CIELabObject[] { + return getBlendReturn( + from, + to, + ColorModel.CIELab, + false, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendCIELabA( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendCIELabA( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendCIELabA( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.CIELab, + true, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendLCHObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): LCHObject[]; + public static getBlendLCHObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): LCHObject[]; + public static getBlendLCHObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): LCHObject[] { + return getBlendReturn( + from, + to, + ColorModel.LCH, + false, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendLCH( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendLCH( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendLCH( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.LCH, + true, + false, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendLCHAObject( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): LCHObject[]; + public static getBlendLCHAObject( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): LCHObject[]; + public static getBlendLCHAObject( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): LCHObject[] { + return getBlendReturn( + from, + to, + ColorModel.LCH, + false, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + public static getBlendLCHA( + from: ColorInput, + to: ColorInput, + options?: InputOptions + ): string[]; + public static getBlendLCHA( + from: ColorInput, + to: ColorInput, + steps?: number, + options?: InputOptions + ): string[]; + public static getBlendLCHA( + from: ColorInput, + to: ColorInput, + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions + ): string[] { + return getBlendReturn( + from, + to, + ColorModel.LCH, + true, + true, + ...getBlendReturnParams( + thirdParameter, + fourthParameter + ) + ); + } + + // Color Mix Static Methods + public static getMixHEXObject(colors: ColorInput[], mode?: MixString): HEXObject { + return getMixReturn( + colors, + ColorModel.HEX, + false, + false, + mode + ); + } + + public static getMixHEX(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): string { + return getMixReturn( + colors, + ColorModel.HEX, + true, + false, + mode + ); + } + + public static getMixHEXAObject(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): HEXObject { + return getMixReturn( + colors, + ColorModel.HEX, + false, + true, + mode + ); + } + + public static getMixHEXA(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): string { + return getMixReturn( + colors, + ColorModel.HEX, + true, + true, + mode + ); + } + + public static getMixRGBObject( + colors: ColorInput[], + options?: InputOptions + ): RGBObject; + public static getMixRGBObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): RGBObject; + public static getMixRGBObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): RGBObject { + return getMixReturn( + colors, + ColorModel.RGB, + false, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixRGB( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixRGB( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixRGB( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.RGB, + true, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixRGBAObject( + colors: ColorInput[], + options?: InputOptions + ): RGBObject; + public static getMixRGBAObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): RGBObject; + public static getMixRGBAObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): RGBObject { + return getMixReturn( + colors, + ColorModel.RGB, + false, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixRGBA( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixRGBA( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixRGBA( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.RGB, + true, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHSLObject( + colors: ColorInput[], + options?: InputOptions + ): HSLObject; + public static getMixHSLObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): HSLObject; + public static getMixHSLObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): HSLObject { + return getMixReturn( + colors, + ColorModel.HSL, + false, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHSL( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixHSL( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixHSL( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.HSL, + true, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHSLAObject( + colors: ColorInput[], + options?: InputOptions + ): HSLObject; + public static getMixHSLAObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): HSLObject; + public static getMixHSLAObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): HSLObject { + return getMixReturn( + colors, + ColorModel.HSL, + false, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHSLA( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixHSLA( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixHSLA( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.HSL, + true, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHWBObject( + colors: ColorInput[], + options?: InputOptions + ): HWBObject; + public static getMixHWBObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): HWBObject; + public static getMixHWBObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): HWBObject { + return getMixReturn( + colors, + ColorModel.HWB, + false, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHWB( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixHWB( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixHWB( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.HWB, + true, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHWBAObject( + colors: ColorInput[], + options?: InputOptions + ): HWBObject; + public static getMixHWBAObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): HWBObject; + public static getMixHWBAObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): HWBObject { + return getMixReturn( + colors, + ColorModel.HWB, + false, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixHWBA( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixHWBA( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixHWBA( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.HWB, + true, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixCIELabObject( + colors: ColorInput[], + options?: InputOptions + ): CIELabObject; + public static getMixCIELabObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): CIELabObject; + public static getMixCIELabObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): CIELabObject { + return getMixReturn( + colors, + ColorModel.CIELab, + false, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixCIELab( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixCIELab( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixCIELab( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.CIELab, + true, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixCIELabAObject( + colors: ColorInput[], + options?: InputOptions + ): CIELabObject; + public static getMixCIELabAObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): CIELabObject; + public static getMixCIELabAObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): CIELabObject { + return getMixReturn( + colors, + ColorModel.CIELab, + false, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixCIELabA( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixCIELabA( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixCIELabA( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.CIELab, + true, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixLCHObject( + colors: ColorInput[], + options?: InputOptions + ): LCHObject; + public static getMixLCHObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): LCHObject; + public static getMixLCHObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): LCHObject { + return getMixReturn( + colors, + ColorModel.LCH, + false, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixLCH( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixLCH( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixLCH( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.LCH, + true, + false, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixLCHAObject( + colors: ColorInput[], + options?: InputOptions + ): LCHObject; + public static getMixLCHAObject( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): LCHObject; + public static getMixLCHAObject( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): LCHObject { + return getMixReturn( + colors, + ColorModel.LCH, + false, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + public static getMixLCHA( + colors: ColorInput[], + options?: InputOptions + ): string; + public static getMixLCHA( + colors: ColorInput[], + mode?: MixString, + options?: InputOptions + ): string; + public static getMixLCHA( + colors: ColorInput[], + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions + ): string { + return getMixReturn( + colors, + ColorModel.LCH, + true, + true, + ...getMixReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + // Get shades static method + public static getShades(color: string, options?: InputOptions): string[]; + public static getShades(color: HEXObject, options?: InputOptions): HEXObject[]; + public static getShades(color: RGBObject, options?: InputOptions): RGBObject[]; + public static getShades(color: HSLObjectGeneric, options?: InputOptions): HSLObject[]; + public static getShades(color: HWBObjectGeneric, options?: InputOptions): HWBObject[]; + public static getShades(color: CIELabObjectGeneric, options?: InputOptions): CIELabObject[]; + public static getShades(color: LCHObjectGeneric, options?: InputOptions): LCHObject[]; + + public static getShades(color: string, shades?: number, options?: InputOptions): string[]; + public static getShades(color: HEXObject, shades?: number, options?: InputOptions): HEXObject[]; + public static getShades(color: RGBObject, shades?: number, options?: InputOptions): RGBObject[]; + public static getShades(color: HSLObjectGeneric, shades?: number, options?: InputOptions): HSLObject[]; + public static getShades(color: HWBObjectGeneric, shades?: number, options?: InputOptions): HWBObject[]; + public static getShades(color: CIELabObjectGeneric, shades?: number, options?: InputOptions): CIELabObject[]; + public static getShades(color: LCHObjectGeneric, shades?: number, options?: InputOptions): LCHObject[]; + + public static getShades( + color: ColorInputWithoutCMYK, + secondParameter?: number | InputOptions, + thirdParameter?: InputOptions + ): ColorOutput[] { + return getShadesOrTintsReturn( + true, + color, + ...getShadesOrTintsReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + // Get tints static method + public static getTints(color: string, options?: InputOptions): string[]; + public static getTints(color: HEXObject, options?: InputOptions): HEXObject[]; + public static getTints(color: RGBObject, options?: InputOptions): RGBObject[]; + public static getTints(color: HSLObjectGeneric, options?: InputOptions): HSLObject[]; + public static getTints(color: HWBObjectGeneric, options?: InputOptions): HWBObject[]; + public static getTints(color: CIELabObjectGeneric, options?: InputOptions): CIELabObject[]; + public static getTints(color: LCHObjectGeneric, options?: InputOptions): LCHObject[]; + + public static getTints(color: string, tints?: number, options?: InputOptions): string[]; + public static getTints(color: HEXObject, tints?: number, options?: InputOptions): HEXObject[]; + public static getTints(color: RGBObject, tints?: number, options?: InputOptions): RGBObject[]; + public static getTints(color: HSLObjectGeneric, tints?: number, options?: InputOptions): HSLObject[]; + public static getTints(color: HWBObjectGeneric, tints?: number, options?: InputOptions): HWBObject[]; + public static getTints(color: CIELabObjectGeneric, tints?: number, options?: InputOptions): CIELabObject[]; + public static getTints(color: LCHObjectGeneric, tints?: number, options?: InputOptions): LCHObject[]; + + public static getTints( + color: ColorInputWithoutCMYK, + secondParameter?: number | InputOptions, + thirdParameter?: InputOptions + ): ColorOutput[] { + return getShadesOrTintsReturn( + false, + color, + ...getShadesOrTintsReturnParameters( + secondParameter, + thirdParameter + ) + ); + } + + // Color Harmony Static Method + public static getHarmony(color: string, options?: InputOptions): string[]; + public static getHarmony(color: HEXObject, options?: InputOptions): HEXObject[]; + public static getHarmony(color: RGBObject, options?: InputOptions): RGBObject[]; + public static getHarmony(color: HSLObjectGeneric, options?: InputOptions): HSLObject[]; + public static getHarmony(color: HWBObjectGeneric, options?: InputOptions): HWBObject[]; + public static getHarmony(color: CIELabObjectGeneric, options?: InputOptions): CIELabObject[]; + public static getHarmony(color: LCHObjectGeneric, options?: InputOptions): LCHObject[]; + + public static getHarmony(color: string, mode?: MixString, options?: InputOptions): string[]; + public static getHarmony(color: HEXObject, mode?: MixString, options?: InputOptions): HEXObject[]; + public static getHarmony(color: RGBObject, mode?: MixString, options?: InputOptions): RGBObject[]; + public static getHarmony(color: HSLObjectGeneric, mode?: MixString, options?: InputOptions): HSLObject[]; + public static getHarmony(color: HWBObjectGeneric, mode?: MixString, options?: InputOptions): HWBObject[]; + public static getHarmony(color: CIELabObjectGeneric, mode?: MixString, options?: InputOptions): CIELabObject[]; + public static getHarmony(color: LCHObjectGeneric, mode?: MixString, options?: InputOptions): LCHObject[]; + + public static getHarmony(color: string, harmony?: Harmony, options?: InputOptions): string[]; + public static getHarmony(color: HEXObject, harmony?: Harmony, options?: InputOptions): HEXObject[]; + public static getHarmony(color: RGBObject, harmony?: Harmony, options?: InputOptions): RGBObject[]; + public static getHarmony(color: HSLObjectGeneric, harmony?: Harmony, options?: InputOptions): HSLObject[]; + public static getHarmony(color: HWBObjectGeneric, harmony?: Harmony, options?: InputOptions): HWBObject[]; + public static getHarmony(color: CIELabObjectGeneric, harmony?: Harmony, options?: InputOptions): CIELabObject[]; + public static getHarmony(color: LCHObjectGeneric, harmony?: Harmony, options?: InputOptions): LCHObject[]; + + public static getHarmony(color: string, harmony?: Harmony, mode?: MixString, options?: InputOptions): string[]; + public static getHarmony(color: HEXObject, harmony?: Harmony, mode?: MixString, options?: InputOptions): HEXObject[]; + public static getHarmony(color: RGBObject, harmony?: Harmony, mode?: MixString, options?: InputOptions): RGBObject[]; + public static getHarmony(color: HSLObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): HSLObject[]; + public static getHarmony(color: HWBObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): HWBObject[]; + public static getHarmony(color: CIELabObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): CIELabObject[]; + public static getHarmony(color: LCHObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): LCHObject[]; + + public static getHarmony( + color: ColorInputWithoutCMYK, + secondParam?: HarmonyString | MixString | InputOptions, + thirdParam?: MixString | InputOptions, + fourthParam?: InputOptions + ): ColorOutput[] { + return getHarmonyReturn( + color, + ...getHarmonyReturnParameters( + secondParam, + thirdParam, + fourthParam + ) + ); + } +} \ No newline at end of file diff --git a/src/classes/HEXParser.ts b/src/classes/HEXParser.ts new file mode 100644 index 0000000..58089ce --- /dev/null +++ b/src/classes/HEXParser.ts @@ -0,0 +1,150 @@ +import { + ColorInput, + ColorObject, + CSSOptionsBase, + HEXObject, + HEXRegExpMatchArray, + NumberOrString, + Options, + RGBObject, + RGBObjectGeneric +} from '@types'; +import { + BASE_255, + COLOR_KEYS, + ColorKeywords, + ColorModel, + COLORREGS, + HEX +} from '#constants'; +import { getRGB } from '#color/rgb'; +import { getResultFromCSSTemplate, prepareColorForCss } from '#css'; +import { + getDEC, + getHEX, + getBase255Number, + isString, + isUndefined, + isRGBObject, + round, + toHEX +} from '#utilities'; +import { ColorParser } from './ColorParserContext'; + +export class HEXParser extends ColorParser { + + private _extract(input: string): HEXRegExpMatchArray['groups'] { + const colorStr = !~COLOR_KEYS.indexOf(input) + ? input + : ColorKeywords[input as keyof typeof ColorKeywords]; + const match = colorStr.match(COLORREGS.HEX) as HEXRegExpMatchArray; + return match.groups; + } + + supports(input: ColorInput): boolean { + + if (isString(input)) { + return ( + COLORREGS.HEX.test(input) || + !!~COLOR_KEYS.indexOf(input) + ); + } + + const hasInvalidHex = Object.entries(input).some((item: [string, string | number]): boolean => { + return !HEX.test(`${item[1]}`); + }); + + return isRGBObject(input) && !hasInvalidHex; + } + + parse(input: string | RGBObjectGeneric): RGBObject { + + if (isString(input)) { + + const groups = this._extract(input); + + const r = groups.r ?? groups.rr; + const g = groups.g ?? groups.gg; + const b = groups.b ?? groups.bb; + const a = groups.a ?? groups.aa; + + return { + R: getDEC(r), + G: getDEC(g), + B: getDEC(b), + ...( + isUndefined(a) + ? {} + : { + A: getDEC(a) / BASE_255 + } + ) + }; + + } + + return { + R: getBase255Number(`${input.R}`), + G: getBase255Number(`${input.G}`), + B: getBase255Number(`${input.B}`), + ...( + isUndefined(input.A) + ? {} + : { + A: Math.min(getBase255Number(`${input.A}`, true), 1) + } + ) + }; + + } + + convert( + color: ColorObject, + __decimals: number, + withAlpha: boolean + ): HEXObject { + const rgb: RGBObject = isRGBObject(color) + ? color as RGBObject + : getRGB(color); + return { + R: getHEX(rgb.R), + G: getHEX(rgb.G), + B: getHEX(rgb.B), + ...( + withAlpha + ? { + A: isUndefined(rgb.A) + ? '0xFF' + : getHEX(rgb.A * BASE_255) + } + : {} + ) + }; + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const rgb = this.convert(color, options.decimals, withAlpha); + const transformer = (value: NumberOrString): string => toHEX(round(value)); + const values = prepareColorForCss(rgb, transformer); + const template = values.length === 4 + ? '#{1}{2}{3}{4}' + : '#{1}{2}{3}'; + return getResultFromCSSTemplate(template, values); + } + + public getCSSOptions(input: string): CSSOptionsBase { + const groups = this._extract(input); + return { + hasAlpha: !isUndefined(groups.a ?? groups.aa) + }; + } + + public get model(): ColorModel { + return ColorModel.HEX; + } + +} \ No newline at end of file diff --git a/src/classes/HSLParser.ts b/src/classes/HSLParser.ts new file mode 100644 index 0000000..0b3f102 --- /dev/null +++ b/src/classes/HSLParser.ts @@ -0,0 +1,254 @@ +import { + AnglesUnitEnum, + ColorObject, + ColorInput, + CSSOptionsBase, + HSLObject, + HSLObjectGeneric, + HSLRegExpMatchArray, + Options +} from '@types'; +import { + COLORREGS, + ColorModel, + MAX_ALPHA, + PCENT +} from '#constants'; +import { + getAngleUnit, + isHSLObject, + isString, + isUndefined, + minmax, + normalizeAlpha, + normalizeHue, + percent, + round +} from '#utilities'; +import { + buildCSSHueTransformer, + getCSSComma, + getResultFromCSSTemplate, + prepareColorForCss +} from '#css'; +import { getRGB } from '#color/rgb'; +import { rgbToHsl } from '#color/translators'; +import { CalcParser } from './CalcParser'; +import { ColorParserContext, ColorParser } from './ColorParserContext'; + +interface CSSOptions extends CSSOptionsBase { + angleUnit: AnglesUnitEnum; + hasPercentageAlpha: boolean; +} + +export class HSLParser extends ColorParser { + + private _extract(input: string): HSLRegExpMatchArray['groups'] { + const match = input.match(COLORREGS.HSL) as HSLRegExpMatchArray; + return match.groups; + } + + supports(input: ColorInput): boolean { + if (isString(input)) { + return COLORREGS.HSL.test(input); + } + return isHSLObject(input); + } + + parse( + input: string | HSLObjectGeneric, + context: ColorParserContext + ): HSLObject { + + if (isString(input)) { + + const groups = this._extract(input); + + const { + // Legacy values + h_legacy, + s_legacy, + l_legacy, + a_legacy, + // HSL values + h, + s, + l, + a, + // Relative values + from, + relative_h, + relative_s, + relative_l, + relative_a + } = groups; + + if (from) { + + const fromColor = context.parse(from); + const fromRGB = getRGB(fromColor); + const fromHSL = rgbToHsl( + fromRGB.R, + fromRGB.G, + fromRGB.B, + fromRGB.A + ); + const fromHSLVars = { + h: fromHSL.H, + s: fromHSL.S, + l: fromHSL.L, + alpha: fromHSL.A + }; + + const H = new CalcParser('h', relative_h, fromHSLVars).result; + const S = new CalcParser('s', relative_s, fromHSLVars).result; + const L = new CalcParser('l', relative_l, fromHSLVars).result; + + const hsl: HSLObject = { + H: normalizeHue(H), + S: percent(S), + L: percent(L) + }; + + if (relative_a) { + const A = new CalcParser('alpha', relative_a, fromHSLVars).result; + hsl.A = minmax(A, 0, MAX_ALPHA); + } + + return hsl; + + } else { + + const H = h_legacy ?? h; + const S = s_legacy ?? s; + const L = l_legacy ?? l; + const A = a_legacy ?? a; + + return { + H: normalizeHue(H), + S: percent(S), + L: percent(L), + ...( + isUndefined(A) + ? {} + : { + A: normalizeAlpha(A) + } + ) + }; + + } + + } + + return { + H: normalizeHue(input.H), + S: percent(`${input.S}`), + L: percent(`${input.L}`), + ...( + isUndefined(input.A) + ? {} + : { + A: minmax(+input.A, 0, MAX_ALPHA) + } + ) + }; + + } + + convert( + color: ColorObject, + decimals: number, + withAlpha: boolean + ): HSLObject { + let hsl: HSLObject; + if (isHSLObject(color)) { + hsl = color as HSLObject; + } else { + const rgb = getRGB(color); + hsl = rgbToHsl( + rgb.R, + rgb.G, + rgb.B, + rgb.A + ); + } + return this._roundHSLObject( + { + H: hsl.H, + S: hsl.S, + L: hsl.L, + ...( + withAlpha + ? { + A: hsl.A ?? 1 + } + : {} + ) + }, + decimals + ); + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const { legacyCSS, spacesAfterCommas } = options; + const comma = getCSSComma(spacesAfterCommas); + const hsl = this.convert(color, options.decimals, withAlpha); + const transformer = buildCSSHueTransformer(options); + const values = prepareColorForCss(hsl, transformer); + const template = legacyCSS + ? ( + values.length === 4 + ? `hsla({1}${comma}{2}%${comma}{3}%${comma}{4})` + : `hsl({1}${comma}{2}%${comma}{3}%)` + ) + : ( + values.length === 4 + ? `hsl({1} {2}% {3}% / {4})` + : `hsl({1} {2}% {3}%)` + ); + return getResultFromCSSTemplate(template, values); + } + + private _roundHSLObject(color: HSLObject, decimals: number): HSLObject { + return { + H: round( + normalizeHue(color.H), + decimals + ), + S: round(color.S, decimals), + L: round(color.L, decimals), + ...( + isUndefined(color.A) + ? {} + : { + A: round(color.A, decimals) + } + ) + }; + } + + public getCSSOptions(input: string): CSSOptions { + const groups = this._extract(input); + const { + h_legacy, + h, + a_legacy, + a + } = groups; + return { + angleUnit: getAngleUnit(h_legacy ?? h), + hasPercentageAlpha: PCENT.test(a_legacy ?? a), + hasAlpha: !isUndefined(a_legacy ?? a) + }; + } + + public get model(): ColorModel { + return ColorModel.HSL; + } + +} \ No newline at end of file diff --git a/src/classes/HWBParser.ts b/src/classes/HWBParser.ts new file mode 100644 index 0000000..7b05c70 --- /dev/null +++ b/src/classes/HWBParser.ts @@ -0,0 +1,226 @@ +import { + AnglesUnitEnum, + ColorInput, + ColorObject, + CSSOptionsBase, + HWBObject, + HWBObjectGeneric, + HWBRegExpMatchArray, + Options +} from '@types'; +import { + COLORREGS, + ColorModel, + MAX_ALPHA, + MAX_HUE, + MAX_PCENT, + PCENT +} from '#constants'; +import { + getAngleUnit, + isHWBObject, + isString, + isUndefined, + minmax, + normalizeAlpha, + normalizeHue, + percent, + round +} from '#utilities'; +import { + buildCSSHueTransformer, + getResultFromCSSTemplate, + prepareColorForCss +} from '#css'; +import { getRGB } from '#color/rgb'; +import { rgbToHwb } from '#color/translators'; +import { CalcParser } from './CalcParser'; +import { ColorParserContext, ColorParser } from './ColorParserContext'; + +interface CSSOptions extends CSSOptionsBase { + angleUnit: AnglesUnitEnum; + hasPercentageAlpha: boolean; +} + +export class HWBParser extends ColorParser { + + private _extract(input: string): HWBRegExpMatchArray['groups'] { + const match = input.match(COLORREGS.HWB) as HWBRegExpMatchArray; + return match.groups; + } + + supports(input: ColorInput): boolean { + if (isString(input)) { + return COLORREGS.HWB.test(input); + } + return isHWBObject(input); + } + + parse(input: string | HWBObjectGeneric, context: ColorParserContext): HWBObject { + + if (isString(input)) { + + const groups = this._extract(input); + + const { + // HWB values + h, + w, + b, + a, + // Relative values + from, + relative_h, + relative_w, + relative_b, + relative_a + } = groups; + + if (from) { + + const fromColor = context.parse(from); + const fromRGB = getRGB(fromColor); + const fromHWB = rgbToHwb( + fromRGB.R, + fromRGB.G, + fromRGB.B, + fromRGB.A + ); + const fromHWBVars = { + h: fromHWB.H, + w: fromHWB.W, + b: fromHWB.B, + alpha: fromHWB.A + }; + + const H = new CalcParser('h', relative_h, fromHWBVars).result; + const W = new CalcParser('w', relative_w, fromHWBVars).result; + const B = new CalcParser('b', relative_b, fromHWBVars).result; + + const hwb: HWBObject = { + H: minmax(H, 0, MAX_HUE), + W: minmax(W, 0, MAX_PCENT), + B: minmax(B, 0, MAX_PCENT) + }; + + if (relative_a) { + const A = new CalcParser('alpha', relative_a, fromHWBVars).result; + hwb.A = minmax(A, 0, MAX_ALPHA); + } + + return hwb; + + } else { + + return { + H: normalizeHue(h), + W: percent(w), + B: percent(b), + ...( + isUndefined(a) + ? {} + : { + A: normalizeAlpha(a) + } + ) + }; + + } + + } + + return { + H: normalizeHue(input.H), + W: percent(input.W), + B: percent(input.B), + ...( + isUndefined(input.A) + ? {} + : { + A: normalizeAlpha(input.A) + } + ) + }; + + } + + convert( + color: ColorObject, + decimals: number, + withAlpha: boolean + ): HWBObject { + let hwb: HWBObject; + if (isHWBObject(color)) { + hwb = color as HWBObject; + } else { + const rgb = getRGB(color); + hwb = rgbToHwb( + rgb.R, + rgb.G, + rgb.B, + rgb.A + ); + } + return this._roundHWBObject( + { + H: hwb.H, + W: hwb.W, + B: hwb.B, + ...( + withAlpha + ? { + A: hwb.A ?? 1 + } + : {} + ) + }, + decimals + ); + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const hwb = this.convert(color, options.decimals, withAlpha); + const transformer = buildCSSHueTransformer(options); + const values = prepareColorForCss(hwb, transformer); + const template = values.length === 4 + ? `hwb({1} {2}% {3}% / {4})` + : `hwb({1} {2}% {3}%)`; + return getResultFromCSSTemplate(template, values); + } + + private _roundHWBObject(color: HWBObject, decimals: number): HWBObject { + return { + H: round( + normalizeHue(color.H), + decimals + ), + W: round(color.W, decimals), + B: round(color.B, decimals), + ...( + isUndefined(color.A) + ? {} + : { + A: round(color.A, decimals) + } + ) + }; + } + + public getCSSOptions(input: string): CSSOptions { + const groups = this._extract(input); + return { + angleUnit: getAngleUnit(groups.h), + hasPercentageAlpha: PCENT.test(groups.a), + hasAlpha: !isUndefined(groups.a) + }; + } + + public get model(): ColorModel { + return ColorModel.HWB; + } + +} \ No newline at end of file diff --git a/src/classes/LCHParser.ts b/src/classes/LCHParser.ts new file mode 100644 index 0000000..b80d2b3 --- /dev/null +++ b/src/classes/LCHParser.ts @@ -0,0 +1,269 @@ +import { + AnglesUnitEnum, + ColorInput, + ColorObject, + ColorUnitEnum, + CSSOptionsBase, + LCHObject, + LCHObjectGeneric, + LCHRegExpMatchArray, + NumberOrString, + Options +} from '@types'; +import { + COLORREGS, + ColorModel, + MAX_ALPHA, + MAX_LCH_C, + MAX_PCENT, + PCENT +} from '#constants'; +import { + from150NumberToPercent, + getAngleUnit, + getBase150Number, + isLCHObject, + isString, + isUndefined, + minmax, + normalizeAlpha, + normalizeHue, + percent, + round, + translateDegrees +} from '#utilities'; +import { + getCSSAlpha, + getResultFromCSSTemplate, + prepareColorForCss +} from '#css'; +import { getRGB } from '#color/rgb'; +import { rgbToLch } from '#color/translators'; +import { CalcParser } from './CalcParser'; +import { ColorParserContext, ColorParser } from './ColorParserContext'; + +interface CSSOptions extends CSSOptionsBase { + angleUnit: AnglesUnitEnum; + hasPercentageValues: boolean; + hasPercentageAlpha: boolean; +} + +export class LCHParser extends ColorParser { + + private _extract(input: string): LCHRegExpMatchArray['groups'] { + const match = input.match(COLORREGS.LCH) as LCHRegExpMatchArray; + return match.groups; + } + + supports(input: ColorInput): boolean { + if (isString(input)) { + return COLORREGS.LCH.test(input); + } + return isLCHObject(input); + } + + parse(input: string | LCHObjectGeneric, context: ColorParserContext): LCHObject { + + if (isString(input)) { + + const groups = this._extract(input); + + const { + // LCH values + l, + c, + h, + a, + // Relative values + from, + relative_l, + relative_c, + relative_h, + relative_a + } = groups; + + if (from) { + + const fromColor = context.parse(from); + const fromRGB = getRGB(fromColor); + + const fromLCH = rgbToLch( + fromRGB.R, + fromRGB.G, + fromRGB.B + ); + const fromLCHVars = { + l: fromLCH.L, + c: fromLCH.C, + h: fromLCH.H, + alpha: fromRGB.A ?? 1 + }; + + const L = new CalcParser('l', relative_l, fromLCHVars).result; + const C = new CalcParser('c', relative_c, fromLCHVars).result; + const H = new CalcParser('h', relative_h, fromLCHVars).result; + + const lch: LCHObject = { + L: minmax(L, 0, MAX_PCENT), + C: minmax(C, - MAX_LCH_C, MAX_LCH_C), + H: normalizeHue(H) + }; + + if (relative_a) { + const A = new CalcParser('alpha', relative_a, fromLCHVars).result; + lch.A = minmax(A, 0, MAX_ALPHA); + } + + return lch; + + } else { + + return { + L: percent(l), + C: getBase150Number(c), + H: normalizeHue(h), + ...( + isUndefined(a) + ? {} + : { + A: normalizeAlpha(a) + } + ) + }; + + } + + } + + return { + L: percent(input.L), + C: getBase150Number(`${input.C}`), + H: normalizeHue(input.H), + ...( + isUndefined(input.A) + ? {} + : { + A: normalizeAlpha(input.A) + } + ) + }; + + } + + convert( + color: ColorObject, + decimals: number, + withAlpha: boolean + ): LCHObject { + let lch: LCHObject; + if (isLCHObject(color)) { + lch = color as LCHObject; + } else { + const rgb = getRGB(color); + lch = rgbToLch( + rgb.R, + rgb.G, + rgb.B + ); + } + return this._roundLCHObject( + { + L: lch.L, + C: lch.C, + H: lch.H, + ...( + withAlpha + ? { + A: +(color.A ?? 1) + } + : {} + ) + }, + decimals + ); + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const { + decimals, + lchUnit, + anglesUnit + } = options; + const lch = this.convert(color, options.decimals, withAlpha); + const transformer = (value: number, index: number): NumberOrString => { + if (index === 0) { + const L = round( + percent(value), + decimals + ); + return lchUnit === ColorUnitEnum.PERCENT + ? `${L}%` + : `${L}`; + } + if (index === 1) { + return lchUnit === ColorUnitEnum.PERCENT + ? `${from150NumberToPercent(value, decimals)}%` + : round(value, decimals); + } + if (index === 2) { + if (anglesUnit !== AnglesUnitEnum.NONE) { + const translated = round( + translateDegrees( + value, + anglesUnit + ), + decimals + ); + return `${translated}${anglesUnit}`; + } + return round(value, decimals); + } + return getCSSAlpha(value, options, true); + }; + const values = prepareColorForCss(lch, transformer); + const template = values.length === 4 + ? `lch({1} {2} {3} / {4})` + : `lch({1} {2} {3})`; + return getResultFromCSSTemplate(template, values); + } + + private _roundLCHObject(color: LCHObject, decimals: number): LCHObject { + return { + L: round(color.L, decimals), + C: round(color.C, decimals), + H: round( + normalizeHue(color.H), + decimals + ), + ...( + isUndefined(color.A) + ? {} + : { + A: round(color.A, decimals) + } + ) + }; + } + + public getCSSOptions(input: string): CSSOptions { + const groups = this._extract(input); + return { + angleUnit: getAngleUnit(groups.h), + hasPercentageValues: ( + PCENT.test(groups.l) && + PCENT.test(groups.c) + ), + hasPercentageAlpha: PCENT.test(groups.a), + hasAlpha: !isUndefined(groups.a) + }; + } + + public get model(): ColorModel { + return ColorModel.LCH; + } + +} \ No newline at end of file diff --git a/src/classes/RGBParser.ts b/src/classes/RGBParser.ts new file mode 100644 index 0000000..4215726 --- /dev/null +++ b/src/classes/RGBParser.ts @@ -0,0 +1,286 @@ +import { + ColorInput, + ColorObject, + ColorUnitEnum, + CSSOptionsBase, + NumberOrString, + Options, + RGBObject, + RGBObjectGeneric, + RGBRegExpMatchArray +} from '@types'; +import { + BASE_255, + COLORREGS, + ColorModel, + HEX, + PCENT +} from '#constants'; +import { + from255NumberToPercent, + getBase255Number, + isString, + isRGBObject, + isUndefined, + normalizeAlpha, + round +} from '#utilities'; +import { + getCSSAlpha, + getCSSComma, + getResultFromCSSTemplate, + prepareColorForCss +} from '#css'; +import { getRGB } from '#color/rgb'; +import { CalcParser } from './CalcParser'; +import { ColorParserContext, ColorParser } from './ColorParserContext'; + +interface CSSOptions extends CSSOptionsBase { + hasPercentageValues: boolean; + hasPercentageAlpha: boolean; +} + +export class RGBParser extends ColorParser { + + private _extract(input: string): RGBRegExpMatchArray['groups'] { + const match = input.match(COLORREGS.RGB) as RGBRegExpMatchArray; + return match.groups; + } + + supports(input: ColorInput): boolean { + + if (isString(input)) { + return COLORREGS.RGB.test(input); + } + + const hasInvalidRegb = Object.entries(input).some((item: [string, string | number]): boolean => { + return !( + PCENT.test(`${item[1]}`) || + ( + !HEX.test(`${item[1]}`) && + !isNaN(+item[1]) && + +item[1] <= BASE_255 + ) + ); + }); + + return isRGBObject(input) && !hasInvalidRegb; + + } + + parse(input: string | RGBObjectGeneric, context: ColorParserContext): RGBObject { + + if (isString(input)) { + + const groups = this._extract(input); + const { + // Legacy values + r_legacy, + g_legacy, + b_legacy, + a_legacy, + // RGB values + r, + g, + b, + a, + // Relative values + from, + relative_r, + relative_g, + relative_b, + relative_a + } = groups; + + if (from) { + + const fromColor = context.parse(from); + const fromRGB = getRGB(fromColor as ColorObject); + const fromRGBVars = { + r: fromRGB.R, + g: fromRGB.G, + b: fromRGB.B, + alpha: fromRGB.A ?? 1 + }; + const R = new CalcParser('r', relative_r, fromRGBVars).result; + const G = new CalcParser('g', relative_g, fromRGBVars).result; + const B = new CalcParser('b', relative_b, fromRGBVars).result; + + const rgb: RGBObject = { + R: Math.min( + R, + BASE_255 + ), + G: Math.min( + G, + BASE_255 + ), + B: Math.min( + B, + BASE_255 + ) + }; + + if (relative_a) { + const A = new CalcParser('alpha', relative_a, fromRGBVars).result; + rgb.A = Math.min(A, 1); + } + + return rgb; + + } else { + + const R = r_legacy ?? r; + const G = g_legacy ?? g; + const B = b_legacy ?? b; + const A = a_legacy ?? a; + + return { + R: Math.min( + getBase255Number(R), + BASE_255 + ), + G: Math.min( + getBase255Number(G), + BASE_255 + ), + B: Math.min( + getBase255Number(B), + BASE_255 + ), + ...( + isUndefined(A) + ? {} + : { + A: normalizeAlpha(A) + } + ) + }; + + } + + } + + return { + R: getBase255Number(`${input.R}`), + G: getBase255Number(`${input.G}`), + B: getBase255Number(`${input.B}`), + ...( + isUndefined(input.A) + ? {} + : { + A: Math.min(getBase255Number(`${input.A}`, true), 1) + } + ) + }; + + } + + convert( + color: ColorObject, + decimals: number, + withAlpha: boolean + ): RGBObject { + const rgb: RGBObject = isRGBObject(color) + ? color as RGBObject + : getRGB(color); + return this._roundRGBObject( + { + R: rgb.R, + G: rgb.G, + B: rgb.B, + ...( + withAlpha + ? { + A: rgb.A ?? 1 + } + : {} + ) + }, + decimals + ); + } + + convertCSS( + color: ColorObject, + options: Options, + withAlpha: boolean + ): string { + const { + decimals, + legacyCSS, + spacesAfterCommas, + rgbUnit + } = options; + const rgb = this.convert(color, options.decimals, withAlpha); + const comma = getCSSComma(spacesAfterCommas); + const transformer = (value: number, index: number): NumberOrString => { + return rgbUnit === ColorUnitEnum.PERCENT && index < 3 + ? `${from255NumberToPercent(value, decimals)}%` + : ( + index === 3 + ? getCSSAlpha(value, options) + : round(value, decimals) + ); + }; + const values = prepareColorForCss(rgb, transformer); + const template = legacyCSS + ? ( + values.length === 4 + ? `rgba({1}${comma}{2}${comma}{3}${comma}{4})` + : `rgb({1}${comma}{2}${comma}{3})` + ) + : ( + values.length === 4 + ? `rgb({1} {2} {3} / {4})` + : `rgb({1} {2} {3})` + ); + return getResultFromCSSTemplate(template, values); + } + + private _roundRGBObject(color: RGBObject, decimals: number): RGBObject { + const R = round(color.R, decimals); + const G = round(color.G, decimals); + const B = round(color.B, decimals); + return { + R, + G, + B, + ...( + isUndefined(color.A) + ? {} + : { + A: round(color.A, decimals) + } + ) + }; + } + + public getCSSOptions(input: string): CSSOptions { + const groups = this._extract(input); + const { + r_legacy, + g_legacy, + b_legacy, + a_legacy, + r, + g, + b, + a + } = groups; + return { + hasPercentageValues: ( + PCENT.test(r_legacy ?? r) && + PCENT.test(g_legacy ?? g) && + PCENT.test(b_legacy ?? b) + ), + hasPercentageAlpha: PCENT.test(a_legacy ?? a), + hasAlpha: !isUndefined(a_legacy ?? a) + }; + } + + public get model(): ColorModel { + return ColorModel.RGB; + } + +} \ No newline at end of file diff --git a/src/color/css.ts b/src/color/css.ts deleted file mode 100644 index d492a0d..0000000 --- a/src/color/css.ts +++ /dev/null @@ -1,267 +0,0 @@ -import { - AnglesUnitEnum, - CIELabObject, - CMYKObject, - Color, - ColorUnitEnum, - HEXObject, - HSLObject, - HWBObject, - LCHObject, - NumberOrString, - Options, - RGBObject -} from '@types'; -import { - COLOR_PROPS, - ColorModel, - TEMPLATE_VAR, - VALID_COLOR_OBJECTS -} from '#constants'; -import { - from125NumberToPercent, - from150NumberToPercent, - from255NumberToPercent, - getOrderedArrayString, - percent, - round, - toHEX, - translateDegrees -} from '#helpers'; - -const getComma = (withSpace: boolean): string => withSpace - ? ', ' - : ','; - -type Transformer = (value: NumberOrString, index?: number) => NumberOrString; - -const prepareColorForCss = ( - color: Color, - transformer: Transformer -): NumberOrString[] => { - const props = getOrderedArrayString(Object.keys(color)); - const model = VALID_COLOR_OBJECTS[props]; - const keys = COLOR_PROPS[model]; - return keys.reduce((result: NumberOrString[], key: keyof typeof color, index: number): NumberOrString[] => { - const value = color[key]; - if (typeof value !== 'undefined') { - result.push(transformer(value, index)); - } - return result; - }, []); -}; - -const getResultFromTemplate = (template: string, vars: NumberOrString[]): string => { - return template.replace(TEMPLATE_VAR, (__match: string, indexStr: string): string => { - const index = +indexStr - 1; - return `${vars[index]}`; - }); -}; - -const getAlpha = (value: number, options: Options, ignoreLegacy = false): NumberOrString => { - const { alphaUnit, legacyCSS, decimals } = options; - if ( - alphaUnit === ColorUnitEnum.PERCENT && - ( - !legacyCSS || - ignoreLegacy - ) - ) { - return `${round(value * 100, decimals)}%`; - } - return round(value, decimals); -}; - -const buildHueTransformer = (options: Options) => { - const { anglesUnit, decimals } = options; - return (value: number, index: number): NumberOrString => { - if ( - index === 0 && - anglesUnit !== AnglesUnitEnum.NONE - ) { - const translated = round( - translateDegrees( - value, - anglesUnit - ), - decimals - ); - return `${translated}${anglesUnit}`; - } - return index === 3 - ? getAlpha(value, options) - : round(value, decimals); - }; -}; - -export const CSS = { - [ColorModel.HEX]: (color: HEXObject | RGBObject): string => { - const transformer = (value: NumberOrString): string => toHEX(round(value)); - const values = prepareColorForCss(color, transformer); - const template = values.length === 4 - ? '#{1}{2}{3}{4}' - : '#{1}{2}{3}'; - return getResultFromTemplate(template, values); - }, - [ColorModel.RGB]: (color: RGBObject, options: Options): string => { - const { - decimals, - legacyCSS, - spacesAfterCommas, - rgbUnit - } = options; - const comma = getComma(spacesAfterCommas); - const transformer = (value: number, index: number): NumberOrString => { - return rgbUnit === ColorUnitEnum.PERCENT && index < 3 - ? `${from255NumberToPercent(value, decimals)}%` - : ( - index === 3 - ? getAlpha(value, options) - : round(value, decimals) - ); - }; - const values = prepareColorForCss(color, transformer); - const template = legacyCSS - ? ( - values.length === 4 - ? `rgba({1}${comma}{2}${comma}{3}${comma}{4})` - : `rgb({1}${comma}{2}${comma}{3})` - ) - : ( - values.length === 4 - ? `rgb({1} {2} {3} / {4})` - : `rgb({1} {2} {3})` - ); - return getResultFromTemplate(template, values); - }, - [ColorModel.HSL]: (color: HSLObject, options: Options): string => { - const { legacyCSS, spacesAfterCommas } = options; - const comma = getComma(spacesAfterCommas); - const transformer = buildHueTransformer(options); - const values = prepareColorForCss(color, transformer); - const template = legacyCSS - ? ( - values.length === 4 - ? `hsla({1}${comma}{2}%${comma}{3}%${comma}{4})` - : `hsl({1}${comma}{2}%${comma}{3}%)` - ) - : ( - values.length === 4 - ? `hsl({1} {2}% {3}% / {4})` - : `hsl({1} {2}% {3}%)` - ); - return getResultFromTemplate(template, values); - }, - [ColorModel.HWB]: (color: HWBObject, options: Options) => { - const transformer = buildHueTransformer(options); - const values = prepareColorForCss(color, transformer); - const template = values.length === 4 - ? `hwb({1} {2}% {3}% / {4})` - : `hwb({1} {2}% {3}%)`; - return getResultFromTemplate(template, values); - }, - [ColorModel.CIELab]: (color: CIELabObject, options: Options) => { - const { - decimals, - labUnit - } = options; - const transformer = (value: number, index: number): NumberOrString => { - if (index === 0) { - const L = round( - percent(value), - decimals - ); - return labUnit === ColorUnitEnum.PERCENT - ? `${L}%` - : `${L}`; - } - if (index < 3) { - return labUnit === ColorUnitEnum.PERCENT - ? `${from125NumberToPercent(value, decimals)}%` - : round(value, decimals); - } - return getAlpha(value, options, true); - }; - const values = prepareColorForCss(color, transformer); - const template = values.length === 4 - ? `lab({1} {2} {3} / {4})` - : `lab({1} {2} {3})`; - return getResultFromTemplate(template, values); - }, - [ColorModel.LCH]: (color: LCHObject, options: Options) => { - const { - decimals, - lchUnit, - anglesUnit - } = options; - const transformer = (value: number, index: number): NumberOrString => { - if (index === 0) { - const L = round( - percent(value), - decimals - ); - return lchUnit === ColorUnitEnum.PERCENT - ? `${L}%` - : `${L}`; - } - if (index === 1) { - return lchUnit === ColorUnitEnum.PERCENT - ? `${from150NumberToPercent(value, decimals)}%` - : round(value, decimals); - } - if (index === 2) { - if (anglesUnit !== AnglesUnitEnum.NONE) { - const translated = round( - translateDegrees( - value, - anglesUnit - ), - decimals - ); - return `${translated}${anglesUnit}`; - } - return round(value, decimals); - } - return getAlpha(value, options, true); - }; - const values = prepareColorForCss(color, transformer); - const template = values.length === 4 - ? `lch({1} {2} {3} / {4})` - : `lch({1} {2} {3})`; - return getResultFromTemplate(template, values); - }, - [ColorModel.CMYK]: (color: CMYKObject, options: Options): string => { - const { - decimals, - legacyCSS, - spacesAfterCommas, - cmykUnit, - cmykFunction - } = options; - const comma = getComma(spacesAfterCommas); - const transformer = (value: number, index: number): NumberOrString => { - if ( - cmykUnit === ColorUnitEnum.PERCENT && - index < 4 - ) { - return `${round(value, decimals)}%`; - } - return index === 4 - ? getAlpha(value, options) - : round(value / 100, decimals); - }; - const values = prepareColorForCss(color, transformer); - const template = legacyCSS - ? ( - values.length === 5 - ? `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4}${comma}{5})` - : `${cmykFunction}({1}${comma}{2}${comma}{3}${comma}{4})` - ) - : ( - values.length === 5 - ? `${cmykFunction}({1} {2} {3} {4} / {5})` - : `${cmykFunction}({1} {2} {3} {4})` - ); - return getResultFromTemplate(template, values); - } -}; \ No newline at end of file diff --git a/src/color/extractors.ts b/src/color/extractors.ts deleted file mode 100644 index 2c77862..0000000 --- a/src/color/extractors.ts +++ /dev/null @@ -1,410 +0,0 @@ -import { - AnglesUnitEnum, - CIELabObjectGeneric, - CMYKFunctionEnum, - CMYKObjectGeneric, - Color, - ColorInput, - ColorUnitEnum, - HSLObjectGeneric, - HWBObjectGeneric, - InputOptions, - LCHObjectGeneric, - MatchOptions, - Options, - RGBObject, - RGBObjectGeneric -} from '@types'; -import { - BASE_255, - COLOR_KEYS, - ColorKeywords, - ColorModel, - COLORREGS, - COMMAS_AND_NEXT_CHARS, - DEFAULT_OPTIONS, - ERRORS, - HEX, - PCENT, - SPACES, - TypeOf, - VALID_COLOR_OBJECTS -} from '#constants'; -import { - getBase125Number, - getBase150Number, - getBase255Number, - getCMYKNumber, - getOrderedArrayString, - hasProp, - normalizeAlpha, - normalizeHue, - percent -} from '#helpers'; -import { - CIELabStringParser, - CMYKStringParser, - HEXStringParser, - HSLStringParser, - HWBStringParser, - LCHStringParser, - RGBStringParser -} from '#parsers'; -import { - cmykToRgb, - hslToRgb, - hwbToRgb, - labToRgb, - lchToRgb -} from '#color/translators'; - -//---Detect the color model from an string -const getColorModelFromString = (color: string): ColorModel => { - let model; - Object.keys(ColorModel).some((p: ColorModel): boolean => { - const reg = COLORREGS[p]; - if (reg.test(color)) { - model = p; - return true; - } - }); - if ( - !model && - !!~COLOR_KEYS.indexOf(color) - ) { - model = ColorModel.HEX; - } - if (!model) { - throw new Error(ERRORS.NOT_ACCEPTED_STRING_INPUT); - } - return model; -}; - -//---Detect the color model from an object -const getColorModelFromObject = (color: Color): ColorModel => { - - let model: ColorModel; - let invalid = false; - const props = getOrderedArrayString(Object.keys(color)); - - if(VALID_COLOR_OBJECTS[props]) { - model = VALID_COLOR_OBJECTS[props]; - } - - if (model && model === ColorModel.RGB) { - - const hasInvalidHex = Object.entries(color).some((item: [string, string | number]): boolean => { - return !HEX.test(`${item[1]}`); - }); - - const hasInvalidRegb = Object.entries(color).some((item: [string, string | number]): boolean => { - return !( - PCENT.test(`${item[1]}`) || - ( - !HEX.test(`${item[1]}`) && - !isNaN(+item[1]) && - +item[1] <= BASE_255 - ) - ); - }); - - if (hasInvalidHex && hasInvalidRegb) { - invalid = true; - } - - if (!hasInvalidHex) { - model = ColorModel.HEX; - } - - } - if (!model || invalid) { - throw new Error(ERRORS.NOT_ACCEPTED_OBJECT_INPUT); - } - return model; -}; - -//---Detect the color model -export const getColorModel = (color: string | Color): ColorModel => typeof color === 'string' - ? getColorModelFromString(color) - : getColorModelFromObject(color); - -//---Convert a color string to an RGB object -export const getRGBObjectFromString = { - [ColorModel.HEX](color: string): RGBObject { - const colorStr = !~COLOR_KEYS.indexOf(color) - ? color - : ColorKeywords[color as keyof typeof ColorKeywords]; - return new HEXStringParser(colorStr).rgb; - }, - [ColorModel.RGB](color: string): RGBObject { - return new RGBStringParser(color, getRGBObject).rgb; - }, - [ColorModel.HSL](color: string): RGBObject { - return new HSLStringParser(color, getRGBObject).rgb; - }, - [ColorModel.HWB](color: string): RGBObject { - return new HWBStringParser(color, getRGBObject).rgb; - }, - [ColorModel.CIELab](color: string): RGBObject { - return new CIELabStringParser(color, getRGBObject).rgb; - }, - [ColorModel.LCH](color: string): RGBObject { - return new LCHStringParser(color, getRGBObject).rgb; - }, - [ColorModel.CMYK](color: string): RGBObject { - return new CMYKStringParser(color).rgb; - } -}; - -//---Convert a color object to an RGB object -export const getRGBObjectFromObject = { - [ColorModel.HEX](color: RGBObjectGeneric): RGBObject { - const object: RGBObject = { - R: getBase255Number(`${color.R}`), - G: getBase255Number(`${color.G}`), - B: getBase255Number(`${color.B}`) - }; - if (hasProp(color, 'A')) { - object.A = Math.min(getBase255Number(`${color.A}`, true), 1); - } - return object; - }, - [ColorModel.RGB](color: RGBObjectGeneric): RGBObject { - return this.HEX(color); - }, - [ColorModel.HSL](color: HSLObjectGeneric): RGBObject { - const S = percent(`${color.S}`); - const L = percent(`${color.L}`); - const RGB = hslToRgb(normalizeHue(color.H), S, L); - if (hasProp(color, 'A')) { - RGB.A = normalizeAlpha(color.A); - } - return RGB; - }, - [ColorModel.HWB](color: HWBObjectGeneric): RGBObject { - const W = percent(`${color.W}`); - const B = percent(`${color.B}`); - const RGB = hwbToRgb(normalizeHue(color.H), W, B); - if (hasProp(color, 'A')) { - RGB.A = normalizeAlpha(color.A); - } - return RGB; - }, - [ColorModel.CIELab](color: CIELabObjectGeneric): RGBObject { - const L = percent(`${color.L}`); - const a = getBase125Number(`${color.a}`); - const b = getBase125Number(`${color.b}`); - const RGB = labToRgb(L, a, b); - if (hasProp(color, 'A')) { - RGB.A = normalizeAlpha(color.A); - } - return RGB; - }, - [ColorModel.LCH](color: LCHObjectGeneric): RGBObject { - const L = percent(`${color.L}`); - const C = getBase150Number(`${color.C}`); - const H = normalizeHue(`${color.H}`); - const RGB = lchToRgb(L, C, H); - if (hasProp(color, 'A')) { - RGB.A = normalizeAlpha(color.A); - } - return RGB; - }, - [ColorModel.CMYK](color: CMYKObjectGeneric): RGBObject { - const C = getCMYKNumber(`${color.C}`); - const M = getCMYKNumber(`${color.M}`); - const Y = getCMYKNumber(`${color.Y}`); - const K = getCMYKNumber(`${color.K}`); - const RGB = cmykToRgb(C, M, Y, K); - if (hasProp(color, 'A')) { - RGB.A = normalizeAlpha(color.A); - } - return RGB; - } -}; - -export const getRGBObject = (color: ColorInput, model: ColorModel = getColorModel(color)): RGBObject => { - return typeof color === 'string' - ? getRGBObjectFromString[model](color) - : getRGBObjectFromObject[model]( - color as ( - RGBObjectGeneric & - HSLObjectGeneric & - HWBObjectGeneric & - CIELabObjectGeneric & - LCHObjectGeneric & - CMYKObjectGeneric - ) - ); -}; - -export const getOptionsFromColorInput = (options: InputOptions, ...colors: ColorInput[]): Options => { - const cssColors: string[] = []; - const anglesUnits: AnglesUnitEnum[] = []; - const rgbColors: boolean[] = []; - const labColors: boolean[] = []; - const lchColors: boolean[] = []; - const cmykColors: boolean[] = []; - const alphaValues: boolean[] = []; - const anglesUnitValues = Object.values(AnglesUnitEnum); - const colorUnitValues = Object.values(ColorUnitEnum); - const cmykFunctionValues = Object.values(CMYKFunctionEnum); - - const matchOptions: MatchOptions = { - legacyCSS: 0, - spacesAfterCommas: 0, - cmykFunction: 0 - }; - - for(const color of colors) { - - if (typeof color === 'string') { - - cssColors.push(color); - - if (color.includes(',')){ - matchOptions.legacyCSS ++; - const commasWithNextCharacter = color.match(COMMAS_AND_NEXT_CHARS); - if ( - new Set(commasWithNextCharacter).size === 1 && - SPACES.test(commasWithNextCharacter[0].slice(1)) - ) { - matchOptions.spacesAfterCommas ++; - } - } - - if (HSLStringParser.test(color)) { - const parser = new HSLStringParser(color, getRGBObject); - anglesUnits.push(parser.angleUnit); - alphaValues.push( - parser.hasPercentageAlpha - ); - continue; - } - - if (HWBStringParser.test(color)) { - const parser = new HWBStringParser(color, getRGBObject); - anglesUnits.push(parser.angleUnit); - alphaValues.push( - parser.hasPercentageAlpha - ); - continue; - } - - if (RGBStringParser.test(color)) { - const parser = new RGBStringParser(color, getRGBObject); - rgbColors.push( - parser.hasPercentageValues - ); - alphaValues.push( - parser.hasPercentageAlpha - ); - continue; - } - - if (CIELabStringParser.test(color)) { - const parser = new CIELabStringParser(color, getRGBObject); - labColors.push( - parser.hasPercentageValues - ); - alphaValues.push( - parser.hasPercentageAlpha - ); - continue; - } - - if (LCHStringParser.test(color)) { - const parser = new LCHStringParser(color, getRGBObject); - anglesUnits.push(parser.angleUnit); - lchColors.push( - parser.hasPercentageValues - ); - alphaValues.push( - parser.hasPercentageAlpha - ); - continue; - } - - if (CMYKStringParser.test(color)) { - const parser = new CMYKStringParser(color); - cmykColors.push( - parser.hasPercentageValues - ); - if (color.startsWith('cmyk')) { - matchOptions.cmykFunction ++; - } - alphaValues.push( - parser.hasPercentageAlpha - ); - } - - } - - } - return { - decimals: typeof options.decimals === TypeOf.NUMBER - ? options.decimals - : DEFAULT_OPTIONS.decimals, - legacyCSS: typeof options.legacyCSS === TypeOf.BOOLEAN - ? options.legacyCSS - : Boolean( - cssColors.length && - matchOptions.legacyCSS === cssColors.length - ) || DEFAULT_OPTIONS.legacyCSS, - spacesAfterCommas: typeof options.spacesAfterCommas === TypeOf.BOOLEAN - ? options.spacesAfterCommas - : Boolean( - cssColors.length && - matchOptions.spacesAfterCommas === cssColors.length - ) || DEFAULT_OPTIONS.spacesAfterCommas, - anglesUnit: options.anglesUnit && anglesUnitValues.includes(options.anglesUnit) - ? options.anglesUnit as AnglesUnitEnum - : ( - new Set(anglesUnits).size === 1 - ? anglesUnits[0] - : DEFAULT_OPTIONS.anglesUnit - ), - rgbUnit: options.rgbUnit && colorUnitValues.includes(options.rgbUnit) - ? options.rgbUnit as ColorUnitEnum - : ( - new Set(rgbColors).size === 1 && rgbColors[0] - ? ColorUnitEnum.PERCENT - : DEFAULT_OPTIONS.rgbUnit - ), - labUnit: options.labUnit && colorUnitValues.includes(options.labUnit) - ? options.labUnit as ColorUnitEnum - : ( - new Set(labColors).size === 1 && labColors[0] - ? ColorUnitEnum.PERCENT - : DEFAULT_OPTIONS.labUnit - ), - lchUnit: options.lchUnit && colorUnitValues.includes(options.lchUnit) - ? options.lchUnit as ColorUnitEnum - : ( - new Set(lchColors).size === 1 && lchColors[0] - ? ColorUnitEnum.PERCENT - : DEFAULT_OPTIONS.lchUnit - ), - cmykUnit: options.cmykUnit && colorUnitValues.includes(options.cmykUnit) - ? options.cmykUnit as ColorUnitEnum - : ( - new Set(cmykColors).size === 1 && !cmykColors[0] - ? ColorUnitEnum.NONE - : DEFAULT_OPTIONS.cmykUnit - ), - alphaUnit: options.alphaUnit && colorUnitValues.includes(options.alphaUnit) - ? options.alphaUnit as ColorUnitEnum - : ( - new Set(alphaValues).size === 1 && alphaValues[0] - ? ColorUnitEnum.PERCENT - : DEFAULT_OPTIONS.alphaUnit - ), - cmykFunction: options.cmykFunction && cmykFunctionValues.includes(options.cmykFunction) - ? options.cmykFunction as CMYKFunctionEnum - : ( - cmykColors.length && cmykColors.length === matchOptions.cmykFunction - ? CMYKFunctionEnum.CMYK - : DEFAULT_OPTIONS.cmykFunction - ) - }; -}; \ No newline at end of file diff --git a/src/color/rgb.ts b/src/color/rgb.ts new file mode 100644 index 0000000..e94a0b4 --- /dev/null +++ b/src/color/rgb.ts @@ -0,0 +1,92 @@ +import { + ColorObject, + RGBObject +} from '@types'; +import { + cmykToRgb, + hslToRgb, + hwbToRgb, + labToRgb, + lchToRgb +} from '#color/translators'; +import { + isCIELabObject, + isCMYKObject, + isHSLObject, + isHWBObject, + isLCHObject, + isUndefined +} from '#utilities'; + +const getAlpha = (color: ColorObject): { A?: number} => { + if (isUndefined(color.A)) { + return {}; + } + return { + A: +color.A + }; +}; + +export const getRGB = (color: ColorObject): RGBObject => { + + const alpha = getAlpha(color); + + if (isHSLObject(color)) { + return { + ...hslToRgb( + color.H, + color.S, + color.L + ), + ...alpha + }; + } + + if (isHWBObject(color)) { + return { + ...hwbToRgb( + color.H, + color.W, + color.B + ), + ...alpha + }; + } + + if (isCIELabObject(color)) { + return { + ...labToRgb( + color.L, + color.a, + color.b + ), + ...alpha + }; + } + + if (isLCHObject(color)) { + return { + ...lchToRgb( + color.L, + color.C, + color.H + ), + ...alpha + }; + } + + if (isCMYKObject(color)) { + return { + ...cmykToRgb( + color.C, + color.M, + color.Y, + color.K + ), + ...alpha + }; + } + + return color as RGBObject; + +}; \ No newline at end of file diff --git a/src/color/rounders.ts b/src/color/rounders.ts deleted file mode 100644 index 0d495c1..0000000 --- a/src/color/rounders.ts +++ /dev/null @@ -1,64 +0,0 @@ -import { - CIELabObject, - CMYKObject, - HSLObject, - HWBObject, - LCHObject -} from '@types'; -import { round } from '#helpers'; - -export const roundHSLObject = ( - color: HSLObject, - decimals: number -): HSLObject => { - return { - H: round(color.H, decimals), - S: round(color.S, decimals), - L: round(color.L, decimals) - }; -}; - -export const roundHWBObject = ( - color: HWBObject, - decimals: number -): HWBObject => { - return { - H: round(color.H, decimals), - W: round(color.W, decimals), - B: round(color.B, decimals) - }; -}; - -export const roundCIELabObject = ( - color: CIELabObject, - decimals: number -): CIELabObject => { - return { - L: round(color.L, decimals), - a: round(color.a, decimals), - b: round(color.b, decimals) - }; -}; - -export const roundLCHObject = ( - color: LCHObject, - decimals: number -): LCHObject => { - return { - L: round(color.L, decimals), - C: round(color.C, decimals), - H: round(color.H, decimals) - }; -}; - -export const roundCMYKObject = ( - color: CMYKObject, - decimals: number -): CMYKObject => { - return { - C: round(color.C, decimals), - M: round(color.M, decimals), - Y: round(color.Y, decimals), - K: round(color.K, decimals) - }; -}; \ No newline at end of file diff --git a/src/color/translators.ts b/src/color/translators.ts index 6a4fd81..8479564 100644 --- a/src/color/translators.ts +++ b/src/color/translators.ts @@ -15,7 +15,7 @@ import { normalizeHue, radians, round -} from '#helpers'; +} from '#utilities'; const MATRIX_LRGB_XYZ_D50: [ColorArray, ColorArray, ColorArray] = [ [0.4360747, 0.3850649, 0.1430804], @@ -320,9 +320,21 @@ export const hwbToRgb = (H: number, W: number, B: number): RGBObject => { export const cmykToRgb = (C: number, M: number, Y: number, K: number): RGBObject => { K = 1 - K; return { - R: round(BASE_255 * (1 - C) * K), - G: round(BASE_255 * (1 - M) * K), - B: round(BASE_255 * (1 - Y) * K) + R: minmax( + round(BASE_255 * (1 - C) * K), + 0, + BASE_255 + ), + G: minmax( + round(BASE_255 * (1 - M) * K), + 0, + BASE_255 + ), + B: minmax( + round(BASE_255 * (1 - Y) * K), + 0, + BASE_255 + ) }; }; diff --git a/src/color/utils.ts b/src/color/utils.ts deleted file mode 100644 index 572102b..0000000 --- a/src/color/utils.ts +++ /dev/null @@ -1,1013 +0,0 @@ -import { - CIELabObject, - CIELabObjectGeneric, - CIELabOutput, - CMYKObject, - ColorInput, - ColorInputWithoutCMYK, - ColorOutput, - HEXObject, - HEXOutput, - HSLObject, - HSLObjectGeneric, - HSLOutput, - HWBObject, - HWBObjectGeneric, - HWBOutput, - LCHObject, - LCHObjectGeneric, - LCHOutput, - Options, - RGBObject, - RGBObjectGeneric, - RGBOutput, - RGYBObject, - RYBObject -} from '@types'; -import { - BASE_255, - ColorModel, - Mix, - MixString -} from '#constants'; -import { - getHEX, - hasProp, - minmax, - normalizeAlpha, - normalizeHue, - round -} from '#helpers'; -import { - hslToRgb, - hueRyb, - rgbToCmyk, - rgbToHsl, - rgbToHwb, - rgbToLab, - rgbToLch, - rgbToRyb, - rybToRgb -} from '#color/translators'; -import { - getColorModel, - getRGBObject -} from './extractors'; -import { - roundCIELabObject, - roundCMYKObject, - roundHSLObject, - roundHWBObject, - roundLCHObject -} from './rounders'; -import { CSS } from '#color/css'; - -type HarmonyFunction = (color: HSLObject, mode: MixString) => HSLObject[]; - -//---Harmony -const harmony = ( - color: HSLObject, - angles: number[], - mode: MixString -): HSLObject[] => - angles.reduce( - (arr: HSLObject[], num: number): HSLObject[] => - ( - [ - ...arr, - { - ...color, - H: mode === Mix.ADDITIVE - ? normalizeHue(color.H + num) - : normalizeHue(hueRyb(hueRyb(color.H, false) + num, true)) - } - ] - ), [{...color}] - ); - -export const analogous = (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [30, -30], mode); -export const complementary = (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [180], mode); -export const splitComplementary = (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [150, -150], mode); -export const triadic = (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [120, -120], mode); -export const tetradic = (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [60, -120, 180], mode); -export const square = (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [90, -90, 180], mode); - -//---Get the color values from an object -export const translateColor = { - - [ColorModel.HEX](color: RGBObject): HEXObject { - return { - R: getHEX(color.R), - G: getHEX(color.G), - B: getHEX(color.B) - }; - }, - - HEXA(color: RGBObject): HEXObject { - const RGB = translateColor.HEX(color); - RGB.A = hasProp(color, 'A') - ? getHEX(color.A * BASE_255) - : '0xFF'; - return RGB; - }, - - [ColorModel.RGB](color: RGBObject, decimals: number): RGBObject { - const RGB = roundRGBObject(color, decimals); - if (hasProp(RGB, 'A')) { - delete RGB.A; - } - return RGB; - }, - - RGBA(color: RGBObject, decimals: number): RGBObject { - const RGB = translateColor.RGB(color, decimals); - RGB.A = hasProp(color, 'A') - ? round(color.A) - : 1; - return RGB; - }, - - [ColorModel.HSL](color: RGBObject, decimals: number): HSLObject { - const HSL = rgbToHsl(color.R, color.G, color.B); - delete HSL.A; - return roundHSLObject(HSL, decimals); - }, - - HSLA(color: RGBObject, decimals: number): HSLObject { - const HSL = translateColor.HSL(color, decimals); - HSL.A = hasProp(color, 'A') - ? round(color.A, decimals) - : 1; - return HSL; - }, - - [ColorModel.HWB](color: RGBObject, decimals: number): HWBObject { - const HWB = rgbToHwb(color.R, color.G, color.B); - delete HWB.A; - return roundHWBObject(HWB, decimals); - }, - - HWBA(color: RGBObject, decimals: number): HWBObject { - const HWB = translateColor.HWB(color, decimals); - HWB.A = hasProp(color, 'A') - ? round(color.A, decimals) - : 1; - return HWB; - }, - - [ColorModel.CIELab](color: RGBObject, decimals: number): CIELabObject { - const Lab = rgbToLab(color.R, color.G, color.B); - return roundCIELabObject(Lab, decimals); - }, - - CIELabA(color: RGBObject, decimals: number): CIELabObject { - const Lab = translateColor.CIELab(color, decimals); - Lab.A = hasProp(color, 'A') - ? round(color.A, decimals) - : 1; - return Lab; - }, - - [ColorModel.LCH](color: RGBObject, decimals: number): LCHObject { - const lch = rgbToLch(color.R, color.G, color.B); - return roundLCHObject(lch, decimals); - }, - - LCHA(color: RGBObject, decimals: number): LCHObject { - const lch = translateColor.LCH(color, decimals); - lch.A = hasProp(color, 'A') - ? round(color.A, decimals) - : 1; - return lch; - }, - - [ColorModel.CMYK](color: RGBObject, decimals: number): CMYKObject { - return roundCMYKObject( - rgbToCmyk(color.R, color.G, color.B), - decimals - ); - }, - - CMYKA(color: RGBObject, decimals: number): CMYKObject { - const CMYK = translateColor.CMYK(color, decimals); - CMYK.A = hasProp(color, 'A') - ? round(color.A, decimals) - : 1; - return CMYK; - } -}; - -//---Blending -export const blend = (from: RGBObject, to: RGBObject, steps: number): RGBObject[] => { - const div = steps - 1; - const diffR = (to.R - from.R) / div; - const diffG = (to.G - from.G) / div; - const diffB = (to.B - from.B) / div; - const fromA = normalizeAlpha(from.A); - const toA = normalizeAlpha(to.A); - const diffA = (toA - fromA) / div; - return Array(steps).fill(null).map((__n, i): RGBObject => { - if (i === 0) { return from; } - if (i === div) { return to; } - return { - R: round(from.R + diffR * i), - G: round(from.G + diffG * i), - B: round(from.B + diffB * i), - A: round(fromA + diffA * i) - }; - }); -}; - -//---Shades -export const getColorMixture = ( - color: ColorInputWithoutCMYK, - steps: number, - shades: boolean, - options: Options -): ColorOutput[] => { - const model = getColorModel(color); - const isCSS = typeof color === 'string'; - const RGB = getRGBObject(color, model); - const hasAlpha = ( - (typeof color === 'string' && hasProp(RGB, 'A')) || - (typeof color !== 'string' && - hasProp< - | RGBObjectGeneric - | HSLObjectGeneric - | HWBObjectGeneric - | CIELabObjectGeneric - | LCHObjectGeneric - >(color, 'A')) - ); - const HSL: HSLObject = rgbToHsl(RGB.R, RGB.G, RGB.B, RGB.A); - if (!hasAlpha) delete HSL.A; - const increment = shades - ? HSL.L / (steps + 1) - : (100 - HSL.L) / (steps + 1); - const hslMap = Array(steps).fill(null).map((__n, i): HSLObject => ({ - ...HSL, - L: HSL.L + increment * (i + 1) * (1 - +shades * 2) - })); - switch(model) { - case ColorModel.HEX: - default: - return hslMap.map((HSLColor: HSLObject): HEXOutput => { - const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L); - if (hasAlpha) RGBColor.A = HSLColor.A; - return isCSS - ? hasAlpha - ? CSS.HEX( - { - ...RGBColor, - A: round(RGBColor.A * BASE_255) - } - ) - : CSS.HEX(RGBColor) - : hasAlpha - ? translateColor.HEXA(RGBColor) - : translateColor.HEX(RGBColor); - }); - case ColorModel.RGB: - return hslMap.map((HSLColor: HSLObject): RGBOutput => { - const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L); - if (hasAlpha) RGBColor.A = HSLColor.A; - return isCSS - ? CSS.RGB(RGBColor, options) - : hasAlpha - ? translateColor.RGBA(RGBColor, options.decimals) - : translateColor.RGB(RGBColor, options.decimals);; - }); - case ColorModel.HSL: - return hslMap.map((HSLColor: HSLObject): HSLOutput => { - return isCSS - ? CSS.HSL(HSLColor, options) - : hasAlpha - ? translateColor.HSLA( - { - ...hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L), - A: HSLColor.A - }, - options.decimals - ) - : translateColor.HSL( - hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L), - options.decimals - ); - }); - case ColorModel.HWB: - return hslMap.map((HSLColor: HSLObject): HWBOutput => { - const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L); - if (hasAlpha) RGBColor.A = HSLColor.A; - const hwb = hasAlpha - ? translateColor.HWBA(RGBColor, options.decimals) - : translateColor.HWB(RGBColor, options.decimals); - return isCSS - ? CSS.HWB(hwb, options) - : hwb; - }); - case ColorModel.CIELab: - return hslMap.map((HSLColor: HSLObject): CIELabOutput => { - const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L); - if (hasAlpha) RGBColor.A = HSLColor.A; - const lab = hasAlpha - ? translateColor.CIELabA(RGBColor, options.decimals) - : translateColor.CIELab(RGBColor, options.decimals); - return isCSS - ? CSS.CIELab(lab, options) - : lab; - }); - case ColorModel.LCH: - return hslMap.map((HSLColor: HSLObject): LCHOutput => { - const RGBColor = hslToRgb(HSLColor.H, HSLColor.S, HSLColor.L); - const LCHColor = rgbToLch(RGBColor.R, RGBColor.G, RGBColor.B); - if (hasAlpha) LCHColor.A = HSLColor.A; - return isCSS - ? CSS.LCH(LCHColor, options) - : hasAlpha - ? translateColor.LCHA( - { - ...RGBColor, - A: HSLColor.A - }, - options.decimals - ) - : translateColor.LCH( - RGBColor, - options.decimals - ); - }); - } -}; - -//---Harmony -export const colorHarmony = { - - buildHarmony( - color: ColorInputWithoutCMYK, - harmonyFunction: HarmonyFunction, - mode: MixString, - options: Options - ): ColorOutput[] { - const model = getColorModel(color); - const RGB = getRGBObject(color, model); - const HSL = rgbToHsl(RGB.R, RGB.G, RGB.B, RGB.A); - const hasAlpha = ( - (typeof color === 'string' && hasProp(RGB, 'A')) || - ( - typeof color !== 'string' && - hasProp< - | RGBObjectGeneric - | HSLObjectGeneric - | HWBObjectGeneric - | CIELabObjectGeneric - | LCHObjectGeneric - >(color, 'A') - ) - ); - const isCSS = typeof color === 'string'; - switch(model) { - case ColorModel.HEX: - default: - return hasAlpha - ? this.HEXA( - roundHSLObject(HSL, 0), - harmonyFunction, - mode, - isCSS - ) - : this.HEX( - roundHSLObject(HSL, 0), - harmonyFunction, - mode, - isCSS - ); - case ColorModel.HSL: - return hasAlpha - ? this.HSLA(HSL, harmonyFunction, mode, isCSS, options) - : this.HSL(HSL, harmonyFunction, mode, isCSS, options); - case ColorModel.HWB: - return hasAlpha - ? this.HWBA(HSL, harmonyFunction, mode, isCSS, options) - : this.HWB(HSL, harmonyFunction, mode, isCSS, options); - case ColorModel.RGB: - return hasAlpha - ? this.RGBA(HSL, harmonyFunction, mode, isCSS, options) - : this.RGB(HSL, harmonyFunction, mode, isCSS, options); - case ColorModel.CIELab: - return hasAlpha - ? this.CIELabA(HSL, harmonyFunction, mode, isCSS, options) - : this.CIELab(HSL, harmonyFunction, mode, isCSS, options); - case ColorModel.LCH: - return hasAlpha - ? this.LCHA(HSL, harmonyFunction, mode, isCSS, options) - : this.LCH(HSL, harmonyFunction, mode, isCSS, options); - } - }, - - [ColorModel.HEX]( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean - ): HEXOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): HEXOutput => ( - css - ? CSS.HEX( - hslToRgb(c.H, c.S, c.L) - ) - : translateColor.HEX( - hslToRgb(c.H, c.S, c.L) - ) - ) - ); - }, - - HEXA( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean - ): HEXOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): HEXOutput => ( - css - ? CSS.HEX( - { - ...hslToRgb(c.H, c.S, c.L), - A: normalizeAlpha(c.A) * BASE_255 - } - ) - : translateColor.HEXA({ - ...hslToRgb(c.H, c.S, c.L), - A: normalizeAlpha(c.A) - }) - ) - ); - }, - - [ColorModel.RGB]( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): RGBOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): RGBOutput => ( - css - ? CSS.RGB( - hslToRgb(c.H, c.S, c.L), - options - ) - : translateColor.RGB( - hslToRgb(c.H, c.S, c.L), - options.decimals - ) - ) - ); - }, - - RGBA( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): RGBOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): RGBOutput => ( - css - ? CSS.RGB( - { - ...hslToRgb(c.H, c.S, c.L), - A: normalizeAlpha(c.A) - }, - options - ) - : translateColor.RGBA( - { - ...hslToRgb(c.H, c.S, c.L), - A: normalizeAlpha(c.A) - }, - options.decimals - ) - ) - ); - }, - - [ColorModel.HSL]( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): HSLOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): HSLOutput => ( - css - ? CSS.HSL( - { - H: c.H, - S: c.S, - L: c.L - }, - options - ) - : translateColor.HSL( - hslToRgb(c.H, c.S, c.L), - options.decimals - ) - ) - ); - }, - - HSLA( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): HSLOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): HSLOutput => ( - css - ? CSS.HSL( - { - ...c, - A: normalizeAlpha(c.A) - }, - options - ) - : translateColor.HSLA( - { - ...hslToRgb(c.H, c.S, c.L), - A: normalizeAlpha(c.A) - }, - options.decimals - ) - ) - ); - }, - - [ColorModel.HWB]( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): HWBOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): HWBOutput => { - const rgb = hslToRgb(c.H, c.S, c.L); - const hwb = rgbToHwb(rgb.R, rgb.G, rgb.B); - return css - ? CSS.HWB( - { - H: hwb.H, - W: hwb.W, - B: hwb.B - }, - options - ) - : translateColor.HWB( - rgb, - options.decimals - ); - } - ); - }, - - HWBA( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): HWBOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): HWBOutput => { - const rgb = hslToRgb(c.H, c.S, c.L); - const hwb = rgbToHwb(rgb.R, rgb.G, rgb.B); - return css - ? CSS.HWB( - { - ...hwb, - A: normalizeAlpha(c.A) - }, - options - ) - : translateColor.HWBA( - { - ...rgb, - A: normalizeAlpha(c.A) - }, - options.decimals - ); - } - ); - }, - - [ColorModel.CIELab]( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): CIELabOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): CIELabOutput => { - const RGB = hslToRgb(c.H, c.S, c.L); - return ( - css - ? CSS.CIELab( - rgbToLab( - RGB.R, - RGB.G, - RGB.B - ), - options - ) - : translateColor.CIELab( - RGB, - options.decimals - ) - ); - } - ); - }, - - CIELabA( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): CIELabOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): CIELabOutput => { - const RGB = hslToRgb(c.H, c.S, c.L); - return ( - css - ? CSS.CIELab( - { - ...rgbToLab( - RGB.R, - RGB.G, - RGB.B - ), - A: normalizeAlpha(c.A) - }, - options - ) - : translateColor.CIELabA( - { - ...RGB, - A: normalizeAlpha(c.A) - }, - options.decimals - ) - ); - } - ); - }, - - [ColorModel.LCH]( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): LCHOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): LCHOutput => { - const RGB = hslToRgb(c.H, c.S, c.L); - return ( - css - ? CSS.LCH( - rgbToLch( - RGB.R, - RGB.G, - RGB.B - ), - options - ) - : translateColor.LCH( - RGB, - options.decimals - ) - ); - } - ); - }, - - LCHA( - color: HSLObject, - harmonyFunction: HarmonyFunction, - mode: MixString, - css: boolean, - options: Options - ): LCHOutput[] { - const array = harmonyFunction(color, mode); - return array.map( - (c: HSLObject): LCHOutput => { - const RGB = hslToRgb(c.H, c.S, c.L); - return ( - css - ? CSS.LCH( - { - ...rgbToLch( - RGB.R, - RGB.G, - RGB.B - ), - A: normalizeAlpha(c.A) - }, - options - ) - : translateColor.LCHA( - { - ...RGB, - A: normalizeAlpha(c.A) - }, - options.decimals - ) - ); - } - ); - } -}; - -export const colorMixer = { - - mix(colors: ColorInput[], mode: MixString): RGBObject { - - const rgbMap = colors.map((color: ColorInput): RGBObject => { - const model = getColorModel(color); - return getRGBObject(color, model); - }); - - const rybMap = mode === Mix.SUBTRACTIVE - ? rgbMap.map((color: RGBObject): RYBObject => { - const RYB = rgbToRyb(color.R, color.G, color.B); - if (hasProp(color, 'A')) { - RYB.A = color.A; - } - return RYB; - }) - : null; - - function createMix(items: RGBObject[]): RGBObject; - function createMix(items: RYBObject[]): RYBObject; - function createMix(items: RGYBObject[]): RGYBObject { - const initial = mode === Mix.ADDITIVE - ? {R: 0, G: 0, B: 0, A: 0} - : {R: 0, Y: 0, B: 0, A: 0}; - return items.reduce((mix: RGYBObject, color: RGYBObject): RGYBObject => { - const colorA = hasProp(color, 'A') ? color.A : 1; - const common = { - R: Math.min(mix.R + color.R * colorA, BASE_255), - B: Math.min(mix.B + color.B * colorA, BASE_255), - A: 1 - (1 - colorA) * (1 - mix.A) - }; - const mixGY = 'G' in mix - ? mix.G - : mix.Y; - const colorGY = 'G' in color - ? color.G - : color.Y; - return { - ...common, - ...(mode === Mix.ADDITIVE - ? { G: Math.min(mixGY + colorGY * colorA, BASE_255) } - : { Y: Math.min(mixGY + colorGY * colorA, BASE_255) } - ) - }; - }, initial); - } - - let mix: RGBObject; - - if (mode === Mix.ADDITIVE) { - mix = createMix(rgbMap); - } else { - const RYB = createMix(rybMap); - mix = rybToRgb(RYB.R, RYB.Y, RYB.B); - mix.A = RYB.A; - } - - return { - R: round(mix.R), - G: round(mix.G), - B: round(mix.B), - A: minmax(mix.A, 0, 1) - }; - }, - [ColorModel.HEX]( - colors: ColorInput[], - mode: MixString, - css: CSS - ): R { - const mix = this.mix(colors, mode); - delete mix.A; - return ( - css - ? CSS.HEX(mix) - : translateColor.HEX(mix) - ) as R; - }, - HEXA( - colors: ColorInput[], - mode: MixString, - css: CSS - ): R { - const mix = this.mix(colors, mode); - mix.A = css - ? normalizeAlpha(mix.A) * BASE_255 - : normalizeAlpha(mix.A); - return ( - css - ? CSS.HEX(mix) - : translateColor.HEXA(mix) - ) as R; - }, - [ColorModel.RGB]( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - delete mix.A; - return ( - css - ? CSS.RGB(mix, options) - : translateColor.RGB(mix, options.decimals) - ) as R; - }, - RGBA( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - return ( - css - ? CSS.RGB(mix, options) - : translateColor.RGBA(mix, options.decimals) - ) as R; - }, - [ColorModel.HSL]( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const HSL = rgbToHsl(mix.R, mix.G, mix.B); - delete mix.A; - delete HSL.A; - return ( - css - ? CSS.HSL(HSL, options) - : translateColor.HSL(mix, options.decimals) - ) as R; - }, - HSLA( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const HSL = rgbToHsl(mix.R, mix.G, mix.B, mix.A); - return ( - css - ? CSS.HSL(HSL, options) - : translateColor.HSLA(mix, options.decimals) - ) as R; - }, - [ColorModel.HWB]( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const HWB = rgbToHwb(mix.R, mix.G, mix.B); - delete mix.A; - delete HWB.A; - return ( - css - ? CSS.HWB(HWB, options) - : translateColor.HWB(mix, options.decimals) - ) as R; - }, - HWBA( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const HWB = rgbToHwb(mix.R, mix.G, mix.B, mix.A); - return ( - css - ? CSS.HWB(HWB, options) - : translateColor.HWBA(mix, options.decimals) - ) as R; - }, - [ColorModel.CIELab]( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const Lab = rgbToLab(mix.R, mix.G, mix.B); - delete mix.A; - return ( - css - ? CSS.CIELab(Lab, options) - : translateColor.CIELab(mix, options.decimals) - ) as R; - }, - CIELabA( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const Lab = rgbToLab(mix.R, mix.G, mix.B); - Lab.A = mix.A; - return ( - css - ? CSS.CIELab(Lab, options) - : translateColor.CIELabA(mix, options.decimals) - ) as R; - }, - [ColorModel.LCH]( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const lch = rgbToLch(mix.R, mix.G, mix.B); - delete mix.A; - return ( - css - ? CSS.LCH(lch, options) - : translateColor.LCH(mix, options.decimals) - ) as R; - }, - LCHA( - colors: ColorInput[], - mode: MixString, - css: CSS, - options: Options - ): R { - const mix = this.mix(colors, mode); - const lch = rgbToLch(mix.R, mix.G, mix.B); - lch.A = mix.A; - return ( - css - ? CSS.LCH(lch, options) - : translateColor.LCHA(mix, options.decimals) - ) as R; - } -}; - -export const roundRGBObject = ( - color: RGBObject, - decimals: number -): RGBObject => { - const R = round(color.R, decimals); - const G = round(color.G, decimals); - const B = round(color.B, decimals); - return { - R, - G, - B, - ...( - hasProp(color, 'A') - ? { - A: round(color.A, decimals) - } - : {} - ) - }; -}; \ No newline at end of file diff --git a/src/constants/enums-strings.ts b/src/constants/enums-strings.ts deleted file mode 100644 index 3dfc7de..0000000 --- a/src/constants/enums-strings.ts +++ /dev/null @@ -1,4 +0,0 @@ -import { Harmony, Mix } from './enums'; - -export type HarmonyString = `${Harmony}`; -export type MixString = `${Mix}`; \ No newline at end of file diff --git a/src/constants/enums.ts b/src/constants/enums.ts index 68a3996..1948be5 100644 --- a/src/constants/enums.ts +++ b/src/constants/enums.ts @@ -172,33 +172,3 @@ export enum ColorKeywords { 'yellowgreen' = '#9ACD32', 'rebeccapurple' = '#663399' } - -export const COLOR_KEYS = Object.keys(ColorKeywords); -export const COLOR_PROPS = { - HEX: ['R', 'G', 'B', 'A'], - RGB: ['R', 'G', 'B', 'A'], - HSL: ['H', 'S', 'L', 'A'], - HWB: ['H', 'W', 'B', 'A'], - CIELab: ['L', 'a', 'b', 'A'], - LCH: ['L', 'C', 'H', 'A'], - CMYK: ['C', 'M', 'Y', 'K', 'A'] -}; -export const VALID_COLOR_OBJECTS: Record = { - ABGR: ColorModel.RGB, - ABHW: ColorModel.HWB, - ACHL: ColorModel.LCH, - ACKMY: ColorModel.CMYK, - AHLS: ColorModel.HSL, - ALAB: ColorModel.CIELab, - BGR: ColorModel.RGB, - BHW: ColorModel.HWB, - CHL: ColorModel.LCH, - CKMY: ColorModel.CMYK, - HLS: ColorModel.HSL, - LAB: ColorModel.CIELab -}; - -export enum TypeOf { - NUMBER = 'number', - BOOLEAN = 'boolean' -} \ No newline at end of file diff --git a/src/constants/errors.ts b/src/constants/errors.ts deleted file mode 100644 index b327107..0000000 --- a/src/constants/errors.ts +++ /dev/null @@ -1,5 +0,0 @@ -export const ERRORS = { - NOT_ACCEPTED_STRING_INPUT: 'The provided string color doesn\'t have a correct format', - NOT_ACCEPTED_OBJECT_INPUT: 'The provided color object doesn\'t have the proper keys or format', - NOT_A_VALID_RELATIVE_COLOR: 'is not a valid operation for a relative color' -}; \ No newline at end of file diff --git a/src/constants/index.ts b/src/constants/index.ts index 2d02536..b55f38c 100644 --- a/src/constants/index.ts +++ b/src/constants/index.ts @@ -1,6 +1,74 @@ -export * from './numbers'; -export * from './enums'; -export * from './enums-strings'; +import { + AnglesUnitEnum, + CMYKFunctionEnum, + ColorUnitEnum, + Options +} from '@types'; +import { + ColorKeywords, + ColorModel, + Harmony, + Mix +} from './enums'; + +export const MAX_DECIMALS = 6; +export const DEFAULT_BLEND_STEPS = 5; +export const DEFAULT_SHADES_TINTS_STEPS = 5; +export const BASE_255 = 255; +export const MAX_HUE = 360; +export const MAX_PCENT = 100; +export const MAX_ALPHA = 1; +export const MAX_LAB = 125; +export const MAX_LCH_C = 150; +export const GRADIANS = 10 / 9; + +export const COLOR_KEYS = Object.keys(ColorKeywords); + +export const COLOR_PROPS = Object.freeze({ + HEX: ['R', 'G', 'B', 'A'], + RGB: ['R', 'G', 'B', 'A'], + HSL: ['H', 'S', 'L', 'A'], + HWB: ['H', 'W', 'B', 'A'], + CIELab: ['L', 'a', 'b', 'A'], + LCH: ['L', 'C', 'H', 'A'], + CMYK: ['C', 'M', 'Y', 'K', 'A'] +}); + +export const VALID_COLOR_OBJECTS: Record = Object.freeze({ + ABGR: ColorModel.RGB, + ABHW: ColorModel.HWB, + ACHL: ColorModel.LCH, + ACKMY: ColorModel.CMYK, + AHLS: ColorModel.HSL, + ALAB: ColorModel.CIELab, + BGR: ColorModel.RGB, + BHW: ColorModel.HWB, + CHL: ColorModel.LCH, + CKMY: ColorModel.CMYK, + HLS: ColorModel.HSL, + LAB: ColorModel.CIELab +}); + +export type HarmonyString = `${Harmony}`; +export type MixString = `${Mix}`; + +export const DEFAULT_OPTIONS: Options = Object.freeze({ + decimals: MAX_DECIMALS, + legacyCSS: false, + spacesAfterCommas: false, + anglesUnit: AnglesUnitEnum.NONE, + rgbUnit: ColorUnitEnum.NONE, + labUnit: ColorUnitEnum.NONE, + lchUnit: ColorUnitEnum.NONE, + cmykUnit: ColorUnitEnum.PERCENT, + alphaUnit: ColorUnitEnum.NONE, + cmykFunction: CMYKFunctionEnum.DEVICE_CMYK +}); + +export const ERRORS = Object.freeze({ + NOT_ACCEPTED_INPUT: `The provided string color doesn't have a correct format`, + NOT_A_VALID_RELATIVE_COLOR: 'is not a valid operation for a relative color' +}); + export * from './regexps'; -export * from './errors'; -export * from './options'; \ No newline at end of file +export * from './enums'; \ No newline at end of file diff --git a/src/constants/numbers.ts b/src/constants/numbers.ts deleted file mode 100644 index 0abc1dc..0000000 --- a/src/constants/numbers.ts +++ /dev/null @@ -1,9 +0,0 @@ -export const MAX_DECIMALS = 6; -export const DEFAULT_BLEND_STEPS = 5; -export const DEFAULT_SHADES_TINTS_STEPS = 5; -export const BASE_255 = 255; -export const MAX_HUE = 360; -export const MAX_PCENT = 100; -export const MAX_ALPHA = 1; -export const MAX_LAB = 125; -export const MAX_LCH_C = 150; diff --git a/src/constants/options.ts b/src/constants/options.ts deleted file mode 100644 index 7aaefe8..0000000 --- a/src/constants/options.ts +++ /dev/null @@ -1,20 +0,0 @@ -import { - AnglesUnitEnum, - CMYKFunctionEnum, - ColorUnitEnum, - Options -} from '@types'; -import { MAX_DECIMALS } from './numbers'; - -export const DEFAULT_OPTIONS: Options = { - decimals: MAX_DECIMALS, - legacyCSS: false, - spacesAfterCommas: false, - anglesUnit: AnglesUnitEnum.NONE, - rgbUnit: ColorUnitEnum.NONE, - labUnit: ColorUnitEnum.NONE, - lchUnit: ColorUnitEnum.NONE, - cmykUnit: ColorUnitEnum.PERCENT, - alphaUnit: ColorUnitEnum.NONE, - cmykFunction: CMYKFunctionEnum.DEVICE_CMYK -}; \ No newline at end of file diff --git a/src/css/index.ts b/src/css/index.ts new file mode 100644 index 0000000..a054fd8 --- /dev/null +++ b/src/css/index.ts @@ -0,0 +1,82 @@ +import { + AnglesUnitEnum, + Color, + ColorUnitEnum, + NumberOrString, + Options +} from '@types'; +import { + COLOR_PROPS, + TEMPLATE_VAR, + VALID_COLOR_OBJECTS +} from '#constants'; +import { + getOrderedArrayString, + round, + translateDegrees +} from '#utilities'; + +type Transformer = (value: NumberOrString, index?: number) => NumberOrString; + +export const getCSSComma = (withSpace: boolean): string => withSpace + ? ', ' + : ','; + +export const prepareColorForCss = ( + color: Color, + transformer: Transformer +): NumberOrString[] => { + const props = getOrderedArrayString(Object.keys(color)); + const model = VALID_COLOR_OBJECTS[props]; + const keys = COLOR_PROPS[model]; + return keys.reduce((result: NumberOrString[], key: keyof typeof color, index: number): NumberOrString[] => { + const value = color[key]; + if (typeof value !== 'undefined') { + result.push(transformer(value, index)); + } + return result; + }, []); +}; + +export const getResultFromCSSTemplate = (template: string, vars: NumberOrString[]): string => { + return template.replace(TEMPLATE_VAR, (__match: string, indexStr: string): string => { + const index = +indexStr - 1; + return `${vars[index]}`; + }); +}; + +export const getCSSAlpha = (value: number, options: Options, ignoreLegacy = false): NumberOrString => { + const { alphaUnit, legacyCSS, decimals } = options; + if ( + alphaUnit === ColorUnitEnum.PERCENT && + ( + !legacyCSS || + ignoreLegacy + ) + ) { + return `${round(value * 100, decimals)}%`; + } + return round(value, decimals); +}; + +export const buildCSSHueTransformer = (options: Options) => { + const { anglesUnit, decimals } = options; + return (value: number, index: number): NumberOrString => { + if ( + index === 0 && + anglesUnit !== AnglesUnitEnum.NONE + ) { + const translated = round( + translateDegrees( + value, + anglesUnit + ), + decimals + ); + return `${translated}${anglesUnit}`; + } + return index === 3 + ? getCSSAlpha(value, options) + : round(value, decimals); + }; +}; diff --git a/src/index.ts b/src/index.ts index 3cc1efc..e4cf600 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,2194 +1,11 @@ -import { +export { CIELabObject, - CIELabObjectGeneric, CMYKObject, - ColorInput, - ColorInputWithoutCMYK, - ColorOutput, - HEXObject, HSLObject, - HSLObjectGeneric, HWBObject, - HWBObjectGeneric, InputOptions, LCHObject, - LCHObjectGeneric, - Options, RGBObject } from '@types'; -import { - BASE_255, - DEFAULT_BLEND_STEPS, - DEFAULT_SHADES_TINTS_STEPS, - Harmony, - HarmonyString, - MAX_ALPHA, - MAX_LAB, - MAX_LCH_C, - MAX_PCENT, - Mix, - MixString -} from '#constants'; -import { - cmykToRgb, - hslToRgb, - hwbToRgb, - labToLch, - labToRgb, - lchToLab, - lchToRgb, - rgbToCmyk, - rgbToHsl, - rgbToHwb, - rgbToLab, - rgbToLch -} from '#color/translators'; -import * as utils from '#color/utils'; -import { - getColorModel, - getOptionsFromColorInput, - getRGBObject -} from '#color/extractors'; -import { CSS } from '#color/css'; -import { - isHarmony, - isMix, - minmax, - normalizeHue, - round -} from '#helpers'; -import { - getBlendReturn, - getBlendReturnWithParameters, - getColorReturn, - getHarmonyReturn, - getMixReturn -} from '#returns'; - -const bindedMixers = Object.fromEntries( - Object.entries(utils.colorMixer).map((entry) => { - const [key, fn] = entry; - return [key, fn.bind(utils.colorMixer)]; - }) -) as typeof utils.colorMixer; - -export class ColorTranslator { - - // Constructor - public constructor(color: ColorInput, options: InputOptions = {}) { - this._options = getOptionsFromColorInput(options, color); - this.rgb = getRGBObject(color); - this.update('rgb'); - } - - // Private properties - private _options: Options; - private rgb: RGBObject; - private hsl: HSLObject; - private hwb: HWBObject; - private lab: CIELabObject; - private lch: LCHObject; - private cmyk: CMYKObject; - - // Private methods - private update(...exclude: ('rgb' | 'hsl' | 'hwb' | 'lab' | 'lch' | 'cmyk')[]): void { - if (!exclude.includes('rgb')) { - this.updateRGB(); - } - if (!exclude.includes('hsl')) { - this.updateHSL(); - } - if (!exclude.includes('hwb')) { - this.updateHWB(); - } - if (!exclude.includes('lab')) { - this.updateLAB(); - } - if (!exclude.includes('lch')) { - this.updateLCH(); - } - if (!exclude.includes('cmyk')) { - this.updateCMYK(); - } - } - - private updateRGB(): void { - this.rgb = { - ...hslToRgb( - this.hsl.H, - this.hsl.S, - this.hsl.L - ), - A: this.hsl.A - }; - } - - private updateHSL(): void { - this.hsl = rgbToHsl( - this.rgb.R, - this.rgb.G, - this.rgb.B, - this.rgb.A - ); - } - - private updateHWB(): void { - this.hwb = rgbToHwb( - this.rgb.R, - this.rgb.G, - this.rgb.B, - this.rgb.A - ); - } - - private updateLAB(): void { - this.lab = { - ...rgbToLab( - this.rgb.R, - this.rgb.G, - this.rgb.B - ), - A: this.rgb.A - }; - } - - private updateLCH(): void { - this.lch = { - ...rgbToLch( - this.rgb.R, - this.rgb.G, - this.rgb.B - ), - A: this.rgb.A - }; - } - - private updateCMYK(): void { - this.cmyk = rgbToCmyk( - this.rgb.R, - this.rgb.G, - this.rgb.B - ); - } - - private updateRGBFromHWB(): void { - this.rgb = { - ...hwbToRgb( - this.hwb.H, - this.hwb.W, - this.hwb.B - ), - A: this.rgb.A - }; - } - - private updateRGBFromLCH(): void { - this.rgb = { - ...lchToRgb( - this.lch.L, - this.lch.C, - this.lch.H - ), - A: this.rgb.A - }; - } - - private updateRGBFromCMYK(): void { - this.rgb = { - ...cmykToRgb( - this.cmyk.C, - this.cmyk.M, - this.cmyk.Y, - this.cmyk.K - ), - A: this.rgb.A - }; - } - - private updateRGBFromLAB(): void { - this.rgb = { - ...labToRgb( - this.lab.L, - this.lab.a, - this.lab.b - ), - A: this.rgb.A - }; - } - - private updateLCHFromLAB(): void { - this.lch = { - ...labToLch( - this.lab.L, - this.lab.a, - this.lab.b - ), - A: this.lab.A - }; - } - - private updateLABromLCH(): void { - this.lab = { - ...lchToLab( - this.lch.L, - this.lch.C, - this.lch.H - ), - A: this.lch.A - }; - } - - // Public options method - public setOptions(options: InputOptions = {}): ColorTranslator { - this._options = { - ...this._options, - ...options - } as Options; - return this; - } - - // Public RGB methods - public setR(R: number): ColorTranslator { - this.rgb.R = minmax(R, 0, BASE_255); - this.update('rgb'); - return; - } - - public setG(G: number): ColorTranslator { - this.rgb.G = minmax(G, 0, BASE_255); - this.update('rgb'); - return this; - } - - public setB(B: number): ColorTranslator { - this.rgb.B = minmax(B, 0, BASE_255); - this.update('rgb'); - return this; - } - - // Public HSL methods - public setH(H: number): ColorTranslator { - this.hsl.H = normalizeHue(H); - this.update('hsl'); - return this; - } - - public setS(S: number): ColorTranslator { - this.hsl.S = minmax(S, 0, MAX_PCENT); - this.update('hsl'); - return this; - } - - public setL(L: number): ColorTranslator { - this.hsl.L = minmax(L, 0, MAX_PCENT); - this.update('hsl'); - return this; - } - - // Public HWB methods - public setWhiteness(W: number): ColorTranslator { - this.hwb.W = minmax(W, 0, MAX_PCENT); - this.updateRGBFromHWB(); - this.update('rgb', 'hwb'); - return this; - } - - public setBlackness(B: number): ColorTranslator { - this.hwb.B = minmax(B, 0, MAX_PCENT); - this.updateRGBFromHWB(); - this.update('rgb', 'hwb'); - return this; - } - - // Public Lab methods - public setCIEL(L: number): ColorTranslator { - this.lab.L = minmax(L, 0, MAX_PCENT); - this.updateRGBFromLAB(); - this.updateLCHFromLAB(); - this.update('rgb', 'lab', 'lch'); - return this; - } - - public setCIEa(a: number): ColorTranslator { - this.lab.a = minmax(a, -MAX_LAB, MAX_LAB); - this.updateRGBFromLAB(); - this.updateLCHFromLAB(); - this.update('rgb', 'lab', 'lch'); - return this; - } - - public setCIEb(b: number): ColorTranslator { - this.lab.b = minmax(b, -MAX_LAB, MAX_LAB); - this.updateRGBFromLAB(); - this.updateLCHFromLAB(); - this.update('rgb', 'lab', 'lch'); - return this; - } - - // Puclic LCH methods - public setLCHL(l: number): ColorTranslator { - this.lch.L = minmax(l, 0, MAX_PCENT); - this.updateRGBFromLCH(); - this.updateLABromLCH(); - this.update('rgb', 'lab', 'lch'); - return this; - } - - public setLCHC(c: number): ColorTranslator { - this.lch.C = minmax(c, 0, MAX_LCH_C); - this.updateRGBFromLCH(); - this.updateLABromLCH(); - this.update('rgb', 'lab', 'lch'); - return this; - } - - public setLCHH(h: number): ColorTranslator { - this.lch.H = normalizeHue(h); - this.updateRGBFromLCH(); - this.updateLABromLCH(); - this.update('rgb', 'lab', 'lch'); - return this; - } - - // Public alpha method - public setA(A: number): ColorTranslator { - const alpha = minmax(A, 0, MAX_ALPHA); - this.rgb.A = alpha; - this.hsl.A = alpha; - this.hwb.A = alpha; - this.lab.A = alpha; - this.lch.A = alpha; - this.cmyk.A = alpha; - return this; - } - - // Public CMYK methods - public setC(C: number): ColorTranslator { - this.cmyk.C = minmax(C, 0, 100); - this.updateRGBFromCMYK(); - this.update('cmyk'); - return this; - } - - public setM(M: number): ColorTranslator { - this.cmyk.M = minmax(M, 0, 100); - this.updateRGBFromCMYK(); - this.update('cmyk'); - return this; - } - - public setY(Y: number): ColorTranslator { - this.cmyk.Y = minmax(Y, 0, 100); - this.updateRGBFromCMYK(); - this.update('cmyk'); - return this; - } - - public setK(K: number): ColorTranslator { - this.cmyk.K = minmax(K, 0, 100); - this.updateRGBFromCMYK(); - this.update('cmyk'); - return this; - } - - // Public options property - public get options(): Options { - return this._options; - } - - // Public RGB properties - public get R(): number { - return round(this.rgb.R, this.options.decimals); - } - - public get G(): number { - return round(this.rgb.G, this.options.decimals); - } - - public get B(): number { - return round(this.rgb.B, this.options.decimals); - } - - // Public HSL properties - public get H(): number { - return round(this.hsl.H, this.options.decimals); - } - - public get S(): number { - return round(this.hsl.S, this.options.decimals); - } - - public get L(): number { - return round(this.hsl.L, this.options.decimals); - } - - // Public HWB properties - public get Whiteness(): number { - return round(this.hwb.W, this.options.decimals); - } - - public get Blackness(): number { - return round(this.hwb.B, this.options.decimals); - } - - // Public Lab properties - public get CIEL(): number { - return round(this.lab.L, this.options.decimals); - } - - public get CIEa(): number { - return round(this.lab.a, this.options.decimals); - } - - public get CIEb(): number { - return round(this.lab.b, this.options.decimals); - } - - // Pulic LCH properties - public get LCHL(): number { - return round(this.lch.L, this.options.decimals); - } - - public get LCHC(): number { - return round(this.lch.C, this.options.decimals); - } - - public get LCHH(): number { - return round(this.lch.H, this.options.decimals); - } - - // Public alpha property - public get A(): number { - return round(this.hsl.A, this.options.decimals); - } - - // Public CMYK properties - public get C(): number { - return round(this.cmyk.C, this.options.decimals); - } - - public get M(): number { - return round(this.cmyk.M, this.options.decimals); - } - - public get Y(): number { - return round(this.cmyk.Y, this.options.decimals); - } - - public get K(): number { - return round(this.cmyk.K, this.options.decimals); - } - - // Object public properties - public get HEXObject(): HEXObject { - return utils.translateColor.HEX(this.rgb); - } - - public get HEXAObject(): HEXObject { - return utils.translateColor.HEXA(this.rgb); - } - - public get RGBObject(): RGBObject { - return { - R: this.R, - G: this.G, - B: this.B - }; - } - - public get RGBAObject(): RGBObject { - return { - ...this.RGBObject, - A: this.A - }; - } - - public get HSLObject(): HSLObject { - return { - H: this.H, - S: this.S, - L: this.L - }; - } - - public get HSLAObject(): HSLObject { - return { - ...this.HSLObject, - A: this.A - }; - } - - public get HWBObject(): HWBObject { - return { - H: this.H, - W: this.Whiteness, - B: this.Blackness - }; - } - - public get HWBAObject(): HWBObject { - return { - ...this.HWBObject, - A: this.A - }; - } - - public get CIELabObject(): CIELabObject { - return { - L: this.CIEL, - a: this.CIEa, - b: this.CIEb - }; - } - - public get CIELabAObject(): CIELabObject { - return { - ...this.CIELabObject, - A: this.A - }; - } - - public get LCHObject(): LCHObject { - return { - L: this.LCHL, - C: this.LCHC, - H: this.LCHH - }; - } - - public get LCHAObject(): LCHObject { - return { - ...this.LCHObject, - A: this.A - }; - } - - public get CMYKObject(): CMYKObject { - return { - C: this.C, - M: this.M, - Y: this.Y, - K: this.K - }; - } - - public get CMYKAObject(): CMYKObject { - return { - ...this.CMYKObject, - A: this.A - }; - } - - // CSS public properties - public get HEX(): string { - return CSS.HEX({ - R: this.R, - G: this.G, - B: this.B - }); - } - - public get HEXA(): string { - return CSS.HEX({ - R: this.R, - G: this.G, - B: this.B, - A: this.A * BASE_255 - }); - } - - public get RGB(): string { - return CSS.RGB( - { - R: this.R, - G: this.G, - B: this.B - }, - this.options - ); - } - - public get RGBA(): string { - return CSS.RGB( - { - R: this.R, - G: this.G, - B: this.B, - A: this.A - }, - this.options - ); - } - - public get HSL(): string { - return CSS.HSL( - { - H: this.H, - S: this.S, - L: this.L - }, - this.options - ); - } - - public get HSLA(): string { - return CSS.HSL( - { - H: this.H, - S: this.S, - L: this.L, - A: this.A - }, - this.options - ); - } - - public get HWB(): string { - return CSS.HWB( - { - H: this.H, - W: this.Whiteness, - B: this.Blackness - }, - this.options - ); - } - - public get HWBA(): string { - return CSS.HWB( - { - H: this.H, - W: this.Whiteness, - B: this.Blackness, - A: this.A - }, - this.options - ); - } - - public get CIELab(): string { - return CSS.CIELab( - { - L: this.CIEL, - a: this.CIEa, - b: this.CIEb - }, - this.options - ); - } - - public get CIELabA(): string { - return CSS.CIELab( - { - L: this.CIEL, - a: this.CIEa, - b: this.CIEb, - A: this.A - }, - this.options - ); - } - - public get LCH(): string { - return CSS.LCH( - { - L: this.LCHL, - C: this.LCHC, - H: this.LCHH - }, - this.options - ); - } - - public get LCHA(): string { - return CSS.LCH( - { - L: this.LCHL, - C: this.LCHC, - H: this.LCHH, - A: this.A - }, - this.options - ); - } - - public get CMYK(): string { - return CSS.CMYK( - { - C: this.C, - M: this.M, - Y: this.Y, - K: this.K - }, - this.options - ); - } - - public get CMYKA(): string { - return CSS.CMYK( - { - C: this.C, - M: this.M, - Y: this.Y, - K: this.K, - A: this.A - }, - this.options - ); - } - - // Color Conversion Static Methods - public static toHEXObject(color: ColorInput): HEXObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - 0, - utils.translateColor.HEX - ); - } - - public static toHEX(color: ColorInput): string { - return CSS.HEX( - ColorTranslator.toHEXObject(color) - ); - } - - public static toHEXAObject(color: ColorInput): HEXObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - 0, - utils.translateColor.HEXA - ); - } - - public static toHEXA(color: ColorInput): string { - return CSS.HEX( - ColorTranslator.toHEXAObject(color) - ); - } - - public static toRGBObject(color: ColorInput, options: InputOptions = {}): RGBObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.RGB - ); - } - - public static toRGB(color: ColorInput, options: InputOptions = {}): string { - const rgb = ColorTranslator.toRGBObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.RGB(rgb, detectedOptions); - } - - public static toRGBAObject(color: ColorInput, options: InputOptions = {}): RGBObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.RGBA - ); - } - - public static toRGBA(color: ColorInput, options: InputOptions = {}): string { - const rgba = ColorTranslator.toRGBAObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.RGB(rgba, detectedOptions); - } - - public static toHSLObject(color: ColorInput, options: InputOptions = {}): HSLObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.HSL - ); - } - - public static toHSL(color: ColorInput, options: InputOptions = {}): string { - const hsl = ColorTranslator.toHSLObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.HSL(hsl, detectedOptions); - } - - public static toHSLAObject(color: ColorInput, options: InputOptions = {}): HSLObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.HSLA - ); - } - - public static toHSLA(color: ColorInput, options: InputOptions = {}): string { - const hsla = ColorTranslator.toHSLAObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.HSL(hsla, detectedOptions); - } - - public static toHWBObject(color: ColorInput, options: InputOptions = {}): HWBObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.HWB - ); - } - - public static toHWB(color: ColorInput, options: InputOptions = {}): string { - const hwb = ColorTranslator.toHWBObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.HWB(hwb, detectedOptions); - } - - public static toHWBAObject(color: ColorInput, options: InputOptions = {}): HWBObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.HWBA - ); - } - - public static toHWBA(color: ColorInput, options: InputOptions = {}): string { - const hwb = ColorTranslator.toHWBAObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.HWB(hwb, detectedOptions); - } - - public static toCIELabObject(color: ColorInput, options: InputOptions = {}): CIELabObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.CIELab - ); - } - - public static toCIELab(color: ColorInput, options: InputOptions = {}): string { - const lab = ColorTranslator.toCIELabObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.CIELab(lab, detectedOptions); - } - - public static toCIELabAObject(color: ColorInput, options: InputOptions = {}): CIELabObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.CIELabA - ); - } - - public static toCIELabA(color: ColorInput, options: InputOptions = {}): string { - const lab = ColorTranslator.toCIELabAObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.CIELab(lab, detectedOptions); - } - - public static toLCHObject(color: ColorInput, options: InputOptions = {}): LCHObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.LCH - ); - } - - public static toLCH(color: ColorInput, options: InputOptions = {}): string { - const lch = ColorTranslator.toLCHObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.LCH(lch, detectedOptions); - } - - public static toLCHAObject(color: ColorInput, options: InputOptions = {}): LCHObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.LCHA - ); - } - - public static toLCHA(color: ColorInput, options: InputOptions = {}): string { - const lch = ColorTranslator.toLCHAObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.LCH(lch, detectedOptions); - } - - public static toCMYKObject(color: ColorInput, options: InputOptions = {}): CMYKObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.CMYK - ); - } - - public static toCMYK(color: ColorInput, options: InputOptions = {}): string { - const cmyk = ColorTranslator.toCMYKObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.CMYK(cmyk, detectedOptions); - } - - public static toCMYKAObject(color: ColorInput, options: InputOptions = {}): CMYKObject { - const model = getColorModel(color); - return getColorReturn( - color, - model, - options.decimals, - utils.translateColor.CMYKA - ); - } - - public static toCMYKA(color: ColorInput, options: InputOptions = {}): string { - const cmyka = ColorTranslator.toCMYKAObject(color, options); - const detectedOptions = getOptionsFromColorInput(options, color); - return CSS.CMYK(cmyka, detectedOptions); - } - - // Color Blending Static Methods - public static getBlendHEXObject( - from: ColorInput, - to: ColorInput, - steps: number = DEFAULT_BLEND_STEPS - ): HEXObject[] { - return getBlendReturn( - from, - to, - steps, - 0, - utils.translateColor.HEX - ); - } - - public static getBlendHEX( - from: ColorInput, - to: ColorInput, - steps: number = DEFAULT_BLEND_STEPS - ): string[] { - return ColorTranslator.getBlendHEXObject(from, to, steps) - .map((color: HEXObject): string => CSS.HEX(color)); - } - - public static getBlendHEXAObject( - from: ColorInput, - to: ColorInput, - steps: number = DEFAULT_BLEND_STEPS - ): HEXObject[] { - return getBlendReturn( - from, - to, - steps, - 0, - utils.translateColor.HEXA - ); - } - - public static getBlendHEXA( - from: ColorInput, - to: ColorInput, - steps: number = DEFAULT_BLEND_STEPS - ): string[] { - return ColorTranslator.getBlendHEXAObject(from, to, steps) - .map((color: HEXObject): string => CSS.HEX(color)); - } - - public static getBlendRGBObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): RGBObject[]; - public static getBlendRGBObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): RGBObject[]; - public static getBlendRGBObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): RGBObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.RGB - }); - } - - public static getBlendRGB( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendRGB( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendRGB( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.RGB, - cssFunction: CSS.RGB - }); - } - - public static getBlendRGBAObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): RGBObject[]; - public static getBlendRGBAObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): RGBObject[]; - public static getBlendRGBAObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): RGBObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.RGBA - }); - } - - public static getBlendRGBA( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendRGBA( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendRGBA( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.RGBA, - cssFunction: CSS.RGB - }); - } - - public static getBlendHSLObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): HSLObject[]; - public static getBlendHSLObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): HSLObject[]; - public static getBlendHSLObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): HSLObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HSL - }); - } - - public static getBlendHSL( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendHSL( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendHSL( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HSL, - cssFunction: CSS.HSL - }); - } - - public static getBlendHSLAObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): HSLObject[]; - public static getBlendHSLAObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): HSLObject[]; - public static getBlendHSLAObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): HSLObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HSLA - }); - } - - public static getBlendHSLA( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendHSLA( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendHSLA( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HSLA, - cssFunction: CSS.HSL - }); - } - - public static getBlendHWBObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): HWBObject[]; - public static getBlendHWBObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): HWBObject[]; - public static getBlendHWBObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): HWBObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HWB - }); - } - - public static getBlendHWB( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendHWB( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendHWB( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HWB, - cssFunction: CSS.HWB - }); - } - - public static getBlendHWBAObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): HWBObject[]; - public static getBlendHWBAObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): HWBObject[]; - public static getBlendHWBAObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): HWBObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HWBA - }); - } - - public static getBlendHWBA( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendHWBA( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendHWBA( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.HWBA, - cssFunction: CSS.HWB - }); - } - - public static getBlendCIELabObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): CIELabObject[]; - public static getBlendCIELabObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): CIELabObject[]; - public static getBlendCIELabObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): CIELabObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.CIELab - }); - } - - public static getBlendCIELab( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendCIELab( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendCIELab( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.CIELab, - cssFunction: CSS.CIELab - }); - } - - public static getBlendCIELabAObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): CIELabObject[]; - public static getBlendCIELabAObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): CIELabObject[]; - public static getBlendCIELabAObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): CIELabObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.CIELabA - }); - } - - public static getBlendCIELabA( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendCIELabA( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendCIELabA( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.CIELabA, - cssFunction: CSS.CIELab - }); - } - - public static getBlendLCHObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): LCHObject[]; - public static getBlendLCHObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): LCHObject[]; - public static getBlendLCHObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): LCHObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.LCH - }); - } - - public static getBlendLCH( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendLCH( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendLCH( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.LCH, - cssFunction: CSS.LCH - }); - } - - public static getBlendLCHAObject( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): LCHObject[]; - public static getBlendLCHAObject( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): LCHObject[]; - public static getBlendLCHAObject( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): LCHObject[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.LCHA - }); - } - - public static getBlendLCHA( - from: ColorInput, - to: ColorInput, - options?: InputOptions - ): string[]; - public static getBlendLCHA( - from: ColorInput, - to: ColorInput, - steps?: number, - options?: InputOptions - ): string[]; - public static getBlendLCHA( - from: ColorInput, - to: ColorInput, - thirdParameter?: number | InputOptions, - fourthParameter?: InputOptions - ): string[] { - return getBlendReturnWithParameters({ - from, - to, - thirdParameter, - fourthParameter, - translateFunction: utils.translateColor.LCHA, - cssFunction: CSS.LCH - }); - } - - // Color Mix Static Methods - public static getMixHEXObject(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): HEXObject { - return utils.colorMixer.HEX(colors, mode, false); - } - - public static getMixHEX(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): string { - return utils.colorMixer.HEX(colors, mode, true); - } - - public static getMixHEXAObject(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): HEXObject { - return utils.colorMixer.HEXA(colors, mode, false); - } - - public static getMixHEXA(colors: ColorInput[], mode: MixString = Mix.ADDITIVE): string { - return utils.colorMixer.HEXA(colors, mode, true); - } - - public static getMixRGBObject( - colors: ColorInput[], - options?: InputOptions - ): RGBObject; - public static getMixRGBObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): RGBObject; - public static getMixRGBObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): RGBObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.RGB, - css: false - }); - } - - public static getMixRGB( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixRGB( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixRGB( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.RGB, - css: true - }); - } - - public static getMixRGBAObject( - colors: ColorInput[], - options?: InputOptions - ): RGBObject; - public static getMixRGBAObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): RGBObject; - public static getMixRGBAObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): RGBObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.RGBA, - css: false - }); - } - - public static getMixRGBA( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixRGBA( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixRGBA( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.RGBA, - css: true - }); - } - - public static getMixHSLObject( - colors: ColorInput[], - options?: InputOptions - ): HSLObject; - public static getMixHSLObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): HSLObject; - public static getMixHSLObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): HSLObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HSL, - css: false - }); - } - - public static getMixHSL( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixHSL( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixHSL( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HSL, - css: true - }); - } - - public static getMixHSLAObject( - colors: ColorInput[], - options?: InputOptions - ): HSLObject; - public static getMixHSLAObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): HSLObject; - public static getMixHSLAObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): HSLObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HSLA, - css: false - }); - } - - public static getMixHSLA( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixHSLA( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixHSLA( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HSLA, - css: true - }); - } - - public static getMixHWBObject( - colors: ColorInput[], - options?: InputOptions - ): HWBObject; - public static getMixHWBObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): HWBObject; - public static getMixHWBObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): HWBObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HWB, - css: false - }); - } - - public static getMixHWB( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixHWB( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixHWB( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HWB, - css: true - }); - } - - public static getMixHWBAObject( - colors: ColorInput[], - options?: InputOptions - ): HWBObject; - public static getMixHWBAObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): HWBObject; - public static getMixHWBAObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): HWBObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HWBA, - css: false - }); - } - - public static getMixHWBA( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixHWBA( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixHWBA( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.HWBA, - css: true - }); - } - - public static getMixCIELabObject( - colors: ColorInput[], - options?: InputOptions - ): CIELabObject; - public static getMixCIELabObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): CIELabObject; - public static getMixCIELabObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): CIELabObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.CIELab, - css: false - }); - } - - public static getMixCIELab( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixCIELab( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixCIELab( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.CIELab, - css: true - }); - } - - public static getMixCIELabAObject( - colors: ColorInput[], - options?: InputOptions - ): CIELabObject; - public static getMixCIELabAObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): CIELabObject; - public static getMixCIELabAObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): CIELabObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.CIELabA, - css: false - }); - } - - public static getMixCIELabA( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixCIELabA( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixCIELabA( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.CIELabA, - css: true - }); - } - - public static getMixLCHObject( - colors: ColorInput[], - options?: InputOptions - ): LCHObject; - public static getMixLCHObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): LCHObject; - public static getMixLCHObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): LCHObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.LCH, - css: false - }); - } - - public static getMixLCH( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixLCH( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixLCH( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.LCH, - css: true - }); - } - - public static getMixLCHAObject( - colors: ColorInput[], - options?: InputOptions - ): LCHObject; - public static getMixLCHAObject( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): LCHObject; - public static getMixLCHAObject( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): LCHObject { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.LCHA, - css: false - }); - } - - public static getMixLCHA( - colors: ColorInput[], - options?: InputOptions - ): string; - public static getMixLCHA( - colors: ColorInput[], - mode?: MixString, - options?: InputOptions - ): string; - public static getMixLCHA( - colors: ColorInput[], - secondParameter?: MixString | InputOptions, - thirdParameter?: InputOptions - ): string { - return getMixReturn({ - colors, - secondParameter, - thirdParameter, - colorMixerFunction: bindedMixers.LCHA, - css: true - }); - } - - // Get shades static method - public static getShades(color: string, options?: InputOptions): string[]; - public static getShades(color: HEXObject, options?: InputOptions): HEXObject[]; - public static getShades(color: RGBObject, options?: InputOptions): RGBObject[]; - public static getShades(color: HSLObjectGeneric, options?: InputOptions): HSLObject[]; - public static getShades(color: HWBObjectGeneric, options?: InputOptions): HWBObject[]; - public static getShades(color: CIELabObjectGeneric, options?: InputOptions): CIELabObject[]; - public static getShades(color: LCHObjectGeneric, options?: InputOptions): LCHObject[]; - - public static getShades(color: string, shades?: number, options?: InputOptions): string[]; - public static getShades(color: HEXObject, shades?: number, options?: InputOptions): HEXObject[]; - public static getShades(color: RGBObject, shades?: number, options?: InputOptions): RGBObject[]; - public static getShades(color: HSLObjectGeneric, shades?: number, options?: InputOptions): HSLObject[]; - public static getShades(color: HWBObjectGeneric, shades?: number, options?: InputOptions): HWBObject[]; - public static getShades(color: CIELabObjectGeneric, shades?: number, options?: InputOptions): CIELabObject[]; - public static getShades(color: LCHObjectGeneric, shades?: number, options?: InputOptions): LCHObject[]; - - public static getShades( - color: ColorInputWithoutCMYK, - secondParameter?: number | InputOptions, - thirdParameter?: InputOptions - ): ColorOutput[] { - if (typeof secondParameter === 'number') { - return utils.getColorMixture( - color, - secondParameter, - true, - getOptionsFromColorInput( - thirdParameter || {}, - color - ) - ); - } - return utils.getColorMixture( - color, - DEFAULT_SHADES_TINTS_STEPS, - true, - getOptionsFromColorInput( - secondParameter || {}, - color - ) - ); - } - - // Get tints static method - public static getTints(color: string, options?: InputOptions): string[]; - public static getTints(color: HEXObject, options?: InputOptions): HEXObject[]; - public static getTints(color: RGBObject, options?: InputOptions): RGBObject[]; - public static getTints(color: HSLObjectGeneric, options?: InputOptions): HSLObject[]; - public static getTints(color: HWBObjectGeneric, options?: InputOptions): HWBObject[]; - public static getTints(color: CIELabObjectGeneric, options?: InputOptions): CIELabObject[]; - public static getTints(color: LCHObjectGeneric, options?: InputOptions): LCHObject[]; - - public static getTints(color: string, tints?: number, options?: InputOptions): string[]; - public static getTints(color: HEXObject, tints?: number, options?: InputOptions): HEXObject[]; - public static getTints(color: RGBObject, tints?: number, options?: InputOptions): RGBObject[]; - public static getTints(color: HSLObjectGeneric, tints?: number, options?: InputOptions): HSLObject[]; - public static getTints(color: HWBObjectGeneric, tints?: number, options?: InputOptions): HWBObject[]; - public static getTints(color: CIELabObjectGeneric, tints?: number, options?: InputOptions): CIELabObject[]; - public static getTints(color: LCHObjectGeneric, tints?: number, options?: InputOptions): LCHObject[]; - - public static getTints( - color: ColorInputWithoutCMYK, - secondParameter?: number | InputOptions, - thirdParameter?: InputOptions - ): ColorOutput[] { - if (typeof secondParameter === 'number') { - return utils.getColorMixture( - color, - secondParameter, - false, - getOptionsFromColorInput( - thirdParameter || {}, - color - ) - ); - } - return utils.getColorMixture( - color, - DEFAULT_SHADES_TINTS_STEPS, - false, - getOptionsFromColorInput( - secondParameter || {}, - color - ) - ); - } - - // Color Harmony Static Method - public static getHarmony(color: string, options?: InputOptions): string[]; - public static getHarmony(color: HEXObject, options?: InputOptions): HEXObject[]; - public static getHarmony(color: RGBObject, options?: InputOptions): RGBObject[]; - public static getHarmony(color: HSLObjectGeneric, options?: InputOptions): HSLObject[]; - public static getHarmony(color: HWBObjectGeneric, options?: InputOptions): HWBObject[]; - public static getHarmony(color: CIELabObjectGeneric, options?: InputOptions): CIELabObject[]; - public static getHarmony(color: LCHObjectGeneric, options?: InputOptions): LCHObject[]; - - public static getHarmony(color: string, mode?: MixString, options?: InputOptions): string[]; - public static getHarmony(color: HEXObject, mode?: MixString, options?: InputOptions): HEXObject[]; - public static getHarmony(color: RGBObject, mode?: MixString, options?: InputOptions): RGBObject[]; - public static getHarmony(color: HSLObjectGeneric, mode?: MixString, options?: InputOptions): HSLObject[]; - public static getHarmony(color: HWBObjectGeneric, mode?: MixString, options?: InputOptions): HWBObject[]; - public static getHarmony(color: CIELabObjectGeneric, mode?: MixString, options?: InputOptions): CIELabObject[]; - public static getHarmony(color: LCHObjectGeneric, mode?: MixString, options?: InputOptions): LCHObject[]; - - public static getHarmony(color: string, harmony?: Harmony, options?: InputOptions): string[]; - public static getHarmony(color: HEXObject, harmony?: Harmony, options?: InputOptions): HEXObject[]; - public static getHarmony(color: RGBObject, harmony?: Harmony, options?: InputOptions): RGBObject[]; - public static getHarmony(color: HSLObjectGeneric, harmony?: Harmony, options?: InputOptions): HSLObject[]; - public static getHarmony(color: HWBObjectGeneric, harmony?: Harmony, options?: InputOptions): HWBObject[]; - public static getHarmony(color: CIELabObjectGeneric, harmony?: Harmony, options?: InputOptions): CIELabObject[]; - public static getHarmony(color: LCHObjectGeneric, harmony?: Harmony, options?: InputOptions): LCHObject[]; - - public static getHarmony(color: string, harmony?: Harmony, mode?: MixString, options?: InputOptions): string[]; - public static getHarmony(color: HEXObject, harmony?: Harmony, mode?: MixString, options?: InputOptions): HEXObject[]; - public static getHarmony(color: RGBObject, harmony?: Harmony, mode?: MixString, options?: InputOptions): RGBObject[]; - public static getHarmony(color: HSLObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): HSLObject[]; - public static getHarmony(color: HWBObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): HWBObject[]; - public static getHarmony(color: CIELabObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): CIELabObject[]; - public static getHarmony(color: LCHObjectGeneric, harmony?: Harmony, mode?: MixString, options?: InputOptions): LCHObject[]; - - public static getHarmony( - color: ColorInputWithoutCMYK, - secondParam?: HarmonyString | MixString | InputOptions, - thirdParam?: MixString | InputOptions, - fourthParam?: InputOptions - ): ColorOutput[] { - if (isHarmony(secondParam)) { - return getHarmonyReturn( - secondParam, - color, - isMix(thirdParam) - ? thirdParam - : Mix.ADDITIVE, - getOptionsFromColorInput( - isMix(thirdParam) - ? (fourthParam || {}) - : thirdParam || {}, - color - ) - ); - } else if (isMix(secondParam)) { - return getHarmonyReturn( - Harmony.COMPLEMENTARY, - color, - secondParam, - getOptionsFromColorInput( - thirdParam as InputOptions || {}, - color - ) - ); - } - return getHarmonyReturn( - Harmony.COMPLEMENTARY, - color, - Mix.ADDITIVE, - getOptionsFromColorInput( - secondParam || {}, - color - ) - ); - } -} - -export { - InputOptions, - Harmony, - Mix, - HEXObject, - RGBObject, - HSLObject, - HWBObject, - CIELabObject, - LCHObject, - CMYKObject -}; \ No newline at end of file +export { Harmony, Mix } from '#constants'; +export { ColorTranslator } from '#classes/ColorTranslator'; \ No newline at end of file diff --git a/src/parsers/_CIELabStringParser.ts b/src/parsers/_CIELabStringParser.ts deleted file mode 100644 index 5475b1f..0000000 --- a/src/parsers/_CIELabStringParser.ts +++ /dev/null @@ -1,113 +0,0 @@ -import { - CIELabRegExpMatchArray, - ParserGetRgbObject, - RGBObject -} from '@types'; -import { - COLORREGS, - MAX_ALPHA, - MAX_LAB, - MAX_PCENT, - PCENT -} from '#constants'; -import { - getBase125Number, - minmax, - normalizeAlpha, - percent -} from '#helpers'; -import { labToRgb, rgbToLab } from '#color/translators'; -import { CalcParser } from './_CalcParser'; -import { AlphaBaseClass } from './baseClasses/_AlphaBaseClass'; - -export class CIELabStringParser extends AlphaBaseClass { - - constructor(colorString: string, getRGBObject: ParserGetRgbObject) { - - super(); - - const match = colorString.match(COLORREGS.CIELab) as CIELabRegExpMatchArray; - const groups = match.groups; - - const { - // Lab values - L, - a, - b, - A, - // Relative values - from, - relative_L, - relative_a, - relative_b, - relative_A - } = groups; - - if (from) { - - const fromRGB = getRGBObject(from); - const fromLab = rgbToLab( - fromRGB.R, - fromRGB.G, - fromRGB.B - ); - const fromLabVars = { - l: fromLab.L, - a: fromLab.a, - b: fromLab.b, - alpha: fromRGB.A ?? 1 - }; - - const L = new CalcParser('l', relative_L, fromLabVars).result; - const a = new CalcParser('a', relative_a, fromLabVars).result; - const b = new CalcParser('b', relative_b, fromLabVars).result; - - const rgb = labToRgb( - minmax(L, 0, MAX_PCENT), - minmax(a, - MAX_LAB, MAX_LAB), - minmax(b, - MAX_LAB, MAX_LAB) - ); - - if (relative_A) { - const A = new CalcParser('alpha', relative_A, fromLabVars).result; - rgb.A = minmax(A, 0, MAX_ALPHA); - } - - this._rgb = rgb; - - } else { - - this._L = L; - this._A = a; - this._B = b; - this._a = A; - const rgb: RGBObject = labToRgb( - percent(this._L), - getBase125Number(this._A), - getBase125Number(this._B) - ); - if (this._a !== undefined) { - rgb.A = normalizeAlpha(this._a); - } - this._rgb = rgb; - - } - } - - private _L: string; - private _A: string; - private _B: string; - - public get hasPercentageValues(): boolean { - return ( - PCENT.test(this._L) && - PCENT.test(this._A) && - PCENT.test(this._B) - ); - } - - static test(colorString: string): boolean { - return COLORREGS.CIELab.test(colorString); - } - -} \ No newline at end of file diff --git a/src/parsers/_CMYKStringParser.ts b/src/parsers/_CMYKStringParser.ts deleted file mode 100644 index c2a63aa..0000000 --- a/src/parsers/_CMYKStringParser.ts +++ /dev/null @@ -1,50 +0,0 @@ -import { CMYKRegExpMatchArray, RGBObject } from '@types'; -import { COLORREGS, PCENT } from '#constants'; -import { getCMYKNumber, normalizeAlpha } from '#helpers'; -import { cmykToRgb } from '#color/translators'; -import { AlphaBaseClass } from './baseClasses/_AlphaBaseClass'; - -export class CMYKStringParser extends AlphaBaseClass { - - constructor(colorString: string) { - - super(); - - const match = colorString.match(COLORREGS.CMYK) as CMYKRegExpMatchArray; - const groups = match.groups; - this._c = groups.c_legacy ?? groups.c; - this._m = groups.m_legacy ?? groups.m; - this._y = groups.y_legacy ?? groups.y; - this._k = groups.k_legacy ?? groups.k; - this._a = groups.a_legacy ?? groups.a; - const rgb: RGBObject = cmykToRgb( - getCMYKNumber(this._c), - getCMYKNumber(this._m), - getCMYKNumber(this._y), - getCMYKNumber(this._k) - ); - if (this._a !== undefined) { - rgb.A = normalizeAlpha(this._a); - } - this._rgb = rgb; - } - - private _c: string; - private _m: string; - private _y: string; - private _k: string; - - public get hasPercentageValues(): boolean { - return ( - PCENT.test(this._c) && - PCENT.test(this._m) && - PCENT.test(this._y) && - PCENT.test(this._k) - ); - } - - static test(colorString: string): boolean { - return COLORREGS.CMYK.test(colorString); - } - -} \ No newline at end of file diff --git a/src/parsers/_HEXStringParser.ts b/src/parsers/_HEXStringParser.ts deleted file mode 100644 index d77ada9..0000000 --- a/src/parsers/_HEXStringParser.ts +++ /dev/null @@ -1,34 +0,0 @@ -import { RGBObject, HEXRegExpMatchArray } from '@types'; -import { BASE_255, COLORREGS } from '#constants'; -import { getDEC } from '#helpers'; -import { RgbClass } from './baseClasses/_RgbClass'; - -export class HEXStringParser extends RgbClass { - - constructor(colorString: string) { - - super(); - - const match = colorString.match(COLORREGS.HEX) as HEXRegExpMatchArray; - const groups = match.groups; - this._r = groups.r ?? groups.rr; - this._g = groups.g ?? groups.gg; - this._b = groups.b ?? groups.bb; - this._a = groups.a ?? groups.aa; - const rgb: RGBObject = { - R: getDEC(this._r), - G: getDEC(this._g), - B: getDEC(this._b) - }; - if (this._a !== undefined) { - rgb.A = getDEC(this._a) / BASE_255; - } - this._rgb = rgb; - } - - private _r: string; - private _g: string; - private _b: string; - private _a: string | undefined; - -} \ No newline at end of file diff --git a/src/parsers/_HSLStringParser.ts b/src/parsers/_HSLStringParser.ts deleted file mode 100644 index 40e22e0..0000000 --- a/src/parsers/_HSLStringParser.ts +++ /dev/null @@ -1,110 +0,0 @@ -import { - HSLRegExpMatchArray, - ParserGetRgbObject, - RGBObject -} from '@types'; -import { - COLORREGS, - MAX_ALPHA, - MAX_HUE, - MAX_PCENT -} from '#constants'; -import { - minmax, - normalizeAlpha, - normalizeHue, - percent -} from '#helpers'; -import { hslToRgb, rgbToHsl } from '#color/translators'; -import { CalcParser } from './_CalcParser'; -import { HueBaseClass } from './baseClasses/_HueBaseClass'; - -export class HSLStringParser extends HueBaseClass { - - constructor(colorString: string, getRGBObject: ParserGetRgbObject) { - - super(); - - const match = colorString.match(COLORREGS.HSL) as HSLRegExpMatchArray; - const groups = match.groups; - - const { - // Legacy values - h_legacy, - s_legacy, - l_legacy, - a_legacy, - // HSL values - h, - s, - l, - a, - // Relative values - from, - relative_h, - relative_s, - relative_l, - relative_a - } = groups; - - if (from) { - - const fromRGB = getRGBObject(from); - const fromHSL = rgbToHsl( - fromRGB.R, - fromRGB.G, - fromRGB.B, - fromRGB.A - ); - const fromHSLVars = { - h: fromHSL.H, - s: fromHSL.S, - l: fromHSL.L, - alpha: fromHSL.A - }; - - const H = new CalcParser('h', relative_h, fromHSLVars).result; - const S = new CalcParser('s', relative_s, fromHSLVars).result; - const L = new CalcParser('l', relative_l, fromHSLVars).result; - - const rgb = hslToRgb( - minmax(H, 0, MAX_HUE), - minmax(S, 0, MAX_PCENT), - minmax(L, 0, MAX_PCENT) - ); - - if (relative_a) { - const A = new CalcParser('alpha', relative_a, fromHSLVars).result; - rgb.A = minmax(A, 0, MAX_ALPHA); - } - - this._rgb = rgb; - - } else { - - this._h = h_legacy ?? h; - this._s = s_legacy ?? s; - this._l = l_legacy ?? l; - this._a = a_legacy ?? a; - const rgb: RGBObject = hslToRgb( - normalizeHue(this._h), - percent(this._s), - percent(this._l) - ); - if (this._a !== undefined) { - rgb.A = normalizeAlpha(this._a); - } - this._rgb = rgb; - - } - - } - - private _s: string; - private _l: string; - - static test(colorString: string): boolean { - return COLORREGS.HSL.test(colorString); - } - -} \ No newline at end of file diff --git a/src/parsers/_HWBStringParser.ts b/src/parsers/_HWBStringParser.ts deleted file mode 100644 index 6c1182f..0000000 --- a/src/parsers/_HWBStringParser.ts +++ /dev/null @@ -1,104 +0,0 @@ -import { - HWBRegExpMatchArray, - ParserGetRgbObject, - RGBObject -} from '@types'; -import { - COLORREGS, - MAX_ALPHA, - MAX_HUE, - MAX_PCENT -} from '#constants'; -import { - minmax, - normalizeAlpha, - normalizeHue, - percent -} from '#helpers'; -import { hwbToRgb, rgbToHwb } from '#color/translators'; -import { CalcParser } from './_CalcParser'; -import { HueBaseClass } from './baseClasses/_HueBaseClass'; - -export class HWBStringParser extends HueBaseClass { - - constructor(colorString: string, getRGBObject: ParserGetRgbObject) { - - super(); - - const match = colorString.match(COLORREGS.HWB) as HWBRegExpMatchArray; - const groups = match.groups; - - const { - // HWB values - h, - w, - b, - a, - // Relative values - from, - relative_h, - relative_w, - relative_b, - relative_a - } = groups; - - if (from) { - - const fromRGB = getRGBObject(from); - const fromHWB = rgbToHwb( - fromRGB.R, - fromRGB.G, - fromRGB.B, - fromRGB.A - ); - const fromHWBVars = { - h: fromHWB.H, - w: fromHWB.W, - b: fromHWB.B, - alpha: fromHWB.A - }; - - const H = new CalcParser('h', relative_h, fromHWBVars).result; - const W = new CalcParser('w', relative_w, fromHWBVars).result; - const B = new CalcParser('b', relative_b, fromHWBVars).result; - - const rgb = hwbToRgb( - minmax(H, 0, MAX_HUE), - minmax(W, 0, MAX_PCENT), - minmax(B, 0, MAX_PCENT) - ); - - if (relative_a) { - const A = new CalcParser('alpha', relative_a, fromHWBVars).result; - rgb.A = minmax(A, 0, MAX_ALPHA); - } - - this._rgb = rgb; - - } else { - - this._h = h; - this._w = w; - this._b = b; - this._a = a; - const rgb: RGBObject = hwbToRgb( - normalizeHue(this._h), - percent(this._w), - percent(this._b) - ); - if (this._a !== undefined) { - rgb.A = normalizeAlpha(this._a); - } - this._rgb = rgb; - - } - } - - private _w: string; - private _b: string; - - static test(colorString: string): boolean { - return COLORREGS.HWB.test(colorString); - } - -} \ No newline at end of file diff --git a/src/parsers/_LCHStringParser.ts b/src/parsers/_LCHStringParser.ts deleted file mode 100644 index 4955ead..0000000 --- a/src/parsers/_LCHStringParser.ts +++ /dev/null @@ -1,112 +0,0 @@ -import { - LCHRegExpMatchArray, - ParserGetRgbObject, - RGBObject -} from '@types'; -import { - COLORREGS, - MAX_ALPHA, - MAX_LCH_C, - MAX_PCENT, - PCENT -} from '#constants'; -import { - getBase150Number, - minmax, - normalizeAlpha, - normalizeHue, - percent -} from '#helpers'; -import { lchToRgb, rgbToLch } from '#color/translators'; -import { CalcParser } from './_CalcParser'; -import { HueBaseClass } from './baseClasses/_HueBaseClass'; - -export class LCHStringParser extends HueBaseClass { - - constructor(colorString: string, getRGBObject: ParserGetRgbObject) { - - super(); - - const match = colorString.match(COLORREGS.LCH) as LCHRegExpMatchArray; - const groups = match.groups; - - const { - // LCH values - l, - c, - h, - a, - // Relative values - from, - relative_l, - relative_c, - relative_h, - relative_a - } = groups; - - if (from) { - - const fromRGB = getRGBObject(from); - const fromLCH = rgbToLch( - fromRGB.R, - fromRGB.G, - fromRGB.B - ); - const fromLCHVars = { - l: fromLCH.L, - c: fromLCH.C, - h: fromLCH.H, - alpha: fromRGB.A ?? 1 - }; - - const L = new CalcParser('l', relative_l, fromLCHVars).result; - const C = new CalcParser('c', relative_c, fromLCHVars).result; - const H = new CalcParser('h', relative_h, fromLCHVars).result; - - const rgb = lchToRgb( - minmax(L, 0, MAX_PCENT), - minmax(C, - MAX_LCH_C, MAX_LCH_C), - normalizeHue(H) - ); - - if (relative_a) { - const A = new CalcParser('alpha', relative_a, fromLCHVars).result; - rgb.A = minmax(A, 0, MAX_ALPHA); - } - - this._rgb = rgb; - - } else { - - this._l = l; - this._c = c; - this._h = h; - this._a = a; - const rgb: RGBObject = lchToRgb( - percent(this._l), - getBase150Number(this._c), - normalizeHue(this._h) - ); - if (this._a !== undefined) { - rgb.A = normalizeAlpha(this._a); - } - this._rgb = rgb; - - } - } - - private _l: string; - private _c: string; - - public get hasPercentageValues(): boolean { - return ( - PCENT.test(this._l) && - PCENT.test(this._c) - ); - } - - static test(colorString: string): boolean { - return COLORREGS.LCH.test(colorString); - } - -} \ No newline at end of file diff --git a/src/parsers/_RGBStringParser.ts b/src/parsers/_RGBStringParser.ts deleted file mode 100644 index 0d99373..0000000 --- a/src/parsers/_RGBStringParser.ts +++ /dev/null @@ -1,125 +0,0 @@ -import { - ParserGetRgbObject, - RGBObject, - RGBRegExpMatchArray -} from '@types'; -import { - BASE_255, - COLORREGS, - PCENT -} from '#constants'; -import { getBase255Number, normalizeAlpha } from '#helpers'; -import { CalcParser } from './_CalcParser'; -import { AlphaBaseClass } from './baseClasses/_AlphaBaseClass'; - -export class RGBStringParser extends AlphaBaseClass { - - constructor(colorString: string, getRGBObject: ParserGetRgbObject) { - - super(); - - const match = colorString.match(COLORREGS.RGB) as RGBRegExpMatchArray; - const groups = match.groups; - const { - // Legacy values - r_legacy, - g_legacy, - b_legacy, - a_legacy, - // RGB values - r, - g, - b, - a, - // Relative values - from, - relative_r, - relative_g, - relative_b, - relative_a - } = groups; - - if (from) { - - const fromRGB = getRGBObject(from); - const fromRGBVars = { - r: fromRGB.R, - g: fromRGB.G, - b: fromRGB.B, - alpha: fromRGB.A ?? 1 - }; - - const R = new CalcParser('r', relative_r, fromRGBVars).result; - const G = new CalcParser('g', relative_g, fromRGBVars).result; - const B = new CalcParser('b', relative_b, fromRGBVars).result; - - const rgb: RGBObject = { - R: Math.min( - R, - BASE_255 - ), - G: Math.min( - G, - BASE_255 - ), - B: Math.min( - B, - BASE_255 - ) - }; - - if (relative_a) { - const A = new CalcParser('alpha', relative_a, fromRGBVars).result; - rgb.A = Math.min(A, 1); - } - - this._rgb = rgb; - - } else { - - this._r = r_legacy ?? r; - this._g = g_legacy ?? g; - this._b = b_legacy ?? b; - this._a = a_legacy ?? a; - - const rgb: RGBObject = { - R: Math.min( - getBase255Number(this._r), - BASE_255 - ), - G: Math.min( - getBase255Number(this._g), - BASE_255 - ), - B: Math.min( - getBase255Number(this._b), - BASE_255 - ) - }; - - if (this._a !== undefined) { - rgb.A = normalizeAlpha(this._a); - } - - this._rgb = rgb; - - } - } - - private _r: string; - private _g: string; - private _b: string; - - public get hasPercentageValues(): boolean { - return ( - PCENT.test(this._r) && - PCENT.test(this._g) && - PCENT.test(this._b) - ); - } - - static test(colorString: string): boolean { - return COLORREGS.RGB.test(colorString); - } - -} \ No newline at end of file diff --git a/src/parsers/baseClasses/_AlphaBaseClass.ts b/src/parsers/baseClasses/_AlphaBaseClass.ts deleted file mode 100644 index 396a3c8..0000000 --- a/src/parsers/baseClasses/_AlphaBaseClass.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { PCENT } from '#constants'; -import { RgbClass } from './_RgbClass'; - -export class AlphaBaseClass extends RgbClass { - protected _a: string | undefined; - public get hasPercentageAlpha(): boolean { - return PCENT.test(this._a); - } -} \ No newline at end of file diff --git a/src/parsers/baseClasses/_HueBaseClass.ts b/src/parsers/baseClasses/_HueBaseClass.ts deleted file mode 100644 index 8d512b3..0000000 --- a/src/parsers/baseClasses/_HueBaseClass.ts +++ /dev/null @@ -1,17 +0,0 @@ -import { AnglesUnitEnum, AngleUnitRegExpMatchArray } from '@types'; -import { HSL_HUE } from '#constants'; -import { AlphaBaseClass } from './_AlphaBaseClass'; - -export class HueBaseClass extends AlphaBaseClass { - protected _h: string; - public get angleUnit(): AnglesUnitEnum { - if (this._h) { - const angleUnitMatch = this._h.match(HSL_HUE) as AngleUnitRegExpMatchArray; - const angleUnit = angleUnitMatch.groups.units; - return angleUnit === '' - ? AnglesUnitEnum.NONE - : angleUnit as AnglesUnitEnum; - } - return AnglesUnitEnum.NONE; - } -} \ No newline at end of file diff --git a/src/parsers/baseClasses/_RgbClass.ts b/src/parsers/baseClasses/_RgbClass.ts deleted file mode 100644 index 5fb21aa..0000000 --- a/src/parsers/baseClasses/_RgbClass.ts +++ /dev/null @@ -1,8 +0,0 @@ -import { RGBObject } from '@types'; - -export class RgbClass { - protected _rgb: RGBObject; - public get rgb(): RGBObject { - return this._rgb; - } -} \ No newline at end of file diff --git a/src/parsers/index.ts b/src/parsers/index.ts index 04a494b..a29f8b4 100644 --- a/src/parsers/index.ts +++ b/src/parsers/index.ts @@ -1,7 +1,197 @@ -export { HEXStringParser } from './_HEXStringParser'; -export { RGBStringParser } from './_RGBStringParser'; -export { HSLStringParser } from './_HSLStringParser'; -export { HWBStringParser } from './_HWBStringParser'; -export { CIELabStringParser } from './_CIELabStringParser'; -export { LCHStringParser } from './_LCHStringParser'; -export { CMYKStringParser } from './_CMYKStringParser'; \ No newline at end of file +import { + AnglesUnitEnum, + CMYKFunctionEnum, + ColorInput, + ColorUnitEnum, + InputOptions, + MatchOptions, + Options +} from '@types'; +import { + ColorModel, + COMMAS_AND_NEXT_CHARS, + DEFAULT_OPTIONS, + SPACES +} from '#constants'; +import { + isBoolean, + isNumber, + isString +} from '#utilities'; +import { ColorParserContext } from '#classes/ColorParserContext'; +import { HEXParser } from '#classes/HEXParser'; +import { RGBParser } from '#classes/RGBParser'; +import { HSLParser } from '#classes/HSLParser'; +import { HWBParser } from '#classes/HWBParser'; +import { CIELabParser } from '#classes/CIELabParser'; +import { LCHParser } from '#classes/LCHParser'; +import { CMYKParser } from '#classes/CMYKParser'; + +export const hexParser = new HEXParser(); +export const rgbParser = new RGBParser(); +export const hslParser = new HSLParser(); +export const hwbParser = new HWBParser(); +export const cieLabParser = new CIELabParser(); +export const lchParser = new LCHParser(); +export const cmykParser = new CMYKParser(); + +export const colorParserContext = new ColorParserContext({ + [ColorModel.HEX]: hexParser, + [ColorModel.RGB]: rgbParser, + [ColorModel.HSL]: hslParser, + [ColorModel.HWB]: hwbParser, + [ColorModel.CIELab]: cieLabParser, + [ColorModel.LCH]: lchParser, + [ColorModel.CMYK]: cmykParser +}); + +export const getOptionsFromColorInput = (options: InputOptions, ...colors: ColorInput[]): Options => { + const cssColors: string[] = []; + const anglesUnits: AnglesUnitEnum[] = []; + const rgbColors: boolean[] = []; + const labColors: boolean[] = []; + const lchColors: boolean[] = []; + const cmykColors: boolean[] = []; + const alphaValues: boolean[] = []; + const anglesUnitValues = Object.values(AnglesUnitEnum); + const colorUnitValues = Object.values(ColorUnitEnum); + const cmykFunctionValues = Object.values(CMYKFunctionEnum); + + const matchOptions: MatchOptions = { + legacyCSS: 0, + spacesAfterCommas: 0, + cmykFunction: 0 + }; + + for(const color of colors) { + + if (isString(color)) { + + cssColors.push(color); + + if (color.includes(',')) { + matchOptions.legacyCSS ++; + const commasWithNextCharacter = color.match(COMMAS_AND_NEXT_CHARS); + if ( + new Set(commasWithNextCharacter).size === 1 && + SPACES.test(commasWithNextCharacter[0].slice(1)) + ) { + matchOptions.spacesAfterCommas ++; + } + } + + if (hslParser.supports(color)) { + const options = hslParser.getCSSOptions(color); + anglesUnits.push(options.angleUnit); + alphaValues.push(options.hasPercentageAlpha); + continue; + } + + if (hwbParser.supports(color)) { + const options = hwbParser.getCSSOptions(color); + anglesUnits.push(options.angleUnit); + alphaValues.push(options.hasPercentageAlpha); + continue; + } + + if (rgbParser.supports(color)) { + const options = rgbParser.getCSSOptions(color); + rgbColors.push(options.hasPercentageValues); + alphaValues.push(options.hasPercentageAlpha); + continue; + } + + if (cieLabParser.supports(color)) { + const options = cieLabParser.getCSSOptions(color); + labColors.push(options.hasPercentageValues); + alphaValues.push(options.hasPercentageAlpha); + continue; + } + + if (lchParser.supports(color)) { + const options = lchParser.getCSSOptions(color); + anglesUnits.push(options.angleUnit); + lchColors.push(options.hasPercentageValues); + alphaValues.push(options.hasPercentageAlpha); + continue; + } + + if (cmykParser.supports(color)) { + const options = cmykParser.getCSSOptions(color); + cmykColors.push(options.hasPercentageValues); + if (color.startsWith('cmyk')) { + matchOptions.cmykFunction ++; + } + alphaValues.push(options.hasPercentageAlpha); + } + + } + + } + return { + decimals: isNumber(options.decimals) + ? options.decimals + : DEFAULT_OPTIONS.decimals, + legacyCSS: isBoolean(options.legacyCSS) + ? options.legacyCSS + : Boolean( + cssColors.length && + matchOptions.legacyCSS === cssColors.length + ) || DEFAULT_OPTIONS.legacyCSS, + spacesAfterCommas: isBoolean(options.spacesAfterCommas) + ? options.spacesAfterCommas + : Boolean( + cssColors.length && + matchOptions.spacesAfterCommas === cssColors.length + ) || DEFAULT_OPTIONS.spacesAfterCommas, + anglesUnit: options.anglesUnit && anglesUnitValues.includes(options.anglesUnit) + ? options.anglesUnit as AnglesUnitEnum + : ( + new Set(anglesUnits).size === 1 + ? anglesUnits[0] + : DEFAULT_OPTIONS.anglesUnit + ), + rgbUnit: options.rgbUnit && colorUnitValues.includes(options.rgbUnit) + ? options.rgbUnit as ColorUnitEnum + : ( + new Set(rgbColors).size === 1 && rgbColors[0] + ? ColorUnitEnum.PERCENT + : DEFAULT_OPTIONS.rgbUnit + ), + labUnit: options.labUnit && colorUnitValues.includes(options.labUnit) + ? options.labUnit as ColorUnitEnum + : ( + new Set(labColors).size === 1 && labColors[0] + ? ColorUnitEnum.PERCENT + : DEFAULT_OPTIONS.labUnit + ), + lchUnit: options.lchUnit && colorUnitValues.includes(options.lchUnit) + ? options.lchUnit as ColorUnitEnum + : ( + new Set(lchColors).size === 1 && lchColors[0] + ? ColorUnitEnum.PERCENT + : DEFAULT_OPTIONS.lchUnit + ), + cmykUnit: options.cmykUnit && colorUnitValues.includes(options.cmykUnit) + ? options.cmykUnit as ColorUnitEnum + : ( + new Set(cmykColors).size === 1 && !cmykColors[0] + ? ColorUnitEnum.NONE + : DEFAULT_OPTIONS.cmykUnit + ), + alphaUnit: options.alphaUnit && colorUnitValues.includes(options.alphaUnit) + ? options.alphaUnit as ColorUnitEnum + : ( + new Set(alphaValues).size === 1 && alphaValues[0] + ? ColorUnitEnum.PERCENT + : DEFAULT_OPTIONS.alphaUnit + ), + cmykFunction: options.cmykFunction && cmykFunctionValues.includes(options.cmykFunction) + ? options.cmykFunction as CMYKFunctionEnum + : ( + cmykColors.length && cmykColors.length === matchOptions.cmykFunction + ? CMYKFunctionEnum.CMYK + : DEFAULT_OPTIONS.cmykFunction + ) + }; +}; diff --git a/src/returns/index.ts b/src/returns/index.ts index e1d5c6e..4460f86 100644 --- a/src/returns/index.ts +++ b/src/returns/index.ts @@ -1,174 +1,446 @@ import { - Color, ColorInput, ColorInputWithoutCMYK, - ColorOutput, + ColorObject, InputOptions, - Options, - RGBObject + RGBObject, + RYBObject, + RGYBObject, + HSLObject, + CMYKObjectGeneric, + CMYKObject } from '@types'; import { + BASE_255, ColorModel, DEFAULT_BLEND_STEPS, + DEFAULT_SHADES_TINTS_STEPS, Harmony, HarmonyString, Mix, MixString } from '#constants'; -import * as utils from '#color/utils'; -import { getOptionsFromColorInput, getRGBObject } from '#color/extractors'; +import { + isHarmony, + isNumber, + isString, + isMix, + isUndefined, + normalizeAlpha, + normalizeHue, + round +} from '#utilities'; +import { + hueRyb, + rgbToRyb, + rybToRgb +} from '#color/translators'; +import { getRGB } from '#color/rgb'; +import { colorParserContext, getOptionsFromColorInput } from '#parsers'; -export const getColorReturn = ( - color: ColorInput, - model: ColorModel, - decimals: number, - translateFunction: (color: Color, decimals: number) => T -): T => { - const rgbObject = getRGBObject(color, model); - return translateFunction(rgbObject, decimals); +//---Blending +const blend = (from: RGBObject, to: RGBObject, steps: number): RGBObject[] => { + const div = steps - 1; + const diffR = (to.R - from.R) / div; + const diffG = (to.G - from.G) / div; + const diffB = (to.B - from.B) / div; + const fromA = normalizeAlpha(from.A); + const toA = normalizeAlpha(to.A); + const diffA = (toA - fromA) / div; + return Array(steps).fill(null).map((__n, i): RGBObject => { + if (i === 0) { return from; } + if (i === div) { return to; } + return { + R: round(from.R + diffR * i), + G: round(from.G + diffG * i), + B: round(from.B + diffB * i), + A: round(fromA + diffA * i) + }; + }); }; -export const getBlendReturn = ( +export function getBlendReturn( + from: ColorInput, + to: ColorInput, + model: ColorModel, + css: false, + withAlpha?: boolean, + steps?: number, + options?: InputOptions +): T[]; +export function getBlendReturn( + from: ColorInput, + to: ColorInput, + model: ColorModel, + css: true, + withAlpha?: boolean, + steps?: number, + options?: InputOptions +): string[]; +export function getBlendReturn( from: ColorInput, to: ColorInput, - steps: number, - decimals: number, - translateFunction: (color: Color, decimals: number) => T -): T[] => { + model: ColorModel, + css: boolean, + withAlpha: boolean, + steps: number = DEFAULT_BLEND_STEPS, + options: InputOptions = {} +) { if (steps < 1) steps = DEFAULT_BLEND_STEPS; - const fromRGBObject = getRGBObject(from); - const toRGBObject = getRGBObject(to); - const blendArray = utils.blend(fromRGBObject, toRGBObject, steps); - return blendArray.map((color: RGBObject): T => { - return translateFunction(color, decimals); + const fromParsed = colorParserContext.parse(from); + const toParsed = colorParserContext.parse(to); + const fromRGBObject = getRGB(fromParsed); + const toRGBObject = getRGB(toParsed); + const blendArray = blend(fromRGBObject, toRGBObject, steps); + return blendArray.map((color: RGBObject) => { + if (css) { + return colorParserContext.convertCSS( + color, + model, + getOptionsFromColorInput( + options, + from, + to + ), + withAlpha + ); + } + return colorParserContext.convert( + color, + model, + options.decimals, + withAlpha + ); }); -}; - -interface GetBlendReturnObjectWithParameters{ - from: ColorInput; - to: ColorInput; - thirdParameter?: number | InputOptions; - fourthParameter?: InputOptions; - translateFunction: (color: Color, decimals: number) => T; } -interface GetBlendReturnStringWithParameters extends GetBlendReturnObjectWithParameters { - cssFunction?: (color: T, options: Options) => string; -} +export const getBlendReturnParams = ( + thirdParameter?: number | InputOptions, + fourthParameter?: InputOptions +): [number | undefined, InputOptions] => { + const stepsParameter = isNumber(thirdParameter) + ? thirdParameter + : undefined; + const optionsParameter = isNumber(thirdParameter) + ? fourthParameter + : thirdParameter; + return [ + stepsParameter, + optionsParameter + ]; +}; -export function getBlendReturnWithParameters( - params: GetBlendReturnObjectWithParameters -): T[]; -export function getBlendReturnWithParameters( - params: GetBlendReturnStringWithParameters -): string[]; -export function getBlendReturnWithParameters( - params: GetBlendReturnStringWithParameters -): T[] | string[] { - const { - from, - to, - thirdParameter, - fourthParameter, - translateFunction, - cssFunction - } = params; - const result = typeof thirdParameter === 'number' - ? getBlendReturn( - from, - to, - thirdParameter, - fourthParameter?.decimals, - translateFunction - ) - : getBlendReturn( - from, - to, - DEFAULT_BLEND_STEPS, - thirdParameter?.decimals, - translateFunction - ); - if (cssFunction) { - return result.map((color: T): string => cssFunction( +export function getMixReturn( + colors: ColorInput[], + model: ColorModel, + css?: false, + withAlpha?: boolean, + mode?: MixString, + options?: InputOptions +): T; +export function getMixReturn( + colors: ColorInput[], + model: ColorModel, + css: true, + withAlpha?: boolean, + mode?: MixString, + options?: InputOptions +): string; +export function getMixReturn( + colors: ColorInput[], + model: ColorModel, + css: boolean, + withAlpha: boolean, + mode: MixString = Mix.ADDITIVE, + options: InputOptions = {} +): T | string { + + const rgbMap = colors.map((color: ColorInput): RGBObject => { + return colorParserContext.convert( color, - getOptionsFromColorInput( - ( - typeof thirdParameter === 'number' - ? fourthParameter - : thirdParameter - ) ?? {}, - from, - to - ) - )); - } - return result; + ColorModel.RGB, + options.decimals, + withAlpha + ); + }); -} + const rybMap = mode === Mix.SUBTRACTIVE + ? rgbMap.map((color: RGBObject): RYBObject => { + const RYB = rgbToRyb(color.R, color.G, color.B); + if (!isUndefined(color.A)) { + RYB.A = color.A; + } + return RYB; + }) + : null; -interface GetMixReturn { - colors: ColorInput[]; - secondParameter?: MixString | InputOptions; - thirdParameter?: InputOptions; - colorMixerFunction: (color: ColorInput[], mix: MixString, isCSS: boolean, options: Options) => string; -} + function createMix(items: RGBObject[]): RGBObject; + function createMix(items: RYBObject[]): RYBObject; + function createMix(items: RGYBObject[]): RGYBObject { + const initial = mode === Mix.ADDITIVE + ? {R: 0, G: 0, B: 0, A: 0} + : {R: 0, Y: 0, B: 0, A: 0}; + return items.reduce((mix: RGYBObject, color: RGYBObject): RGYBObject => { + const colorA = isUndefined(color.A) + ? 1 + : color.A; + const common = { + R: Math.min(mix.R + color.R * colorA, BASE_255), + B: Math.min(mix.B + color.B * colorA, BASE_255), + A: 1 - (1 - colorA) * (1 - mix.A) + }; + const mixGY = 'G' in mix + ? mix.G + : mix.Y; + const colorGY = 'G' in color + ? color.G + : color.Y; + return { + ...common, + ...(mode === Mix.ADDITIVE + ? { G: Math.min(mixGY + colorGY * colorA, BASE_255) } + : { Y: Math.min(mixGY + colorGY * colorA, BASE_255) } + ) + }; + }, initial); + } -interface GetMixObjectReturn extends GetMixReturn { - css: false; -} + let mix: RGBObject; -interface GetMixCssReturn extends GetMixReturn { - css: true; -} + if (mode === Mix.ADDITIVE) { + mix = createMix(rgbMap); + } else { + const RYB = createMix(rybMap); + mix = rybToRgb(RYB.R, RYB.Y, RYB.B); + mix.A = RYB.A; + } -export function getMixReturn(params: GetMixObjectReturn): T; -export function getMixReturn(params: GetMixCssReturn): string; -export function getMixReturn( - params: GetMixObjectReturn | GetMixCssReturn -): T | string { - const { - colors, - secondParameter, - thirdParameter, - colorMixerFunction, - css - } = params; - const options = getOptionsFromColorInput( - ( - typeof secondParameter === 'string' - ? thirdParameter - : secondParameter - ) ?? {}, - ...colors - ); - if (typeof secondParameter === 'string') { - return colorMixerFunction( - colors, - secondParameter, - css, - options + if (css) { + return colorParserContext.convertCSS( + mix, + model, + getOptionsFromColorInput(options, ...colors), + withAlpha ); } - return colorMixerFunction( - colors, - Mix.ADDITIVE, - css, - options + + return colorParserContext.convert( + mix, + model, + options.decimals, + withAlpha ); +}; + +export const getMixReturnParameters = ( + secondParameter?: MixString | InputOptions, + thirdParameter?: InputOptions +): [MixString | undefined, InputOptions] => { + const modeParam = isString(secondParameter) + ? secondParameter + : undefined; + const optionsParam = isString(secondParameter) + ? thirdParameter + : secondParameter; + return [ + modeParam, + optionsParam + ]; +}; + +export function getShadesOrTintsReturn( + shades: boolean, + color: string, + steps?: number, + options?: InputOptions +): string[]; +export function getShadesOrTintsReturn>( + shades: boolean, + color: ColorInputWithoutCMYK, + steps?: number, + options?: InputOptions +): T[]; +export function getShadesOrTintsReturn>( + shades: boolean, + color: ColorInputWithoutCMYK, + steps = DEFAULT_SHADES_TINTS_STEPS, + options: InputOptions = {} +): T[] | string[] { + const isCSS = isString(color); + const parser = colorParserContext.getParser(color); + const model = parser.model; + const withAlpha = parser.hasAlpha(color); + const hsl = colorParserContext.convert( + color, + ColorModel.HSL, + undefined, + withAlpha + ) as HSLObject; + const increment = shades + ? hsl.L / (steps + 1) + : (100 - hsl.L) / (steps + 1); + const hslMap = Array.from(Array(steps)).map((__n, i): HSLObject => ({ + ...hsl, + L: hsl.L + increment * (i + 1) * (1 - +shades * 2) + })); + if (isCSS) { + return hslMap.map((hslColor: HSLObject): string => { + return colorParserContext.convertCSS( + hslColor, + model, + getOptionsFromColorInput(options, color), + withAlpha + ); + }); + } + return hslMap.map((hslColor: HSLObject): T => { + return colorParserContext.convert( + hslColor, + model, + options.decimals, + withAlpha + ); + }); } -export const getHarmonyReturn = ( - harmony: HarmonyString, +export const getShadesOrTintsReturnParameters = ( + secondParameter?: number | InputOptions, + thirdParameter?: InputOptions +): [number | undefined, InputOptions] => { + const stepsParam = isNumber(secondParameter) + ? secondParameter + : undefined; + const optionsParam = isNumber(secondParameter) + ? thirdParameter + : secondParameter; + return [ + stepsParam, + optionsParam + ]; +}; + +//---Harmony +const harmony = ( + color: HSLObject, + angles: number[], + mode: MixString +): HSLObject[] => + angles.reduce( + (arr: HSLObject[], num: number): HSLObject[] => { + return [ + ...arr, + { + ...color, + H: mode === Mix.ADDITIVE + ? normalizeHue(color.H + num) + : normalizeHue( + hueRyb( + hueRyb( + color.H, + false + ) + num, + true + ) + ) + } + ]; + }, + [{...color}] + ); + +type HarmonyFunction = (color: HSLObject, mode: MixString) => HSLObject[]; + +const HARMONIES = new Map<`${Harmony}`, HarmonyFunction>([ + [ + Harmony.ANALOGOUS, + (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [30, -30], mode) + ], + [ + Harmony.COMPLEMENTARY, + (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [180], mode) + ], + [ + Harmony.SPLIT_COMPLEMENTARY, + (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [150, -150], mode) + ], + [ + Harmony.TRIADIC, + (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [120, -120], mode) + ], + [ + Harmony.TETRADIC, + (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [60, -120, 180], mode) + ], + [ + Harmony.SQUARE, + (color: HSLObject, mode: MixString): HSLObject[] => harmony(color, [90, -90, 180], mode) + ] +]); + +export const getHarmonyReturn = >( color: ColorInputWithoutCMYK, + harmony: HarmonyString, mode: MixString, - options: Options -): ColorOutput[] => { - return ({ - [Harmony.ANALOGOUS]: utils.colorHarmony.buildHarmony(color, utils.analogous, mode, options), - [Harmony.COMPLEMENTARY]: utils.colorHarmony.buildHarmony(color, utils.complementary, mode, options), - [Harmony.SPLIT_COMPLEMENTARY]: utils.colorHarmony.buildHarmony(color, utils.splitComplementary, mode, options), - [Harmony.TRIADIC]: utils.colorHarmony.buildHarmony(color, utils.triadic, mode, options), - [Harmony.TETRADIC]: utils.colorHarmony.buildHarmony(color, utils.tetradic, mode, options), - [Harmony.SQUARE]: utils.colorHarmony.buildHarmony(color, utils.square, mode, options) - })[harmony]; + options: InputOptions = {} +): T[] | string[] => { + const harmonyFunction = HARMONIES.get(harmony); + const isCSS = isString(color); + const parser = colorParserContext.getParser(color); + const model = parser.model; + const withAlpha = parser.hasAlpha(color); + const hsl = colorParserContext.convert( + color, + ColorModel.HSL + ); + const array = harmonyFunction(hsl, mode); + if (isCSS) { + return array.map((harmonyColor: HSLObject): string => { + return colorParserContext.convertCSS( + harmonyColor, + model, + getOptionsFromColorInput(options, color), + withAlpha + ); + }); + } + return array.map( + (harmonyColor: HSLObject) => { + return colorParserContext.convert( + harmonyColor, + model, + options.decimals, + withAlpha + ); + } + ); +}; + +export const getHarmonyReturnParameters = ( + secondParam?: HarmonyString | MixString | InputOptions, + thirdParam?: MixString | InputOptions, + fourthParam?: InputOptions +): [HarmonyString, MixString, InputOptions | undefined] => { + if (isHarmony(secondParam)) { + return [ + secondParam, + isMix(thirdParam) + ? thirdParam + : Mix.ADDITIVE, + isMix(thirdParam) + ? fourthParam + : thirdParam + ]; + } + if (isMix(secondParam)) { + return [ + Harmony.COMPLEMENTARY, + secondParam, + thirdParam as InputOptions + ]; + } + return [ + Harmony.COMPLEMENTARY, + Mix.ADDITIVE, + secondParam + ]; }; \ No newline at end of file diff --git a/src/helpers/index.ts b/src/utilities/index.ts similarity index 69% rename from src/helpers/index.ts rename to src/utilities/index.ts index a706766..7706e99 100644 --- a/src/helpers/index.ts +++ b/src/utilities/index.ts @@ -1,26 +1,57 @@ import { AnglesUnitEnum, AngleUnitRegExpMatchArray, + CIELabObject, + CMYKObject, + Color, + HSLObject, + HWBObject, InputOptions, - NumberOrString + LCHObject, + NumberOrString, + RGBObject } from '@types'; import { BASE_255, + ColorModel, + GRADIANS, Harmony, HarmonyString, HEX, HSL_HUE, MAX_ALPHA, MAX_DECIMALS, + MAX_HUE, MAX_LAB, MAX_LCH_C, Mix, MixString, - PCENT + PCENT, + VALID_COLOR_OBJECTS } from '#constants'; -//---Has property -export const hasProp = (obj: T, prop: K): boolean => Object.prototype.hasOwnProperty.call(obj, prop); +//---Return an ordered string from an array values +export const getOrderedArrayString = (keys: string[]): string => [...keys].sort().join('').toUpperCase(); + +// Primitive predicates +export const isString = (input: unknown): input is string => typeof input === 'string'; +export const isNumber = (input: unknown): input is number => typeof input === 'number'; +export const isBoolean = (input: unknown): input is boolean => typeof input === 'boolean'; +export const isUndefined = (input: unknown): input is undefined => input === undefined; + +// Color predicates +export const getColorModel = (color: Color): ColorModel => { + return VALID_COLOR_OBJECTS[ + getOrderedArrayString(Object.keys(color)) + ]; +}; + +export const isRGBObject = (color: Color): color is RGBObject => getColorModel(color) === ColorModel.RGB; +export const isHSLObject = (color: Color): color is HSLObject => getColorModel(color) === ColorModel.HSL; +export const isHWBObject = (color: Color): color is HWBObject => getColorModel(color) === ColorModel.HWB; +export const isCIELabObject = (color: Color): color is CIELabObject => getColorModel(color) === ColorModel.CIELab; +export const isLCHObject = (color: Color): color is LCHObject => getColorModel(color) === ColorModel.LCH; +export const isCMYKObject = (color: Color): color is CMYKObject => getColorModel(color) === ColorModel.CMYK; //---Get percent number export const percentNumber = (percent: NumberOrString): number => { @@ -96,10 +127,15 @@ export const getBase150Number = (color: string): number => { }; //---Calculate a decimal 0-1 value from CMYK value -export const getCMYKNumber = (color: string): number => Math.min(PCENT.test(color) ? percentNumber(color) / 100 : +color, 1); - -//---Return an ordered string from an array values -export const getOrderedArrayString = (keys: string[]): string => [...keys].sort().join('').toUpperCase(); +export const getCMYKNumber = (color: string, base100: boolean): number => { + const value = PCENT.test(color) + ? percentNumber(color) + : +color; + if (base100) { + return Math.min(value * 100, 100); + } + return Math.min(value, 100); +}; //---Round value export const round = (value: NumberOrString, decimals = MAX_DECIMALS): number => { @@ -117,11 +153,9 @@ export const degrees = (radian: number): number => radian * 180 / Math.PI; export const radians = (degrees: number): number => degrees * Math.PI / 180; //---Normalize hue -const pi2 = 360; - export const normalizeHue = (hue: number | string): number => { - if (typeof hue === 'string') { + if (isString(hue)) { const matches = hue.match(HSL_HUE) as AngleUnitRegExpMatchArray; const groups = matches.groups; @@ -132,7 +166,7 @@ export const normalizeHue = (hue: number | string): number => { hue = round(degrees(value)); break; case AnglesUnitEnum.TURNS: - hue = round(value * pi2); + hue = round(value * MAX_HUE); break; case AnglesUnitEnum.GRADIANS: hue = round(9 / 10 * value); @@ -143,8 +177,8 @@ export const normalizeHue = (hue: number | string): number => { } } - if (hue > 360 || hue < 0) { - hue -= Math.floor(hue / pi2) * pi2; + if (hue >= MAX_HUE || hue < 0) { + hue -= Math.floor(hue / MAX_HUE) * MAX_HUE; } return hue; @@ -152,7 +186,7 @@ export const normalizeHue = (hue: number | string): number => { //---Normalize alpha export const normalizeAlpha = (alpha: number | string | undefined | null): number => { - if (typeof alpha === 'string') { + if (isString(alpha)) { if(PCENT.test(alpha)) { alpha = percentNumber(alpha) / 100; } else { @@ -171,10 +205,10 @@ export const translateDegrees = (degrees: number, units: `${AnglesUnitEnum}`): n hue = round(radians(degrees)); break; case AnglesUnitEnum.TURNS: - hue = round(degrees / pi2); + hue = round(degrees / MAX_HUE); break; case AnglesUnitEnum.GRADIANS: - hue = round(10 / 9 * degrees); + hue = round(GRADIANS * degrees); break; case AnglesUnitEnum.DEGREES: case AnglesUnitEnum.NONE: @@ -191,4 +225,15 @@ export const isHarmony = (param: HarmonyString | MixString | InputOptions): para export const isMix = (param: MixString | InputOptions): param is MixString => { return `${param}` in Mix; -}; \ No newline at end of file +}; + +export const getAngleUnit = (unit: string | undefined): AnglesUnitEnum => { + if (unit) { + const angleUnitMatch = unit.match(HSL_HUE) as AngleUnitRegExpMatchArray; + const angleUnit = angleUnitMatch.groups.units; + return angleUnit === '' + ? AnglesUnitEnum.NONE + : angleUnit as AnglesUnitEnum; + } + return AnglesUnitEnum.NONE; +}; diff --git a/tests/01 - instance-get-properties.test.ts b/tests/01 - instance-get-properties.test.ts index 482f92f..4ef2bef 100644 --- a/tests/01 - instance-get-properties.test.ts +++ b/tests/01 - instance-get-properties.test.ts @@ -34,12 +34,12 @@ COLORS.forEach((color): void => { // HEXObject it(`HEXObject property => ${JSON.stringify(color.HEXObject)}`, () => { - expect(instance.HEXObject).toMatchObject(color.HEXObject); + expect(instance.HEXObject).toEqual(color.HEXObject); }); // HEXAObject it(`HEXAObject property => ${JSON.stringify(color.HEXAObject)}`, () => { - expect(instance.HEXAObject).toMatchObject(color.HEXAObject); + expect(instance.HEXAObject).toEqual(color.HEXAObject); }); // RGB @@ -56,12 +56,12 @@ COLORS.forEach((color): void => { // RGBObject it(`RGBObject property => ${JSON.stringify(color.RGBObject)}`, () => { - expect(instance.RGBObject).toMatchObject(color.RGBObject); + expect(instance.RGBObject).toEqual(color.RGBObject); }); // RGBAObject it(`RGBAObject property => ${JSON.stringify(color.RGBAObject)}`, () => { - expect(instance.RGBAObject).toMatchObject(color.RGBAObject); + expect(instance.RGBAObject).toEqual(color.RGBAObject); }); // HSL @@ -78,12 +78,12 @@ COLORS.forEach((color): void => { // HSLObject it(`HSLObject property => ${JSON.stringify(color.HSLObject)}`, () => { - expect(instance.HSLObject).toMatchObject(color.HSLObject); + expect(instance.HSLObject).toEqual(color.HSLObject); }); // HSLAObject it(`HSLAObject property => ${JSON.stringify(color.HSLAObject)}`, () => { - expect(instance.HSLAObject).toMatchObject(color.HSLAObject); + expect(instance.HSLAObject).toEqual(color.HSLAObject); }); // HWB @@ -100,12 +100,12 @@ COLORS.forEach((color): void => { // HWBObject it(`HWBObject property => ${JSON.stringify(color.HWBObject)}`, () => { - expect(instance.HWBObject).toMatchObject(color.HWBObject); + expect(instance.HWBObject).toEqual(color.HWBObject); }); // HWBAObject it(`HWBAObject property => ${JSON.stringify(color.HWBAObject)}`, () => { - expect(instance.HWBAObject).toMatchObject(color.HWBAObject); + expect(instance.HWBAObject).toEqual(color.HWBAObject); }); // H @@ -188,12 +188,12 @@ CMYK_COLORS.forEach((color) => { // CMYKObject it(`CMYKObject property => ${JSON.stringify(color.CMYKIntObject100)}`, () => { - expect(instance.CMYKObject).toMatchObject(color.CMYKIntObject100); + expect(instance.CMYKObject).toEqual(color.CMYKIntObject100); }); // CMYKAObject it(`CMYKAObject property => ${JSON.stringify(color.CMYKIntObject100WithAlpha)}`, () => { - expect(instance.CMYKAObject).toMatchObject(color.CMYKIntObject100WithAlpha); + expect(instance.CMYKAObject).toEqual(color.CMYKIntObject100WithAlpha); }); // C @@ -252,16 +252,16 @@ LAB_AND_LCH_COLORS.forEach((color) => { expect(instanceKeywordPercentages.CIELab).toBe(color.CIELabInPrcentage); }); - it(`CIELabA property in percentages => ${ color.CIELabAInPrcentage }`, () => { - expect(instanceKeywordPercentages.CIELabA).toBe(color.CIELabAInPrcentage); + it(`CIELabA property in percentages => ${ color.CIELabAInPercentage }`, () => { + expect(instanceKeywordPercentages.CIELabA).toBe(color.CIELabAInPercentage); }); it(`CIELabObject property => ${ JSON.stringify(color.CIELabObject) }`, () => { - expect(instanceKeyword.CIELabObject).toMatchObject(color.CIELabObject); + expect(instanceKeyword.CIELabObject).toEqual(color.CIELabObject); }); it(`CIELabAObject property => ${ JSON.stringify(color.CIELabAObject) }`, () => { - expect(instanceKeyword.CIELabAObject).toMatchObject(color.CIELabAObject); + expect(instanceKeyword.CIELabAObject).toEqual(color.CIELabAObject); }); it(`CIEL property => ${ color.CIELabObject.L }`, () => { @@ -297,11 +297,11 @@ LAB_AND_LCH_COLORS.forEach((color) => { }); it(`LCHObject property => ${ JSON.stringify(color.LCHObject) }`, () => { - expect(instanceKeyword.LCHObject).toMatchObject(color.LCHObject); + expect(instanceKeyword.LCHObject).toEqual(color.LCHObject); }); it(`LCHAObject property => ${ JSON.stringify(color.LCHAObject) }`, () => { - expect(instanceKeyword.LCHAObject).toMatchObject(color.LCHAObject); + expect(instanceKeyword.LCHAObject).toEqual(color.LCHAObject); }); it(`LCHL property => ${ color.LCHObject.L }`, () => { @@ -318,4 +318,40 @@ LAB_AND_LCH_COLORS.forEach((color) => { }); + describe('CIELab and LCH round trip', () => { + + it('CIELab round trip', () => { + const instance = new ColorTranslator(color.CIELab); + const instancePercentages = new ColorTranslator(color.CIELabInPrcentage); + const instanceAlpha = new ColorTranslator(color.CIELabA); + const instanceAlphaPercentages = new ColorTranslator(color.CIELabAInPercentage); + const instanceObject = new ColorTranslator(color.CIELabObject); + const instanceAlphaObject = new ColorTranslator(color.CIELabAObject); + + expect(instance.CIELab).toBe(color.CIELab); + expect(instancePercentages.CIELab).toBe(color.CIELabInPrcentage); + expect(instanceAlpha.CIELabA).toBe(color.CIELabA); + expect(instanceAlphaPercentages.CIELabA).toBe(color.CIELabAInPercentage); + expect(instanceObject.CIELabObject).toEqual(color.CIELabObject); + expect(instanceAlphaObject.CIELabAObject).toEqual(color.CIELabAObject); + }); + + it('LCH round trip', () => { + const instance = new ColorTranslator(color.LCH); + const instancePercentages = new ColorTranslator(color.LCHInPercentage); + const instanceAlpha = new ColorTranslator(color.LCHA); + const instanceAlphaPercentages = new ColorTranslator(color.LCHAInPercentage); + const instanceObject = new ColorTranslator(color.LCHObject); + const instanceAlphaObject = new ColorTranslator(color.LCHAObject); + + expect(instance.LCH).toBe(color.LCH); + expect(instancePercentages.LCH).toBe(color.LCHInPercentage); + expect(instanceAlpha.LCHA).toBe(color.LCHA); + expect(instanceAlphaPercentages.LCHA).toBe(color.LCHAInPercentage); + expect(instanceObject.LCHObject).toEqual(color.LCHObject); + expect(instanceAlphaObject.LCHAObject).toEqual(color.LCHAObject); + }); + + }); + }); \ No newline at end of file diff --git a/tests/02 - instance-set-properties.test.ts b/tests/02 - instance-set-properties.test.ts index 0be8833..1199071 100644 --- a/tests/02 - instance-set-properties.test.ts +++ b/tests/02 - instance-set-properties.test.ts @@ -111,29 +111,29 @@ describe('ColorTranslator set instance properties', () => { expect(instance.A).toBe(0.5); expect(instance.HEX).toBe(TEST_COLORS.red.HEX); expect(instance.HEXA).toBe(TEST_COLORS.red.HEX + '80'); - expect(instance.HEXObject).toMatchObject(TEST_COLORS.red.HEXObject); - expect(instance.HEXAObject).toMatchObject({ + expect(instance.HEXObject).toEqual(TEST_COLORS.red.HEXObject); + expect(instance.HEXAObject).toEqual({ ...TEST_COLORS.red.HEXObject, A: '0x80' }); expect(instance.RGB).toBe(TEST_COLORS.red.RGB); expect(instance.RGBA).toBe(TEST_COLORS.red.RGBA.replace(REG, '$10.5$3')); - expect(instance.RGBObject).toMatchObject(TEST_COLORS.red.RGBObject); - expect(instance.RGBAObject).toMatchObject({ + expect(instance.RGBObject).toEqual(TEST_COLORS.red.RGBObject); + expect(instance.RGBAObject).toEqual({ ...TEST_COLORS.red.RGBObject, A: 0.5 }); expect(instance.HSL).toBe(TEST_COLORS.red.HSL); expect(instance.HSLA).toBe(TEST_COLORS.red.HSLA.replace(REG, '$10.5$3')); - expect(instance.HSLObject).toMatchObject(TEST_COLORS.red.HSLObject); - expect(instance.HSLAObject).toMatchObject({ + expect(instance.HSLObject).toEqual(TEST_COLORS.red.HSLObject); + expect(instance.HSLAObject).toEqual({ ...TEST_COLORS.red.HSLObject, A: 0.5 }); expect(instance.HWB).toBe(TEST_COLORS.red.HWB); expect(instance.HWBA).toBe(TEST_COLORS.red.HWBA.replace(REG, '$10.5$3')); - expect(instance.HWBObject).toMatchObject(TEST_COLORS.red.HWBObject); - expect(instance.HWBAObject).toMatchObject({ + expect(instance.HWBObject).toEqual(TEST_COLORS.red.HWBObject); + expect(instance.HWBAObject).toEqual({ ...TEST_COLORS.red.HWBObject, A: 0.5 }); diff --git a/tests/03 - static-color-conversion.test.ts b/tests/03 - static-color-conversion.test.ts index ae2002c..f380a11 100644 --- a/tests/03 - static-color-conversion.test.ts +++ b/tests/03 - static-color-conversion.test.ts @@ -32,7 +32,7 @@ COLORS.forEach((color): void => { }); it(`toHEXObject method from ${colorValueStr} => ${JSON.stringify(color.HEXObject)}`, () => { - expect(ColorTranslator.toHEXObject(colorValue)).toMatchObject(color.HEXObject); + expect(ColorTranslator.toHEXObject(colorValue)).toEqual(color.HEXObject); }); // toHEXA @@ -41,7 +41,7 @@ COLORS.forEach((color): void => { }); it(`toHEXAObject method from ${colorValueStr} => ${JSON.stringify(color.HEXAObject)}`, () => { - expect(ColorTranslator.toHEXAObject(colorValue)).toMatchObject(color.HEXAObject); + expect(ColorTranslator.toHEXAObject(colorValue)).toEqual(color.HEXAObject); }); // toRGB @@ -50,7 +50,7 @@ COLORS.forEach((color): void => { }); it(`toRGBObject method from ${colorValueStr} => ${JSON.stringify(color.RGBObject)}`, () => { - expect(ColorTranslator.toRGBObject(colorValue, options)).toMatchObject(color.RGBObject); + expect(ColorTranslator.toRGBObject(colorValue, options)).toEqual(color.RGBObject); }); // toRGBA @@ -59,7 +59,7 @@ COLORS.forEach((color): void => { }); it(`toRGBAObject method from ${colorValueStr} => ${JSON.stringify(color.RGBAObject)}`, () => { - expect(ColorTranslator.toRGBAObject(colorValue, options)).toMatchObject(color.RGBAObject); + expect(ColorTranslator.toRGBAObject(colorValue, options)).toEqual(color.RGBAObject); }); // toHSL @@ -68,7 +68,7 @@ COLORS.forEach((color): void => { }); it(`toHSLObject method from ${colorValueStr} => ${JSON.stringify(color.HSLObject)}`, () => { - expect(ColorTranslator.toHSLObject(colorValue, options)).toMatchObject(color.HSLObject); + expect(ColorTranslator.toHSLObject(colorValue, options)).toEqual(color.HSLObject); }); // toHSLA @@ -77,7 +77,7 @@ COLORS.forEach((color): void => { }); it(`toHSLAObject method from ${colorValueStr} => ${JSON.stringify(color.HSLAObject)}`, () => { - expect(ColorTranslator.toHSLAObject(colorValue, options)).toMatchObject(color.HSLAObject); + expect(ColorTranslator.toHSLAObject(colorValue, options)).toEqual(color.HSLAObject); }); // toHWB @@ -86,7 +86,7 @@ COLORS.forEach((color): void => { }); it(`toHWBObject method from ${colorValueStr} => ${JSON.stringify(color.HWBObject)}`, () => { - expect(ColorTranslator.toHWBObject(colorValue, options)).toMatchObject(color.HWBObject); + expect(ColorTranslator.toHWBObject(colorValue, options)).toEqual(color.HWBObject); }); // toHWBA @@ -95,7 +95,7 @@ COLORS.forEach((color): void => { }); it(`toHWBAObject method from ${colorValueStr} => ${JSON.stringify(color.HWBAObject)}`, () => { - expect(ColorTranslator.toHWBAObject(colorValue, options)).toMatchObject(color.HWBAObject); + expect(ColorTranslator.toHWBAObject(colorValue, options)).toEqual(color.HWBAObject); }); }); @@ -133,18 +133,18 @@ LAB_AND_LCH_COLORS.forEach((color) => { expect(ColorTranslator.toCIELabA(keyword, options)).toBe(color.CIELabA); }); - it(`toCIELabA with parcentages => ${ color.CIELabAInPrcentage }`, () => { + it(`toCIELabA with parcentages => ${ color.CIELabAInPercentage }`, () => { expect( ColorTranslator.toCIELabA(keyword, optionsWithPercentage) - ).toBe(color.CIELabAInPrcentage); + ).toBe(color.CIELabAInPercentage); }); it(`toCIELabObject => ${ JSON.stringify(color.CIELabObject) }`, () => { - expect(ColorTranslator.toCIELabObject(keyword, options)).toMatchObject(color.CIELabObject); + expect(ColorTranslator.toCIELabObject(keyword, options)).toEqual(color.CIELabObject); }); it(`toCIELabAObject => ${ JSON.stringify(color.CIELabAObject) }`, () => { - expect(ColorTranslator.toCIELabAObject(keyword, options)).toMatchObject(color.CIELabAObject); + expect(ColorTranslator.toCIELabAObject(keyword, options)).toEqual(color.CIELabAObject); }); // LCH @@ -169,11 +169,57 @@ LAB_AND_LCH_COLORS.forEach((color) => { }); it(`toLCHObject => ${ JSON.stringify(color.LCHObject) }`, () => { - expect(ColorTranslator.toLCHObject(keyword, options)).toMatchObject(color.LCHObject); + expect(ColorTranslator.toLCHObject(keyword, options)).toEqual(color.LCHObject); }); it(`toLCHAObject => ${ JSON.stringify(color.LCHAObject) }`, () => { - expect(ColorTranslator.toLCHAObject(keyword, options)).toMatchObject(color.LCHAObject); + expect(ColorTranslator.toLCHAObject(keyword, options)).toEqual(color.LCHAObject); + }); + + }); + + describe('CIELab and LCH static methods round trip', () => { + + it('CIELab round trip', () => { + expect( + ColorTranslator.toCIELab(color.CIELab) + ).toBe(color.CIELab); + expect( + ColorTranslator.toCIELab(color.CIELabInPrcentage) + ).toBe(color.CIELabInPrcentage); + expect( + ColorTranslator.toCIELabA(color.CIELabA) + ).toBe(color.CIELabA); + expect( + ColorTranslator.toCIELabA(color.CIELabAInPercentage) + ).toBe(color.CIELabAInPercentage); + expect( + ColorTranslator.toCIELabObject(color.CIELabObject) + ).toEqual(color.CIELabObject); + expect( + ColorTranslator.toCIELabAObject(color.CIELabAObject) + ).toEqual(color.CIELabAObject); + }); + + it('LCH round trip', () => { + expect( + ColorTranslator.toLCH(color.LCH) + ).toBe(color.LCH); + expect( + ColorTranslator.toLCH(color.LCHInPercentage) + ).toBe(color.LCHInPercentage); + expect( + ColorTranslator.toLCHA(color.LCHA) + ).toBe(color.LCHA); + expect( + ColorTranslator.toLCHA(color.LCHAInPercentage) + ).toBe(color.LCHAInPercentage); + expect( + ColorTranslator.toLCHObject(color.LCHObject) + ).toEqual(color.LCHObject); + expect( + ColorTranslator.toLCHAObject(color.LCHAObject) + ).toEqual(color.LCHAObject); }); }); @@ -193,7 +239,7 @@ COLORS.forEach((color): void => { expect(ColorTranslator.toHWBA(color.RGBObject, optionsNoDecimals)).toBe(color.HWBA); }); - it('Legacy conversion', () => { + it(' Legacy conversion', () => { expect(ColorTranslator.toRGB(color.HSLLegacy, optionsNoDecimals)).toBe(color.RGBLegacy); expect(ColorTranslator.toRGBA(color.HSLALegacy, optionsNoDecimals)).toBe(color.RGBALegacy); expect(ColorTranslator.toHSL(color.RGBALegacy, optionsNoDecimals)).toBe(color.HSLLegacy); @@ -218,7 +264,7 @@ CMYK_COLORS.forEach((color) => { }); it(`toCMYKObject method from ${colorValueStr} => ${JSON.stringify(color.CMYKIntObject100)}`, () => { - expect(ColorTranslator.toCMYKObject(colorValue, options)).toMatchObject(color.CMYKIntObject100); + expect(ColorTranslator.toCMYKObject(colorValue, options)).toEqual(color.CMYKIntObject100); }); // toCMYKA @@ -227,7 +273,7 @@ CMYK_COLORS.forEach((color) => { }); it(`toCMYKAObject method from ${colorValueStr} => ${JSON.stringify(color.CMYKIntObject100WithAlpha)}`, () => { - expect(ColorTranslator.toCMYKAObject(colorValue, options)).toMatchObject(color.CMYKIntObject100WithAlpha); + expect(ColorTranslator.toCMYKAObject(colorValue, options)).toEqual(color.CMYKIntObject100WithAlpha); }); it(`toCMYK method with decimals from ${colorValueStr}`, () => { @@ -256,6 +302,12 @@ CMYK_COLORS.forEach((color) => { }); + describe('Conversion from CMYK', () => { + expect(ColorTranslator.toHEX(colorValue)).toBe( + ColorTranslator.toHEX(color.RGB) + ); + }); + }); }); \ No newline at end of file diff --git a/tests/04 - relative-colors.test.ts b/tests/04 - relative-colors.test.ts index c9b5854..cac3a05 100644 --- a/tests/04 - relative-colors.test.ts +++ b/tests/04 - relative-colors.test.ts @@ -84,11 +84,11 @@ describe('Relative colors', () => { // RGB { input: 'rgb(from #FF0000 h s l)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'rgb(from rgb(255 0 0) r g b alpha)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { @@ -102,11 +102,11 @@ describe('Relative colors', () => { // HSL { input: 'hsl(from #FF0000 r g b)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'hsl(from hsl(0 100% 50%) h s l alpha)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'hsl(from hsl(0 100% 50%) h s calc(hsl * 2))', @@ -119,11 +119,11 @@ describe('Relative colors', () => { // HWB { input: 'hwb(from #FF0000 h s l)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'hwb(from hwb(0 0% 0%) h w b alpha)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'hwb(from hwb(0 0% 0%) calc(hwb - 50) w b)', @@ -136,11 +136,11 @@ describe('Relative colors', () => { // Lab { input: 'lab(from #FF0000 h w b)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'lab(from #FF0000 h w b alpha)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'lab(from #FF0000 l a calc(lab / 2))', @@ -153,11 +153,11 @@ describe('Relative colors', () => { // LCH { input: 'lch(from #FF0000 l a b)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'lch(from #FF0000 l c h alpha)', - error: ERRORS.NOT_ACCEPTED_STRING_INPUT + error: ERRORS.NOT_ACCEPTED_INPUT }, { input: 'lch(from #FF0000 l c calc(lch / 2))', diff --git a/tests/05 - config-options.test.ts b/tests/05 - config-options.test.ts index 7c73bab..56e9eb1 100644 --- a/tests/05 - config-options.test.ts +++ b/tests/05 - config-options.test.ts @@ -655,16 +655,16 @@ describe('ColorTranslator CSS config options autodetection', () => { const instancePercentage = new ColorTranslator('device-cmyk(100% 100% 100% 100%)'); - expect(instancePercentage.CMYK).toBe('device-cmyk(0% 0% 0% 100%)'); - expect(instancePercentage.CMYKA).toBe('device-cmyk(0% 0% 0% 100% / 1)'); + expect(instancePercentage.CMYK).toBe('device-cmyk(100% 100% 100% 100%)'); + expect(instancePercentage.CMYKA).toBe('device-cmyk(100% 100% 100% 100% / 1)'); const instanceNone = new ColorTranslator('device-cmyk(1 1 1 1)'); - expect(instanceNone.CMYK).toBe('device-cmyk(0 0 0 1)'); - expect(instanceNone.CMYKA).toBe('device-cmyk(0 0 0 1 / 1)'); + expect(instanceNone.CMYK).toBe('device-cmyk(1 1 1 1)'); + expect(instanceNone.CMYKA).toBe('device-cmyk(1 1 1 1 / 1)'); - expect(ColorTranslator.toCMYK('device-cmyk(100% 100% 100% 100% / 0.5)')).toBe('device-cmyk(0% 0% 0% 100%)'); - expect(ColorTranslator.toCMYKA('device-cmyk(1 1 1 1)')).toBe('device-cmyk(0 0 0 1 / 1)'); + expect(ColorTranslator.toCMYK('device-cmyk(100% 100% 100% 100% / 0.5)')).toBe('device-cmyk(100% 100% 100% 100%)'); + expect(ColorTranslator.toCMYKA('device-cmyk(1 1 1 1)')).toBe('device-cmyk(1 1 1 1 / 1)'); }); @@ -753,7 +753,7 @@ describe('ColorTranslator CSS config options autodetection', () => { } ); - expect(instanceWrong.options).toMatchObject(DEFAULT_OPTIONS); + expect(instanceWrong.options).toEqual(DEFAULT_OPTIONS); }); diff --git a/tests/06 - hex3.test.ts b/tests/06 - hex3.test.ts index 2af3385..f3595ca 100644 --- a/tests/06 - hex3.test.ts +++ b/tests/06 - hex3.test.ts @@ -25,8 +25,8 @@ HEX3.forEach((item: HexProps): void => { }); it('Object RGB', (): void => { - expect(ColorTranslator.toRGBObject(item[prop])).toMatchObject(item.RGBObject); - expect(ColorTranslator.toRGBObject(item.KEYWORD)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(item[prop])).toEqual(item.RGBObject); + expect(ColorTranslator.toRGBObject(item.KEYWORD)).toEqual(item.RGBObject); }); it('CSS RGBA', (): void => { @@ -37,8 +37,8 @@ HEX3.forEach((item: HexProps): void => { }); it('Object RGBA', (): void => { - expect(ColorTranslator.toRGBAObject(item[prop])).toMatchObject(item.RGBAObject); - expect(ColorTranslator.toRGBAObject(item.KEYWORD)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(item[prop])).toEqual(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(item.KEYWORD)).toEqual(item.RGBAObject); }); it('CSS HSL', (): void => { @@ -49,8 +49,8 @@ HEX3.forEach((item: HexProps): void => { }); it('Object HSL', (): void => { - expect(ColorTranslator.toHSLObject(item[prop])).toMatchObject(item.HSLObject); - expect(ColorTranslator.toHSLObject(item.KEYWORD)).toMatchObject(item.HSLObject); + expect(ColorTranslator.toHSLObject(item[prop])).toEqual(item.HSLObject); + expect(ColorTranslator.toHSLObject(item.KEYWORD)).toEqual(item.HSLObject); }); it('CSS HSLA', (): void => { @@ -61,8 +61,8 @@ HEX3.forEach((item: HexProps): void => { }); it('Object HSLA', (): void => { - expect(ColorTranslator.toHSLAObject(item[prop])).toMatchObject(item.HSLAObject); - expect(ColorTranslator.toHSLAObject(item.KEYWORD)).toMatchObject(item.HSLAObject); + expect(ColorTranslator.toHSLAObject(item[prop])).toEqual(item.HSLAObject); + expect(ColorTranslator.toHSLAObject(item.KEYWORD)).toEqual(item.HSLAObject); }); }); diff --git a/tests/07 - hsl.test.ts b/tests/07 - hsl.test.ts index 75426dc..6ba4c1c 100644 --- a/tests/07 - hsl.test.ts +++ b/tests/07 - hsl.test.ts @@ -20,11 +20,11 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGB(HSLPercentages, options)).toBe(item.RGB); expect(ColorTranslator.toRGB(HSLPercentages, legacyOptions)).toBe(item.RGBLegacy); - expect(ColorTranslator.toRGBObject(HSLPercentages, options)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(HSLPercentages, options)).toEqual(item.RGBObject); expect(ColorTranslator.toHSL(HSLPercentages, options)).toBe(item.HSL); expect(ColorTranslator.toHSL(HSLPercentages, legacyOptions)).toBe(item.HSLLegacy); - expect(ColorTranslator.toHSLObject(HSLPercentages, options)).toMatchObject(item.HSLObject); + expect(ColorTranslator.toHSLObject(HSLPercentages, options)).toEqual(item.HSLObject); expect(ColorTranslator.toRGB(HSLPercentages)).toMatchSnapshot(); expect(ColorTranslator.toHSL(HSLPercentages)).toMatchSnapshot(); @@ -35,11 +35,11 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGBA(HSLAPercentages, options)).toBe(item.RGBA); expect(ColorTranslator.toRGBA(HSLAPercentages, legacyOptions)).toBe(item.RGBALegacy); - expect(ColorTranslator.toRGBAObject(HSLAPercentages, options)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(HSLAPercentages, options)).toEqual(item.RGBAObject); expect(ColorTranslator.toHSLA(HSLAPercentages, options)).toBe(item.HSLA); expect(ColorTranslator.toHSLA(HSLAPercentages, legacyOptions)).toBe(item.HSLALegacy); - expect(ColorTranslator.toHSLAObject(HSLAPercentages, options)).toMatchObject(item.HSLAObject); + expect(ColorTranslator.toHSLAObject(HSLAPercentages, options)).toEqual(item.HSLAObject); expect(ColorTranslator.toRGBA(HSLAPercentages)).toMatchSnapshot(); expect(ColorTranslator.toHSLA(HSLAPercentages)).toMatchSnapshot(); @@ -50,11 +50,11 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGB(HSLBigHue, options)).toBe(item.RGB); expect(ColorTranslator.toRGB(HSLBigHue, legacyOptions)).toBe(item.RGBLegacy); - expect(ColorTranslator.toRGBObject(HSLBigHue, options)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(HSLBigHue, options)).toEqual(item.RGBObject); expect(ColorTranslator.toHSL(HSLBigHue, options)).toBe(item.HSL); expect(ColorTranslator.toHSL(HSLBigHue, legacyOptions)).toBe(item.HSLLegacy); - expect(ColorTranslator.toHSLObject(HSLBigHue, options)).toMatchObject(item.HSLObject); + expect(ColorTranslator.toHSLObject(HSLBigHue, options)).toEqual(item.HSLObject); }); @@ -62,11 +62,11 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGBA(HSLABigHue, options)).toBe(item.RGBA); expect(ColorTranslator.toRGBA(HSLABigHue, legacyOptions)).toBe(item.RGBALegacy); - expect(ColorTranslator.toRGBAObject(HSLABigHue, options)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(HSLABigHue, options)).toEqual(item.RGBAObject); expect(ColorTranslator.toHSLA(HSLABigHue, options)).toBe(item.HSLA); expect(ColorTranslator.toHSLA(HSLABigHue, legacyOptions)).toBe(item.HSLALegacy); - expect(ColorTranslator.toHSLAObject(HSLABigHue, options)).toMatchObject(item.HSLAObject); + expect(ColorTranslator.toHSLAObject(HSLABigHue, options)).toEqual(item.HSLAObject); }); @@ -74,11 +74,11 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGB(HSLLowHue, options)).toBe(item.RGB); expect(ColorTranslator.toRGB(HSLLowHue, legacyOptions)).toBe(item.RGBLegacy); - expect(ColorTranslator.toRGBObject(HSLLowHue, options)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(HSLLowHue, options)).toEqual(item.RGBObject); expect(ColorTranslator.toHSL(HSLLowHue, options)).toBe(item.HSL); expect(ColorTranslator.toHSL(HSLLowHue, legacyOptions)).toBe(item.HSLLegacy); - expect(ColorTranslator.toHSLObject(HSLLowHue, options)).toMatchObject(item.HSLObject); + expect(ColorTranslator.toHSLObject(HSLLowHue, options)).toEqual(item.HSLObject); }); @@ -86,11 +86,11 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGBA(HSLALowHue, options)).toBe(item.RGBA); expect(ColorTranslator.toRGBA(HSLALowHue, legacyOptions)).toBe(item.RGBALegacy); - expect(ColorTranslator.toRGBAObject(HSLALowHue, options)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(HSLALowHue, options)).toEqual(item.RGBAObject); expect(ColorTranslator.toHSLA(HSLALowHue, options)).toBe(item.HSLA); expect(ColorTranslator.toHSLA(HSLALowHue, legacyOptions)).toBe(item.HSLALegacy); - expect(ColorTranslator.toHSLAObject(HSLALowHue, options)).toMatchObject(item.HSLAObject); + expect(ColorTranslator.toHSLAObject(HSLALowHue, options)).toEqual(item.HSLAObject); }); diff --git a/tests/08 - hwb.test.ts b/tests/08 - hwb.test.ts index ed632f1..9b462af 100644 --- a/tests/08 - hwb.test.ts +++ b/tests/08 - hwb.test.ts @@ -20,10 +20,10 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGB(HWBPercentages, options)).toBe(item.RGB); expect(ColorTranslator.toRGB(HWBPercentages, legacyOptions)).toBe(item.RGBLegacy); - expect(ColorTranslator.toRGBObject(HWBPercentages, options)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(HWBPercentages, options)).toEqual(item.RGBObject); expect(ColorTranslator.toHWB(HWBPercentages, options)).toBe(item.HWB); - expect(ColorTranslator.toHWBObject(HWBPercentages, options)).toMatchObject(item.HWBObject); + expect(ColorTranslator.toHWBObject(HWBPercentages, options)).toEqual(item.HWBObject); expect(ColorTranslator.toRGB(HWBPercentages)).toMatchSnapshot(); expect(ColorTranslator.toHWB(HWBPercentages)).toMatchSnapshot(); @@ -34,10 +34,10 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGBA(HWBAPercentages, options)).toBe(item.RGBA); expect(ColorTranslator.toRGBA(HWBAPercentages, legacyOptions)).toBe(item.RGBALegacy); - expect(ColorTranslator.toRGBAObject(HWBAPercentages, options)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(HWBAPercentages, options)).toEqual(item.RGBAObject); expect(ColorTranslator.toHWBA(HWBAPercentages, options)).toBe(item.HWBA); - expect(ColorTranslator.toHWBAObject(HWBAPercentages, options)).toMatchObject(item.HWBAObject); + expect(ColorTranslator.toHWBAObject(HWBAPercentages, options)).toEqual(item.HWBAObject); expect(ColorTranslator.toRGBA(HWBAPercentages)).toMatchSnapshot(); expect(ColorTranslator.toHWB(HWBAPercentages)).toMatchSnapshot(); @@ -48,10 +48,10 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGB(HWBBigHue, options)).toBe(item.RGB); expect(ColorTranslator.toRGB(HWBBigHue, legacyOptions)).toBe(item.RGBLegacy); - expect(ColorTranslator.toRGBObject(HWBBigHue, options)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(HWBBigHue, options)).toEqual(item.RGBObject); expect(ColorTranslator.toHWB(HWBBigHue, options)).toBe(item.HWB); - expect(ColorTranslator.toHWBObject(HWBBigHue, options)).toMatchObject(item.HWBObject); + expect(ColorTranslator.toHWBObject(HWBBigHue, options)).toEqual(item.HWBObject); }); @@ -59,10 +59,10 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGBA(HWBABigHue, options)).toBe(item.RGBA); expect(ColorTranslator.toRGBA(HWBABigHue, legacyOptions)).toBe(item.RGBALegacy); - expect(ColorTranslator.toRGBAObject(HWBABigHue, options)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(HWBABigHue, options)).toEqual(item.RGBAObject); expect(ColorTranslator.toHWBA(HWBABigHue, options)).toBe(item.HWBA); - expect(ColorTranslator.toHWBAObject(HWBABigHue, options)).toMatchObject(item.HWBAObject); + expect(ColorTranslator.toHWBAObject(HWBABigHue, options)).toEqual(item.HWBAObject); }); @@ -70,10 +70,10 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGB(HWBLowHue, options)).toBe(item.RGB); expect(ColorTranslator.toRGB(HWBLowHue, legacyOptions)).toBe(item.RGBLegacy); - expect(ColorTranslator.toRGBObject(HWBLowHue, options)).toMatchObject(item.RGBObject); + expect(ColorTranslator.toRGBObject(HWBLowHue, options)).toEqual(item.RGBObject); expect(ColorTranslator.toHWB(HWBLowHue, options)).toBe(item.HWB); - expect(ColorTranslator.toHWBObject(HWBLowHue, options)).toMatchObject(item.HWBObject); + expect(ColorTranslator.toHWBObject(HWBLowHue, options)).toEqual(item.HWBObject); }); @@ -81,10 +81,10 @@ COLORS.forEach((item): void => { expect(ColorTranslator.toRGBA(HWBALowHue, options)).toBe(item.RGBA); expect(ColorTranslator.toRGBA(HWBALowHue, legacyOptions)).toBe(item.RGBALegacy); - expect(ColorTranslator.toRGBAObject(HWBALowHue, options)).toMatchObject(item.RGBAObject); + expect(ColorTranslator.toRGBAObject(HWBALowHue, options)).toEqual(item.RGBAObject); expect(ColorTranslator.toHWBA(HWBALowHue, options)).toBe(item.HWBA); - expect(ColorTranslator.toHWBAObject(HWBALowHue, options)).toMatchObject(item.HWBAObject); + expect(ColorTranslator.toHWBAObject(HWBALowHue, options)).toEqual(item.HWBAObject); }); diff --git a/tests/09 - lab.test.ts b/tests/09 - lab.test.ts index d0dad04..1edba86 100644 --- a/tests/09 - lab.test.ts +++ b/tests/09 - lab.test.ts @@ -1,5 +1,5 @@ import { ColorTranslator } from '../src'; -import { COLORS } from './tests.constants'; +import { COLORS, LAB_AND_LCH_COLORS } from './tests.constants'; COLORS.forEach((item): void => { @@ -22,8 +22,8 @@ COLORS.forEach((item): void => { const laba = ColorTranslator.toCIELabAObject(item.HEX); const hex = ColorTranslator.toHEXObject(lab); const hexa = ColorTranslator.toHEXAObject(laba); - expect(hex).toMatchObject(item.HEXObject); - expect(hexa).toMatchObject(item.HEXAObject); + expect(hex).toEqual(item.HEXObject); + expect(hexa).toEqual(item.HEXAObject); }); @@ -39,6 +39,43 @@ COLORS.forEach((item): void => { }); + describe('CIE L*a*b round trip', () => { + + LAB_AND_LCH_COLORS.forEach((color) => { + + it.each([ + color.CIELab, + color.CIELabInPrcentage, + color.CIELabObject, + color.CIELabA, + color.CIELabAInPercentage, + color.CIELabAObject + ])('round trip of %s', (lab) => { + expect( + new ColorTranslator(lab, { legacyCSS: false, labUnit: 'none', decimals: 0 }).CIELab + ).toBe(color.CIELab); + expect( + new ColorTranslator(lab, { legacyCSS: false, labUnit: 'percent', decimals: 0 }).CIELab + ).toBe(color.CIELabInPrcentage); + expect( + new ColorTranslator(lab, { decimals: 0 }).CIELabObject + ).toEqual(color.CIELabObject); + + expect( + new ColorTranslator(lab, { legacyCSS: false, labUnit: 'none', decimals: 0, alphaUnit: 'none' }).CIELabA + ).toBe(color.CIELabA); + expect( + new ColorTranslator(lab, { legacyCSS: false, labUnit: 'percent', decimals: 0, alphaUnit: 'percent' }).CIELabA + ).toBe(color.CIELabAInPercentage); + expect( + new ColorTranslator(lab, { decimals: 0 }).CIELabAObject + ).toEqual(color.CIELabAObject); + }); + + }); + + }); + }); describe('L*a*b with percentages', (): void => { diff --git a/tests/10 - lch.test.ts b/tests/10 - lch.test.ts index 599637b..55a069c 100644 --- a/tests/10 - lch.test.ts +++ b/tests/10 - lch.test.ts @@ -22,8 +22,8 @@ COLORS.forEach((item): void => { const lcha = ColorTranslator.toLCHAObject(item.HEX); const hex = ColorTranslator.toHEXObject(lch); const hexa = ColorTranslator.toHEXAObject(lcha); - expect(hex).toMatchObject(item.HEXObject); - expect(hexa).toMatchObject(item.HEXAObject); + expect(hex).toEqual(item.HEXObject); + expect(hexa).toEqual(item.HEXAObject); }); diff --git a/tests/11 - blending.test.ts b/tests/11 - blending.test.ts index 83fa43b..6525181 100644 --- a/tests/11 - blending.test.ts +++ b/tests/11 - blending.test.ts @@ -54,46 +54,46 @@ describe('ColorTranslator blending tests', (): void => { const r2 = result2.map(c => obj.colorFn(c)); const r3 = result3.map(c => obj.colorFn(c)); - expect(obj.blendFn(from, to, r1.length)).toMatchObject(r1); - expect(obj.blendFn(from, to, r2.length)).toMatchObject(r2); - expect(obj.blendFn(from, to)).toMatchObject(r3); - expect(obj.blendFn(from, to, 0)).toMatchObject(r3); + expect(obj.blendFn(from, to, r1.length)).toEqual(r1); + expect(obj.blendFn(from, to, r2.length)).toEqual(r2); + expect(obj.blendFn(from, to)).toEqual(r3); + expect(obj.blendFn(from, to, 0)).toEqual(r3); }); blendFunctions.forEach((obj): void => { const r1 = result1.map(c => obj.colorFn(c, options)); const r2 = result2.map(c => obj.colorFn(c, options)); - expect(obj.blendFn(from, to, r1.length, options)).toMatchObject(r1); - expect(obj.blendFn(from, to, r2.length, options)).toMatchObject(r2); + expect(obj.blendFn(from, to, r1.length, options)).toEqual(r1); + expect(obj.blendFn(from, to, r2.length, options)).toEqual(r2); expect(obj.blendFn(from, to).length).toBe(5); expect( obj.blendFn(from, to, { decimals: 6 }) - ).toMatchObject( + ).toEqual( obj.blendFn(from, to) ); expect( obj.blendFn(from, to, 4, { decimals: 6 }) - ).toMatchObject( + ).toEqual( obj.blendFn(from, to, 4) ); expect( obj.blendFn(from, to, { cmykUnit: 'percent' }) - ).toMatchObject( + ).toEqual( obj.blendFn(from, to) ); expect( obj.blendFn(from, to, 3, { cmykUnit: 'percent' }) - ).toMatchObject( + ).toEqual( obj.blendFn(from, to, 3) ); }); // Check default steps - expect(ColorTranslator.getBlendHEX(from, to)).toMatchObject(ColorTranslator.getBlendHEX(from, to, 5)); - expect(ColorTranslator.getBlendHEX(from, to, -5)).toMatchObject(ColorTranslator.getBlendHEX(from, to, 5)); + expect(ColorTranslator.getBlendHEX(from, to)).toEqual(ColorTranslator.getBlendHEX(from, to, 5)); + expect(ColorTranslator.getBlendHEX(from, to, -5)).toEqual(ColorTranslator.getBlendHEX(from, to, 5)); }); diff --git a/tests/12 - color-mixing.test.ts b/tests/12 - color-mixing.test.ts index b61ed32..64f9376 100644 --- a/tests/12 - color-mixing.test.ts +++ b/tests/12 - color-mixing.test.ts @@ -34,7 +34,7 @@ describe('Additive Color mixing', (): void => { if (typeof mix === 'string') { expect(mix).toBe(fnObject.fn(item.mix, options)); } else { - expect(mix).toMatchObject(fnObject.fn(item.mix, options)); + expect(mix).toEqual(fnObject.fn(item.mix, options)); } }); it('Default mixing should be ADDITIVE', () => { @@ -43,7 +43,7 @@ describe('Additive Color mixing', (): void => { if (typeof mixAdditive === 'string') { expect(mixAdditive).toBe(mixDefault); } else { - expect(mixAdditive).toMatchObject(mixDefault); + expect(mixAdditive).toEqual(mixDefault); } }); }); @@ -141,7 +141,7 @@ describe('Color mixing with L*a*b colors', (): void => { Mix.ADDITIVE, { decimals: 0 } ) - ).toMatchObject( + ).toEqual( { L: 60, a: 94, b: -60 } ); }); @@ -153,7 +153,7 @@ describe('Color mixing with L*a*b colors', (): void => { { R: 0, G: 0, B: 255 } ] ) - ).toMatchObject( + ).toEqual( { L: 60.169696, a: 93.550025, b: -60.498556 } ); }); @@ -166,7 +166,7 @@ describe('Color mixing with L*a*b colors', (): void => { ], Mix.SUBTRACTIVE ) - ).toMatchObject( + ).toEqual( { L: 39.282789, a: 74.659748, b: -95.543967 } ); }); @@ -201,7 +201,7 @@ describe('Color mixing with L*a*b colors', (): void => { Mix.ADDITIVE, { decimals: 0 } ) - ).toMatchObject( + ).toEqual( { L: 60, a: 94, b: -60, A: 1 } ); }); @@ -214,7 +214,7 @@ describe('Color mixing with L*a*b colors', (): void => { ], Mix.SUBTRACTIVE ) - ).toMatchObject( + ).toEqual( { L: 39.282789, a: 74.659748, b: -95.543967, A: 1 } ); }); @@ -226,7 +226,7 @@ describe('Color mixing with L*a*b colors', (): void => { { R: 0, G: 0, B: 255 } ] ) - ).toMatchObject( + ).toEqual( { L: 60.169696, a: 93.550025, b: -60.498556, A: 1 } ); }); @@ -269,7 +269,7 @@ describe('Color mixing with lch colors', (): void => { Mix.ADDITIVE, { decimals: 0 } ) - ).toMatchObject( + ).toEqual( { L: 60, C: 111, H: 327 } ); }); @@ -281,7 +281,7 @@ describe('Color mixing with lch colors', (): void => { { R: 0, G: 0, B: 255 } ] ) - ).toMatchObject( + ).toEqual( { L: 60.169696, C: 111.407731, H: 327.109357 } ); }); @@ -294,7 +294,7 @@ describe('Color mixing with lch colors', (): void => { ], Mix.SUBTRACTIVE ) - ).toMatchObject( + ).toEqual( { L: 39.282789, C: 121.254804, H: 308.004699 } ); }); @@ -329,7 +329,7 @@ describe('Color mixing with lch colors', (): void => { Mix.ADDITIVE, { decimals: 0 } ) - ).toMatchObject( + ).toEqual( { L: 60, C: 111, H: 327, A: 1 } ); }); @@ -342,7 +342,7 @@ describe('Color mixing with lch colors', (): void => { ], Mix.SUBTRACTIVE ) - ).toMatchObject( + ).toEqual( { L: 39.282789, C: 121.254804, H: 308.004699, A: 1 } ); }); @@ -354,7 +354,7 @@ describe('Color mixing with lch colors', (): void => { { R: 0, G: 0, B: 255 } ] ) - ).toMatchObject( + ).toEqual( { L: 60.169696, C: 111.407731, H: 327.109357, A: 1 } ); }); diff --git a/tests/13 - shades-tints.test.ts b/tests/13 - shades-tints.test.ts index 2b17a79..1cefb7a 100644 --- a/tests/13 - shades-tints.test.ts +++ b/tests/13 - shades-tints.test.ts @@ -60,32 +60,32 @@ describe('ColorTranslator shades and tints tests', (): void => { it(`Shades tests from ${JSON.stringify(input)}`, (): void => { const output = shades_results.map((color: string) => fn(color)); const shades = ColorTranslator.getShades(input, 5); - expect(shades).toMatchObject(output); + expect(shades).toEqual(output); }); it(`Shades tests without number of shades is equal to 5 from ${JSON.stringify(input)}`, (): void => { const shades = ColorTranslator.getShades(input, 5); const shadesDefault = ColorTranslator.getShades(input); - expect(shades).toMatchObject(shadesDefault); + expect(shades).toEqual(shadesDefault); }); it(`Shades tests with alpha from ${JSON.stringify(inputWithAlpha)}`, (): void => { const output = shades_results.map((color: string) => fn(color + alpha)); const shades = ColorTranslator.getShades(inputWithAlpha, 5); - expect(shades).toMatchObject(output); + expect(shades).toEqual(output); }); it(`Tints tests from ${JSON.stringify(input)}`, (): void => { const output = tints_results.map((color: string) => fn(color)); const tints = ColorTranslator.getTints(input, 5); - expect(tints).toMatchObject(output); + expect(tints).toEqual(output); }); it(`Tints tests without number of tints from ${JSON.stringify(input)}`, (): void => { const tints = ColorTranslator.getTints(input, 5); const tintsDefault = ColorTranslator.getTints(input); - expect(tints).toMatchObject(tintsDefault); + expect(tints).toEqual(tintsDefault); }); it(`Tints tests with alpha from ${JSON.stringify(inputWithAlpha)}`, (): void => { const output = tints_results.map((color: string) => fn(color + alpha)); const tints = ColorTranslator.getTints(inputWithAlpha, 5); - expect(tints).toMatchObject(output); + expect(tints).toEqual(output); }); }); @@ -97,22 +97,22 @@ describe('ColorTranslator shades and tints tests', (): void => { it(`Shades tests from ${JSON.stringify(input)}`, (): void => { const output = shades_results.map((color: string) => fn(color, options)); const shades = ColorTranslator.getShades(input, 5, options); - expect(shades).toMatchObject(output); + expect(shades).toEqual(output); }); it(`Shades tests with alpha from ${JSON.stringify(inputWithAlpha)}`, (): void => { const output = shades_results.map((color: string) => fn(color + alpha, options)); const shades = ColorTranslator.getShades(inputWithAlpha, 5, options); - expect(shades).toMatchObject(output); + expect(shades).toEqual(output); }); it(`Tints tests from ${JSON.stringify(input)}`, (): void => { const output = tints_results.map((color: string) => fn(color, options)); const tints = ColorTranslator.getTints(input, 5, options); - expect(tints).toMatchObject(output); + expect(tints).toEqual(output); }); it(`Tints tests with alpha from ${JSON.stringify(inputWithAlpha)}`, (): void => { const output = tints_results.map((color: string) => fn(color + alpha, options)); const tints = ColorTranslator.getTints(inputWithAlpha, 5, options); - expect(tints).toMatchObject(output); + expect(tints).toEqual(output); }); it(`Shades tests from ${JSON.stringify(input)} with decimals`, (): void => { const shades = ColorTranslator.getShades(input, 5, options); diff --git a/tests/14 - harmony.test.ts b/tests/14 - harmony.test.ts index e9bf12b..1cb414a 100644 --- a/tests/14 - harmony.test.ts +++ b/tests/14 - harmony.test.ts @@ -80,12 +80,12 @@ describe('ColorTranslator harmony tests', (): void => { const colors = harmony === Harmony.COMPLEMENTARY ? ColorTranslator.getHarmony(color, Harmony.COMPLEMENTARY, Mix.ADDITIVE, options) : ColorTranslator.getHarmony(color, Harmony[harmony as Harmony], Mix.ADDITIVE, options); - expect(colors).toMatchObject(additiveResult[index]); + expect(colors).toEqual(additiveResult[index]); }); it(`Subtractive Harmony deep equals: ${harmony} for ${color} => ${JSON.stringify(subtractiveResult[index])}`, (): void => { const colors = ColorTranslator.getHarmony(color, Harmony[harmony as Harmony], Mix.SUBTRACTIVE, options); - expect(colors).toMatchObject(subtractiveResult[index]); + expect(colors).toEqual(subtractiveResult[index]); }); it('Additive Complementary > 360ยบ', (): void => { @@ -105,7 +105,7 @@ describe('ColorTranslator harmony tests', (): void => { it(`Additive Harmony deep equals: ${harmony} for ${color} => ${JSON.stringify(additiveResult[index])}`, (): void => { const colors = ColorTranslator.getHarmony(color, Harmony[harmony as Harmony], Mix.ADDITIVE, options); - expect(colors).toMatchObject(additiveResult[index]); + expect(colors).toEqual(additiveResult[index]); }); it(`Additive Harmony with decimals for ${JSON.stringify(color)}`, (): void => { @@ -115,7 +115,7 @@ describe('ColorTranslator harmony tests', (): void => { it(`Subtractive Harmony deep equals: ${harmony} for ${color} => ${JSON.stringify(subtractiveResult[index])}`, (): void => { const colors = ColorTranslator.getHarmony(color, Harmony[harmony as Harmony], Mix.SUBTRACTIVE, options); - expect(colors).toMatchObject(subtractiveResult[index]); + expect(colors).toEqual(subtractiveResult[index]); }); it(`Subtractive Harmony with decimals and auto legacyCSS for ${JSON.stringify(color)}`, (): void => { @@ -164,31 +164,31 @@ describe('ColorTranslator harmony tests', (): void => { it('Harmony excluding optional parameters', (): void => { expect( ColorTranslator.getHarmony(base, Harmony.COMPLEMENTARY, Mix.ADDITIVE) - ).toMatchObject( + ).toEqual( ColorTranslator.getHarmony(base, Harmony.COMPLEMENTARY) ); expect( ColorTranslator.getHarmony(base, Harmony.COMPLEMENTARY, Mix.ADDITIVE) - ).toMatchObject( + ).toEqual( ColorTranslator.getHarmony(base) ); expect( ColorTranslator.getHarmony(base, Harmony.COMPLEMENTARY, { decimals: 0 }) - ).toMatchObject( + ).toEqual( ColorTranslator.getHarmony(base, { decimals: 0 }) ); expect( ColorTranslator.getHarmony(base, Mix.ADDITIVE) - ).toMatchObject( + ).toEqual( ColorTranslator.getHarmony(base) ); expect( ColorTranslator.getHarmony(base, Mix.ADDITIVE, { decimals: 0 }) - ).toMatchObject( + ).toEqual( ColorTranslator.getHarmony(base, { decimals: 0 }) ); }); diff --git a/tests/15 - error.test.ts b/tests/15 - error.test.ts index dda21e4..7e42714 100644 --- a/tests/15 - error.test.ts +++ b/tests/15 - error.test.ts @@ -8,7 +8,7 @@ describe('Wrong inputs', (): void => { expect(() => { ColorTranslator.toHEX('AAA'); - }).toThrow(ERRORS.NOT_ACCEPTED_STRING_INPUT); + }).toThrow(ERRORS.NOT_ACCEPTED_INPUT); }); @@ -16,7 +16,7 @@ describe('Wrong inputs', (): void => { expect(() => { ColorTranslator.toHEX({P: 100, H: 20, T: 360} as unknown as ColorInput); - }).toThrow(ERRORS.NOT_ACCEPTED_OBJECT_INPUT); + }).toThrow(ERRORS.NOT_ACCEPTED_INPUT); }); @@ -24,7 +24,7 @@ describe('Wrong inputs', (): void => { expect(() => { ColorTranslator.toHEX({R: '0x25', G: 20, B: '0xFF'} as unknown as ColorInput); - }).toThrow(ERRORS.NOT_ACCEPTED_OBJECT_INPUT); + }).toThrow(ERRORS.NOT_ACCEPTED_INPUT); }); @@ -32,7 +32,7 @@ describe('Wrong inputs', (): void => { expect(() => { ColorTranslator.toHEX({R: '0x255', G: '0x128', B: '0xFFF'} as unknown as ColorInput); - }).toThrow(ERRORS.NOT_ACCEPTED_OBJECT_INPUT); + }).toThrow(ERRORS.NOT_ACCEPTED_INPUT); }); diff --git a/tests/16 - package-exports.test.ts b/tests/16 - package-exports.test.ts new file mode 100644 index 0000000..33fee1e --- /dev/null +++ b/tests/16 - package-exports.test.ts @@ -0,0 +1,13 @@ +import * as Library from '../src'; +import { ColorTranslator } from '../src/classes/ColorTranslator'; +import { Harmony, Mix } from '../src/constants'; + +describe('exports from the main package', () => { + it('@testing should match exports', () => { + expect(Library).toEqual({ + ColorTranslator, + Harmony, + Mix + }); + }); +}); \ No newline at end of file diff --git a/tests/tests.constants.ts b/tests/tests.constants.ts index b5d2e87..d271a3b 100644 --- a/tests/tests.constants.ts +++ b/tests/tests.constants.ts @@ -342,7 +342,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(54 81 70)', CIELabA: 'lab(54 81 70 / 1)', CIELabInPrcentage: 'lab(54% 65% 56%)', - CIELabAInPrcentage: 'lab(54% 65% 56% / 100%)', + CIELabAInPercentage: 'lab(54% 65% 56% / 100%)', CIELabObject: { L: 54, a: 81, b: 70 }, CIELabAObject: { L: 54, a: 81, b: 70, A: 1 }, LCH: 'lch(54 107 41)', @@ -357,7 +357,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(88 -79 81)', CIELabA: 'lab(88 -79 81 / 1)', CIELabInPrcentage: 'lab(88% -63% 65%)', - CIELabAInPrcentage: 'lab(88% -63% 65% / 100%)', + CIELabAInPercentage: 'lab(88% -63% 65% / 100%)', CIELabObject: { L: 88, a: -79, b: 81 }, CIELabAObject: { L: 88, a: -79, b: 81, A: 1 }, LCH: 'lch(88 113 134)', @@ -372,7 +372,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(30 68 -112)', CIELabA: 'lab(30 68 -112 / 1)', CIELabInPrcentage: 'lab(30% 54% -90%)', - CIELabAInPrcentage: 'lab(30% 54% -90% / 100%)', + CIELabAInPercentage: 'lab(30% 54% -90% / 100%)', CIELabObject: { L: 30, a: 68, b: -112 }, CIELabAObject: { L: 30, a: 68, b: -112, A: 1 }, LCH: 'lch(30 131 301)', @@ -387,7 +387,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(60 94 -60)', CIELabA: 'lab(60 94 -60 / 1)', CIELabInPrcentage: 'lab(60% 75% -48%)', - CIELabAInPrcentage: 'lab(60% 75% -48% / 100%)', + CIELabAInPercentage: 'lab(60% 75% -48% / 100%)', CIELabObject: { L: 60, a: 94, b: -60 }, CIELabAObject: { L: 60, a: 94, b: -60, A: 1 }, LCH: 'lch(60 111 327)', @@ -402,7 +402,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(100 0 0)', CIELabA: 'lab(100 0 0 / 1)', CIELabInPrcentage: 'lab(100% 0% 0%)', - CIELabAInPrcentage: 'lab(100% 0% 0% / 100%)', + CIELabAInPercentage: 'lab(100% 0% 0% / 100%)', CIELabObject: { L: 100, a: 0, b: 0 }, CIELabAObject: { L: 100, a: 0, b: 0, A: 1 }, LCH: 'lch(100 0 0)', @@ -417,7 +417,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(0 0 0)', CIELabA: 'lab(0 0 0 / 1)', CIELabInPrcentage: 'lab(0% 0% 0%)', - CIELabAInPrcentage: 'lab(0% 0% 0% / 100%)', + CIELabAInPercentage: 'lab(0% 0% 0% / 100%)', CIELabObject: { L: 0, a: 0, b: 0 }, CIELabAObject: { L: 0, a: 0, b: 0, A: 1 }, LCH: 'lch(0 0 0)', @@ -432,7 +432,7 @@ export const LAB_AND_LCH_COLORS = [ CIELab: 'lab(54 0 0)', CIELabA: 'lab(54 0 0 / 1)', CIELabInPrcentage: 'lab(54% 0% 0%)', - CIELabAInPrcentage: 'lab(54% 0% 0% / 100%)', + CIELabAInPercentage: 'lab(54% 0% 0% / 100%)', CIELabObject: { L: 54, a: 0, b: 0 }, CIELabAObject: { L: 54, a: 0, b: 0, A: 1 }, LCH: 'lch(54 0 0)', diff --git a/tsconfig.json b/tsconfig.json index b799e0a..ed20533 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -12,11 +12,13 @@ "baseUrl": "./src", "paths": { "@types": ["@types"], - "#helpers": ["helpers"], "#constants": ["constants"], + "#classes/*": ["classes/*"], "#color/*": ["color/*"], + "#css": ["css"], "#parsers": ["parsers"], - "#returns": ["returns"] + "#returns": ["returns"], + "#utilities": ["utilities"] } }, "include": ["src/**/*.ts"],