Ignore:
Timestamp:
12/12/24 17:06:06 (5 weeks ago)
Author:
stefan toskovski <stefantoska84@…>
Branches:
main
Parents:
d565449
Message:

Pred finalna verzija

File:
1 edited

Legend:

Unmodified
Added
Removed
  • imaps-frontend/node_modules/color-convert/conversions.js

    rd565449 r0c6b92a  
    11/* MIT license */
    2 var cssKeywords = require('color-name');
     2/* eslint-disable no-mixed-operators */
     3const cssKeywords = require('color-name');
    34
    45// NOTE: conversions should only return primitive values (i.e. arrays, or
     
    67//       do not use box values types (i.e. Number(), String(), etc.)
    78
    8 var reverseKeywords = {};
    9 for (var key in cssKeywords) {
    10         if (cssKeywords.hasOwnProperty(key)) {
    11                 reverseKeywords[cssKeywords[key]] = key;
    12         }
     9const reverseKeywords = {};
     10for (const key of Object.keys(cssKeywords)) {
     11        reverseKeywords[cssKeywords[key]] = key;
    1312}
    1413
    15 var convert = module.exports = {
     14const convert = {
    1615        rgb: {channels: 3, labels: 'rgb'},
    1716        hsl: {channels: 3, labels: 'hsl'},
     
    3130};
    3231
    33 // hide .channels and .labels properties
    34 for (var model in convert) {
    35         if (convert.hasOwnProperty(model)) {
    36                 if (!('channels' in convert[model])) {
    37                         throw new Error('missing channels property: ' + model);
    38                 }
    39 
    40                 if (!('labels' in convert[model])) {
    41                         throw new Error('missing channel labels property: ' + model);
    42                 }
    43 
    44                 if (convert[model].labels.length !== convert[model].channels) {
    45                         throw new Error('channel and label counts mismatch: ' + model);
    46                 }
    47 
    48                 var channels = convert[model].channels;
    49                 var labels = convert[model].labels;
    50                 delete convert[model].channels;
    51                 delete convert[model].labels;
    52                 Object.defineProperty(convert[model], 'channels', {value: channels});
    53                 Object.defineProperty(convert[model], 'labels', {value: labels});
    54         }
     32module.exports = convert;
     33
     34// Hide .channels and .labels properties
     35for (const model of Object.keys(convert)) {
     36        if (!('channels' in convert[model])) {
     37                throw new Error('missing channels property: ' + model);
     38        }
     39
     40        if (!('labels' in convert[model])) {
     41                throw new Error('missing channel labels property: ' + model);
     42        }
     43
     44        if (convert[model].labels.length !== convert[model].channels) {
     45                throw new Error('channel and label counts mismatch: ' + model);
     46        }
     47
     48        const {channels, labels} = convert[model];
     49        delete convert[model].channels;
     50        delete convert[model].labels;
     51        Object.defineProperty(convert[model], 'channels', {value: channels});
     52        Object.defineProperty(convert[model], 'labels', {value: labels});
    5553}
    5654
    5755convert.rgb.hsl = function (rgb) {
    58         var r = rgb[0] / 255;
    59         var g = rgb[1] / 255;
    60         var b = rgb[2] / 255;
    61         var min = Math.min(r, g, b);
    62         var max = Math.max(r, g, b);
    63         var delta = max - min;
    64         var h;
    65         var s;
    66         var l;
     56        const r = rgb[0] / 255;
     57        const g = rgb[1] / 255;
     58        const b = rgb[2] / 255;
     59        const min = Math.min(r, g, b);
     60        const max = Math.max(r, g, b);
     61        const delta = max - min;
     62        let h;
     63        let s;
    6764
    6865        if (max === min) {
     
    8279        }
    8380
    84         l = (min + max) / 2;
     81        const l = (min + max) / 2;
    8582
    8683        if (max === min) {
     
    9693
    9794convert.rgb.hsv = function (rgb) {
    98         var rdif;
    99         var gdif;
    100         var bdif;
    101         var h;
    102         var s;
    103 
    104         var r = rgb[0] / 255;
    105         var g = rgb[1] / 255;
    106         var b = rgb[2] / 255;
    107         var v = Math.max(r, g, b);
    108         var diff = v - Math.min(r, g, b);
    109         var diffc = function (c) {
     95        let rdif;
     96        let gdif;
     97        let bdif;
     98        let h;
     99        let s;
     100
     101        const r = rgb[0] / 255;
     102        const g = rgb[1] / 255;
     103        const b = rgb[2] / 255;
     104        const v = Math.max(r, g, b);
     105        const diff = v - Math.min(r, g, b);
     106        const diffc = function (c) {
    110107                return (v - c) / 6 / diff + 1 / 2;
    111108        };
    112109
    113110        if (diff === 0) {
    114                 h = s = 0;
     111                h = 0;
     112                s = 0;
    115113        } else {
    116114                s = diff / v;
     
    126124                        h = (2 / 3) + gdif - rdif;
    127125                }
     126
    128127                if (h < 0) {
    129128                        h += 1;
     
    141140
    142141convert.rgb.hwb = function (rgb) {
    143         var r = rgb[0];
    144         var g = rgb[1];
    145         var b = rgb[2];
    146         var h = convert.rgb.hsl(rgb)[0];
    147         var w = 1 / 255 * Math.min(r, Math.min(g, b));
     142        const r = rgb[0];
     143        const g = rgb[1];
     144        let b = rgb[2];
     145        const h = convert.rgb.hsl(rgb)[0];
     146        const w = 1 / 255 * Math.min(r, Math.min(g, b));
    148147
    149148        b = 1 - 1 / 255 * Math.max(r, Math.max(g, b));
     
    153152
    154153convert.rgb.cmyk = function (rgb) {
    155         var r = rgb[0] / 255;
    156         var g = rgb[1] / 255;
    157         var b = rgb[2] / 255;
    158         var c;
    159         var m;
    160         var y;
    161         var k;
    162 
    163         k = Math.min(1 - r, 1 - g, 1 - b);
    164         c = (1 - r - k) / (1 - k) || 0;
    165         m = (1 - g - k) / (1 - k) || 0;
    166         y = (1 - b - k) / (1 - k) || 0;
     154        const r = rgb[0] / 255;
     155        const g = rgb[1] / 255;
     156        const b = rgb[2] / 255;
     157
     158        const k = Math.min(1 - r, 1 - g, 1 - b);
     159        const c = (1 - r - k) / (1 - k) || 0;
     160        const m = (1 - g - k) / (1 - k) || 0;
     161        const y = (1 - b - k) / (1 - k) || 0;
    167162
    168163        return [c * 100, m * 100, y * 100, k * 100];
    169164};
    170165
    171 /**
    172  * See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance
    173  * */
    174166function comparativeDistance(x, y) {
     167        /*
     168                See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance
     169        */
    175170        return (
    176                 Math.pow(x[0] - y[0], 2) +
    177                 Math.pow(x[1] - y[1], 2) +
    178                 Math.pow(x[2] - y[2], 2)
     171                ((x[0] - y[0]) ** 2) +
     172                ((x[1] - y[1]) ** 2) +
     173                ((x[2] - y[2]) ** 2)
    179174        );
    180175}
    181176
    182177convert.rgb.keyword = function (rgb) {
    183         var reversed = reverseKeywords[rgb];
     178        const reversed = reverseKeywords[rgb];
    184179        if (reversed) {
    185180                return reversed;
    186181        }
    187182
    188         var currentClosestDistance = Infinity;
    189         var currentClosestKeyword;
    190 
    191         for (var keyword in cssKeywords) {
    192                 if (cssKeywords.hasOwnProperty(keyword)) {
    193                         var value = cssKeywords[keyword];
    194 
    195                         // Compute comparative distance
    196                         var distance = comparativeDistance(rgb, value);
    197 
    198                         // Check if its less, if so set as closest
    199                         if (distance < currentClosestDistance) {
    200                                 currentClosestDistance = distance;
    201                                 currentClosestKeyword = keyword;
    202                         }
     183        let currentClosestDistance = Infinity;
     184        let currentClosestKeyword;
     185
     186        for (const keyword of Object.keys(cssKeywords)) {
     187                const value = cssKeywords[keyword];
     188
     189                // Compute comparative distance
     190                const distance = comparativeDistance(rgb, value);
     191
     192                // Check if its less, if so set as closest
     193                if (distance < currentClosestDistance) {
     194                        currentClosestDistance = distance;
     195                        currentClosestKeyword = keyword;
    203196                }
    204197        }
     
    212205
    213206convert.rgb.xyz = function (rgb) {
    214         var r = rgb[0] / 255;
    215         var g = rgb[1] / 255;
    216         var b = rgb[2] / 255;
    217 
    218         // assume sRGB
    219         r = r > 0.04045 ? Math.pow(((r + 0.055) / 1.055), 2.4) : (r / 12.92);
    220         g = g > 0.04045 ? Math.pow(((g + 0.055) / 1.055), 2.4) : (g / 12.92);
    221         b = b > 0.04045 ? Math.pow(((b + 0.055) / 1.055), 2.4) : (b / 12.92);
    222 
    223         var x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);
    224         var y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);
    225         var z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);
     207        let r = rgb[0] / 255;
     208        let g = rgb[1] / 255;
     209        let b = rgb[2] / 255;
     210
     211        // Assume sRGB
     212        r = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92);
     213        g = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92);
     214        b = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92);
     215
     216        const x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);
     217        const y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);
     218        const z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);
    226219
    227220        return [x * 100, y * 100, z * 100];
     
    229222
    230223convert.rgb.lab = function (rgb) {
    231         var xyz = convert.rgb.xyz(rgb);
    232         var x = xyz[0];
    233         var y = xyz[1];
    234         var z = xyz[2];
    235         var l;
    236         var a;
    237         var b;
     224        const xyz = convert.rgb.xyz(rgb);
     225        let x = xyz[0];
     226        let y = xyz[1];
     227        let z = xyz[2];
    238228
    239229        x /= 95.047;
     
    241231        z /= 108.883;
    242232
    243         x = x > 0.008856 ? Math.pow(x, 1 / 3) : (7.787 * x) + (16 / 116);
    244         y = y > 0.008856 ? Math.pow(y, 1 / 3) : (7.787 * y) + (16 / 116);
    245         z = z > 0.008856 ? Math.pow(z, 1 / 3) : (7.787 * z) + (16 / 116);
    246 
    247         l = (116 * y) - 16;
    248         a = 500 * (x - y);
    249         b = 200 * (y - z);
     233        x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);
     234        y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);
     235        z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);
     236
     237        const l = (116 * y) - 16;
     238        const a = 500 * (x - y);
     239        const b = 200 * (y - z);
    250240
    251241        return [l, a, b];
     
    253243
    254244convert.hsl.rgb = function (hsl) {
    255         var h = hsl[0] / 360;
    256         var s = hsl[1] / 100;
    257         var l = hsl[2] / 100;
    258         var t1;
    259         var t2;
    260         var t3;
    261         var rgb;
    262         var val;
     245        const h = hsl[0] / 360;
     246        const s = hsl[1] / 100;
     247        const l = hsl[2] / 100;
     248        let t2;
     249        let t3;
     250        let val;
    263251
    264252        if (s === 0) {
     
    273261        }
    274262
    275         t1 = 2 * l - t2;
    276 
    277         rgb = [0, 0, 0];
    278         for (var i = 0; i < 3; i++) {
     263        const t1 = 2 * l - t2;
     264
     265        const rgb = [0, 0, 0];
     266        for (let i = 0; i < 3; i++) {
    279267                t3 = h + 1 / 3 * -(i - 1);
    280268                if (t3 < 0) {
    281269                        t3++;
    282270                }
     271
    283272                if (t3 > 1) {
    284273                        t3--;
     
    302291
    303292convert.hsl.hsv = function (hsl) {
    304         var h = hsl[0];
    305         var s = hsl[1] / 100;
    306         var l = hsl[2] / 100;
    307         var smin = s;
    308         var lmin = Math.max(l, 0.01);
    309         var sv;
    310         var v;
     293        const h = hsl[0];
     294        let s = hsl[1] / 100;
     295        let l = hsl[2] / 100;
     296        let smin = s;
     297        const lmin = Math.max(l, 0.01);
    311298
    312299        l *= 2;
    313300        s *= (l <= 1) ? l : 2 - l;
    314301        smin *= lmin <= 1 ? lmin : 2 - lmin;
    315         v = (l + s) / 2;
    316         sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);
     302        const v = (l + s) / 2;
     303        const sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);
    317304
    318305        return [h, sv * 100, v * 100];
     
    320307
    321308convert.hsv.rgb = function (hsv) {
    322         var h = hsv[0] / 60;
    323         var s = hsv[1] / 100;
    324         var v = hsv[2] / 100;
    325         var hi = Math.floor(h) % 6;
    326 
    327         var f = h - Math.floor(h);
    328         var p = 255 * v * (1 - s);
    329         var q = 255 * v * (1 - (s * f));
    330         var t = 255 * v * (1 - (s * (1 - f)));
     309        const h = hsv[0] / 60;
     310        const s = hsv[1] / 100;
     311        let v = hsv[2] / 100;
     312        const hi = Math.floor(h) % 6;
     313
     314        const f = h - Math.floor(h);
     315        const p = 255 * v * (1 - s);
     316        const q = 255 * v * (1 - (s * f));
     317        const t = 255 * v * (1 - (s * (1 - f)));
    331318        v *= 255;
    332319
     
    348335
    349336convert.hsv.hsl = function (hsv) {
    350         var h = hsv[0];
    351         var s = hsv[1] / 100;
    352         var v = hsv[2] / 100;
    353         var vmin = Math.max(v, 0.01);
    354         var lmin;
    355         var sl;
    356         var l;
     337        const h = hsv[0];
     338        const s = hsv[1] / 100;
     339        const v = hsv[2] / 100;
     340        const vmin = Math.max(v, 0.01);
     341        let sl;
     342        let l;
    357343
    358344        l = (2 - s) * v;
    359         lmin = (2 - s) * vmin;
     345        const lmin = (2 - s) * vmin;
    360346        sl = s * vmin;
    361347        sl /= (lmin <= 1) ? lmin : 2 - lmin;
     
    368354// http://dev.w3.org/csswg/css-color/#hwb-to-rgb
    369355convert.hwb.rgb = function (hwb) {
    370         var h = hwb[0] / 360;
    371         var wh = hwb[1] / 100;
    372         var bl = hwb[2] / 100;
    373         var ratio = wh + bl;
    374         var i;
    375         var v;
    376         var f;
    377         var n;
    378 
    379         // wh + bl cant be > 1
     356        const h = hwb[0] / 360;
     357        let wh = hwb[1] / 100;
     358        let bl = hwb[2] / 100;
     359        const ratio = wh + bl;
     360        let f;
     361
     362        // Wh + bl cant be > 1
    380363        if (ratio > 1) {
    381364                wh /= ratio;
     
    383366        }
    384367
    385         i = Math.floor(6 * h);
    386         v = 1 - bl;
     368        const i = Math.floor(6 * h);
     369        const v = 1 - bl;
    387370        f = 6 * h - i;
    388371
     
    391374        }
    392375
    393         n = wh + f * (v - wh); // linear interpolation
    394 
    395         var r;
    396         var g;
    397         var b;
     376        const n = wh + f * (v - wh); // Linear interpolation
     377
     378        let r;
     379        let g;
     380        let b;
     381        /* eslint-disable max-statements-per-line,no-multi-spaces */
    398382        switch (i) {
    399383                default:
    400384                case 6:
    401                 case 0: r = v; g = n; b = wh; break;
    402                 case 1: r = n; g = v; b = wh; break;
    403                 case 2: r = wh; g = v; b = n; break;
    404                 case 3: r = wh; g = n; b = v; break;
    405                 case 4: r = n; g = wh; b = v; break;
    406                 case 5: r = v; g = wh; b = n; break;
    407         }
     385                case 0: r = v;  g = n;  b = wh; break;
     386                case 1: r = n;  g = v;  b = wh; break;
     387                case 2: r = wh; g = v;  b = n; break;
     388                case 3: r = wh; g = n;  b = v; break;
     389                case 4: r = n;  g = wh; b = v; break;
     390                case 5: r = v;  g = wh; b = n; break;
     391        }
     392        /* eslint-enable max-statements-per-line,no-multi-spaces */
    408393
    409394        return [r * 255, g * 255, b * 255];
     
    411396
    412397convert.cmyk.rgb = function (cmyk) {
    413         var c = cmyk[0] / 100;
    414         var m = cmyk[1] / 100;
    415         var y = cmyk[2] / 100;
    416         var k = cmyk[3] / 100;
    417         var r;
    418         var g;
    419         var b;
    420 
    421         r = 1 - Math.min(1, c * (1 - k) + k);
    422         g = 1 - Math.min(1, m * (1 - k) + k);
    423         b = 1 - Math.min(1, y * (1 - k) + k);
     398        const c = cmyk[0] / 100;
     399        const m = cmyk[1] / 100;
     400        const y = cmyk[2] / 100;
     401        const k = cmyk[3] / 100;
     402
     403        const r = 1 - Math.min(1, c * (1 - k) + k);
     404        const g = 1 - Math.min(1, m * (1 - k) + k);
     405        const b = 1 - Math.min(1, y * (1 - k) + k);
    424406
    425407        return [r * 255, g * 255, b * 255];
     
    427409
    428410convert.xyz.rgb = function (xyz) {
    429         var x = xyz[0] / 100;
    430         var y = xyz[1] / 100;
    431         var z = xyz[2] / 100;
    432         var r;
    433         var g;
    434         var b;
     411        const x = xyz[0] / 100;
     412        const y = xyz[1] / 100;
     413        const z = xyz[2] / 100;
     414        let r;
     415        let g;
     416        let b;
    435417
    436418        r = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);
     
    438420        b = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);
    439421
    440         // assume sRGB
     422        // Assume sRGB
    441423        r = r > 0.0031308
    442                 ? ((1.055 * Math.pow(r, 1.0 / 2.4)) - 0.055)
     424                ? ((1.055 * (r ** (1.0 / 2.4))) - 0.055)
    443425                : r * 12.92;
    444426
    445427        g = g > 0.0031308
    446                 ? ((1.055 * Math.pow(g, 1.0 / 2.4)) - 0.055)
     428                ? ((1.055 * (g ** (1.0 / 2.4))) - 0.055)
    447429                : g * 12.92;
    448430
    449431        b = b > 0.0031308
    450                 ? ((1.055 * Math.pow(b, 1.0 / 2.4)) - 0.055)
     432                ? ((1.055 * (b ** (1.0 / 2.4))) - 0.055)
    451433                : b * 12.92;
    452434
     
    459441
    460442convert.xyz.lab = function (xyz) {
    461         var x = xyz[0];
    462         var y = xyz[1];
    463         var z = xyz[2];
    464         var l;
    465         var a;
    466         var b;
     443        let x = xyz[0];
     444        let y = xyz[1];
     445        let z = xyz[2];
    467446
    468447        x /= 95.047;
     
    470449        z /= 108.883;
    471450
    472         x = x > 0.008856 ? Math.pow(x, 1 / 3) : (7.787 * x) + (16 / 116);
    473         y = y > 0.008856 ? Math.pow(y, 1 / 3) : (7.787 * y) + (16 / 116);
    474         z = z > 0.008856 ? Math.pow(z, 1 / 3) : (7.787 * z) + (16 / 116);
    475 
    476         l = (116 * y) - 16;
    477         a = 500 * (x - y);
    478         b = 200 * (y - z);
     451        x = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);
     452        y = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);
     453        z = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);
     454
     455        const l = (116 * y) - 16;
     456        const a = 500 * (x - y);
     457        const b = 200 * (y - z);
    479458
    480459        return [l, a, b];
     
    482461
    483462convert.lab.xyz = function (lab) {
    484         var l = lab[0];
    485         var a = lab[1];
    486         var b = lab[2];
    487         var x;
    488         var y;
    489         var z;
     463        const l = lab[0];
     464        const a = lab[1];
     465        const b = lab[2];
     466        let x;
     467        let y;
     468        let z;
    490469
    491470        y = (l + 16) / 116;
     
    493472        z = y - b / 200;
    494473
    495         var y2 = Math.pow(y, 3);
    496         var x2 = Math.pow(x, 3);
    497         var z2 = Math.pow(z, 3);
     474        const y2 = y ** 3;
     475        const x2 = x ** 3;
     476        const z2 = z ** 3;
    498477        y = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;
    499478        x = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;
     
    508487
    509488convert.lab.lch = function (lab) {
    510         var l = lab[0];
    511         var a = lab[1];
    512         var b = lab[2];
    513         var hr;
    514         var h;
    515         var c;
    516 
    517         hr = Math.atan2(b, a);
     489        const l = lab[0];
     490        const a = lab[1];
     491        const b = lab[2];
     492        let h;
     493
     494        const hr = Math.atan2(b, a);
    518495        h = hr * 360 / 2 / Math.PI;
    519496
     
    522499        }
    523500
    524         c = Math.sqrt(a * a + b * b);
     501        const c = Math.sqrt(a * a + b * b);
    525502
    526503        return [l, c, h];
     
    528505
    529506convert.lch.lab = function (lch) {
    530         var l = lch[0];
    531         var c = lch[1];
    532         var h = lch[2];
    533         var a;
    534         var b;
    535         var hr;
    536 
    537         hr = h / 360 * 2 * Math.PI;
    538         a = c * Math.cos(hr);
    539         b = c * Math.sin(hr);
     507        const l = lch[0];
     508        const c = lch[1];
     509        const h = lch[2];
     510
     511        const hr = h / 360 * 2 * Math.PI;
     512        const a = c * Math.cos(hr);
     513        const b = c * Math.sin(hr);
    540514
    541515        return [l, a, b];
    542516};
    543517
    544 convert.rgb.ansi16 = function (args) {
    545         var r = args[0];
    546         var g = args[1];
    547         var b = args[2];
    548         var value = 1 in arguments ? arguments[1] : convert.rgb.hsv(args)[2]; // hsv -> ansi16 optimization
     518convert.rgb.ansi16 = function (args, saturation = null) {
     519        const [r, g, b] = args;
     520        let value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization
    549521
    550522        value = Math.round(value / 50);
     
    554526        }
    555527
    556         var ansi = 30
     528        let ansi = 30
    557529                + ((Math.round(b / 255) << 2)
    558530                | (Math.round(g / 255) << 1)
     
    567539
    568540convert.hsv.ansi16 = function (args) {
    569         // optimization here; we already know the value and don't need to get
     541        // Optimization here; we already know the value and don't need to get
    570542        // it converted for us.
    571543        return convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);
     
    573545
    574546convert.rgb.ansi256 = function (args) {
    575         var r = args[0];
    576         var g = args[1];
    577         var b = args[2];
    578 
    579         // we use the extended greyscale palette here, with the exception of
     547        const r = args[0];
     548        const g = args[1];
     549        const b = args[2];
     550
     551        // We use the extended greyscale palette here, with the exception of
    580552        // black and white. normal palette only has 4 greyscale shades.
    581553        if (r === g && g === b) {
     
    591563        }
    592564
    593         var ansi = 16
     565        const ansi = 16
    594566                + (36 * Math.round(r / 255 * 5))
    595567                + (6 * Math.round(g / 255 * 5))
     
    600572
    601573convert.ansi16.rgb = function (args) {
    602         var color = args % 10;
    603 
    604         // handle greyscale
     574        let color = args % 10;
     575
     576        // Handle greyscale
    605577        if (color === 0 || color === 7) {
    606578                if (args > 50) {
     
    613585        }
    614586
    615         var mult = (~~(args > 50) + 1) * 0.5;
    616         var r = ((color & 1) * mult) * 255;
    617         var g = (((color >> 1) & 1) * mult) * 255;
    618         var b = (((color >> 2) & 1) * mult) * 255;
     587        const mult = (~~(args > 50) + 1) * 0.5;
     588        const r = ((color & 1) * mult) * 255;
     589        const g = (((color >> 1) & 1) * mult) * 255;
     590        const b = (((color >> 2) & 1) * mult) * 255;
    619591
    620592        return [r, g, b];
     
    622594
    623595convert.ansi256.rgb = function (args) {
    624         // handle greyscale
     596        // Handle greyscale
    625597        if (args >= 232) {
    626                 var c = (args - 232) * 10 + 8;
     598                const c = (args - 232) * 10 + 8;
    627599                return [c, c, c];
    628600        }
     
    630602        args -= 16;
    631603
    632         var rem;
    633         var r = Math.floor(args / 36) / 5 * 255;
    634         var g = Math.floor((rem = args % 36) / 6) / 5 * 255;
    635         var b = (rem % 6) / 5 * 255;
     604        let rem;
     605        const r = Math.floor(args / 36) / 5 * 255;
     606        const g = Math.floor((rem = args % 36) / 6) / 5 * 255;
     607        const b = (rem % 6) / 5 * 255;
    636608
    637609        return [r, g, b];
     
    639611
    640612convert.rgb.hex = function (args) {
    641         var integer = ((Math.round(args[0]) & 0xFF) << 16)
     613        const integer = ((Math.round(args[0]) & 0xFF) << 16)
    642614                + ((Math.round(args[1]) & 0xFF) << 8)
    643615                + (Math.round(args[2]) & 0xFF);
    644616
    645         var string = integer.toString(16).toUpperCase();
     617        const string = integer.toString(16).toUpperCase();
    646618        return '000000'.substring(string.length) + string;
    647619};
    648620
    649621convert.hex.rgb = function (args) {
    650         var match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);
     622        const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);
    651623        if (!match) {
    652624                return [0, 0, 0];
    653625        }
    654626
    655         var colorString = match[0];
     627        let colorString = match[0];
    656628
    657629        if (match[0].length === 3) {
    658                 colorString = colorString.split('').map(function (char) {
     630                colorString = colorString.split('').map(char => {
    659631                        return char + char;
    660632                }).join('');
    661633        }
    662634
    663         var integer = parseInt(colorString, 16);
    664         var r = (integer >> 16) & 0xFF;
    665         var g = (integer >> 8) & 0xFF;
    666         var b = integer & 0xFF;
     635        const integer = parseInt(colorString, 16);
     636        const r = (integer >> 16) & 0xFF;
     637        const g = (integer >> 8) & 0xFF;
     638        const b = integer & 0xFF;
    667639
    668640        return [r, g, b];
     
    670642
    671643convert.rgb.hcg = function (rgb) {
    672         var r = rgb[0] / 255;
    673         var g = rgb[1] / 255;
    674         var b = rgb[2] / 255;
    675         var max = Math.max(Math.max(r, g), b);
    676         var min = Math.min(Math.min(r, g), b);
    677         var chroma = (max - min);
    678         var grayscale;
    679         var hue;
     644        const r = rgb[0] / 255;
     645        const g = rgb[1] / 255;
     646        const b = rgb[2] / 255;
     647        const max = Math.max(Math.max(r, g), b);
     648        const min = Math.min(Math.min(r, g), b);
     649        const chroma = (max - min);
     650        let grayscale;
     651        let hue;
    680652
    681653        if (chroma < 1) {
     
    694666                hue = 2 + (b - r) / chroma;
    695667        } else {
    696                 hue = 4 + (r - g) / chroma + 4;
     668                hue = 4 + (r - g) / chroma;
    697669        }
    698670
     
    704676
    705677convert.hsl.hcg = function (hsl) {
    706         var s = hsl[1] / 100;
    707         var l = hsl[2] / 100;
    708         var c = 1;
    709         var f = 0;
    710 
    711         if (l < 0.5) {
    712                 c = 2.0 * s * l;
    713         } else {
    714                 c = 2.0 * s * (1.0 - l);
    715         }
    716 
     678        const s = hsl[1] / 100;
     679        const l = hsl[2] / 100;
     680
     681        const c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l));
     682
     683        let f = 0;
    717684        if (c < 1.0) {
    718685                f = (l - 0.5 * c) / (1.0 - c);
     
    723690
    724691convert.hsv.hcg = function (hsv) {
    725         var s = hsv[1] / 100;
    726         var v = hsv[2] / 100;
    727 
    728         var c = s * v;
    729         var f = 0;
     692        const s = hsv[1] / 100;
     693        const v = hsv[2] / 100;
     694
     695        const c = s * v;
     696        let f = 0;
    730697
    731698        if (c < 1.0) {
     
    737704
    738705convert.hcg.rgb = function (hcg) {
    739         var h = hcg[0] / 360;
    740         var c = hcg[1] / 100;
    741         var g = hcg[2] / 100;
     706        const h = hcg[0] / 360;
     707        const c = hcg[1] / 100;
     708        const g = hcg[2] / 100;
    742709
    743710        if (c === 0.0) {
     
    745712        }
    746713
    747         var pure = [0, 0, 0];
    748         var hi = (h % 1) * 6;
    749         var v = hi % 1;
    750         var w = 1 - v;
    751         var mg = 0;
    752 
     714        const pure = [0, 0, 0];
     715        const hi = (h % 1) * 6;
     716        const v = hi % 1;
     717        const w = 1 - v;
     718        let mg = 0;
     719
     720        /* eslint-disable max-statements-per-line */
    753721        switch (Math.floor(hi)) {
    754722                case 0:
     
    765733                        pure[0] = 1; pure[1] = 0; pure[2] = w;
    766734        }
     735        /* eslint-enable max-statements-per-line */
    767736
    768737        mg = (1.0 - c) * g;
     
    776745
    777746convert.hcg.hsv = function (hcg) {
    778         var c = hcg[1] / 100;
    779         var g = hcg[2] / 100;
    780 
    781         var v = c + g * (1.0 - c);
    782         var f = 0;
     747        const c = hcg[1] / 100;
     748        const g = hcg[2] / 100;
     749
     750        const v = c + g * (1.0 - c);
     751        let f = 0;
    783752
    784753        if (v > 0.0) {
     
    790759
    791760convert.hcg.hsl = function (hcg) {
    792         var c = hcg[1] / 100;
    793         var g = hcg[2] / 100;
    794 
    795         var l = g * (1.0 - c) + 0.5 * c;
    796         var s = 0;
     761        const c = hcg[1] / 100;
     762        const g = hcg[2] / 100;
     763
     764        const l = g * (1.0 - c) + 0.5 * c;
     765        let s = 0;
    797766
    798767        if (l > 0.0 && l < 0.5) {
     
    807776
    808777convert.hcg.hwb = function (hcg) {
    809         var c = hcg[1] / 100;
    810         var g = hcg[2] / 100;
    811         var v = c + g * (1.0 - c);
     778        const c = hcg[1] / 100;
     779        const g = hcg[2] / 100;
     780        const v = c + g * (1.0 - c);
    812781        return [hcg[0], (v - c) * 100, (1 - v) * 100];
    813782};
    814783
    815784convert.hwb.hcg = function (hwb) {
    816         var w = hwb[1] / 100;
    817         var b = hwb[2] / 100;
    818         var v = 1 - b;
    819         var c = v - w;
    820         var g = 0;
     785        const w = hwb[1] / 100;
     786        const b = hwb[2] / 100;
     787        const v = 1 - b;
     788        const c = v - w;
     789        let g = 0;
    821790
    822791        if (c < 1) {
     
    839808};
    840809
    841 convert.gray.hsl = convert.gray.hsv = function (args) {
     810convert.gray.hsl = function (args) {
    842811        return [0, 0, args[0]];
    843812};
     813
     814convert.gray.hsv = convert.gray.hsl;
    844815
    845816convert.gray.hwb = function (gray) {
     
    856827
    857828convert.gray.hex = function (gray) {
    858         var val = Math.round(gray[0] / 100 * 255) & 0xFF;
    859         var integer = (val << 16) + (val << 8) + val;
    860 
    861         var string = integer.toString(16).toUpperCase();
     829        const val = Math.round(gray[0] / 100 * 255) & 0xFF;
     830        const integer = (val << 16) + (val << 8) + val;
     831
     832        const string = integer.toString(16).toUpperCase();
    862833        return '000000'.substring(string.length) + string;
    863834};
    864835
    865836convert.rgb.gray = function (rgb) {
    866         var val = (rgb[0] + rgb[1] + rgb[2]) / 3;
     837        const val = (rgb[0] + rgb[1] + rgb[2]) / 3;
    867838        return [val / 255 * 100];
    868839};
Note: See TracChangeset for help on using the changeset viewer.