acacia-ui 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/main.js CHANGED
@@ -3249,6 +3249,4044 @@ function useComponentConfig(propName) {
3249
3249
  };
3250
3250
  }
3251
3251
 
3252
+ /***/ },
3253
+
3254
+ /***/ "./node_modules/chroma-js/dist/chroma.cjs"
3255
+ /*!************************************************!*\
3256
+ !*** ./node_modules/chroma-js/dist/chroma.cjs ***!
3257
+ \************************************************/
3258
+ (module) {
3259
+
3260
+ /**
3261
+ * chroma.js - JavaScript library for color conversions
3262
+ *
3263
+ * Copyright (c) 2011-2025, Gregor Aisch
3264
+ * All rights reserved.
3265
+ *
3266
+ * Redistribution and use in source and binary forms, with or without
3267
+ * modification, are permitted provided that the following conditions are met:
3268
+ *
3269
+ * 1. Redistributions of source code must retain the above copyright notice, this
3270
+ * list of conditions and the following disclaimer.
3271
+ *
3272
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
3273
+ * this list of conditions and the following disclaimer in the documentation
3274
+ * and/or other materials provided with the distribution.
3275
+ *
3276
+ * 3. The name Gregor Aisch may not be used to endorse or promote products
3277
+ * derived from this software without specific prior written permission.
3278
+ *
3279
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
3280
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
3281
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
3282
+ * DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
3283
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
3284
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
3285
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
3286
+ * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
3287
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
3288
+ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
3289
+ *
3290
+ * -------------------------------------------------------
3291
+ *
3292
+ * chroma.js includes colors from colorbrewer2.org, which are released under
3293
+ * the following license:
3294
+ *
3295
+ * Copyright (c) 2002 Cynthia Brewer, Mark Harrower,
3296
+ * and The Pennsylvania State University.
3297
+ *
3298
+ * Licensed under the Apache License, Version 2.0 (the "License");
3299
+ * you may not use this file except in compliance with the License.
3300
+ * You may obtain a copy of the License at
3301
+ * http://www.apache.org/licenses/LICENSE-2.0
3302
+ *
3303
+ * Unless required by applicable law or agreed to in writing,
3304
+ * software distributed under the License is distributed on an
3305
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
3306
+ * either express or implied. See the License for the specific
3307
+ * language governing permissions and limitations under the License.
3308
+ *
3309
+ * ------------------------------------------------------
3310
+ *
3311
+ * Named colors are taken from X11 Color Names.
3312
+ * http://www.w3.org/TR/css3-color/#svg-color
3313
+ *
3314
+ * @preserve
3315
+ */
3316
+
3317
+ (function (global, factory) {
3318
+ true ? module.exports = factory() :
3319
+ 0;
3320
+ })(this, (function () { 'use strict';
3321
+
3322
+ var min$4 = Math.min;
3323
+ var max$4 = Math.max;
3324
+
3325
+ function limit (x, low, high) {
3326
+ if ( low === void 0 ) low = 0;
3327
+ if ( high === void 0 ) high = 1;
3328
+
3329
+ return min$4(max$4(low, x), high);
3330
+ }
3331
+
3332
+ function clip_rgb (rgb) {
3333
+ rgb._clipped = false;
3334
+ rgb._unclipped = rgb.slice(0);
3335
+ for (var i = 0; i <= 3; i++) {
3336
+ if (i < 3) {
3337
+ if (rgb[i] < 0 || rgb[i] > 255) { rgb._clipped = true; }
3338
+ rgb[i] = limit(rgb[i], 0, 255);
3339
+ } else if (i === 3) {
3340
+ rgb[i] = limit(rgb[i], 0, 1);
3341
+ }
3342
+ }
3343
+ return rgb;
3344
+ }
3345
+
3346
+ // ported from jQuery's $.type
3347
+ var classToType = {};
3348
+ for (var i = 0, list = [
3349
+ 'Boolean',
3350
+ 'Number',
3351
+ 'String',
3352
+ 'Function',
3353
+ 'Array',
3354
+ 'Date',
3355
+ 'RegExp',
3356
+ 'Undefined',
3357
+ 'Null'
3358
+ ]; i < list.length; i += 1) {
3359
+ var name = list[i];
3360
+
3361
+ classToType[("[object " + name + "]")] = name.toLowerCase();
3362
+ }
3363
+ function type (obj) {
3364
+ return classToType[Object.prototype.toString.call(obj)] || 'object';
3365
+ }
3366
+
3367
+ function unpack (args, keyOrder) {
3368
+ if ( keyOrder === void 0 ) keyOrder = null;
3369
+
3370
+ // if called with more than 3 arguments, we return the arguments
3371
+ if (args.length >= 3) { return Array.prototype.slice.call(args); }
3372
+ // with less than 3 args we check if first arg is object
3373
+ // and use the keyOrder string to extract and sort properties
3374
+ if (type(args[0]) == 'object' && keyOrder) {
3375
+ return keyOrder
3376
+ .split('')
3377
+ .filter(function (k) { return args[0][k] !== undefined; })
3378
+ .map(function (k) { return args[0][k]; });
3379
+ }
3380
+ // otherwise we just return the first argument
3381
+ // (which we suppose is an array of args)
3382
+ return args[0].slice(0);
3383
+ }
3384
+
3385
+ function last (args) {
3386
+ if (args.length < 2) { return null; }
3387
+ var l = args.length - 1;
3388
+ if (type(args[l]) == 'string') { return args[l].toLowerCase(); }
3389
+ return null;
3390
+ }
3391
+
3392
+ var PI$2 = Math.PI;
3393
+ var min$3 = Math.min;
3394
+ var max$3 = Math.max;
3395
+
3396
+ var rnd2 = function (a) { return Math.round(a * 100) / 100; };
3397
+ var rnd3 = function (a) { return Math.round(a * 100) / 100; };
3398
+
3399
+ var TWOPI = PI$2 * 2;
3400
+ var PITHIRD = PI$2 / 3;
3401
+ var DEG2RAD = PI$2 / 180;
3402
+ var RAD2DEG = 180 / PI$2;
3403
+
3404
+ /**
3405
+ * Reverse the first three elements of an array
3406
+ *
3407
+ * @param {any[]} arr
3408
+ * @returns {any[]}
3409
+ */
3410
+ function reverse3(arr) {
3411
+ return arr.slice(0, 3).reverse().concat( arr.slice(3));
3412
+ }
3413
+
3414
+ var input = {
3415
+ format: {},
3416
+ autodetect: []
3417
+ };
3418
+
3419
+ var Color = function Color() {
3420
+ var args = [], len = arguments.length;
3421
+ while ( len-- ) args[ len ] = arguments[ len ];
3422
+
3423
+ var me = this;
3424
+ if (
3425
+ type(args[0]) === 'object' &&
3426
+ args[0].constructor &&
3427
+ args[0].constructor === this.constructor
3428
+ ) {
3429
+ // the argument is already a Color instance
3430
+ return args[0];
3431
+ }
3432
+ // last argument could be the mode
3433
+ var mode = last(args);
3434
+ var autodetect = false;
3435
+ if (!mode) {
3436
+ autodetect = true;
3437
+
3438
+ if (!input.sorted) {
3439
+ input.autodetect = input.autodetect.sort(function (a, b) { return b.p - a.p; });
3440
+ input.sorted = true;
3441
+ }
3442
+
3443
+ // auto-detect format
3444
+ for (var i = 0, list = input.autodetect; i < list.length; i += 1) {
3445
+ var chk = list[i];
3446
+
3447
+ mode = chk.test.apply(chk, args);
3448
+ if (mode) { break; }
3449
+ }
3450
+ }
3451
+ if (input.format[mode]) {
3452
+ var rgb = input.format[mode].apply(
3453
+ null,
3454
+ autodetect ? args : args.slice(0, -1)
3455
+ );
3456
+ me._rgb = clip_rgb(rgb);
3457
+ } else {
3458
+ throw new Error('unknown format: ' + args);
3459
+ }
3460
+ // add alpha channel
3461
+ if (me._rgb.length === 3) { me._rgb.push(1); }
3462
+ };
3463
+ Color.prototype.toString = function toString () {
3464
+ if (type(this.hex) == 'function') { return this.hex(); }
3465
+ return ("[" + (this._rgb.join(',')) + "]");
3466
+ };
3467
+
3468
+ // this gets updated automatically
3469
+ var version = '3.2.0';
3470
+
3471
+ var chroma = function () {
3472
+ var args = [], len = arguments.length;
3473
+ while ( len-- ) args[ len ] = arguments[ len ];
3474
+
3475
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args) ));
3476
+ };
3477
+
3478
+ chroma.version = version;
3479
+
3480
+ var cmyk2rgb = function () {
3481
+ var args = [], len = arguments.length;
3482
+ while ( len-- ) args[ len ] = arguments[ len ];
3483
+
3484
+ args = unpack(args, 'cmyk');
3485
+ var c = args[0];
3486
+ var m = args[1];
3487
+ var y = args[2];
3488
+ var k = args[3];
3489
+ var alpha = args.length > 4 ? args[4] : 1;
3490
+ if (k === 1) { return [0, 0, 0, alpha]; }
3491
+ return [
3492
+ c >= 1 ? 0 : 255 * (1 - c) * (1 - k), // r
3493
+ m >= 1 ? 0 : 255 * (1 - m) * (1 - k), // g
3494
+ y >= 1 ? 0 : 255 * (1 - y) * (1 - k), // b
3495
+ alpha
3496
+ ];
3497
+ };
3498
+
3499
+ var max$2 = Math.max;
3500
+
3501
+ var rgb2cmyk = function () {
3502
+ var args = [], len = arguments.length;
3503
+ while ( len-- ) args[ len ] = arguments[ len ];
3504
+
3505
+ var ref = unpack(args, 'rgb');
3506
+ var r = ref[0];
3507
+ var g = ref[1];
3508
+ var b = ref[2];
3509
+ r = r / 255;
3510
+ g = g / 255;
3511
+ b = b / 255;
3512
+ var k = 1 - max$2(r, max$2(g, b));
3513
+ var f = k < 1 ? 1 / (1 - k) : 0;
3514
+ var c = (1 - r - k) * f;
3515
+ var m = (1 - g - k) * f;
3516
+ var y = (1 - b - k) * f;
3517
+ return [c, m, y, k];
3518
+ };
3519
+
3520
+ Color.prototype.cmyk = function () {
3521
+ return rgb2cmyk(this._rgb);
3522
+ };
3523
+
3524
+ var cmyk = function () {
3525
+ var args = [], len = arguments.length;
3526
+ while ( len-- ) args[ len ] = arguments[ len ];
3527
+
3528
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['cmyk']) ));
3529
+ };
3530
+ Object.assign(chroma, { cmyk: cmyk });
3531
+
3532
+ input.format.cmyk = cmyk2rgb;
3533
+
3534
+ input.autodetect.push({
3535
+ p: 2,
3536
+ test: function () {
3537
+ var args = [], len = arguments.length;
3538
+ while ( len-- ) args[ len ] = arguments[ len ];
3539
+
3540
+ args = unpack(args, 'cmyk');
3541
+ if (type(args) === 'array' && args.length === 4) {
3542
+ return 'cmyk';
3543
+ }
3544
+ }
3545
+ });
3546
+
3547
+ /*
3548
+ * supported arguments:
3549
+ * - hsl2css(h,s,l)
3550
+ * - hsl2css(h,s,l,a)
3551
+ * - hsl2css([h,s,l], mode)
3552
+ * - hsl2css([h,s,l,a], mode)
3553
+ * - hsl2css({h,s,l,a}, mode)
3554
+ */
3555
+ var hsl2css = function () {
3556
+ var args = [], len = arguments.length;
3557
+ while ( len-- ) args[ len ] = arguments[ len ];
3558
+
3559
+ var hsla = unpack(args, 'hsla');
3560
+ var mode = last(args) || 'lsa';
3561
+ hsla[0] = rnd2(hsla[0] || 0) + 'deg';
3562
+ hsla[1] = rnd2(hsla[1] * 100) + '%';
3563
+ hsla[2] = rnd2(hsla[2] * 100) + '%';
3564
+ if (mode === 'hsla' || (hsla.length > 3 && hsla[3] < 1)) {
3565
+ hsla[3] = '/ ' + (hsla.length > 3 ? hsla[3] : 1);
3566
+ mode = 'hsla';
3567
+ } else {
3568
+ hsla.length = 3;
3569
+ }
3570
+ return ((mode.substr(0, 3)) + "(" + (hsla.join(' ')) + ")");
3571
+ };
3572
+
3573
+ /*
3574
+ * supported arguments:
3575
+ * - rgb2hsl(r,g,b)
3576
+ * - rgb2hsl(r,g,b,a)
3577
+ * - rgb2hsl([r,g,b])
3578
+ * - rgb2hsl([r,g,b,a])
3579
+ * - rgb2hsl({r,g,b,a})
3580
+ */
3581
+ var rgb2hsl$1 = function () {
3582
+ var args = [], len = arguments.length;
3583
+ while ( len-- ) args[ len ] = arguments[ len ];
3584
+
3585
+ args = unpack(args, 'rgba');
3586
+ var r = args[0];
3587
+ var g = args[1];
3588
+ var b = args[2];
3589
+
3590
+ r /= 255;
3591
+ g /= 255;
3592
+ b /= 255;
3593
+
3594
+ var minRgb = min$3(r, g, b);
3595
+ var maxRgb = max$3(r, g, b);
3596
+
3597
+ var l = (maxRgb + minRgb) / 2;
3598
+ var s, h;
3599
+
3600
+ if (maxRgb === minRgb) {
3601
+ s = 0;
3602
+ h = Number.NaN;
3603
+ } else {
3604
+ s =
3605
+ l < 0.5
3606
+ ? (maxRgb - minRgb) / (maxRgb + minRgb)
3607
+ : (maxRgb - minRgb) / (2 - maxRgb - minRgb);
3608
+ }
3609
+
3610
+ if (r == maxRgb) { h = (g - b) / (maxRgb - minRgb); }
3611
+ else if (g == maxRgb) { h = 2 + (b - r) / (maxRgb - minRgb); }
3612
+ else if (b == maxRgb) { h = 4 + (r - g) / (maxRgb - minRgb); }
3613
+
3614
+ h *= 60;
3615
+ if (h < 0) { h += 360; }
3616
+ if (args.length > 3 && args[3] !== undefined) { return [h, s, l, args[3]]; }
3617
+ return [h, s, l];
3618
+ };
3619
+
3620
+ /*
3621
+ * supported arguments:
3622
+ * - lab2css(l,a,b)
3623
+ * - lab2css(l,a,b,alpha)
3624
+ * - lab2css([l,a,b], mode)
3625
+ * - lab2css([l,a,b,alpha], mode)
3626
+ */
3627
+ var lab2css = function () {
3628
+ var args = [], len = arguments.length;
3629
+ while ( len-- ) args[ len ] = arguments[ len ];
3630
+
3631
+ var laba = unpack(args, 'lab');
3632
+ var mode = last(args) || 'lab';
3633
+ laba[0] = rnd2(laba[0]) + '%';
3634
+ laba[1] = rnd2(laba[1]);
3635
+ laba[2] = rnd2(laba[2]);
3636
+ if (mode === 'laba' || (laba.length > 3 && laba[3] < 1)) {
3637
+ laba[3] = '/ ' + (laba.length > 3 ? laba[3] : 1);
3638
+ } else {
3639
+ laba.length = 3;
3640
+ }
3641
+ return ("lab(" + (laba.join(' ')) + ")");
3642
+ };
3643
+
3644
+ var labConstants = {
3645
+ // Corresponds roughly to RGB brighter/darker
3646
+ Kn: 18,
3647
+
3648
+ // D65 standard referent
3649
+ labWhitePoint: 'd65',
3650
+ Xn: 0.95047,
3651
+ Yn: 1,
3652
+ Zn: 1.08883,
3653
+
3654
+ kE: 216.0 / 24389.0,
3655
+ kKE: 8.0,
3656
+ kK: 24389.0 / 27.0,
3657
+
3658
+ RefWhiteRGB: {
3659
+ // sRGB
3660
+ X: 0.95047,
3661
+ Y: 1,
3662
+ Z: 1.08883
3663
+ },
3664
+
3665
+ MtxRGB2XYZ: {
3666
+ m00: 0.4124564390896922,
3667
+ m01: 0.21267285140562253,
3668
+ m02: 0.0193338955823293,
3669
+ m10: 0.357576077643909,
3670
+ m11: 0.715152155287818,
3671
+ m12: 0.11919202588130297,
3672
+ m20: 0.18043748326639894,
3673
+ m21: 0.07217499330655958,
3674
+ m22: 0.9503040785363679
3675
+ },
3676
+
3677
+ MtxXYZ2RGB: {
3678
+ m00: 3.2404541621141045,
3679
+ m01: -0.9692660305051868,
3680
+ m02: 0.055643430959114726,
3681
+ m10: -1.5371385127977166,
3682
+ m11: 1.8760108454466942,
3683
+ m12: -0.2040259135167538,
3684
+ m20: -0.498531409556016,
3685
+ m21: 0.041556017530349834,
3686
+ m22: 1.0572251882231791
3687
+ },
3688
+
3689
+ // used in rgb2xyz
3690
+ As: 0.9414285350000001,
3691
+ Bs: 1.040417467,
3692
+ Cs: 1.089532651,
3693
+
3694
+ MtxAdaptMa: {
3695
+ m00: 0.8951,
3696
+ m01: -0.7502,
3697
+ m02: 0.0389,
3698
+ m10: 0.2664,
3699
+ m11: 1.7135,
3700
+ m12: -0.0685,
3701
+ m20: -0.1614,
3702
+ m21: 0.0367,
3703
+ m22: 1.0296
3704
+ },
3705
+
3706
+ MtxAdaptMaI: {
3707
+ m00: 0.9869929054667123,
3708
+ m01: 0.43230526972339456,
3709
+ m02: -0.008528664575177328,
3710
+ m10: -0.14705425642099013,
3711
+ m11: 0.5183602715367776,
3712
+ m12: 0.04004282165408487,
3713
+ m20: 0.15996265166373125,
3714
+ m21: 0.0492912282128556,
3715
+ m22: 0.9684866957875502
3716
+ }
3717
+ };
3718
+
3719
+ // taken from https://de.mathworks.com/help/images/ref/whitepoint.html
3720
+ var ILLUMINANTS = new Map([
3721
+ // ASTM E308-01
3722
+ ['a', [1.0985, 0.35585]],
3723
+ // Wyszecki & Stiles, p. 769
3724
+ ['b', [1.0985, 0.35585]],
3725
+ // C ASTM E308-01
3726
+ ['c', [0.98074, 1.18232]],
3727
+ // D50 (ASTM E308-01)
3728
+ ['d50', [0.96422, 0.82521]],
3729
+ // D55 (ASTM E308-01)
3730
+ ['d55', [0.95682, 0.92149]],
3731
+ // D65 (ASTM E308-01)
3732
+ ['d65', [0.95047, 1.08883]],
3733
+ // E (ASTM E308-01)
3734
+ ['e', [1, 1, 1]],
3735
+ // F2 (ASTM E308-01)
3736
+ ['f2', [0.99186, 0.67393]],
3737
+ // F7 (ASTM E308-01)
3738
+ ['f7', [0.95041, 1.08747]],
3739
+ // F11 (ASTM E308-01)
3740
+ ['f11', [1.00962, 0.6435]],
3741
+ ['icc', [0.96422, 0.82521]]
3742
+ ]);
3743
+
3744
+ function setLabWhitePoint(name) {
3745
+ var ill = ILLUMINANTS.get(String(name).toLowerCase());
3746
+ if (!ill) {
3747
+ throw new Error('unknown Lab illuminant ' + name);
3748
+ }
3749
+ labConstants.labWhitePoint = name;
3750
+ labConstants.Xn = ill[0];
3751
+ labConstants.Zn = ill[1];
3752
+ }
3753
+
3754
+ function getLabWhitePoint() {
3755
+ return labConstants.labWhitePoint;
3756
+ }
3757
+
3758
+ var rgb2lab = function () {
3759
+ var args = [], len = arguments.length;
3760
+ while ( len-- ) args[ len ] = arguments[ len ];
3761
+
3762
+ var ref = unpack(args, 'rgb');
3763
+ var r = ref[0];
3764
+ var g = ref[1];
3765
+ var b = ref[2];
3766
+ var rest = ref.slice(3);
3767
+ var ref$1 = rgb2xyz(r, g, b);
3768
+ var x = ref$1[0];
3769
+ var y = ref$1[1];
3770
+ var z = ref$1[2];
3771
+ var ref$2 = xyz2lab(x, y, z);
3772
+ var L = ref$2[0];
3773
+ var a = ref$2[1];
3774
+ var b_ = ref$2[2];
3775
+ return [L, a, b_ ].concat( (rest.length > 0 && rest[0] < 1 ? [rest[0]] : []));
3776
+ };
3777
+
3778
+ function xyz2lab(x, y, z) {
3779
+ var Xn = labConstants.Xn;
3780
+ var Yn = labConstants.Yn;
3781
+ var Zn = labConstants.Zn;
3782
+ var kE = labConstants.kE;
3783
+ var kK = labConstants.kK;
3784
+ var xr = x / Xn;
3785
+ var yr = y / Yn;
3786
+ var zr = z / Zn;
3787
+
3788
+ var fx = xr > kE ? Math.pow(xr, 1.0 / 3.0) : (kK * xr + 16.0) / 116.0;
3789
+ var fy = yr > kE ? Math.pow(yr, 1.0 / 3.0) : (kK * yr + 16.0) / 116.0;
3790
+ var fz = zr > kE ? Math.pow(zr, 1.0 / 3.0) : (kK * zr + 16.0) / 116.0;
3791
+
3792
+ return [116.0 * fy - 16.0, 500.0 * (fx - fy), 200.0 * (fy - fz)];
3793
+ }
3794
+
3795
+ function gammaAdjustSRGB(companded) {
3796
+ var sign = Math.sign(companded);
3797
+ companded = Math.abs(companded);
3798
+ var linear =
3799
+ companded <= 0.04045
3800
+ ? companded / 12.92
3801
+ : Math.pow((companded + 0.055) / 1.055, 2.4);
3802
+ return linear * sign;
3803
+ }
3804
+
3805
+ var rgb2xyz = function (r, g, b) {
3806
+ // normalize and gamma adjust
3807
+ r = gammaAdjustSRGB(r / 255);
3808
+ g = gammaAdjustSRGB(g / 255);
3809
+ b = gammaAdjustSRGB(b / 255);
3810
+
3811
+ var MtxRGB2XYZ = labConstants.MtxRGB2XYZ;
3812
+ var MtxAdaptMa = labConstants.MtxAdaptMa;
3813
+ var MtxAdaptMaI = labConstants.MtxAdaptMaI;
3814
+ var Xn = labConstants.Xn;
3815
+ var Yn = labConstants.Yn;
3816
+ var Zn = labConstants.Zn;
3817
+ var As = labConstants.As;
3818
+ var Bs = labConstants.Bs;
3819
+ var Cs = labConstants.Cs;
3820
+
3821
+ var x = r * MtxRGB2XYZ.m00 + g * MtxRGB2XYZ.m10 + b * MtxRGB2XYZ.m20;
3822
+ var y = r * MtxRGB2XYZ.m01 + g * MtxRGB2XYZ.m11 + b * MtxRGB2XYZ.m21;
3823
+ var z = r * MtxRGB2XYZ.m02 + g * MtxRGB2XYZ.m12 + b * MtxRGB2XYZ.m22;
3824
+
3825
+ var Ad = Xn * MtxAdaptMa.m00 + Yn * MtxAdaptMa.m10 + Zn * MtxAdaptMa.m20;
3826
+ var Bd = Xn * MtxAdaptMa.m01 + Yn * MtxAdaptMa.m11 + Zn * MtxAdaptMa.m21;
3827
+ var Cd = Xn * MtxAdaptMa.m02 + Yn * MtxAdaptMa.m12 + Zn * MtxAdaptMa.m22;
3828
+
3829
+ var X = x * MtxAdaptMa.m00 + y * MtxAdaptMa.m10 + z * MtxAdaptMa.m20;
3830
+ var Y = x * MtxAdaptMa.m01 + y * MtxAdaptMa.m11 + z * MtxAdaptMa.m21;
3831
+ var Z = x * MtxAdaptMa.m02 + y * MtxAdaptMa.m12 + z * MtxAdaptMa.m22;
3832
+
3833
+ X *= Ad / As;
3834
+ Y *= Bd / Bs;
3835
+ Z *= Cd / Cs;
3836
+
3837
+ x = X * MtxAdaptMaI.m00 + Y * MtxAdaptMaI.m10 + Z * MtxAdaptMaI.m20;
3838
+ y = X * MtxAdaptMaI.m01 + Y * MtxAdaptMaI.m11 + Z * MtxAdaptMaI.m21;
3839
+ z = X * MtxAdaptMaI.m02 + Y * MtxAdaptMaI.m12 + Z * MtxAdaptMaI.m22;
3840
+
3841
+ return [x, y, z];
3842
+ };
3843
+
3844
+ /*
3845
+ * supported arguments:
3846
+ * - lab2css(l,a,b)
3847
+ * - lab2css(l,a,b,alpha)
3848
+ * - lab2css([l,a,b], mode)
3849
+ * - lab2css([l,a,b,alpha], mode)
3850
+ */
3851
+ var lch2css = function () {
3852
+ var args = [], len = arguments.length;
3853
+ while ( len-- ) args[ len ] = arguments[ len ];
3854
+
3855
+ var lcha = unpack(args, 'lch');
3856
+ var mode = last(args) || 'lab';
3857
+ lcha[0] = rnd2(lcha[0]) + '%';
3858
+ lcha[1] = rnd2(lcha[1]);
3859
+ lcha[2] = isNaN(lcha[2]) ? 'none' : rnd2(lcha[2]) + 'deg'; // add deg unit to hue
3860
+ if (mode === 'lcha' || (lcha.length > 3 && lcha[3] < 1)) {
3861
+ lcha[3] = '/ ' + (lcha.length > 3 ? lcha[3] : 1);
3862
+ } else {
3863
+ lcha.length = 3;
3864
+ }
3865
+ return ("lch(" + (lcha.join(' ')) + ")");
3866
+ };
3867
+
3868
+ var sqrt$4 = Math.sqrt;
3869
+ var atan2$2 = Math.atan2;
3870
+ var round$5 = Math.round;
3871
+
3872
+ var lab2lch = function () {
3873
+ var args = [], len = arguments.length;
3874
+ while ( len-- ) args[ len ] = arguments[ len ];
3875
+
3876
+ var ref = unpack(args, 'lab');
3877
+ var l = ref[0];
3878
+ var a = ref[1];
3879
+ var b = ref[2];
3880
+ var c = sqrt$4(a * a + b * b);
3881
+ var h = (atan2$2(b, a) * RAD2DEG + 360) % 360;
3882
+ if (round$5(c * 10000) === 0) { h = Number.NaN; }
3883
+ return [l, c, h];
3884
+ };
3885
+
3886
+ var rgb2lch = function () {
3887
+ var args = [], len = arguments.length;
3888
+ while ( len-- ) args[ len ] = arguments[ len ];
3889
+
3890
+ var ref = unpack(args, 'rgb');
3891
+ var r = ref[0];
3892
+ var g = ref[1];
3893
+ var b = ref[2];
3894
+ var rest = ref.slice(3);
3895
+ var ref$1 = rgb2lab(r, g, b);
3896
+ var l = ref$1[0];
3897
+ var a = ref$1[1];
3898
+ var b_ = ref$1[2];
3899
+ var ref$2 = lab2lch(l, a, b_);
3900
+ var L = ref$2[0];
3901
+ var c = ref$2[1];
3902
+ var h = ref$2[2];
3903
+ return [L, c, h ].concat( (rest.length > 0 && rest[0] < 1 ? [rest[0]] : []));
3904
+ };
3905
+
3906
+ // from https://www.w3.org/TR/css-color-4/multiply-matrices.js
3907
+ function multiplyMatrices(A, B) {
3908
+ var m = A.length;
3909
+
3910
+ if (!Array.isArray(A[0])) {
3911
+ // A is vector, convert to [[a, b, c, ...]]
3912
+ A = [A];
3913
+ }
3914
+
3915
+ if (!Array.isArray(B[0])) {
3916
+ // B is vector, convert to [[a], [b], [c], ...]]
3917
+ B = B.map(function (x) { return [x]; });
3918
+ }
3919
+
3920
+ var p = B[0].length;
3921
+ var B_cols = B[0].map(function (_, i) { return B.map(function (x) { return x[i]; }); }); // transpose B
3922
+ var product = A.map(function (row) { return B_cols.map(function (col) {
3923
+ if (!Array.isArray(row)) {
3924
+ return col.reduce(function (a, c) { return a + c * row; }, 0);
3925
+ }
3926
+
3927
+ return row.reduce(function (a, c, i) { return a + c * (col[i] || 0); }, 0);
3928
+ }); }
3929
+ );
3930
+
3931
+ if (m === 1) {
3932
+ product = product[0]; // Avoid [[a, b, c, ...]]
3933
+ }
3934
+
3935
+ if (p === 1) {
3936
+ return product.map(function (x) { return x[0]; }); // Avoid [[a], [b], [c], ...]]
3937
+ }
3938
+
3939
+ return product;
3940
+ }
3941
+
3942
+ var rgb2oklab = function () {
3943
+ var args = [], len = arguments.length;
3944
+ while ( len-- ) args[ len ] = arguments[ len ];
3945
+
3946
+ var ref = unpack(args, 'rgb');
3947
+ var r = ref[0];
3948
+ var g = ref[1];
3949
+ var b = ref[2];
3950
+ var rest = ref.slice(3);
3951
+ var xyz = rgb2xyz(r, g, b);
3952
+ var oklab = XYZ_to_OKLab(xyz);
3953
+ return oklab.concat( (rest.length > 0 && rest[0] < 1 ? [rest[0]] : []));
3954
+ };
3955
+
3956
+ // from https://www.w3.org/TR/css-color-4/#color-conversion-code
3957
+ function XYZ_to_OKLab(XYZ) {
3958
+ // Given XYZ relative to D65, convert to OKLab
3959
+ var XYZtoLMS = [
3960
+ [0.819022437996703, 0.3619062600528904, -0.1288737815209879],
3961
+ [0.0329836539323885, 0.9292868615863434, 0.0361446663506424],
3962
+ [0.0481771893596242, 0.2642395317527308, 0.6335478284694309]
3963
+ ];
3964
+ var LMStoOKLab = [
3965
+ [0.210454268309314, 0.7936177747023054, -0.0040720430116193],
3966
+ [1.9779985324311684, -2.42859224204858, 0.450593709617411],
3967
+ [0.0259040424655478, 0.7827717124575296, -0.8086757549230774]
3968
+ ];
3969
+
3970
+ var LMS = multiplyMatrices(XYZtoLMS, XYZ);
3971
+ // JavaScript Math.cbrt returns a sign-matched cube root
3972
+ // beware if porting to other languages
3973
+ // especially if tempted to use a general power function
3974
+ return multiplyMatrices(
3975
+ LMStoOKLab,
3976
+ LMS.map(function (c) { return Math.cbrt(c); })
3977
+ );
3978
+ // L in range [0,1]. For use in CSS, multiply by 100 and add a percent
3979
+ }
3980
+
3981
+ var oklab2css = function () {
3982
+ var args = [], len = arguments.length;
3983
+ while ( len-- ) args[ len ] = arguments[ len ];
3984
+
3985
+ var laba = unpack(args, 'lab');
3986
+ laba[0] = rnd2(laba[0] * 100) + '%';
3987
+ laba[1] = rnd3(laba[1]);
3988
+ laba[2] = rnd3(laba[2]);
3989
+ if (laba.length > 3 && laba[3] < 1) {
3990
+ laba[3] = '/ ' + (laba.length > 3 ? laba[3] : 1);
3991
+ } else {
3992
+ laba.length = 3;
3993
+ }
3994
+ return ("oklab(" + (laba.join(' ')) + ")");
3995
+ };
3996
+
3997
+ var rgb2oklch = function () {
3998
+ var args = [], len = arguments.length;
3999
+ while ( len-- ) args[ len ] = arguments[ len ];
4000
+
4001
+ var ref = unpack(args, 'rgb');
4002
+ var r = ref[0];
4003
+ var g = ref[1];
4004
+ var b = ref[2];
4005
+ var rest = ref.slice(3);
4006
+ var ref$1 = rgb2oklab(r, g, b);
4007
+ var l = ref$1[0];
4008
+ var a = ref$1[1];
4009
+ var b_ = ref$1[2];
4010
+ var ref$2 = lab2lch(l, a, b_);
4011
+ var L = ref$2[0];
4012
+ var c = ref$2[1];
4013
+ var h = ref$2[2];
4014
+ return [L, c, h ].concat( (rest.length > 0 && rest[0] < 1 ? [rest[0]] : []));
4015
+ };
4016
+
4017
+ var oklch2css = function () {
4018
+ var args = [], len = arguments.length;
4019
+ while ( len-- ) args[ len ] = arguments[ len ];
4020
+
4021
+ var lcha = unpack(args, 'lch');
4022
+ lcha[0] = rnd2(lcha[0] * 100) + '%';
4023
+ lcha[1] = rnd3(lcha[1]);
4024
+ lcha[2] = isNaN(lcha[2]) ? 'none' : rnd2(lcha[2]) + 'deg'; // add deg unit to hue
4025
+ if (lcha.length > 3 && lcha[3] < 1) {
4026
+ lcha[3] = '/ ' + (lcha.length > 3 ? lcha[3] : 1);
4027
+ } else {
4028
+ lcha.length = 3;
4029
+ }
4030
+ return ("oklch(" + (lcha.join(' ')) + ")");
4031
+ };
4032
+
4033
+ var round$4 = Math.round;
4034
+
4035
+ /*
4036
+ * supported arguments:
4037
+ * - rgb2css(r,g,b)
4038
+ * - rgb2css(r,g,b,a)
4039
+ * - rgb2css([r,g,b], mode)
4040
+ * - rgb2css([r,g,b,a], mode)
4041
+ * - rgb2css({r,g,b,a}, mode)
4042
+ */
4043
+ var rgb2css = function () {
4044
+ var args = [], len = arguments.length;
4045
+ while ( len-- ) args[ len ] = arguments[ len ];
4046
+
4047
+ var rgba = unpack(args, 'rgba');
4048
+ var mode = last(args) || 'rgb';
4049
+ if (mode.substr(0, 3) === 'hsl') {
4050
+ return hsl2css(rgb2hsl$1(rgba), mode);
4051
+ }
4052
+ if (mode.substr(0, 3) === 'lab') {
4053
+ // change to D50 lab whitepoint since this is what W3C is using for CSS Lab colors
4054
+ var prevWhitePoint = getLabWhitePoint();
4055
+ setLabWhitePoint('d50');
4056
+ var cssColor = lab2css(rgb2lab(rgba), mode);
4057
+ setLabWhitePoint(prevWhitePoint);
4058
+ return cssColor;
4059
+ }
4060
+ if (mode.substr(0, 3) === 'lch') {
4061
+ // change to D50 lab whitepoint since this is what W3C is using for CSS Lab colors
4062
+ var prevWhitePoint$1 = getLabWhitePoint();
4063
+ setLabWhitePoint('d50');
4064
+ var cssColor$1 = lch2css(rgb2lch(rgba), mode);
4065
+ setLabWhitePoint(prevWhitePoint$1);
4066
+ return cssColor$1;
4067
+ }
4068
+ if (mode.substr(0, 5) === 'oklab') {
4069
+ return oklab2css(rgb2oklab(rgba));
4070
+ }
4071
+ if (mode.substr(0, 5) === 'oklch') {
4072
+ return oklch2css(rgb2oklch(rgba));
4073
+ }
4074
+ rgba[0] = round$4(rgba[0]);
4075
+ rgba[1] = round$4(rgba[1]);
4076
+ rgba[2] = round$4(rgba[2]);
4077
+ if (mode === 'rgba' || (rgba.length > 3 && rgba[3] < 1)) {
4078
+ rgba[3] = '/ ' + (rgba.length > 3 ? rgba[3] : 1);
4079
+ mode = 'rgba';
4080
+ }
4081
+ return ((mode.substr(0, 3)) + "(" + (rgba.slice(0, mode === 'rgb' ? 3 : 4).join(' ')) + ")");
4082
+ };
4083
+
4084
+ var hsl2rgb = function () {
4085
+ var assign;
4086
+
4087
+ var args = [], len = arguments.length;
4088
+ while ( len-- ) args[ len ] = arguments[ len ];
4089
+ args = unpack(args, 'hsl');
4090
+ var h = args[0];
4091
+ var s = args[1];
4092
+ var l = args[2];
4093
+ var r, g, b;
4094
+ if (s === 0) {
4095
+ r = g = b = l * 255;
4096
+ } else {
4097
+ var t3 = [0, 0, 0];
4098
+ var c = [0, 0, 0];
4099
+ var t2 = l < 0.5 ? l * (1 + s) : l + s - l * s;
4100
+ var t1 = 2 * l - t2;
4101
+ var h_ = h / 360;
4102
+ t3[0] = h_ + 1 / 3;
4103
+ t3[1] = h_;
4104
+ t3[2] = h_ - 1 / 3;
4105
+ for (var i = 0; i < 3; i++) {
4106
+ if (t3[i] < 0) { t3[i] += 1; }
4107
+ if (t3[i] > 1) { t3[i] -= 1; }
4108
+ if (6 * t3[i] < 1) { c[i] = t1 + (t2 - t1) * 6 * t3[i]; }
4109
+ else if (2 * t3[i] < 1) { c[i] = t2; }
4110
+ else if (3 * t3[i] < 2) { c[i] = t1 + (t2 - t1) * (2 / 3 - t3[i]) * 6; }
4111
+ else { c[i] = t1; }
4112
+ }
4113
+ (assign = [c[0] * 255, c[1] * 255, c[2] * 255], r = assign[0], g = assign[1], b = assign[2]);
4114
+ }
4115
+ if (args.length > 3) {
4116
+ // keep alpha channel
4117
+ return [r, g, b, args[3]];
4118
+ }
4119
+ return [r, g, b, 1];
4120
+ };
4121
+
4122
+ /*
4123
+ * L* [0..100]
4124
+ * a [-100..100]
4125
+ * b [-100..100]
4126
+ */
4127
+ var lab2rgb = function () {
4128
+ var args = [], len = arguments.length;
4129
+ while ( len-- ) args[ len ] = arguments[ len ];
4130
+
4131
+ args = unpack(args, 'lab');
4132
+ var L = args[0];
4133
+ var a = args[1];
4134
+ var b = args[2];
4135
+ var ref = lab2xyz(L, a, b);
4136
+ var x = ref[0];
4137
+ var y = ref[1];
4138
+ var z = ref[2];
4139
+ var ref$1 = xyz2rgb(x, y, z);
4140
+ var r = ref$1[0];
4141
+ var g = ref$1[1];
4142
+ var b_ = ref$1[2];
4143
+ return [r, g, b_, args.length > 3 ? args[3] : 1];
4144
+ };
4145
+
4146
+ var lab2xyz = function (L, a, b) {
4147
+ var kE = labConstants.kE;
4148
+ var kK = labConstants.kK;
4149
+ var kKE = labConstants.kKE;
4150
+ var Xn = labConstants.Xn;
4151
+ var Yn = labConstants.Yn;
4152
+ var Zn = labConstants.Zn;
4153
+
4154
+ var fy = (L + 16.0) / 116.0;
4155
+ var fx = 0.002 * a + fy;
4156
+ var fz = fy - 0.005 * b;
4157
+
4158
+ var fx3 = fx * fx * fx;
4159
+ var fz3 = fz * fz * fz;
4160
+
4161
+ var xr = fx3 > kE ? fx3 : (116.0 * fx - 16.0) / kK;
4162
+ var yr = L > kKE ? Math.pow((L + 16.0) / 116.0, 3.0) : L / kK;
4163
+ var zr = fz3 > kE ? fz3 : (116.0 * fz - 16.0) / kK;
4164
+
4165
+ var x = xr * Xn;
4166
+ var y = yr * Yn;
4167
+ var z = zr * Zn;
4168
+
4169
+ return [x, y, z];
4170
+ };
4171
+
4172
+ var compand = function (linear) {
4173
+ /* sRGB */
4174
+ var sign = Math.sign(linear);
4175
+ linear = Math.abs(linear);
4176
+ return (
4177
+ (linear <= 0.0031308
4178
+ ? linear * 12.92
4179
+ : 1.055 * Math.pow(linear, 1.0 / 2.4) - 0.055) * sign
4180
+ );
4181
+ };
4182
+
4183
+ var xyz2rgb = function (x, y, z) {
4184
+ var MtxAdaptMa = labConstants.MtxAdaptMa;
4185
+ var MtxAdaptMaI = labConstants.MtxAdaptMaI;
4186
+ var MtxXYZ2RGB = labConstants.MtxXYZ2RGB;
4187
+ var RefWhiteRGB = labConstants.RefWhiteRGB;
4188
+ var Xn = labConstants.Xn;
4189
+ var Yn = labConstants.Yn;
4190
+ var Zn = labConstants.Zn;
4191
+
4192
+ var As = Xn * MtxAdaptMa.m00 + Yn * MtxAdaptMa.m10 + Zn * MtxAdaptMa.m20;
4193
+ var Bs = Xn * MtxAdaptMa.m01 + Yn * MtxAdaptMa.m11 + Zn * MtxAdaptMa.m21;
4194
+ var Cs = Xn * MtxAdaptMa.m02 + Yn * MtxAdaptMa.m12 + Zn * MtxAdaptMa.m22;
4195
+
4196
+ var Ad =
4197
+ RefWhiteRGB.X * MtxAdaptMa.m00 +
4198
+ RefWhiteRGB.Y * MtxAdaptMa.m10 +
4199
+ RefWhiteRGB.Z * MtxAdaptMa.m20;
4200
+ var Bd =
4201
+ RefWhiteRGB.X * MtxAdaptMa.m01 +
4202
+ RefWhiteRGB.Y * MtxAdaptMa.m11 +
4203
+ RefWhiteRGB.Z * MtxAdaptMa.m21;
4204
+ var Cd =
4205
+ RefWhiteRGB.X * MtxAdaptMa.m02 +
4206
+ RefWhiteRGB.Y * MtxAdaptMa.m12 +
4207
+ RefWhiteRGB.Z * MtxAdaptMa.m22;
4208
+
4209
+ var X1 =
4210
+ (x * MtxAdaptMa.m00 + y * MtxAdaptMa.m10 + z * MtxAdaptMa.m20) *
4211
+ (Ad / As);
4212
+ var Y1 =
4213
+ (x * MtxAdaptMa.m01 + y * MtxAdaptMa.m11 + z * MtxAdaptMa.m21) *
4214
+ (Bd / Bs);
4215
+ var Z1 =
4216
+ (x * MtxAdaptMa.m02 + y * MtxAdaptMa.m12 + z * MtxAdaptMa.m22) *
4217
+ (Cd / Cs);
4218
+
4219
+ var X2 =
4220
+ X1 * MtxAdaptMaI.m00 + Y1 * MtxAdaptMaI.m10 + Z1 * MtxAdaptMaI.m20;
4221
+ var Y2 =
4222
+ X1 * MtxAdaptMaI.m01 + Y1 * MtxAdaptMaI.m11 + Z1 * MtxAdaptMaI.m21;
4223
+ var Z2 =
4224
+ X1 * MtxAdaptMaI.m02 + Y1 * MtxAdaptMaI.m12 + Z1 * MtxAdaptMaI.m22;
4225
+
4226
+ var r = compand(
4227
+ X2 * MtxXYZ2RGB.m00 + Y2 * MtxXYZ2RGB.m10 + Z2 * MtxXYZ2RGB.m20
4228
+ );
4229
+ var g = compand(
4230
+ X2 * MtxXYZ2RGB.m01 + Y2 * MtxXYZ2RGB.m11 + Z2 * MtxXYZ2RGB.m21
4231
+ );
4232
+ var b = compand(
4233
+ X2 * MtxXYZ2RGB.m02 + Y2 * MtxXYZ2RGB.m12 + Z2 * MtxXYZ2RGB.m22
4234
+ );
4235
+
4236
+ return [r * 255, g * 255, b * 255];
4237
+ };
4238
+
4239
+ var sin$3 = Math.sin;
4240
+ var cos$4 = Math.cos;
4241
+
4242
+ var lch2lab = function () {
4243
+ var args = [], len = arguments.length;
4244
+ while ( len-- ) args[ len ] = arguments[ len ];
4245
+
4246
+ /*
4247
+ Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel.
4248
+ These formulas were invented by David Dalrymple to obtain maximum contrast without going
4249
+ out of gamut if the parameters are in the range 0-1.
4250
+
4251
+ A saturation multiplier was added by Gregor Aisch
4252
+ */
4253
+ var ref = unpack(args, 'lch');
4254
+ var l = ref[0];
4255
+ var c = ref[1];
4256
+ var h = ref[2];
4257
+ if (isNaN(h)) { h = 0; }
4258
+ h = h * DEG2RAD;
4259
+ return [l, cos$4(h) * c, sin$3(h) * c];
4260
+ };
4261
+
4262
+ var lch2rgb = function () {
4263
+ var args = [], len = arguments.length;
4264
+ while ( len-- ) args[ len ] = arguments[ len ];
4265
+
4266
+ args = unpack(args, 'lch');
4267
+ var l = args[0];
4268
+ var c = args[1];
4269
+ var h = args[2];
4270
+ var ref = lch2lab(l, c, h);
4271
+ var L = ref[0];
4272
+ var a = ref[1];
4273
+ var b_ = ref[2];
4274
+ var ref$1 = lab2rgb(L, a, b_);
4275
+ var r = ref$1[0];
4276
+ var g = ref$1[1];
4277
+ var b = ref$1[2];
4278
+ return [r, g, b, args.length > 3 ? args[3] : 1];
4279
+ };
4280
+
4281
+ var oklab2rgb = function () {
4282
+ var args = [], len = arguments.length;
4283
+ while ( len-- ) args[ len ] = arguments[ len ];
4284
+
4285
+ args = unpack(args, 'lab');
4286
+ var L = args[0];
4287
+ var a = args[1];
4288
+ var b = args[2];
4289
+ var rest = args.slice(3);
4290
+ var ref = OKLab_to_XYZ([L, a, b]);
4291
+ var X = ref[0];
4292
+ var Y = ref[1];
4293
+ var Z = ref[2];
4294
+ var ref$1 = xyz2rgb(X, Y, Z);
4295
+ var r = ref$1[0];
4296
+ var g = ref$1[1];
4297
+ var b_ = ref$1[2];
4298
+ return [r, g, b_ ].concat( (rest.length > 0 && rest[0] < 1 ? [rest[0]] : []));
4299
+ };
4300
+
4301
+ // from https://www.w3.org/TR/css-color-4/#color-conversion-code
4302
+ function OKLab_to_XYZ(OKLab) {
4303
+ // Given OKLab, convert to XYZ relative to D65
4304
+ var LMStoXYZ = [
4305
+ [1.2268798758459243, -0.5578149944602171, 0.2813910456659647],
4306
+ [-0.0405757452148008, 1.112286803280317, -0.0717110580655164],
4307
+ [-0.0763729366746601, -0.4214933324022432, 1.5869240198367816]
4308
+ ];
4309
+ var OKLabtoLMS = [
4310
+ [1.0, 0.3963377773761749, 0.2158037573099136],
4311
+ [1.0, -0.1055613458156586, -0.0638541728258133],
4312
+ [1.0, -0.0894841775298119, -1.2914855480194092]
4313
+ ];
4314
+
4315
+ var LMSnl = multiplyMatrices(OKLabtoLMS, OKLab);
4316
+ return multiplyMatrices(
4317
+ LMStoXYZ,
4318
+ LMSnl.map(function (c) { return Math.pow( c, 3 ); })
4319
+ );
4320
+ }
4321
+
4322
+ var oklch2rgb = function () {
4323
+ var args = [], len = arguments.length;
4324
+ while ( len-- ) args[ len ] = arguments[ len ];
4325
+
4326
+ args = unpack(args, 'lch');
4327
+ var l = args[0];
4328
+ var c = args[1];
4329
+ var h = args[2];
4330
+ var rest = args.slice(3);
4331
+ var ref = lch2lab(l, c, h);
4332
+ var L = ref[0];
4333
+ var a = ref[1];
4334
+ var b_ = ref[2];
4335
+ var ref$1 = oklab2rgb(L, a, b_);
4336
+ var r = ref$1[0];
4337
+ var g = ref$1[1];
4338
+ var b = ref$1[2];
4339
+ return [r, g, b ].concat( (rest.length > 0 && rest[0] < 1 ? [rest[0]] : []));
4340
+ };
4341
+
4342
+ var INT_OR_PCT = /((?:-?\d+)|(?:-?\d+(?:\.\d+)?)%|none)/.source;
4343
+ var FLOAT_OR_PCT = /((?:-?(?:\d+(?:\.\d*)?|\.\d+)%?)|none)/.source;
4344
+ var PCT = /((?:-?(?:\d+(?:\.\d*)?|\.\d+)%)|none)/.source;
4345
+ var RE_S = /\s*/.source;
4346
+ var SEP = /\s+/.source;
4347
+ var COMMA = /\s*,\s*/.source;
4348
+ var ANLGE = /((?:-?(?:\d+(?:\.\d*)?|\.\d+)(?:deg)?)|none)/.source;
4349
+ var ALPHA = /\s*(?:\/\s*((?:[01]|[01]?\.\d+)|\d+(?:\.\d+)?%))?/.source;
4350
+
4351
+ // e.g. rgb(250 20 0), rgb(100% 50% 20%), rgb(100% 50% 20% / 0.5)
4352
+ var RE_RGB = new RegExp(
4353
+ '^rgba?\\(' +
4354
+ RE_S +
4355
+ [INT_OR_PCT, INT_OR_PCT, INT_OR_PCT].join(SEP) +
4356
+ ALPHA +
4357
+ '\\)$'
4358
+ );
4359
+ var RE_RGB_LEGACY = new RegExp(
4360
+ '^rgb\\(' +
4361
+ RE_S +
4362
+ [INT_OR_PCT, INT_OR_PCT, INT_OR_PCT].join(COMMA) +
4363
+ RE_S +
4364
+ '\\)$'
4365
+ );
4366
+ var RE_RGBA_LEGACY = new RegExp(
4367
+ '^rgba\\(' +
4368
+ RE_S +
4369
+ [INT_OR_PCT, INT_OR_PCT, INT_OR_PCT, FLOAT_OR_PCT].join(COMMA) +
4370
+ RE_S +
4371
+ '\\)$'
4372
+ );
4373
+
4374
+ var RE_HSL = new RegExp(
4375
+ '^hsla?\\(' + RE_S + [ANLGE, PCT, PCT].join(SEP) + ALPHA + '\\)$'
4376
+ );
4377
+ var RE_HSL_LEGACY = new RegExp(
4378
+ '^hsl?\\(' + RE_S + [ANLGE, PCT, PCT].join(COMMA) + RE_S + '\\)$'
4379
+ );
4380
+ var RE_HSLA_LEGACY =
4381
+ /^hsla\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/;
4382
+
4383
+ var RE_LAB = new RegExp(
4384
+ '^lab\\(' +
4385
+ RE_S +
4386
+ [FLOAT_OR_PCT, FLOAT_OR_PCT, FLOAT_OR_PCT].join(SEP) +
4387
+ ALPHA +
4388
+ '\\)$'
4389
+ );
4390
+ var RE_LCH = new RegExp(
4391
+ '^lch\\(' +
4392
+ RE_S +
4393
+ [FLOAT_OR_PCT, FLOAT_OR_PCT, ANLGE].join(SEP) +
4394
+ ALPHA +
4395
+ '\\)$'
4396
+ );
4397
+ var RE_OKLAB = new RegExp(
4398
+ '^oklab\\(' +
4399
+ RE_S +
4400
+ [FLOAT_OR_PCT, FLOAT_OR_PCT, FLOAT_OR_PCT].join(SEP) +
4401
+ ALPHA +
4402
+ '\\)$'
4403
+ );
4404
+ var RE_OKLCH = new RegExp(
4405
+ '^oklch\\(' +
4406
+ RE_S +
4407
+ [FLOAT_OR_PCT, FLOAT_OR_PCT, ANLGE].join(SEP) +
4408
+ ALPHA +
4409
+ '\\)$'
4410
+ );
4411
+
4412
+ var round$3 = Math.round;
4413
+
4414
+ var roundRGB = function (rgb) {
4415
+ return rgb.map(function (v, i) { return (i <= 2 ? limit(round$3(v), 0, 255) : v); });
4416
+ };
4417
+
4418
+ var percentToAbsolute = function (pct, min, max, signed) {
4419
+ if ( min === void 0 ) min = 0;
4420
+ if ( max === void 0 ) max = 100;
4421
+ if ( signed === void 0 ) signed = false;
4422
+
4423
+ if (typeof pct === 'string' && pct.endsWith('%')) {
4424
+ pct = parseFloat(pct.substring(0, pct.length - 1)) / 100;
4425
+ if (signed) {
4426
+ // signed percentages are in the range -100% to 100%
4427
+ pct = min + (pct + 1) * 0.5 * (max - min);
4428
+ } else {
4429
+ pct = min + pct * (max - min);
4430
+ }
4431
+ }
4432
+ return +pct;
4433
+ };
4434
+
4435
+ var noneToValue = function (v, noneValue) {
4436
+ return v === 'none' ? noneValue : v;
4437
+ };
4438
+
4439
+ var css2rgb = function (css) {
4440
+ css = css.toLowerCase().trim();
4441
+
4442
+ if (css === 'transparent') {
4443
+ return [0, 0, 0, 0];
4444
+ }
4445
+
4446
+ var m;
4447
+
4448
+ if (input.format.named) {
4449
+ try {
4450
+ return input.format.named(css);
4451
+ // eslint-disable-next-line
4452
+ } catch (e) {}
4453
+ }
4454
+
4455
+ // rgb(250 20 0) or rgb(250,20,0)
4456
+ if ((m = css.match(RE_RGB)) || (m = css.match(RE_RGB_LEGACY))) {
4457
+ var rgb = m.slice(1, 4);
4458
+ for (var i = 0; i < 3; i++) {
4459
+ rgb[i] = +percentToAbsolute(noneToValue(rgb[i], 0), 0, 255);
4460
+ }
4461
+ rgb = roundRGB(rgb);
4462
+ var alpha = m[4] !== undefined ? +percentToAbsolute(m[4], 0, 1) : 1;
4463
+ rgb[3] = alpha; // default alpha
4464
+ return rgb;
4465
+ }
4466
+
4467
+ // rgba(250,20,0,0.4)
4468
+ if ((m = css.match(RE_RGBA_LEGACY))) {
4469
+ var rgb$1 = m.slice(1, 5);
4470
+ for (var i$1 = 0; i$1 < 4; i$1++) {
4471
+ rgb$1[i$1] = +percentToAbsolute(rgb$1[i$1], 0, 255);
4472
+ }
4473
+ return rgb$1;
4474
+ }
4475
+
4476
+ // hsl(0,100%,50%)
4477
+ if ((m = css.match(RE_HSL)) || (m = css.match(RE_HSL_LEGACY))) {
4478
+ var hsl = m.slice(1, 4);
4479
+ hsl[0] = +noneToValue(hsl[0].replace('deg', ''), 0);
4480
+ hsl[1] = +percentToAbsolute(noneToValue(hsl[1], 0), 0, 100) * 0.01;
4481
+ hsl[2] = +percentToAbsolute(noneToValue(hsl[2], 0), 0, 100) * 0.01;
4482
+ var rgb$2 = roundRGB(hsl2rgb(hsl));
4483
+ var alpha$1 = m[4] !== undefined ? +percentToAbsolute(m[4], 0, 1) : 1;
4484
+ rgb$2[3] = alpha$1;
4485
+ return rgb$2;
4486
+ }
4487
+
4488
+ // hsla(0,100%,50%,0.5)
4489
+ if ((m = css.match(RE_HSLA_LEGACY))) {
4490
+ var hsl$1 = m.slice(1, 4);
4491
+ hsl$1[1] *= 0.01;
4492
+ hsl$1[2] *= 0.01;
4493
+ var rgb$3 = hsl2rgb(hsl$1);
4494
+ for (var i$2 = 0; i$2 < 3; i$2++) {
4495
+ rgb$3[i$2] = round$3(rgb$3[i$2]);
4496
+ }
4497
+ rgb$3[3] = +m[4]; // default alpha = 1
4498
+ return rgb$3;
4499
+ }
4500
+
4501
+ if ((m = css.match(RE_LAB))) {
4502
+ var lab = m.slice(1, 4);
4503
+ lab[0] = percentToAbsolute(noneToValue(lab[0], 0), 0, 100);
4504
+ lab[1] = percentToAbsolute(noneToValue(lab[1], 0), -125, 125, true);
4505
+ lab[2] = percentToAbsolute(noneToValue(lab[2], 0), -125, 125, true);
4506
+ // convert to D50 Lab whitepoint
4507
+ var wp = getLabWhitePoint();
4508
+ setLabWhitePoint('d50');
4509
+ var rgb$4 = roundRGB(lab2rgb(lab));
4510
+ // convert back to original Lab whitepoint
4511
+ setLabWhitePoint(wp);
4512
+ var alpha$2 = m[4] !== undefined ? +percentToAbsolute(m[4], 0, 1) : 1;
4513
+ rgb$4[3] = alpha$2;
4514
+ return rgb$4;
4515
+ }
4516
+
4517
+ if ((m = css.match(RE_LCH))) {
4518
+ var lch = m.slice(1, 4);
4519
+ lch[0] = percentToAbsolute(lch[0], 0, 100);
4520
+ lch[1] = percentToAbsolute(noneToValue(lch[1], 0), 0, 150, false);
4521
+ lch[2] = +noneToValue(lch[2].replace('deg', ''), 0);
4522
+ // convert to D50 Lab whitepoint
4523
+ var wp$1 = getLabWhitePoint();
4524
+ setLabWhitePoint('d50');
4525
+ var rgb$5 = roundRGB(lch2rgb(lch));
4526
+ // convert back to original Lab whitepoint
4527
+ setLabWhitePoint(wp$1);
4528
+ var alpha$3 = m[4] !== undefined ? +percentToAbsolute(m[4], 0, 1) : 1;
4529
+ rgb$5[3] = alpha$3;
4530
+ return rgb$5;
4531
+ }
4532
+
4533
+ if ((m = css.match(RE_OKLAB))) {
4534
+ var oklab = m.slice(1, 4);
4535
+ oklab[0] = percentToAbsolute(noneToValue(oklab[0], 0), 0, 1);
4536
+ oklab[1] = percentToAbsolute(noneToValue(oklab[1], 0), -0.4, 0.4, true);
4537
+ oklab[2] = percentToAbsolute(noneToValue(oklab[2], 0), -0.4, 0.4, true);
4538
+ var rgb$6 = roundRGB(oklab2rgb(oklab));
4539
+ var alpha$4 = m[4] !== undefined ? +percentToAbsolute(m[4], 0, 1) : 1;
4540
+ rgb$6[3] = alpha$4;
4541
+ return rgb$6;
4542
+ }
4543
+
4544
+ if ((m = css.match(RE_OKLCH))) {
4545
+ var oklch = m.slice(1, 4);
4546
+ oklch[0] = percentToAbsolute(noneToValue(oklch[0], 0), 0, 1);
4547
+ oklch[1] = percentToAbsolute(noneToValue(oklch[1], 0), 0, 0.4, false);
4548
+ oklch[2] = +noneToValue(oklch[2].replace('deg', ''), 0);
4549
+ var rgb$7 = roundRGB(oklch2rgb(oklch));
4550
+ var alpha$5 = m[4] !== undefined ? +percentToAbsolute(m[4], 0, 1) : 1;
4551
+ rgb$7[3] = alpha$5;
4552
+ return rgb$7;
4553
+ }
4554
+ };
4555
+
4556
+ css2rgb.test = function (s) {
4557
+ return (
4558
+ // modern
4559
+ RE_RGB.test(s) ||
4560
+ RE_HSL.test(s) ||
4561
+ RE_LAB.test(s) ||
4562
+ RE_LCH.test(s) ||
4563
+ RE_OKLAB.test(s) ||
4564
+ RE_OKLCH.test(s) ||
4565
+ // legacy
4566
+ RE_RGB_LEGACY.test(s) ||
4567
+ RE_RGBA_LEGACY.test(s) ||
4568
+ RE_HSL_LEGACY.test(s) ||
4569
+ RE_HSLA_LEGACY.test(s) ||
4570
+ s === 'transparent'
4571
+ );
4572
+ };
4573
+
4574
+ Color.prototype.css = function (mode) {
4575
+ return rgb2css(this._rgb, mode);
4576
+ };
4577
+
4578
+ var css = function () {
4579
+ var args = [], len = arguments.length;
4580
+ while ( len-- ) args[ len ] = arguments[ len ];
4581
+
4582
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['css']) ));
4583
+ };
4584
+ chroma.css = css;
4585
+
4586
+ input.format.css = css2rgb;
4587
+
4588
+ input.autodetect.push({
4589
+ p: 5,
4590
+ test: function (h) {
4591
+ var rest = [], len = arguments.length - 1;
4592
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
4593
+
4594
+ if (!rest.length && type(h) === 'string' && css2rgb.test(h)) {
4595
+ return 'css';
4596
+ }
4597
+ }
4598
+ });
4599
+
4600
+ input.format.gl = function () {
4601
+ var args = [], len = arguments.length;
4602
+ while ( len-- ) args[ len ] = arguments[ len ];
4603
+
4604
+ var rgb = unpack(args, 'rgba');
4605
+ rgb[0] *= 255;
4606
+ rgb[1] *= 255;
4607
+ rgb[2] *= 255;
4608
+ return rgb;
4609
+ };
4610
+
4611
+ var gl = function () {
4612
+ var args = [], len = arguments.length;
4613
+ while ( len-- ) args[ len ] = arguments[ len ];
4614
+
4615
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['gl']) ));
4616
+ };
4617
+ chroma.gl = gl;
4618
+
4619
+ Color.prototype.gl = function () {
4620
+ var rgb = this._rgb;
4621
+ return [rgb[0] / 255, rgb[1] / 255, rgb[2] / 255, rgb[3]];
4622
+ };
4623
+
4624
+ var floor$3 = Math.floor;
4625
+
4626
+ /*
4627
+ * this is basically just HSV with some minor tweaks
4628
+ *
4629
+ * hue.. [0..360]
4630
+ * chroma .. [0..1]
4631
+ * grayness .. [0..1]
4632
+ */
4633
+
4634
+ var hcg2rgb = function () {
4635
+ var assign, assign$1, assign$2, assign$3, assign$4, assign$5;
4636
+
4637
+ var args = [], len = arguments.length;
4638
+ while ( len-- ) args[ len ] = arguments[ len ];
4639
+ args = unpack(args, 'hcg');
4640
+ var h = args[0];
4641
+ var c = args[1];
4642
+ var _g = args[2];
4643
+ var r, g, b;
4644
+ _g = _g * 255;
4645
+ var _c = c * 255;
4646
+ if (c === 0) {
4647
+ r = g = b = _g;
4648
+ } else {
4649
+ if (h === 360) { h = 0; }
4650
+ if (h > 360) { h -= 360; }
4651
+ if (h < 0) { h += 360; }
4652
+ h /= 60;
4653
+ var i = floor$3(h);
4654
+ var f = h - i;
4655
+ var p = _g * (1 - c);
4656
+ var q = p + _c * (1 - f);
4657
+ var t = p + _c * f;
4658
+ var v = p + _c;
4659
+ switch (i) {
4660
+ case 0:
4661
+ (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]);
4662
+ break;
4663
+ case 1:
4664
+ (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]);
4665
+ break;
4666
+ case 2:
4667
+ (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]);
4668
+ break;
4669
+ case 3:
4670
+ (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]);
4671
+ break;
4672
+ case 4:
4673
+ (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]);
4674
+ break;
4675
+ case 5:
4676
+ (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]);
4677
+ break;
4678
+ }
4679
+ }
4680
+ return [r, g, b, args.length > 3 ? args[3] : 1];
4681
+ };
4682
+
4683
+ var rgb2hcg = function () {
4684
+ var args = [], len = arguments.length;
4685
+ while ( len-- ) args[ len ] = arguments[ len ];
4686
+
4687
+ var ref = unpack(args, 'rgb');
4688
+ var r = ref[0];
4689
+ var g = ref[1];
4690
+ var b = ref[2];
4691
+ var minRgb = min$3(r, g, b);
4692
+ var maxRgb = max$3(r, g, b);
4693
+ var delta = maxRgb - minRgb;
4694
+ var c = (delta * 100) / 255;
4695
+ var _g = (minRgb / (255 - delta)) * 100;
4696
+ var h;
4697
+ if (delta === 0) {
4698
+ h = Number.NaN;
4699
+ } else {
4700
+ if (r === maxRgb) { h = (g - b) / delta; }
4701
+ if (g === maxRgb) { h = 2 + (b - r) / delta; }
4702
+ if (b === maxRgb) { h = 4 + (r - g) / delta; }
4703
+ h *= 60;
4704
+ if (h < 0) { h += 360; }
4705
+ }
4706
+ return [h, c, _g];
4707
+ };
4708
+
4709
+ Color.prototype.hcg = function () {
4710
+ return rgb2hcg(this._rgb);
4711
+ };
4712
+
4713
+ var hcg$1 = function () {
4714
+ var args = [], len = arguments.length;
4715
+ while ( len-- ) args[ len ] = arguments[ len ];
4716
+
4717
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['hcg']) ));
4718
+ };
4719
+ chroma.hcg = hcg$1;
4720
+
4721
+ input.format.hcg = hcg2rgb;
4722
+
4723
+ input.autodetect.push({
4724
+ p: 1,
4725
+ test: function () {
4726
+ var args = [], len = arguments.length;
4727
+ while ( len-- ) args[ len ] = arguments[ len ];
4728
+
4729
+ args = unpack(args, 'hcg');
4730
+ if (type(args) === 'array' && args.length === 3) {
4731
+ return 'hcg';
4732
+ }
4733
+ }
4734
+ });
4735
+
4736
+ var RE_HEX = /^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;
4737
+ var RE_HEXA = /^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/;
4738
+
4739
+ var hex2rgb = function (hex) {
4740
+ if (hex.match(RE_HEX)) {
4741
+ // remove optional leading #
4742
+ if (hex.length === 4 || hex.length === 7) {
4743
+ hex = hex.substr(1);
4744
+ }
4745
+ // expand short-notation to full six-digit
4746
+ if (hex.length === 3) {
4747
+ hex = hex.split('');
4748
+ hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2];
4749
+ }
4750
+ var u = parseInt(hex, 16);
4751
+ var r = u >> 16;
4752
+ var g = (u >> 8) & 0xff;
4753
+ var b = u & 0xff;
4754
+ return [r, g, b, 1];
4755
+ }
4756
+
4757
+ // match rgba hex format, eg #FF000077
4758
+ if (hex.match(RE_HEXA)) {
4759
+ if (hex.length === 5 || hex.length === 9) {
4760
+ // remove optional leading #
4761
+ hex = hex.substr(1);
4762
+ }
4763
+ // expand short-notation to full eight-digit
4764
+ if (hex.length === 4) {
4765
+ hex = hex.split('');
4766
+ hex =
4767
+ hex[0] +
4768
+ hex[0] +
4769
+ hex[1] +
4770
+ hex[1] +
4771
+ hex[2] +
4772
+ hex[2] +
4773
+ hex[3] +
4774
+ hex[3];
4775
+ }
4776
+ var u$1 = parseInt(hex, 16);
4777
+ var r$1 = (u$1 >> 24) & 0xff;
4778
+ var g$1 = (u$1 >> 16) & 0xff;
4779
+ var b$1 = (u$1 >> 8) & 0xff;
4780
+ var a = Math.round(((u$1 & 0xff) / 0xff) * 100) / 100;
4781
+ return [r$1, g$1, b$1, a];
4782
+ }
4783
+
4784
+ // we used to check for css colors here
4785
+ // if _input.css? and rgb = _input.css hex
4786
+ // return rgb
4787
+
4788
+ throw new Error(("unknown hex color: " + hex));
4789
+ };
4790
+
4791
+ var round$2 = Math.round;
4792
+
4793
+ var rgb2hex = function () {
4794
+ var args = [], len = arguments.length;
4795
+ while ( len-- ) args[ len ] = arguments[ len ];
4796
+
4797
+ var ref = unpack(args, 'rgba');
4798
+ var r = ref[0];
4799
+ var g = ref[1];
4800
+ var b = ref[2];
4801
+ var a = ref[3];
4802
+ var mode = last(args) || 'auto';
4803
+ if (a === undefined) { a = 1; }
4804
+ if (mode === 'auto') {
4805
+ mode = a < 1 ? 'rgba' : 'rgb';
4806
+ }
4807
+ r = round$2(r);
4808
+ g = round$2(g);
4809
+ b = round$2(b);
4810
+ var u = (r << 16) | (g << 8) | b;
4811
+ var str = '000000' + u.toString(16); //#.toUpperCase();
4812
+ str = str.substr(str.length - 6);
4813
+ var hxa = '0' + round$2(a * 255).toString(16);
4814
+ hxa = hxa.substr(hxa.length - 2);
4815
+ switch (mode.toLowerCase()) {
4816
+ case 'rgba':
4817
+ return ("#" + str + hxa);
4818
+ case 'argb':
4819
+ return ("#" + hxa + str);
4820
+ default:
4821
+ return ("#" + str);
4822
+ }
4823
+ };
4824
+
4825
+ Color.prototype.hex = function (mode) {
4826
+ return rgb2hex(this._rgb, mode);
4827
+ };
4828
+
4829
+ var hex = function () {
4830
+ var args = [], len = arguments.length;
4831
+ while ( len-- ) args[ len ] = arguments[ len ];
4832
+
4833
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['hex']) ));
4834
+ };
4835
+ chroma.hex = hex;
4836
+
4837
+ input.format.hex = hex2rgb;
4838
+ input.autodetect.push({
4839
+ p: 4,
4840
+ test: function (h) {
4841
+ var rest = [], len = arguments.length - 1;
4842
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
4843
+
4844
+ if (
4845
+ !rest.length &&
4846
+ type(h) === 'string' &&
4847
+ [3, 4, 5, 6, 7, 8, 9].indexOf(h.length) >= 0
4848
+ ) {
4849
+ return 'hex';
4850
+ }
4851
+ }
4852
+ });
4853
+
4854
+ var cos$3 = Math.cos;
4855
+
4856
+ /*
4857
+ * hue [0..360]
4858
+ * saturation [0..1]
4859
+ * intensity [0..1]
4860
+ */
4861
+ var hsi2rgb = function () {
4862
+ var args = [], len = arguments.length;
4863
+ while ( len-- ) args[ len ] = arguments[ len ];
4864
+
4865
+ /*
4866
+ borrowed from here:
4867
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp
4868
+ */
4869
+ args = unpack(args, 'hsi');
4870
+ var h = args[0];
4871
+ var s = args[1];
4872
+ var i = args[2];
4873
+ var r, g, b;
4874
+
4875
+ if (isNaN(h)) { h = 0; }
4876
+ if (isNaN(s)) { s = 0; }
4877
+ // normalize hue
4878
+ if (h > 360) { h -= 360; }
4879
+ if (h < 0) { h += 360; }
4880
+ h /= 360;
4881
+ if (h < 1 / 3) {
4882
+ b = (1 - s) / 3;
4883
+ r = (1 + (s * cos$3(TWOPI * h)) / cos$3(PITHIRD - TWOPI * h)) / 3;
4884
+ g = 1 - (b + r);
4885
+ } else if (h < 2 / 3) {
4886
+ h -= 1 / 3;
4887
+ r = (1 - s) / 3;
4888
+ g = (1 + (s * cos$3(TWOPI * h)) / cos$3(PITHIRD - TWOPI * h)) / 3;
4889
+ b = 1 - (r + g);
4890
+ } else {
4891
+ h -= 2 / 3;
4892
+ g = (1 - s) / 3;
4893
+ b = (1 + (s * cos$3(TWOPI * h)) / cos$3(PITHIRD - TWOPI * h)) / 3;
4894
+ r = 1 - (g + b);
4895
+ }
4896
+ r = limit(i * r * 3);
4897
+ g = limit(i * g * 3);
4898
+ b = limit(i * b * 3);
4899
+ return [r * 255, g * 255, b * 255, args.length > 3 ? args[3] : 1];
4900
+ };
4901
+
4902
+ var min$2 = Math.min;
4903
+ var sqrt$3 = Math.sqrt;
4904
+ var acos = Math.acos;
4905
+
4906
+ var rgb2hsi = function () {
4907
+ var args = [], len = arguments.length;
4908
+ while ( len-- ) args[ len ] = arguments[ len ];
4909
+
4910
+ /*
4911
+ borrowed from here:
4912
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp
4913
+ */
4914
+ var ref = unpack(args, 'rgb');
4915
+ var r = ref[0];
4916
+ var g = ref[1];
4917
+ var b = ref[2];
4918
+ r /= 255;
4919
+ g /= 255;
4920
+ b /= 255;
4921
+ var h;
4922
+ var min_ = min$2(r, g, b);
4923
+ var i = (r + g + b) / 3;
4924
+ var s = i > 0 ? 1 - min_ / i : 0;
4925
+ if (s === 0) {
4926
+ h = NaN;
4927
+ } else {
4928
+ h = (r - g + (r - b)) / 2;
4929
+ h /= sqrt$3((r - g) * (r - g) + (r - b) * (g - b));
4930
+ h = acos(h);
4931
+ if (b > g) {
4932
+ h = TWOPI - h;
4933
+ }
4934
+ h /= TWOPI;
4935
+ }
4936
+ return [h * 360, s, i];
4937
+ };
4938
+
4939
+ Color.prototype.hsi = function () {
4940
+ return rgb2hsi(this._rgb);
4941
+ };
4942
+
4943
+ var hsi$1 = function () {
4944
+ var args = [], len = arguments.length;
4945
+ while ( len-- ) args[ len ] = arguments[ len ];
4946
+
4947
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['hsi']) ));
4948
+ };
4949
+ chroma.hsi = hsi$1;
4950
+
4951
+ input.format.hsi = hsi2rgb;
4952
+
4953
+ input.autodetect.push({
4954
+ p: 2,
4955
+ test: function () {
4956
+ var args = [], len = arguments.length;
4957
+ while ( len-- ) args[ len ] = arguments[ len ];
4958
+
4959
+ args = unpack(args, 'hsi');
4960
+ if (type(args) === 'array' && args.length === 3) {
4961
+ return 'hsi';
4962
+ }
4963
+ }
4964
+ });
4965
+
4966
+ Color.prototype.hsl = function () {
4967
+ return rgb2hsl$1(this._rgb);
4968
+ };
4969
+
4970
+ var hsl$1 = function () {
4971
+ var args = [], len = arguments.length;
4972
+ while ( len-- ) args[ len ] = arguments[ len ];
4973
+
4974
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['hsl']) ));
4975
+ };
4976
+ chroma.hsl = hsl$1;
4977
+
4978
+ input.format.hsl = hsl2rgb;
4979
+
4980
+ input.autodetect.push({
4981
+ p: 2,
4982
+ test: function () {
4983
+ var args = [], len = arguments.length;
4984
+ while ( len-- ) args[ len ] = arguments[ len ];
4985
+
4986
+ args = unpack(args, 'hsl');
4987
+ if (type(args) === 'array' && args.length === 3) {
4988
+ return 'hsl';
4989
+ }
4990
+ }
4991
+ });
4992
+
4993
+ var floor$2 = Math.floor;
4994
+
4995
+ var hsv2rgb = function () {
4996
+ var assign, assign$1, assign$2, assign$3, assign$4, assign$5;
4997
+
4998
+ var args = [], len = arguments.length;
4999
+ while ( len-- ) args[ len ] = arguments[ len ];
5000
+ args = unpack(args, 'hsv');
5001
+ var h = args[0];
5002
+ var s = args[1];
5003
+ var v = args[2];
5004
+ var r, g, b;
5005
+ v *= 255;
5006
+ if (s === 0) {
5007
+ r = g = b = v;
5008
+ } else {
5009
+ if (h === 360) { h = 0; }
5010
+ if (h > 360) { h -= 360; }
5011
+ if (h < 0) { h += 360; }
5012
+ h /= 60;
5013
+
5014
+ var i = floor$2(h);
5015
+ var f = h - i;
5016
+ var p = v * (1 - s);
5017
+ var q = v * (1 - s * f);
5018
+ var t = v * (1 - s * (1 - f));
5019
+
5020
+ switch (i) {
5021
+ case 0:
5022
+ (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]);
5023
+ break;
5024
+ case 1:
5025
+ (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]);
5026
+ break;
5027
+ case 2:
5028
+ (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]);
5029
+ break;
5030
+ case 3:
5031
+ (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]);
5032
+ break;
5033
+ case 4:
5034
+ (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]);
5035
+ break;
5036
+ case 5:
5037
+ (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]);
5038
+ break;
5039
+ }
5040
+ }
5041
+ return [r, g, b, args.length > 3 ? args[3] : 1];
5042
+ };
5043
+
5044
+ var min$1 = Math.min;
5045
+ var max$1 = Math.max;
5046
+
5047
+ /*
5048
+ * supported arguments:
5049
+ * - rgb2hsv(r,g,b)
5050
+ * - rgb2hsv([r,g,b])
5051
+ * - rgb2hsv({r,g,b})
5052
+ */
5053
+ var rgb2hsl = function () {
5054
+ var args = [], len = arguments.length;
5055
+ while ( len-- ) args[ len ] = arguments[ len ];
5056
+
5057
+ args = unpack(args, 'rgb');
5058
+ var r = args[0];
5059
+ var g = args[1];
5060
+ var b = args[2];
5061
+ var min_ = min$1(r, g, b);
5062
+ var max_ = max$1(r, g, b);
5063
+ var delta = max_ - min_;
5064
+ var h, s, v;
5065
+ v = max_ / 255.0;
5066
+ if (max_ === 0) {
5067
+ h = Number.NaN;
5068
+ s = 0;
5069
+ } else {
5070
+ s = delta / max_;
5071
+ if (r === max_) { h = (g - b) / delta; }
5072
+ if (g === max_) { h = 2 + (b - r) / delta; }
5073
+ if (b === max_) { h = 4 + (r - g) / delta; }
5074
+ h *= 60;
5075
+ if (h < 0) { h += 360; }
5076
+ }
5077
+ return [h, s, v];
5078
+ };
5079
+
5080
+ Color.prototype.hsv = function () {
5081
+ return rgb2hsl(this._rgb);
5082
+ };
5083
+
5084
+ var hsv$1 = function () {
5085
+ var args = [], len = arguments.length;
5086
+ while ( len-- ) args[ len ] = arguments[ len ];
5087
+
5088
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['hsv']) ));
5089
+ };
5090
+ chroma.hsv = hsv$1;
5091
+
5092
+ input.format.hsv = hsv2rgb;
5093
+
5094
+ input.autodetect.push({
5095
+ p: 2,
5096
+ test: function () {
5097
+ var args = [], len = arguments.length;
5098
+ while ( len-- ) args[ len ] = arguments[ len ];
5099
+
5100
+ args = unpack(args, 'hsv');
5101
+ if (type(args) === 'array' && args.length === 3) {
5102
+ return 'hsv';
5103
+ }
5104
+ }
5105
+ });
5106
+
5107
+ Color.prototype.lab = function () {
5108
+ return rgb2lab(this._rgb);
5109
+ };
5110
+
5111
+ var lab$1 = function () {
5112
+ var args = [], len = arguments.length;
5113
+ while ( len-- ) args[ len ] = arguments[ len ];
5114
+
5115
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['lab']) ));
5116
+ };
5117
+ Object.assign(chroma, { lab: lab$1, getLabWhitePoint: getLabWhitePoint, setLabWhitePoint: setLabWhitePoint });
5118
+
5119
+ input.format.lab = lab2rgb;
5120
+
5121
+ input.autodetect.push({
5122
+ p: 2,
5123
+ test: function () {
5124
+ var args = [], len = arguments.length;
5125
+ while ( len-- ) args[ len ] = arguments[ len ];
5126
+
5127
+ args = unpack(args, 'lab');
5128
+ if (type(args) === 'array' && args.length === 3) {
5129
+ return 'lab';
5130
+ }
5131
+ }
5132
+ });
5133
+
5134
+ var hcl2rgb = function () {
5135
+ var args = [], len = arguments.length;
5136
+ while ( len-- ) args[ len ] = arguments[ len ];
5137
+
5138
+ var hcl = reverse3(unpack(args, 'hcl'));
5139
+ return lch2rgb.apply(void 0, hcl);
5140
+ };
5141
+
5142
+ Color.prototype.lch = function () {
5143
+ return rgb2lch(this._rgb);
5144
+ };
5145
+ Color.prototype.hcl = function () {
5146
+ return reverse3(rgb2lch(this._rgb));
5147
+ };
5148
+
5149
+ var lch$1 = function () {
5150
+ var args = [], len = arguments.length;
5151
+ while ( len-- ) args[ len ] = arguments[ len ];
5152
+
5153
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['lch']) ));
5154
+ };
5155
+ var hcl = function () {
5156
+ var args = [], len = arguments.length;
5157
+ while ( len-- ) args[ len ] = arguments[ len ];
5158
+
5159
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['hcl']) ));
5160
+ };
5161
+
5162
+ Object.assign(chroma, { lch: lch$1, hcl: hcl });
5163
+
5164
+ input.format.lch = lch2rgb;
5165
+ input.format.hcl = hcl2rgb;
5166
+ ['lch', 'hcl'].forEach(function (m) { return input.autodetect.push({
5167
+ p: 2,
5168
+ test: function () {
5169
+ var args = [], len = arguments.length;
5170
+ while ( len-- ) args[ len ] = arguments[ len ];
5171
+
5172
+ args = unpack(args, m);
5173
+ if (type(args) === 'array' && args.length === 3) {
5174
+ return m;
5175
+ }
5176
+ }
5177
+ }); }
5178
+ );
5179
+
5180
+ var num2rgb = function (num) {
5181
+ if (type(num) == 'number' && num >= 0 && num <= 0xffffff) {
5182
+ var r = num >> 16;
5183
+ var g = (num >> 8) & 0xff;
5184
+ var b = num & 0xff;
5185
+ return [r, g, b, 1];
5186
+ }
5187
+ throw new Error('unknown num color: ' + num);
5188
+ };
5189
+
5190
+ var rgb2num = function () {
5191
+ var args = [], len = arguments.length;
5192
+ while ( len-- ) args[ len ] = arguments[ len ];
5193
+
5194
+ var ref = unpack(args, 'rgb');
5195
+ var r = ref[0];
5196
+ var g = ref[1];
5197
+ var b = ref[2];
5198
+ return (r << 16) + (g << 8) + b;
5199
+ };
5200
+
5201
+ Color.prototype.num = function () {
5202
+ return rgb2num(this._rgb);
5203
+ };
5204
+
5205
+ var num$1 = function () {
5206
+ var args = [], len = arguments.length;
5207
+ while ( len-- ) args[ len ] = arguments[ len ];
5208
+
5209
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['num']) ));
5210
+ };
5211
+
5212
+ Object.assign(chroma, { num: num$1 });
5213
+
5214
+ input.format.num = num2rgb;
5215
+
5216
+ input.autodetect.push({
5217
+ p: 5,
5218
+ test: function () {
5219
+ var args = [], len = arguments.length;
5220
+ while ( len-- ) args[ len ] = arguments[ len ];
5221
+
5222
+ if (
5223
+ args.length === 1 &&
5224
+ type(args[0]) === 'number' &&
5225
+ args[0] >= 0 &&
5226
+ args[0] <= 0xffffff
5227
+ ) {
5228
+ return 'num';
5229
+ }
5230
+ }
5231
+ });
5232
+
5233
+ var round$1 = Math.round;
5234
+
5235
+ Color.prototype.rgb = function (rnd) {
5236
+ if ( rnd === void 0 ) rnd = true;
5237
+
5238
+ if (rnd === false) { return this._rgb.slice(0, 3); }
5239
+ return this._rgb.slice(0, 3).map(round$1);
5240
+ };
5241
+
5242
+ Color.prototype.rgba = function (rnd) {
5243
+ if ( rnd === void 0 ) rnd = true;
5244
+
5245
+ return this._rgb.slice(0, 4).map(function (v, i) {
5246
+ return i < 3 ? (rnd === false ? v : round$1(v)) : v;
5247
+ });
5248
+ };
5249
+
5250
+ var rgb$1 = function () {
5251
+ var args = [], len = arguments.length;
5252
+ while ( len-- ) args[ len ] = arguments[ len ];
5253
+
5254
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['rgb']) ));
5255
+ };
5256
+ Object.assign(chroma, { rgb: rgb$1 });
5257
+
5258
+ input.format.rgb = function () {
5259
+ var args = [], len = arguments.length;
5260
+ while ( len-- ) args[ len ] = arguments[ len ];
5261
+
5262
+ var rgba = unpack(args, 'rgba');
5263
+ if (rgba[3] === undefined) { rgba[3] = 1; }
5264
+ return rgba;
5265
+ };
5266
+
5267
+ input.autodetect.push({
5268
+ p: 3,
5269
+ test: function () {
5270
+ var args = [], len = arguments.length;
5271
+ while ( len-- ) args[ len ] = arguments[ len ];
5272
+
5273
+ args = unpack(args, 'rgba');
5274
+ if (
5275
+ type(args) === 'array' &&
5276
+ (args.length === 3 ||
5277
+ (args.length === 4 &&
5278
+ type(args[3]) == 'number' &&
5279
+ args[3] >= 0 &&
5280
+ args[3] <= 1))
5281
+ ) {
5282
+ return 'rgb';
5283
+ }
5284
+ }
5285
+ });
5286
+
5287
+ /*
5288
+ * Based on implementation by Neil Bartlett
5289
+ * https://github.com/neilbartlett/color-temperature
5290
+ */
5291
+
5292
+ var log$1 = Math.log;
5293
+
5294
+ var temperature2rgb = function (kelvin) {
5295
+ var temp = kelvin / 100;
5296
+ var r, g, b;
5297
+ if (temp < 66) {
5298
+ r = 255;
5299
+ g =
5300
+ temp < 6
5301
+ ? 0
5302
+ : -155.25485562709179 -
5303
+ 0.44596950469579133 * (g = temp - 2) +
5304
+ 104.49216199393888 * log$1(g);
5305
+ b =
5306
+ temp < 20
5307
+ ? 0
5308
+ : -254.76935184120902 +
5309
+ 0.8274096064007395 * (b = temp - 10) +
5310
+ 115.67994401066147 * log$1(b);
5311
+ } else {
5312
+ r =
5313
+ 351.97690566805693 +
5314
+ 0.114206453784165 * (r = temp - 55) -
5315
+ 40.25366309332127 * log$1(r);
5316
+ g =
5317
+ 325.4494125711974 +
5318
+ 0.07943456536662342 * (g = temp - 50) -
5319
+ 28.0852963507957 * log$1(g);
5320
+ b = 255;
5321
+ }
5322
+ return [r, g, b, 1];
5323
+ };
5324
+
5325
+ /*
5326
+ * Based on implementation by Neil Bartlett
5327
+ * https://github.com/neilbartlett/color-temperature
5328
+ **/
5329
+
5330
+ var round = Math.round;
5331
+
5332
+ var rgb2temperature = function () {
5333
+ var args = [], len = arguments.length;
5334
+ while ( len-- ) args[ len ] = arguments[ len ];
5335
+
5336
+ var rgb = unpack(args, 'rgb');
5337
+ var r = rgb[0],
5338
+ b = rgb[2];
5339
+ var minTemp = 1000;
5340
+ var maxTemp = 40000;
5341
+ var eps = 0.4;
5342
+ var temp;
5343
+ while (maxTemp - minTemp > eps) {
5344
+ temp = (maxTemp + minTemp) * 0.5;
5345
+ var rgb$1 = temperature2rgb(temp);
5346
+ if (rgb$1[2] / rgb$1[0] >= b / r) {
5347
+ maxTemp = temp;
5348
+ } else {
5349
+ minTemp = temp;
5350
+ }
5351
+ }
5352
+ return round(temp);
5353
+ };
5354
+
5355
+ Color.prototype.temp =
5356
+ Color.prototype.kelvin =
5357
+ Color.prototype.temperature =
5358
+ function () {
5359
+ return rgb2temperature(this._rgb);
5360
+ };
5361
+
5362
+ var temp = function () {
5363
+ var args = [], len = arguments.length;
5364
+ while ( len-- ) args[ len ] = arguments[ len ];
5365
+
5366
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['temp']) ));
5367
+ };
5368
+ Object.assign(chroma, { temp: temp, kelvin: temp, temperature: temp });
5369
+
5370
+ input.format.temp =
5371
+ input.format.kelvin =
5372
+ input.format.temperature =
5373
+ temperature2rgb;
5374
+
5375
+ Color.prototype.oklab = function () {
5376
+ return rgb2oklab(this._rgb);
5377
+ };
5378
+
5379
+ var oklab$1 = function () {
5380
+ var args = [], len = arguments.length;
5381
+ while ( len-- ) args[ len ] = arguments[ len ];
5382
+
5383
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['oklab']) ));
5384
+ };
5385
+ Object.assign(chroma, { oklab: oklab$1 });
5386
+
5387
+ input.format.oklab = oklab2rgb;
5388
+
5389
+ input.autodetect.push({
5390
+ p: 2,
5391
+ test: function () {
5392
+ var args = [], len = arguments.length;
5393
+ while ( len-- ) args[ len ] = arguments[ len ];
5394
+
5395
+ args = unpack(args, 'oklab');
5396
+ if (type(args) === 'array' && args.length === 3) {
5397
+ return 'oklab';
5398
+ }
5399
+ }
5400
+ });
5401
+
5402
+ Color.prototype.oklch = function () {
5403
+ return rgb2oklch(this._rgb);
5404
+ };
5405
+
5406
+ var oklch$1 = function () {
5407
+ var args = [], len = arguments.length;
5408
+ while ( len-- ) args[ len ] = arguments[ len ];
5409
+
5410
+ return new (Function.prototype.bind.apply( Color, [ null ].concat( args, ['oklch']) ));
5411
+ };
5412
+ Object.assign(chroma, { oklch: oklch$1 });
5413
+
5414
+ input.format.oklch = oklch2rgb;
5415
+
5416
+ input.autodetect.push({
5417
+ p: 2,
5418
+ test: function () {
5419
+ var args = [], len = arguments.length;
5420
+ while ( len-- ) args[ len ] = arguments[ len ];
5421
+
5422
+ args = unpack(args, 'oklch');
5423
+ if (type(args) === 'array' && args.length === 3) {
5424
+ return 'oklch';
5425
+ }
5426
+ }
5427
+ });
5428
+
5429
+ /**
5430
+ X11 color names
5431
+
5432
+ http://www.w3.org/TR/css3-color/#svg-color
5433
+ */
5434
+
5435
+ var w3cx11 = {
5436
+ aliceblue: '#f0f8ff',
5437
+ antiquewhite: '#faebd7',
5438
+ aqua: '#00ffff',
5439
+ aquamarine: '#7fffd4',
5440
+ azure: '#f0ffff',
5441
+ beige: '#f5f5dc',
5442
+ bisque: '#ffe4c4',
5443
+ black: '#000000',
5444
+ blanchedalmond: '#ffebcd',
5445
+ blue: '#0000ff',
5446
+ blueviolet: '#8a2be2',
5447
+ brown: '#a52a2a',
5448
+ burlywood: '#deb887',
5449
+ cadetblue: '#5f9ea0',
5450
+ chartreuse: '#7fff00',
5451
+ chocolate: '#d2691e',
5452
+ coral: '#ff7f50',
5453
+ cornflowerblue: '#6495ed',
5454
+ cornsilk: '#fff8dc',
5455
+ crimson: '#dc143c',
5456
+ cyan: '#00ffff',
5457
+ darkblue: '#00008b',
5458
+ darkcyan: '#008b8b',
5459
+ darkgoldenrod: '#b8860b',
5460
+ darkgray: '#a9a9a9',
5461
+ darkgreen: '#006400',
5462
+ darkgrey: '#a9a9a9',
5463
+ darkkhaki: '#bdb76b',
5464
+ darkmagenta: '#8b008b',
5465
+ darkolivegreen: '#556b2f',
5466
+ darkorange: '#ff8c00',
5467
+ darkorchid: '#9932cc',
5468
+ darkred: '#8b0000',
5469
+ darksalmon: '#e9967a',
5470
+ darkseagreen: '#8fbc8f',
5471
+ darkslateblue: '#483d8b',
5472
+ darkslategray: '#2f4f4f',
5473
+ darkslategrey: '#2f4f4f',
5474
+ darkturquoise: '#00ced1',
5475
+ darkviolet: '#9400d3',
5476
+ deeppink: '#ff1493',
5477
+ deepskyblue: '#00bfff',
5478
+ dimgray: '#696969',
5479
+ dimgrey: '#696969',
5480
+ dodgerblue: '#1e90ff',
5481
+ firebrick: '#b22222',
5482
+ floralwhite: '#fffaf0',
5483
+ forestgreen: '#228b22',
5484
+ fuchsia: '#ff00ff',
5485
+ gainsboro: '#dcdcdc',
5486
+ ghostwhite: '#f8f8ff',
5487
+ gold: '#ffd700',
5488
+ goldenrod: '#daa520',
5489
+ gray: '#808080',
5490
+ green: '#008000',
5491
+ greenyellow: '#adff2f',
5492
+ grey: '#808080',
5493
+ honeydew: '#f0fff0',
5494
+ hotpink: '#ff69b4',
5495
+ indianred: '#cd5c5c',
5496
+ indigo: '#4b0082',
5497
+ ivory: '#fffff0',
5498
+ khaki: '#f0e68c',
5499
+ laserlemon: '#ffff54',
5500
+ lavender: '#e6e6fa',
5501
+ lavenderblush: '#fff0f5',
5502
+ lawngreen: '#7cfc00',
5503
+ lemonchiffon: '#fffacd',
5504
+ lightblue: '#add8e6',
5505
+ lightcoral: '#f08080',
5506
+ lightcyan: '#e0ffff',
5507
+ lightgoldenrod: '#fafad2',
5508
+ lightgoldenrodyellow: '#fafad2',
5509
+ lightgray: '#d3d3d3',
5510
+ lightgreen: '#90ee90',
5511
+ lightgrey: '#d3d3d3',
5512
+ lightpink: '#ffb6c1',
5513
+ lightsalmon: '#ffa07a',
5514
+ lightseagreen: '#20b2aa',
5515
+ lightskyblue: '#87cefa',
5516
+ lightslategray: '#778899',
5517
+ lightslategrey: '#778899',
5518
+ lightsteelblue: '#b0c4de',
5519
+ lightyellow: '#ffffe0',
5520
+ lime: '#00ff00',
5521
+ limegreen: '#32cd32',
5522
+ linen: '#faf0e6',
5523
+ magenta: '#ff00ff',
5524
+ maroon: '#800000',
5525
+ maroon2: '#7f0000',
5526
+ maroon3: '#b03060',
5527
+ mediumaquamarine: '#66cdaa',
5528
+ mediumblue: '#0000cd',
5529
+ mediumorchid: '#ba55d3',
5530
+ mediumpurple: '#9370db',
5531
+ mediumseagreen: '#3cb371',
5532
+ mediumslateblue: '#7b68ee',
5533
+ mediumspringgreen: '#00fa9a',
5534
+ mediumturquoise: '#48d1cc',
5535
+ mediumvioletred: '#c71585',
5536
+ midnightblue: '#191970',
5537
+ mintcream: '#f5fffa',
5538
+ mistyrose: '#ffe4e1',
5539
+ moccasin: '#ffe4b5',
5540
+ navajowhite: '#ffdead',
5541
+ navy: '#000080',
5542
+ oldlace: '#fdf5e6',
5543
+ olive: '#808000',
5544
+ olivedrab: '#6b8e23',
5545
+ orange: '#ffa500',
5546
+ orangered: '#ff4500',
5547
+ orchid: '#da70d6',
5548
+ palegoldenrod: '#eee8aa',
5549
+ palegreen: '#98fb98',
5550
+ paleturquoise: '#afeeee',
5551
+ palevioletred: '#db7093',
5552
+ papayawhip: '#ffefd5',
5553
+ peachpuff: '#ffdab9',
5554
+ peru: '#cd853f',
5555
+ pink: '#ffc0cb',
5556
+ plum: '#dda0dd',
5557
+ powderblue: '#b0e0e6',
5558
+ purple: '#800080',
5559
+ purple2: '#7f007f',
5560
+ purple3: '#a020f0',
5561
+ rebeccapurple: '#663399',
5562
+ red: '#ff0000',
5563
+ rosybrown: '#bc8f8f',
5564
+ royalblue: '#4169e1',
5565
+ saddlebrown: '#8b4513',
5566
+ salmon: '#fa8072',
5567
+ sandybrown: '#f4a460',
5568
+ seagreen: '#2e8b57',
5569
+ seashell: '#fff5ee',
5570
+ sienna: '#a0522d',
5571
+ silver: '#c0c0c0',
5572
+ skyblue: '#87ceeb',
5573
+ slateblue: '#6a5acd',
5574
+ slategray: '#708090',
5575
+ slategrey: '#708090',
5576
+ snow: '#fffafa',
5577
+ springgreen: '#00ff7f',
5578
+ steelblue: '#4682b4',
5579
+ tan: '#d2b48c',
5580
+ teal: '#008080',
5581
+ thistle: '#d8bfd8',
5582
+ tomato: '#ff6347',
5583
+ turquoise: '#40e0d0',
5584
+ violet: '#ee82ee',
5585
+ wheat: '#f5deb3',
5586
+ white: '#ffffff',
5587
+ whitesmoke: '#f5f5f5',
5588
+ yellow: '#ffff00',
5589
+ yellowgreen: '#9acd32'
5590
+ };
5591
+
5592
+ Color.prototype.name = function () {
5593
+ var hex = rgb2hex(this._rgb, 'rgb');
5594
+ for (var i = 0, list = Object.keys(w3cx11); i < list.length; i += 1) {
5595
+ var n = list[i];
5596
+
5597
+ if (w3cx11[n] === hex) { return n.toLowerCase(); }
5598
+ }
5599
+ return hex;
5600
+ };
5601
+
5602
+ input.format.named = function (name) {
5603
+ name = name.toLowerCase();
5604
+ if (w3cx11[name]) { return hex2rgb(w3cx11[name]); }
5605
+ throw new Error('unknown color name: ' + name);
5606
+ };
5607
+
5608
+ input.autodetect.push({
5609
+ p: 5,
5610
+ test: function (h) {
5611
+ var rest = [], len = arguments.length - 1;
5612
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
5613
+
5614
+ if (!rest.length && type(h) === 'string' && w3cx11[h.toLowerCase()]) {
5615
+ return 'named';
5616
+ }
5617
+ }
5618
+ });
5619
+
5620
+ Color.prototype.alpha = function (a, mutate) {
5621
+ if ( mutate === void 0 ) mutate = false;
5622
+
5623
+ if (a !== undefined && type(a) === 'number') {
5624
+ if (mutate) {
5625
+ this._rgb[3] = a;
5626
+ return this;
5627
+ }
5628
+ return new Color([this._rgb[0], this._rgb[1], this._rgb[2], a], 'rgb');
5629
+ }
5630
+ return this._rgb[3];
5631
+ };
5632
+
5633
+ Color.prototype.clipped = function () {
5634
+ return this._rgb._clipped || false;
5635
+ };
5636
+
5637
+ Color.prototype.darken = function (amount) {
5638
+ if ( amount === void 0 ) amount = 1;
5639
+
5640
+ var me = this;
5641
+ var lab = me.lab();
5642
+ lab[0] -= labConstants.Kn * amount;
5643
+ return new Color(lab, 'lab').alpha(me.alpha(), true);
5644
+ };
5645
+
5646
+ Color.prototype.brighten = function (amount) {
5647
+ if ( amount === void 0 ) amount = 1;
5648
+
5649
+ return this.darken(-amount);
5650
+ };
5651
+
5652
+ Color.prototype.darker = Color.prototype.darken;
5653
+ Color.prototype.brighter = Color.prototype.brighten;
5654
+
5655
+ Color.prototype.get = function (mc) {
5656
+ var ref = mc.split('.');
5657
+ var mode = ref[0];
5658
+ var channel = ref[1];
5659
+ var src = this[mode]();
5660
+ if (channel) {
5661
+ var i = mode.indexOf(channel) - (mode.substr(0, 2) === 'ok' ? 2 : 0);
5662
+ if (i > -1) { return src[i]; }
5663
+ throw new Error(("unknown channel " + channel + " in mode " + mode));
5664
+ } else {
5665
+ return src;
5666
+ }
5667
+ };
5668
+
5669
+ var pow$6 = Math.pow;
5670
+
5671
+ var EPS = 1e-7;
5672
+ var MAX_ITER = 20;
5673
+
5674
+ Color.prototype.luminance = function (lum, mode) {
5675
+ if ( mode === void 0 ) mode = 'rgb';
5676
+
5677
+ if (lum !== undefined && type(lum) === 'number') {
5678
+ if (lum === 0) {
5679
+ // return pure black
5680
+ return new Color([0, 0, 0, this._rgb[3]], 'rgb');
5681
+ }
5682
+ if (lum === 1) {
5683
+ // return pure white
5684
+ return new Color([255, 255, 255, this._rgb[3]], 'rgb');
5685
+ }
5686
+ // compute new color using...
5687
+ var cur_lum = this.luminance();
5688
+ var max_iter = MAX_ITER;
5689
+
5690
+ var test = function (low, high) {
5691
+ var mid = low.interpolate(high, 0.5, mode);
5692
+ var lm = mid.luminance();
5693
+ if (Math.abs(lum - lm) < EPS || !max_iter--) {
5694
+ // close enough
5695
+ return mid;
5696
+ }
5697
+ return lm > lum ? test(low, mid) : test(mid, high);
5698
+ };
5699
+
5700
+ var rgb = (
5701
+ cur_lum > lum
5702
+ ? test(new Color([0, 0, 0]), this)
5703
+ : test(this, new Color([255, 255, 255]))
5704
+ ).rgb();
5705
+ return new Color(rgb.concat( [this._rgb[3]]));
5706
+ }
5707
+ return rgb2luminance.apply(void 0, this._rgb.slice(0, 3));
5708
+ };
5709
+
5710
+ var rgb2luminance = function (r, g, b) {
5711
+ // relative luminance
5712
+ // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef
5713
+ r = luminance_x(r);
5714
+ g = luminance_x(g);
5715
+ b = luminance_x(b);
5716
+ return 0.2126 * r + 0.7152 * g + 0.0722 * b;
5717
+ };
5718
+
5719
+ var luminance_x = function (x) {
5720
+ x /= 255;
5721
+ return x <= 0.03928 ? x / 12.92 : pow$6((x + 0.055) / 1.055, 2.4);
5722
+ };
5723
+
5724
+ var index = {};
5725
+
5726
+ function mix (col1, col2, f) {
5727
+ if ( f === void 0 ) f = 0.5;
5728
+ var rest = [], len = arguments.length - 3;
5729
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 3 ];
5730
+
5731
+ var mode = rest[0] || 'lrgb';
5732
+ if (!index[mode] && !rest.length) {
5733
+ // fall back to the first supported mode
5734
+ mode = Object.keys(index)[0];
5735
+ }
5736
+ if (!index[mode]) {
5737
+ throw new Error(("interpolation mode " + mode + " is not defined"));
5738
+ }
5739
+ if (type(col1) !== 'object') { col1 = new Color(col1); }
5740
+ if (type(col2) !== 'object') { col2 = new Color(col2); }
5741
+ return index[mode](col1, col2, f).alpha(
5742
+ col1.alpha() + f * (col2.alpha() - col1.alpha())
5743
+ );
5744
+ }
5745
+
5746
+ Color.prototype.mix = Color.prototype.interpolate = function (
5747
+ col2,
5748
+ f
5749
+ ) {
5750
+ if ( f === void 0 ) f = 0.5;
5751
+ var rest = [], len = arguments.length - 2;
5752
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ];
5753
+
5754
+ return mix.apply(void 0, [ this, col2, f ].concat( rest ));
5755
+ };
5756
+
5757
+ Color.prototype.premultiply = function (mutate) {
5758
+ if ( mutate === void 0 ) mutate = false;
5759
+
5760
+ var rgb = this._rgb;
5761
+ var a = rgb[3];
5762
+ if (mutate) {
5763
+ this._rgb = [rgb[0] * a, rgb[1] * a, rgb[2] * a, a];
5764
+ return this;
5765
+ } else {
5766
+ return new Color([rgb[0] * a, rgb[1] * a, rgb[2] * a, a], 'rgb');
5767
+ }
5768
+ };
5769
+
5770
+ Color.prototype.saturate = function (amount) {
5771
+ if ( amount === void 0 ) amount = 1;
5772
+
5773
+ var me = this;
5774
+ var lch = me.lch();
5775
+ lch[1] += labConstants.Kn * amount;
5776
+ if (lch[1] < 0) { lch[1] = 0; }
5777
+ return new Color(lch, 'lch').alpha(me.alpha(), true);
5778
+ };
5779
+
5780
+ Color.prototype.desaturate = function (amount) {
5781
+ if ( amount === void 0 ) amount = 1;
5782
+
5783
+ return this.saturate(-amount);
5784
+ };
5785
+
5786
+ Color.prototype.set = function (mc, value, mutate) {
5787
+ if ( mutate === void 0 ) mutate = false;
5788
+
5789
+ var ref = mc.split('.');
5790
+ var mode = ref[0];
5791
+ var channel = ref[1];
5792
+ var src = this[mode]();
5793
+ if (channel) {
5794
+ var i = mode.indexOf(channel) - (mode.substr(0, 2) === 'ok' ? 2 : 0);
5795
+ if (i > -1) {
5796
+ if (type(value) == 'string') {
5797
+ switch (value.charAt(0)) {
5798
+ case '+':
5799
+ src[i] += +value;
5800
+ break;
5801
+ case '-':
5802
+ src[i] += +value;
5803
+ break;
5804
+ case '*':
5805
+ src[i] *= +value.substr(1);
5806
+ break;
5807
+ case '/':
5808
+ src[i] /= +value.substr(1);
5809
+ break;
5810
+ default:
5811
+ src[i] = +value;
5812
+ }
5813
+ } else if (type(value) === 'number') {
5814
+ src[i] = value;
5815
+ } else {
5816
+ throw new Error("unsupported value for Color.set");
5817
+ }
5818
+ var out = new Color(src, mode);
5819
+ if (mutate) {
5820
+ this._rgb = out._rgb;
5821
+ return this;
5822
+ }
5823
+ return out;
5824
+ }
5825
+ throw new Error(("unknown channel " + channel + " in mode " + mode));
5826
+ } else {
5827
+ return src;
5828
+ }
5829
+ };
5830
+
5831
+ Color.prototype.tint = function (f) {
5832
+ if ( f === void 0 ) f = 0.5;
5833
+ var rest = [], len = arguments.length - 1;
5834
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
5835
+
5836
+ return mix.apply(void 0, [ this, 'white', f ].concat( rest ));
5837
+ };
5838
+
5839
+ Color.prototype.shade = function (f) {
5840
+ if ( f === void 0 ) f = 0.5;
5841
+ var rest = [], len = arguments.length - 1;
5842
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
5843
+
5844
+ return mix.apply(void 0, [ this, 'black', f ].concat( rest ));
5845
+ };
5846
+
5847
+ var rgb = function (col1, col2, f) {
5848
+ var xyz0 = col1._rgb;
5849
+ var xyz1 = col2._rgb;
5850
+ return new Color(
5851
+ xyz0[0] + f * (xyz1[0] - xyz0[0]),
5852
+ xyz0[1] + f * (xyz1[1] - xyz0[1]),
5853
+ xyz0[2] + f * (xyz1[2] - xyz0[2]),
5854
+ 'rgb'
5855
+ );
5856
+ };
5857
+
5858
+ // register interpolator
5859
+ index.rgb = rgb;
5860
+
5861
+ var sqrt$2 = Math.sqrt;
5862
+ var pow$5 = Math.pow;
5863
+
5864
+ var lrgb = function (col1, col2, f) {
5865
+ var ref = col1._rgb;
5866
+ var x1 = ref[0];
5867
+ var y1 = ref[1];
5868
+ var z1 = ref[2];
5869
+ var ref$1 = col2._rgb;
5870
+ var x2 = ref$1[0];
5871
+ var y2 = ref$1[1];
5872
+ var z2 = ref$1[2];
5873
+ return new Color(
5874
+ sqrt$2(pow$5(x1, 2) * (1 - f) + pow$5(x2, 2) * f),
5875
+ sqrt$2(pow$5(y1, 2) * (1 - f) + pow$5(y2, 2) * f),
5876
+ sqrt$2(pow$5(z1, 2) * (1 - f) + pow$5(z2, 2) * f),
5877
+ 'rgb'
5878
+ );
5879
+ };
5880
+
5881
+ // register interpolator
5882
+ index.lrgb = lrgb;
5883
+
5884
+ var lab = function (col1, col2, f) {
5885
+ var xyz0 = col1.lab();
5886
+ var xyz1 = col2.lab();
5887
+ return new Color(
5888
+ xyz0[0] + f * (xyz1[0] - xyz0[0]),
5889
+ xyz0[1] + f * (xyz1[1] - xyz0[1]),
5890
+ xyz0[2] + f * (xyz1[2] - xyz0[2]),
5891
+ 'lab'
5892
+ );
5893
+ };
5894
+
5895
+ // register interpolator
5896
+ index.lab = lab;
5897
+
5898
+ function interpolate_hsx (col1, col2, f, m) {
5899
+ var assign, assign$1;
5900
+
5901
+ var xyz0, xyz1;
5902
+ if (m === 'hsl') {
5903
+ xyz0 = col1.hsl();
5904
+ xyz1 = col2.hsl();
5905
+ } else if (m === 'hsv') {
5906
+ xyz0 = col1.hsv();
5907
+ xyz1 = col2.hsv();
5908
+ } else if (m === 'hcg') {
5909
+ xyz0 = col1.hcg();
5910
+ xyz1 = col2.hcg();
5911
+ } else if (m === 'hsi') {
5912
+ xyz0 = col1.hsi();
5913
+ xyz1 = col2.hsi();
5914
+ } else if (m === 'lch' || m === 'hcl') {
5915
+ m = 'hcl';
5916
+ xyz0 = col1.hcl();
5917
+ xyz1 = col2.hcl();
5918
+ } else if (m === 'oklch') {
5919
+ xyz0 = col1.oklch().reverse();
5920
+ xyz1 = col2.oklch().reverse();
5921
+ }
5922
+
5923
+ var hue0, hue1, sat0, sat1, lbv0, lbv1;
5924
+ if (m.substr(0, 1) === 'h' || m === 'oklch') {
5925
+ (assign = xyz0, hue0 = assign[0], sat0 = assign[1], lbv0 = assign[2]);
5926
+ (assign$1 = xyz1, hue1 = assign$1[0], sat1 = assign$1[1], lbv1 = assign$1[2]);
5927
+ }
5928
+
5929
+ var sat, hue, lbv, dh;
5930
+
5931
+ if (!isNaN(hue0) && !isNaN(hue1)) {
5932
+ // both colors have hue
5933
+ if (hue1 > hue0 && hue1 - hue0 > 180) {
5934
+ dh = hue1 - (hue0 + 360);
5935
+ } else if (hue1 < hue0 && hue0 - hue1 > 180) {
5936
+ dh = hue1 + 360 - hue0;
5937
+ } else {
5938
+ dh = hue1 - hue0;
5939
+ }
5940
+ hue = hue0 + f * dh;
5941
+ } else if (!isNaN(hue0)) {
5942
+ hue = hue0;
5943
+ if ((lbv1 == 1 || lbv1 == 0) && m != 'hsv') { sat = sat0; }
5944
+ } else if (!isNaN(hue1)) {
5945
+ hue = hue1;
5946
+ if ((lbv0 == 1 || lbv0 == 0) && m != 'hsv') { sat = sat1; }
5947
+ } else {
5948
+ hue = Number.NaN;
5949
+ }
5950
+
5951
+ if (sat === undefined) { sat = sat0 + f * (sat1 - sat0); }
5952
+ lbv = lbv0 + f * (lbv1 - lbv0);
5953
+ return m === 'oklch'
5954
+ ? new Color([lbv, sat, hue], m)
5955
+ : new Color([hue, sat, lbv], m);
5956
+ }
5957
+
5958
+ var lch = function (col1, col2, f) {
5959
+ return interpolate_hsx(col1, col2, f, 'lch');
5960
+ };
5961
+
5962
+ // register interpolator
5963
+ index.lch = lch;
5964
+ index.hcl = lch;
5965
+
5966
+ var num = function (col1, col2, f) {
5967
+ var c1 = col1.num();
5968
+ var c2 = col2.num();
5969
+ return new Color(c1 + f * (c2 - c1), 'num');
5970
+ };
5971
+
5972
+ // register interpolator
5973
+ index.num = num;
5974
+
5975
+ var hcg = function (col1, col2, f) {
5976
+ return interpolate_hsx(col1, col2, f, 'hcg');
5977
+ };
5978
+
5979
+ // register interpolator
5980
+ index.hcg = hcg;
5981
+
5982
+ var hsi = function (col1, col2, f) {
5983
+ return interpolate_hsx(col1, col2, f, 'hsi');
5984
+ };
5985
+
5986
+ // register interpolator
5987
+ index.hsi = hsi;
5988
+
5989
+ var hsl = function (col1, col2, f) {
5990
+ return interpolate_hsx(col1, col2, f, 'hsl');
5991
+ };
5992
+
5993
+ // register interpolator
5994
+ index.hsl = hsl;
5995
+
5996
+ var hsv = function (col1, col2, f) {
5997
+ return interpolate_hsx(col1, col2, f, 'hsv');
5998
+ };
5999
+
6000
+ // register interpolator
6001
+ index.hsv = hsv;
6002
+
6003
+ var oklab = function (col1, col2, f) {
6004
+ var xyz0 = col1.oklab();
6005
+ var xyz1 = col2.oklab();
6006
+ return new Color(
6007
+ xyz0[0] + f * (xyz1[0] - xyz0[0]),
6008
+ xyz0[1] + f * (xyz1[1] - xyz0[1]),
6009
+ xyz0[2] + f * (xyz1[2] - xyz0[2]),
6010
+ 'oklab'
6011
+ );
6012
+ };
6013
+
6014
+ // register interpolator
6015
+ index.oklab = oklab;
6016
+
6017
+ var oklch = function (col1, col2, f) {
6018
+ return interpolate_hsx(col1, col2, f, 'oklch');
6019
+ };
6020
+
6021
+ // register interpolator
6022
+ index.oklch = oklch;
6023
+
6024
+ var pow$4 = Math.pow;
6025
+ var sqrt$1 = Math.sqrt;
6026
+ var PI$1 = Math.PI;
6027
+ var cos$2 = Math.cos;
6028
+ var sin$2 = Math.sin;
6029
+ var atan2$1 = Math.atan2;
6030
+
6031
+ function average (colors, mode, weights) {
6032
+ if ( mode === void 0 ) mode = 'lrgb';
6033
+ if ( weights === void 0 ) weights = null;
6034
+
6035
+ var l = colors.length;
6036
+ if (!weights) { weights = Array.from(new Array(l)).map(function () { return 1; }); }
6037
+ // normalize weights
6038
+ var k =
6039
+ l /
6040
+ weights.reduce(function (a, b) {
6041
+ return a + b;
6042
+ });
6043
+ weights.forEach(function (w, i) {
6044
+ weights[i] *= k;
6045
+ });
6046
+ // convert colors to Color objects
6047
+ colors = colors.map(function (c) { return new Color(c); });
6048
+ if (mode === 'lrgb') {
6049
+ return _average_lrgb(colors, weights);
6050
+ }
6051
+ var first = colors.shift();
6052
+ var xyz = first.get(mode);
6053
+ var cnt = [];
6054
+ var dx = 0;
6055
+ var dy = 0;
6056
+ // initial color
6057
+ for (var i = 0; i < xyz.length; i++) {
6058
+ xyz[i] = (xyz[i] || 0) * weights[0];
6059
+ cnt.push(isNaN(xyz[i]) ? 0 : weights[0]);
6060
+ if (mode.charAt(i) === 'h' && !isNaN(xyz[i])) {
6061
+ var A = (xyz[i] / 180) * PI$1;
6062
+ dx += cos$2(A) * weights[0];
6063
+ dy += sin$2(A) * weights[0];
6064
+ }
6065
+ }
6066
+
6067
+ var alpha = first.alpha() * weights[0];
6068
+ colors.forEach(function (c, ci) {
6069
+ var xyz2 = c.get(mode);
6070
+ alpha += c.alpha() * weights[ci + 1];
6071
+ for (var i = 0; i < xyz.length; i++) {
6072
+ if (!isNaN(xyz2[i])) {
6073
+ cnt[i] += weights[ci + 1];
6074
+ if (mode.charAt(i) === 'h') {
6075
+ var A = (xyz2[i] / 180) * PI$1;
6076
+ dx += cos$2(A) * weights[ci + 1];
6077
+ dy += sin$2(A) * weights[ci + 1];
6078
+ } else {
6079
+ xyz[i] += xyz2[i] * weights[ci + 1];
6080
+ }
6081
+ }
6082
+ }
6083
+ });
6084
+
6085
+ for (var i$1 = 0; i$1 < xyz.length; i$1++) {
6086
+ if (mode.charAt(i$1) === 'h') {
6087
+ var A$1 = (atan2$1(dy / cnt[i$1], dx / cnt[i$1]) / PI$1) * 180;
6088
+ while (A$1 < 0) { A$1 += 360; }
6089
+ while (A$1 >= 360) { A$1 -= 360; }
6090
+ xyz[i$1] = A$1;
6091
+ } else {
6092
+ xyz[i$1] = xyz[i$1] / cnt[i$1];
6093
+ }
6094
+ }
6095
+ alpha /= l;
6096
+ return new Color(xyz, mode).alpha(alpha > 0.99999 ? 1 : alpha, true);
6097
+ }
6098
+ var _average_lrgb = function (colors, weights) {
6099
+ var l = colors.length;
6100
+ var xyz = [0, 0, 0, 0];
6101
+ for (var i = 0; i < colors.length; i++) {
6102
+ var col = colors[i];
6103
+ var f = weights[i] / l;
6104
+ var rgb = col._rgb;
6105
+ xyz[0] += pow$4(rgb[0], 2) * f;
6106
+ xyz[1] += pow$4(rgb[1], 2) * f;
6107
+ xyz[2] += pow$4(rgb[2], 2) * f;
6108
+ xyz[3] += rgb[3] * f;
6109
+ }
6110
+ xyz[0] = sqrt$1(xyz[0]);
6111
+ xyz[1] = sqrt$1(xyz[1]);
6112
+ xyz[2] = sqrt$1(xyz[2]);
6113
+ if (xyz[3] > 0.9999999) { xyz[3] = 1; }
6114
+ return new Color(clip_rgb(xyz));
6115
+ };
6116
+
6117
+ // minimal multi-purpose interface
6118
+
6119
+
6120
+ var pow$3 = Math.pow;
6121
+
6122
+ function scale (colors) {
6123
+ // constructor
6124
+ var _mode = 'rgb';
6125
+ var _nacol = chroma('#ccc');
6126
+ var _spread = 0;
6127
+ // const _fixed = false;
6128
+ var _positions = [0, 1];
6129
+ var _domain = [0, 1];
6130
+ var _pos = [];
6131
+ var _padding = [0, 0];
6132
+ var _classes = false;
6133
+ var _colors = [];
6134
+ var _out = false;
6135
+ var _min = 0;
6136
+ var _max = 1;
6137
+ var _correctLightness = false;
6138
+ var _colorCache = {};
6139
+ var _useCache = true;
6140
+ var _gamma = 1;
6141
+
6142
+ // private methods
6143
+
6144
+ var setColors = function (colors) {
6145
+ colors = colors || ['#fff', '#000'];
6146
+ if (
6147
+ colors &&
6148
+ type(colors) === 'string' &&
6149
+ chroma.brewer &&
6150
+ chroma.brewer[colors.toLowerCase()]
6151
+ ) {
6152
+ colors = chroma.brewer[colors.toLowerCase()];
6153
+ }
6154
+ if (type(colors) === 'array') {
6155
+ // handle single color
6156
+ if (colors.length === 1) {
6157
+ colors = [colors[0], colors[0]];
6158
+ }
6159
+ // make a copy of the colors
6160
+ colors = colors.slice(0);
6161
+ // convert to chroma classes
6162
+ for (var c = 0; c < colors.length; c++) {
6163
+ colors[c] = chroma(colors[c]);
6164
+ }
6165
+ // auto-fill color position
6166
+ _pos.length = 0;
6167
+ for (var c$1 = 0; c$1 < colors.length; c$1++) {
6168
+ _pos.push(c$1 / (colors.length - 1));
6169
+ }
6170
+ }
6171
+ resetCache();
6172
+ return (_colors = colors);
6173
+ };
6174
+
6175
+ var getClass = function (value) {
6176
+ if (_classes != null) {
6177
+ var n = _classes.length - 1;
6178
+ var i = 0;
6179
+ while (i < n && value >= _classes[i]) {
6180
+ i++;
6181
+ }
6182
+ return i - 1;
6183
+ }
6184
+ return 0;
6185
+ };
6186
+
6187
+ var tMapLightness = function (t) { return t; };
6188
+ var tMapDomain = function (t) { return t; };
6189
+
6190
+ // const classifyValue = function(value) {
6191
+ // let val = value;
6192
+ // if (_classes.length > 2) {
6193
+ // const n = _classes.length-1;
6194
+ // const i = getClass(value);
6195
+ // const minc = _classes[0] + ((_classes[1]-_classes[0]) * (0 + (_spread * 0.5))); // center of 1st class
6196
+ // const maxc = _classes[n-1] + ((_classes[n]-_classes[n-1]) * (1 - (_spread * 0.5))); // center of last class
6197
+ // val = _min + ((((_classes[i] + ((_classes[i+1] - _classes[i]) * 0.5)) - minc) / (maxc-minc)) * (_max - _min));
6198
+ // }
6199
+ // return val;
6200
+ // };
6201
+
6202
+ var getColor = function (val, bypassMap) {
6203
+ var col, t;
6204
+ if (bypassMap == null) {
6205
+ bypassMap = false;
6206
+ }
6207
+ if (isNaN(val) || val === null) {
6208
+ return _nacol;
6209
+ }
6210
+ if (!bypassMap) {
6211
+ if (_classes && _classes.length > 2) {
6212
+ // find the class
6213
+ var c = getClass(val);
6214
+ t = c / (_classes.length - 2);
6215
+ } else if (_max !== _min) {
6216
+ // just interpolate between min/max
6217
+ t = (val - _min) / (_max - _min);
6218
+ } else {
6219
+ t = 1;
6220
+ }
6221
+ } else {
6222
+ t = val;
6223
+ }
6224
+
6225
+ // domain map
6226
+ t = tMapDomain(t);
6227
+
6228
+ if (!bypassMap) {
6229
+ t = tMapLightness(t); // lightness correction
6230
+ }
6231
+
6232
+ if (_gamma !== 1) {
6233
+ t = pow$3(t, _gamma);
6234
+ }
6235
+
6236
+ t = _padding[0] + t * (1 - _padding[0] - _padding[1]);
6237
+
6238
+ t = limit(t, 0, 1);
6239
+
6240
+ var k = Math.floor(t * 10000);
6241
+
6242
+ if (_useCache && _colorCache[k]) {
6243
+ col = _colorCache[k];
6244
+ } else {
6245
+ if (type(_colors) === 'array') {
6246
+ //for i in [0.._pos.length-1]
6247
+ for (var i = 0; i < _pos.length; i++) {
6248
+ var p = _pos[i];
6249
+ if (t <= p) {
6250
+ col = _colors[i];
6251
+ break;
6252
+ }
6253
+ if (t >= p && i === _pos.length - 1) {
6254
+ col = _colors[i];
6255
+ break;
6256
+ }
6257
+ if (t > p && t < _pos[i + 1]) {
6258
+ t = (t - p) / (_pos[i + 1] - p);
6259
+ col = chroma.interpolate(
6260
+ _colors[i],
6261
+ _colors[i + 1],
6262
+ t,
6263
+ _mode
6264
+ );
6265
+ break;
6266
+ }
6267
+ }
6268
+ } else if (type(_colors) === 'function') {
6269
+ col = _colors(t);
6270
+ }
6271
+ if (_useCache) {
6272
+ _colorCache[k] = col;
6273
+ }
6274
+ }
6275
+ return col;
6276
+ };
6277
+
6278
+ var resetCache = function () { return (_colorCache = {}); };
6279
+
6280
+ setColors(colors);
6281
+
6282
+ // public interface
6283
+
6284
+ var f = function (v) {
6285
+ var c = chroma(getColor(v));
6286
+ if (_out && c[_out]) {
6287
+ return c[_out]();
6288
+ } else {
6289
+ return c;
6290
+ }
6291
+ };
6292
+
6293
+ f.classes = function (classes) {
6294
+ if (classes != null) {
6295
+ if (type(classes) === 'array') {
6296
+ _classes = classes;
6297
+ _positions = [classes[0], classes[classes.length - 1]];
6298
+ } else {
6299
+ var d = chroma.analyze(_positions);
6300
+ if (classes === 0) {
6301
+ _classes = [d.min, d.max];
6302
+ } else {
6303
+ _classes = chroma.limits(d, 'e', classes);
6304
+ }
6305
+ }
6306
+ return f;
6307
+ }
6308
+ return _classes;
6309
+ };
6310
+
6311
+ f.domain = function (domain) {
6312
+ if (!arguments.length) {
6313
+ // return original domain
6314
+ return _domain;
6315
+ }
6316
+ // store original domain so we can return it later
6317
+ _domain = domain.slice(0);
6318
+ _min = domain[0];
6319
+ _max = domain[domain.length - 1];
6320
+ _pos = [];
6321
+ var k = _colors.length;
6322
+ if (domain.length === k && _min !== _max) {
6323
+ // update positions
6324
+ for (var i = 0, list = Array.from(domain); i < list.length; i += 1) {
6325
+ var d = list[i];
6326
+
6327
+ _pos.push((d - _min) / (_max - _min));
6328
+ }
6329
+ } else {
6330
+ for (var c = 0; c < k; c++) {
6331
+ _pos.push(c / (k - 1));
6332
+ }
6333
+ if (domain.length > 2) {
6334
+ // set domain map
6335
+ var tOut = domain.map(function (d, i) { return i / (domain.length - 1); });
6336
+ var tBreaks = domain.map(function (d) { return (d - _min) / (_max - _min); });
6337
+ if (!tBreaks.every(function (val, i) { return tOut[i] === val; })) {
6338
+ tMapDomain = function (t) {
6339
+ if (t <= 0 || t >= 1) { return t; }
6340
+ var i = 0;
6341
+ while (t >= tBreaks[i + 1]) { i++; }
6342
+ var f =
6343
+ (t - tBreaks[i]) / (tBreaks[i + 1] - tBreaks[i]);
6344
+ var out = tOut[i] + f * (tOut[i + 1] - tOut[i]);
6345
+ return out;
6346
+ };
6347
+ }
6348
+ }
6349
+ }
6350
+ _positions = [_min, _max];
6351
+ return f;
6352
+ };
6353
+
6354
+ f.mode = function (_m) {
6355
+ if (!arguments.length) {
6356
+ return _mode;
6357
+ }
6358
+ _mode = _m;
6359
+ resetCache();
6360
+ return f;
6361
+ };
6362
+
6363
+ f.range = function (colors, _pos) {
6364
+ setColors(colors);
6365
+ return f;
6366
+ };
6367
+
6368
+ f.out = function (_o) {
6369
+ _out = _o;
6370
+ return f;
6371
+ };
6372
+
6373
+ f.spread = function (val) {
6374
+ if (!arguments.length) {
6375
+ return _spread;
6376
+ }
6377
+ _spread = val;
6378
+ return f;
6379
+ };
6380
+
6381
+ f.correctLightness = function (v) {
6382
+ if (v == null) {
6383
+ v = true;
6384
+ }
6385
+ _correctLightness = v;
6386
+ resetCache();
6387
+ if (_correctLightness) {
6388
+ tMapLightness = function (t) {
6389
+ var L0 = getColor(0, true).lab()[0];
6390
+ var L1 = getColor(1, true).lab()[0];
6391
+ var pol = L0 > L1;
6392
+ var L_actual = getColor(t, true).lab()[0];
6393
+ var L_ideal = L0 + (L1 - L0) * t;
6394
+ var L_diff = L_actual - L_ideal;
6395
+ var t0 = 0;
6396
+ var t1 = 1;
6397
+ var max_iter = 20;
6398
+ while (Math.abs(L_diff) > 1e-2 && max_iter-- > 0) {
6399
+ (function () {
6400
+ if (pol) {
6401
+ L_diff *= -1;
6402
+ }
6403
+ if (L_diff < 0) {
6404
+ t0 = t;
6405
+ t += (t1 - t) * 0.5;
6406
+ } else {
6407
+ t1 = t;
6408
+ t += (t0 - t) * 0.5;
6409
+ }
6410
+ L_actual = getColor(t, true).lab()[0];
6411
+ return (L_diff = L_actual - L_ideal);
6412
+ })();
6413
+ }
6414
+ return t;
6415
+ };
6416
+ } else {
6417
+ tMapLightness = function (t) { return t; };
6418
+ }
6419
+ return f;
6420
+ };
6421
+
6422
+ f.padding = function (p) {
6423
+ if (p != null) {
6424
+ if (type(p) === 'number') {
6425
+ p = [p, p];
6426
+ }
6427
+ _padding = p;
6428
+ return f;
6429
+ } else {
6430
+ return _padding;
6431
+ }
6432
+ };
6433
+
6434
+ f.colors = function (numColors, out) {
6435
+ // If no arguments are given, return the original colors that were provided
6436
+ if (arguments.length < 2) {
6437
+ out = 'hex';
6438
+ }
6439
+ var result = [];
6440
+
6441
+ if (arguments.length === 0) {
6442
+ result = _colors.slice(0);
6443
+ } else if (numColors === 1) {
6444
+ result = [f(0.5)];
6445
+ } else if (numColors > 1) {
6446
+ var dm = _positions[0];
6447
+ var dd = _positions[1] - dm;
6448
+ result = __range__(0, numColors).map(function (i) { return f(dm + (i / (numColors - 1)) * dd); }
6449
+ );
6450
+ } else {
6451
+ // returns all colors based on the defined classes
6452
+ colors = [];
6453
+ var samples = [];
6454
+ if (_classes && _classes.length > 2) {
6455
+ for (
6456
+ var i = 1, end = _classes.length, asc = 1 <= end;
6457
+ asc ? i < end : i > end;
6458
+ asc ? i++ : i--
6459
+ ) {
6460
+ samples.push((_classes[i - 1] + _classes[i]) * 0.5);
6461
+ }
6462
+ } else {
6463
+ samples = _positions;
6464
+ }
6465
+ result = samples.map(function (v) { return f(v); });
6466
+ }
6467
+
6468
+ if (chroma[out]) {
6469
+ result = result.map(function (c) { return c[out](); });
6470
+ }
6471
+ return result;
6472
+ };
6473
+
6474
+ f.cache = function (c) {
6475
+ if (c != null) {
6476
+ _useCache = c;
6477
+ return f;
6478
+ } else {
6479
+ return _useCache;
6480
+ }
6481
+ };
6482
+
6483
+ f.gamma = function (g) {
6484
+ if (g != null) {
6485
+ _gamma = g;
6486
+ return f;
6487
+ } else {
6488
+ return _gamma;
6489
+ }
6490
+ };
6491
+
6492
+ f.nodata = function (d) {
6493
+ if (d != null) {
6494
+ _nacol = chroma(d);
6495
+ return f;
6496
+ } else {
6497
+ return _nacol;
6498
+ }
6499
+ };
6500
+
6501
+ return f;
6502
+ }
6503
+
6504
+ function __range__(left, right, inclusive) {
6505
+ var range = [];
6506
+ var ascending = left < right;
6507
+ var end = right ;
6508
+ for (var i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {
6509
+ range.push(i);
6510
+ }
6511
+ return range;
6512
+ }
6513
+
6514
+ //
6515
+ // interpolates between a set of colors uzing a bezier spline
6516
+ //
6517
+
6518
+
6519
+ // nth row of the pascal triangle
6520
+ var binom_row = function (n) {
6521
+ var row = [1, 1];
6522
+ for (var i = 1; i < n; i++) {
6523
+ var newrow = [1];
6524
+ for (var j = 1; j <= row.length; j++) {
6525
+ newrow[j] = (row[j] || 0) + row[j - 1];
6526
+ }
6527
+ row = newrow;
6528
+ }
6529
+ return row;
6530
+ };
6531
+
6532
+ var bezier = function (colors) {
6533
+ var assign, assign$1, assign$2;
6534
+
6535
+ var I, lab0, lab1, lab2;
6536
+ colors = colors.map(function (c) { return new Color(c); });
6537
+ if (colors.length === 2) {
6538
+ // linear interpolation
6539
+ (assign = colors.map(function (c) { return c.lab(); }), lab0 = assign[0], lab1 = assign[1]);
6540
+ I = function (t) {
6541
+ var lab = [0, 1, 2].map(function (i) { return lab0[i] + t * (lab1[i] - lab0[i]); });
6542
+ return new Color(lab, 'lab');
6543
+ };
6544
+ } else if (colors.length === 3) {
6545
+ // quadratic bezier interpolation
6546
+ (assign$1 = colors.map(function (c) { return c.lab(); }), lab0 = assign$1[0], lab1 = assign$1[1], lab2 = assign$1[2]);
6547
+ I = function (t) {
6548
+ var lab = [0, 1, 2].map(
6549
+ function (i) { return (1 - t) * (1 - t) * lab0[i] +
6550
+ 2 * (1 - t) * t * lab1[i] +
6551
+ t * t * lab2[i]; }
6552
+ );
6553
+ return new Color(lab, 'lab');
6554
+ };
6555
+ } else if (colors.length === 4) {
6556
+ // cubic bezier interpolation
6557
+ var lab3;
6558
+ (assign$2 = colors.map(function (c) { return c.lab(); }), lab0 = assign$2[0], lab1 = assign$2[1], lab2 = assign$2[2], lab3 = assign$2[3]);
6559
+ I = function (t) {
6560
+ var lab = [0, 1, 2].map(
6561
+ function (i) { return (1 - t) * (1 - t) * (1 - t) * lab0[i] +
6562
+ 3 * (1 - t) * (1 - t) * t * lab1[i] +
6563
+ 3 * (1 - t) * t * t * lab2[i] +
6564
+ t * t * t * lab3[i]; }
6565
+ );
6566
+ return new Color(lab, 'lab');
6567
+ };
6568
+ } else if (colors.length >= 5) {
6569
+ // general case (degree n bezier)
6570
+ var labs, row, n;
6571
+ labs = colors.map(function (c) { return c.lab(); });
6572
+ n = colors.length - 1;
6573
+ row = binom_row(n);
6574
+ I = function (t) {
6575
+ var u = 1 - t;
6576
+ var lab = [0, 1, 2].map(function (i) { return labs.reduce(
6577
+ function (sum, el, j) { return sum + row[j] * Math.pow( u, (n - j) ) * Math.pow( t, j ) * el[i]; },
6578
+ 0
6579
+ ); }
6580
+ );
6581
+ return new Color(lab, 'lab');
6582
+ };
6583
+ } else {
6584
+ throw new RangeError('No point in running bezier with only one color.');
6585
+ }
6586
+ return I;
6587
+ };
6588
+
6589
+ function bezier$1 (colors) {
6590
+ var f = bezier(colors);
6591
+ f.scale = function () { return scale(f); };
6592
+ return f;
6593
+ }
6594
+
6595
+ /*
6596
+ * interpolates between a set of colors uzing a bezier spline
6597
+ * blend mode formulas taken from https://web.archive.org/web/20180110014946/http://www.venture-ware.com/kevin/coding/lets-learn-math-photoshop-blend-modes/
6598
+ */
6599
+
6600
+
6601
+ var blend = function (bottom, top, mode) {
6602
+ if (!blend[mode]) {
6603
+ throw new Error('unknown blend mode ' + mode);
6604
+ }
6605
+ return blend[mode](bottom, top);
6606
+ };
6607
+
6608
+ var blend_f = function (f) { return function (bottom, top) {
6609
+ var c0 = chroma(top).rgb();
6610
+ var c1 = chroma(bottom).rgb();
6611
+ return chroma.rgb(f(c0, c1));
6612
+ }; };
6613
+
6614
+ var each = function (f) { return function (c0, c1) {
6615
+ var out = [];
6616
+ out[0] = f(c0[0], c1[0]);
6617
+ out[1] = f(c0[1], c1[1]);
6618
+ out[2] = f(c0[2], c1[2]);
6619
+ return out;
6620
+ }; };
6621
+
6622
+ var normal = function (a) { return a; };
6623
+ var multiply = function (a, b) { return (a * b) / 255; };
6624
+ var darken = function (a, b) { return (a > b ? b : a); };
6625
+ var lighten = function (a, b) { return (a > b ? a : b); };
6626
+ var screen = function (a, b) { return 255 * (1 - (1 - a / 255) * (1 - b / 255)); };
6627
+ var overlay = function (a, b) { return b < 128 ? (2 * a * b) / 255 : 255 * (1 - 2 * (1 - a / 255) * (1 - b / 255)); };
6628
+ var burn = function (a, b) { return 255 * (1 - (1 - b / 255) / (a / 255)); };
6629
+ var dodge = function (a, b) {
6630
+ if (a === 255) { return 255; }
6631
+ a = (255 * (b / 255)) / (1 - a / 255);
6632
+ return a > 255 ? 255 : a;
6633
+ };
6634
+
6635
+ // # add = (a,b) ->
6636
+ // # if (a + b > 255) then 255 else a + b
6637
+
6638
+ blend.normal = blend_f(each(normal));
6639
+ blend.multiply = blend_f(each(multiply));
6640
+ blend.screen = blend_f(each(screen));
6641
+ blend.overlay = blend_f(each(overlay));
6642
+ blend.darken = blend_f(each(darken));
6643
+ blend.lighten = blend_f(each(lighten));
6644
+ blend.dodge = blend_f(each(dodge));
6645
+ blend.burn = blend_f(each(burn));
6646
+
6647
+ // cubehelix interpolation
6648
+ // based on D.A. Green "A colour scheme for the display of astronomical intensity images"
6649
+ // http://astron-soc.in/bulletin/11June/289392011.pdf
6650
+ var pow$2 = Math.pow;
6651
+ var sin$1 = Math.sin;
6652
+ var cos$1 = Math.cos;
6653
+
6654
+ function cubehelix (
6655
+ start,
6656
+ rotations,
6657
+ hue,
6658
+ gamma,
6659
+ lightness
6660
+ ) {
6661
+ if ( start === void 0 ) start = 300;
6662
+ if ( rotations === void 0 ) rotations = -1.5;
6663
+ if ( hue === void 0 ) hue = 1;
6664
+ if ( gamma === void 0 ) gamma = 1;
6665
+ if ( lightness === void 0 ) lightness = [0, 1];
6666
+
6667
+ var dh = 0,
6668
+ dl;
6669
+ if (type(lightness) === 'array') {
6670
+ dl = lightness[1] - lightness[0];
6671
+ } else {
6672
+ dl = 0;
6673
+ lightness = [lightness, lightness];
6674
+ }
6675
+ var f = function (fract) {
6676
+ var a = TWOPI * ((start + 120) / 360 + rotations * fract);
6677
+ var l = pow$2(lightness[0] + dl * fract, gamma);
6678
+ var h = dh !== 0 ? hue[0] + fract * dh : hue;
6679
+ var amp = (h * l * (1 - l)) / 2;
6680
+ var cos_a = cos$1(a);
6681
+ var sin_a = sin$1(a);
6682
+ var r = l + amp * (-0.14861 * cos_a + 1.78277 * sin_a);
6683
+ var g = l + amp * (-0.29227 * cos_a - 0.90649 * sin_a);
6684
+ var b = l + amp * (1.97294 * cos_a);
6685
+ return chroma(clip_rgb([r * 255, g * 255, b * 255, 1]));
6686
+ };
6687
+ f.start = function (s) {
6688
+ if (s == null) {
6689
+ return start;
6690
+ }
6691
+ start = s;
6692
+ return f;
6693
+ };
6694
+ f.rotations = function (r) {
6695
+ if (r == null) {
6696
+ return rotations;
6697
+ }
6698
+ rotations = r;
6699
+ return f;
6700
+ };
6701
+ f.gamma = function (g) {
6702
+ if (g == null) {
6703
+ return gamma;
6704
+ }
6705
+ gamma = g;
6706
+ return f;
6707
+ };
6708
+ f.hue = function (h) {
6709
+ if (h == null) {
6710
+ return hue;
6711
+ }
6712
+ hue = h;
6713
+ if (type(hue) === 'array') {
6714
+ dh = hue[1] - hue[0];
6715
+ if (dh === 0) {
6716
+ hue = hue[1];
6717
+ }
6718
+ } else {
6719
+ dh = 0;
6720
+ }
6721
+ return f;
6722
+ };
6723
+ f.lightness = function (h) {
6724
+ if (h == null) {
6725
+ return lightness;
6726
+ }
6727
+ if (type(h) === 'array') {
6728
+ lightness = h;
6729
+ dl = h[1] - h[0];
6730
+ } else {
6731
+ lightness = [h, h];
6732
+ dl = 0;
6733
+ }
6734
+ return f;
6735
+ };
6736
+ f.scale = function () { return chroma.scale(f); };
6737
+ f.hue(hue);
6738
+ return f;
6739
+ }
6740
+
6741
+ var digits = '0123456789abcdef';
6742
+
6743
+ var floor$1 = Math.floor;
6744
+ var random = Math.random;
6745
+
6746
+ /**
6747
+ * Generates a random color.
6748
+ * @param {() => number} rng - A random number generator function.
6749
+ */
6750
+ function random$1 (rng) {
6751
+ if ( rng === void 0 ) rng = random;
6752
+
6753
+ var code = '#';
6754
+ for (var i = 0; i < 6; i++) {
6755
+ code += digits.charAt(floor$1(rng() * 16));
6756
+ }
6757
+ return new Color(code, 'hex');
6758
+ }
6759
+
6760
+ var log = Math.log;
6761
+ var pow$1 = Math.pow;
6762
+ var floor = Math.floor;
6763
+ var abs$1 = Math.abs;
6764
+
6765
+ function analyze(data, key) {
6766
+ if ( key === void 0 ) key = null;
6767
+
6768
+ var r = {
6769
+ min: Number.MAX_VALUE,
6770
+ max: Number.MAX_VALUE * -1,
6771
+ sum: 0,
6772
+ values: [],
6773
+ count: 0
6774
+ };
6775
+ if (type(data) === 'object') {
6776
+ data = Object.values(data);
6777
+ }
6778
+ data.forEach(function (val) {
6779
+ if (key && type(val) === 'object') { val = val[key]; }
6780
+ if (val !== undefined && val !== null && !isNaN(val)) {
6781
+ r.values.push(val);
6782
+ r.sum += val;
6783
+ if (val < r.min) { r.min = val; }
6784
+ if (val > r.max) { r.max = val; }
6785
+ r.count += 1;
6786
+ }
6787
+ });
6788
+
6789
+ r.domain = [r.min, r.max];
6790
+
6791
+ r.limits = function (mode, num) { return limits(r, mode, num); };
6792
+
6793
+ return r;
6794
+ }
6795
+
6796
+ function limits(data, mode, num) {
6797
+ if ( mode === void 0 ) mode = 'equal';
6798
+ if ( num === void 0 ) num = 7;
6799
+
6800
+ if (type(data) == 'array') {
6801
+ data = analyze(data);
6802
+ }
6803
+ var min = data.min;
6804
+ var max = data.max;
6805
+ var values = data.values.sort(function (a, b) { return a - b; });
6806
+
6807
+ if (num === 1) {
6808
+ return [min, max];
6809
+ }
6810
+
6811
+ var limits = [];
6812
+
6813
+ if (mode.substr(0, 1) === 'c') {
6814
+ // continuous
6815
+ limits.push(min);
6816
+ limits.push(max);
6817
+ }
6818
+
6819
+ if (mode.substr(0, 1) === 'e') {
6820
+ // equal interval
6821
+ limits.push(min);
6822
+ for (var i = 1; i < num; i++) {
6823
+ limits.push(min + (i / num) * (max - min));
6824
+ }
6825
+ limits.push(max);
6826
+ } else if (mode.substr(0, 1) === 'l') {
6827
+ // log scale
6828
+ if (min <= 0) {
6829
+ throw new Error(
6830
+ 'Logarithmic scales are only possible for values > 0'
6831
+ );
6832
+ }
6833
+ var min_log = Math.LOG10E * log(min);
6834
+ var max_log = Math.LOG10E * log(max);
6835
+ limits.push(min);
6836
+ for (var i$1 = 1; i$1 < num; i$1++) {
6837
+ limits.push(pow$1(10, min_log + (i$1 / num) * (max_log - min_log)));
6838
+ }
6839
+ limits.push(max);
6840
+ } else if (mode.substr(0, 1) === 'q') {
6841
+ // quantile scale
6842
+ limits.push(min);
6843
+ for (var i$2 = 1; i$2 < num; i$2++) {
6844
+ var p = ((values.length - 1) * i$2) / num;
6845
+ var pb = floor(p);
6846
+ if (pb === p) {
6847
+ limits.push(values[pb]);
6848
+ } else {
6849
+ // p > pb
6850
+ var pr = p - pb;
6851
+ limits.push(values[pb] * (1 - pr) + values[pb + 1] * pr);
6852
+ }
6853
+ }
6854
+ limits.push(max);
6855
+ } else if (mode.substr(0, 1) === 'k') {
6856
+ // k-means clustering
6857
+ /*
6858
+ implementation based on
6859
+ http://code.google.com/p/figue/source/browse/trunk/figue.js#336
6860
+ simplified for 1-d input values
6861
+ */
6862
+ var cluster;
6863
+ var n = values.length;
6864
+ var assignments = new Array(n);
6865
+ var clusterSizes = new Array(num);
6866
+ var repeat = true;
6867
+ var nb_iters = 0;
6868
+ var centroids = null;
6869
+
6870
+ // get seed values
6871
+ centroids = [];
6872
+ centroids.push(min);
6873
+ for (var i$3 = 1; i$3 < num; i$3++) {
6874
+ centroids.push(min + (i$3 / num) * (max - min));
6875
+ }
6876
+ centroids.push(max);
6877
+
6878
+ while (repeat) {
6879
+ // assignment step
6880
+ for (var j = 0; j < num; j++) {
6881
+ clusterSizes[j] = 0;
6882
+ }
6883
+ for (var i$4 = 0; i$4 < n; i$4++) {
6884
+ var value = values[i$4];
6885
+ var mindist = Number.MAX_VALUE;
6886
+ var best = (void 0);
6887
+ for (var j$1 = 0; j$1 < num; j$1++) {
6888
+ var dist = abs$1(centroids[j$1] - value);
6889
+ if (dist < mindist) {
6890
+ mindist = dist;
6891
+ best = j$1;
6892
+ }
6893
+ clusterSizes[best]++;
6894
+ assignments[i$4] = best;
6895
+ }
6896
+ }
6897
+
6898
+ // update centroids step
6899
+ var newCentroids = new Array(num);
6900
+ for (var j$2 = 0; j$2 < num; j$2++) {
6901
+ newCentroids[j$2] = null;
6902
+ }
6903
+ for (var i$5 = 0; i$5 < n; i$5++) {
6904
+ cluster = assignments[i$5];
6905
+ if (newCentroids[cluster] === null) {
6906
+ newCentroids[cluster] = values[i$5];
6907
+ } else {
6908
+ newCentroids[cluster] += values[i$5];
6909
+ }
6910
+ }
6911
+ for (var j$3 = 0; j$3 < num; j$3++) {
6912
+ newCentroids[j$3] *= 1 / clusterSizes[j$3];
6913
+ }
6914
+
6915
+ // check convergence
6916
+ repeat = false;
6917
+ for (var j$4 = 0; j$4 < num; j$4++) {
6918
+ if (newCentroids[j$4] !== centroids[j$4]) {
6919
+ repeat = true;
6920
+ break;
6921
+ }
6922
+ }
6923
+
6924
+ centroids = newCentroids;
6925
+ nb_iters++;
6926
+
6927
+ if (nb_iters > 200) {
6928
+ repeat = false;
6929
+ }
6930
+ }
6931
+
6932
+ // finished k-means clustering
6933
+ // the next part is borrowed from gabrielflor.it
6934
+ var kClusters = {};
6935
+ for (var j$5 = 0; j$5 < num; j$5++) {
6936
+ kClusters[j$5] = [];
6937
+ }
6938
+ for (var i$6 = 0; i$6 < n; i$6++) {
6939
+ cluster = assignments[i$6];
6940
+ kClusters[cluster].push(values[i$6]);
6941
+ }
6942
+ var tmpKMeansBreaks = [];
6943
+ for (var j$6 = 0; j$6 < num; j$6++) {
6944
+ tmpKMeansBreaks.push(kClusters[j$6][0]);
6945
+ tmpKMeansBreaks.push(kClusters[j$6][kClusters[j$6].length - 1]);
6946
+ }
6947
+ tmpKMeansBreaks = tmpKMeansBreaks.sort(function (a, b) { return a - b; });
6948
+ limits.push(tmpKMeansBreaks[0]);
6949
+ for (var i$7 = 1; i$7 < tmpKMeansBreaks.length; i$7 += 2) {
6950
+ var v = tmpKMeansBreaks[i$7];
6951
+ if (!isNaN(v) && limits.indexOf(v) === -1) {
6952
+ limits.push(v);
6953
+ }
6954
+ }
6955
+ }
6956
+ return limits;
6957
+ }
6958
+
6959
+ function contrast (a, b) {
6960
+ // WCAG contrast ratio
6961
+ // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef
6962
+ a = new Color(a);
6963
+ b = new Color(b);
6964
+ var l1 = a.luminance();
6965
+ var l2 = b.luminance();
6966
+ return l1 > l2 ? (l1 + 0.05) / (l2 + 0.05) : (l2 + 0.05) / (l1 + 0.05);
6967
+ }
6968
+
6969
+ /**
6970
+ * @license
6971
+ *
6972
+ * The APCA contrast prediction algorithm is based of the formulas published
6973
+ * in the APCA-1.0.98G specification by Myndex. The specification is available at:
6974
+ * https://raw.githubusercontent.com/Myndex/apca-w3/master/images/APCAw3_0.1.17_APCA0.0.98G.svg
6975
+ *
6976
+ * Note that the APCA implementation is still beta, so please update to
6977
+ * future versions of chroma.js when they become available.
6978
+ *
6979
+ * You can read more about the APCA Readability Criterion at
6980
+ * https://readtech.org/ARC/
6981
+ */
6982
+
6983
+ // constants
6984
+ var W_offset = 0.027;
6985
+ var P_in = 0.0005;
6986
+ var P_out = 0.1;
6987
+ var R_scale = 1.14;
6988
+ var B_threshold = 0.022;
6989
+ var B_exp = 1.414;
6990
+
6991
+ function contrastAPCA (text, bg) {
6992
+ // parse input colors
6993
+ text = new Color(text);
6994
+ bg = new Color(bg);
6995
+ // if text color has alpha, blend against background
6996
+ if (text.alpha() < 1) {
6997
+ text = mix(bg, text, text.alpha(), 'rgb');
6998
+ }
6999
+ var l_text = lum.apply(void 0, text.rgb());
7000
+ var l_bg = lum.apply(void 0, bg.rgb());
7001
+
7002
+ // soft clamp black levels
7003
+ var Y_text =
7004
+ l_text >= B_threshold
7005
+ ? l_text
7006
+ : l_text + Math.pow(B_threshold - l_text, B_exp);
7007
+ var Y_bg =
7008
+ l_bg >= B_threshold ? l_bg : l_bg + Math.pow(B_threshold - l_bg, B_exp);
7009
+
7010
+ // normal polarity (dark text on light background)
7011
+ var S_norm = Math.pow(Y_bg, 0.56) - Math.pow(Y_text, 0.57);
7012
+ // reverse polarity (light text on dark background)
7013
+ var S_rev = Math.pow(Y_bg, 0.65) - Math.pow(Y_text, 0.62);
7014
+ // clamp noise then scale
7015
+ var C =
7016
+ Math.abs(Y_bg - Y_text) < P_in
7017
+ ? 0
7018
+ : Y_text < Y_bg
7019
+ ? S_norm * R_scale
7020
+ : S_rev * R_scale;
7021
+ // clamp minimum contrast then offset
7022
+ var S_apc = Math.abs(C) < P_out ? 0 : C > 0 ? C - W_offset : C + W_offset;
7023
+ // scale to 100
7024
+ return S_apc * 100;
7025
+ }
7026
+ function lum(r, g, b) {
7027
+ return (
7028
+ 0.2126729 * Math.pow(r / 255, 2.4) +
7029
+ 0.7151522 * Math.pow(g / 255, 2.4) +
7030
+ 0.072175 * Math.pow(b / 255, 2.4)
7031
+ );
7032
+ }
7033
+
7034
+ var sqrt = Math.sqrt;
7035
+ var pow = Math.pow;
7036
+ var min = Math.min;
7037
+ var max = Math.max;
7038
+ var atan2 = Math.atan2;
7039
+ var abs = Math.abs;
7040
+ var cos = Math.cos;
7041
+ var sin = Math.sin;
7042
+ var exp = Math.exp;
7043
+ var PI = Math.PI;
7044
+
7045
+ function deltaE (a, b, Kl, Kc, Kh) {
7046
+ if ( Kl === void 0 ) Kl = 1;
7047
+ if ( Kc === void 0 ) Kc = 1;
7048
+ if ( Kh === void 0 ) Kh = 1;
7049
+
7050
+ // Delta E (CIE 2000)
7051
+ // see http://www.brucelindbloom.com/index.html?Eqn_DeltaE_CIE2000.html
7052
+ var rad2deg = function (rad) {
7053
+ return (360 * rad) / (2 * PI);
7054
+ };
7055
+ var deg2rad = function (deg) {
7056
+ return (2 * PI * deg) / 360;
7057
+ };
7058
+ a = new Color(a);
7059
+ b = new Color(b);
7060
+ var ref = Array.from(a.lab());
7061
+ var L1 = ref[0];
7062
+ var a1 = ref[1];
7063
+ var b1 = ref[2];
7064
+ var ref$1 = Array.from(b.lab());
7065
+ var L2 = ref$1[0];
7066
+ var a2 = ref$1[1];
7067
+ var b2 = ref$1[2];
7068
+ var avgL = (L1 + L2) / 2;
7069
+ var C1 = sqrt(pow(a1, 2) + pow(b1, 2));
7070
+ var C2 = sqrt(pow(a2, 2) + pow(b2, 2));
7071
+ var avgC = (C1 + C2) / 2;
7072
+ var G = 0.5 * (1 - sqrt(pow(avgC, 7) / (pow(avgC, 7) + pow(25, 7))));
7073
+ var a1p = a1 * (1 + G);
7074
+ var a2p = a2 * (1 + G);
7075
+ var C1p = sqrt(pow(a1p, 2) + pow(b1, 2));
7076
+ var C2p = sqrt(pow(a2p, 2) + pow(b2, 2));
7077
+ var avgCp = (C1p + C2p) / 2;
7078
+ var arctan1 = rad2deg(atan2(b1, a1p));
7079
+ var arctan2 = rad2deg(atan2(b2, a2p));
7080
+ var h1p = arctan1 >= 0 ? arctan1 : arctan1 + 360;
7081
+ var h2p = arctan2 >= 0 ? arctan2 : arctan2 + 360;
7082
+ var avgHp =
7083
+ abs(h1p - h2p) > 180 ? (h1p + h2p + 360) / 2 : (h1p + h2p) / 2;
7084
+ var T =
7085
+ 1 -
7086
+ 0.17 * cos(deg2rad(avgHp - 30)) +
7087
+ 0.24 * cos(deg2rad(2 * avgHp)) +
7088
+ 0.32 * cos(deg2rad(3 * avgHp + 6)) -
7089
+ 0.2 * cos(deg2rad(4 * avgHp - 63));
7090
+ var deltaHp = h2p - h1p;
7091
+ deltaHp =
7092
+ abs(deltaHp) <= 180
7093
+ ? deltaHp
7094
+ : h2p <= h1p
7095
+ ? deltaHp + 360
7096
+ : deltaHp - 360;
7097
+ deltaHp = 2 * sqrt(C1p * C2p) * sin(deg2rad(deltaHp) / 2);
7098
+ var deltaL = L2 - L1;
7099
+ var deltaCp = C2p - C1p;
7100
+ var sl = 1 + (0.015 * pow(avgL - 50, 2)) / sqrt(20 + pow(avgL - 50, 2));
7101
+ var sc = 1 + 0.045 * avgCp;
7102
+ var sh = 1 + 0.015 * avgCp * T;
7103
+ var deltaTheta = 30 * exp(-pow((avgHp - 275) / 25, 2));
7104
+ var Rc = 2 * sqrt(pow(avgCp, 7) / (pow(avgCp, 7) + pow(25, 7)));
7105
+ var Rt = -Rc * sin(2 * deg2rad(deltaTheta));
7106
+ var result = sqrt(
7107
+ pow(deltaL / (Kl * sl), 2) +
7108
+ pow(deltaCp / (Kc * sc), 2) +
7109
+ pow(deltaHp / (Kh * sh), 2) +
7110
+ Rt * (deltaCp / (Kc * sc)) * (deltaHp / (Kh * sh))
7111
+ );
7112
+ return max(0, min(100, result));
7113
+ }
7114
+
7115
+ // simple Euclidean distance
7116
+ function distance (a, b, mode) {
7117
+ if ( mode === void 0 ) mode = 'lab';
7118
+
7119
+ // Delta E (CIE 1976)
7120
+ // see http://www.brucelindbloom.com/index.html?Equations.html
7121
+ a = new Color(a);
7122
+ b = new Color(b);
7123
+ var l1 = a.get(mode);
7124
+ var l2 = b.get(mode);
7125
+ var sum_sq = 0;
7126
+ for (var i in l1) {
7127
+ var d = (l1[i] || 0) - (l2[i] || 0);
7128
+ sum_sq += d * d;
7129
+ }
7130
+ return Math.sqrt(sum_sq);
7131
+ }
7132
+
7133
+ function valid () {
7134
+ var args = [], len = arguments.length;
7135
+ while ( len-- ) args[ len ] = arguments[ len ];
7136
+
7137
+ try {
7138
+ new (Function.prototype.bind.apply( Color, [ null ].concat( args) ));
7139
+ return true;
7140
+ // eslint-disable-next-line
7141
+ } catch (e) {
7142
+ return false;
7143
+ }
7144
+ }
7145
+
7146
+ // some pre-defined color scales:
7147
+
7148
+ var scales = {
7149
+ cool: function cool() {
7150
+ return scale([chroma.hsl(180, 1, 0.9), chroma.hsl(250, 0.7, 0.4)]);
7151
+ },
7152
+ hot: function hot() {
7153
+ return scale(['#000', '#f00', '#ff0', '#fff']).mode(
7154
+ 'rgb'
7155
+ );
7156
+ }
7157
+ };
7158
+
7159
+ /**
7160
+ ColorBrewer colors for chroma.js
7161
+
7162
+ Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The
7163
+ Pennsylvania State University.
7164
+
7165
+ Licensed under the Apache License, Version 2.0 (the "License");
7166
+ you may not use this file except in compliance with the License.
7167
+ You may obtain a copy of the License at
7168
+ http://www.apache.org/licenses/LICENSE-2.0
7169
+
7170
+ Unless required by applicable law or agreed to in writing, software distributed
7171
+ under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
7172
+ CONDITIONS OF ANY KIND, either express or implied. See the License for the
7173
+ specific language governing permissions and limitations under the License.
7174
+ */
7175
+
7176
+ var colorbrewer = {
7177
+ // sequential
7178
+ OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],
7179
+ PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],
7180
+ BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],
7181
+ Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],
7182
+ BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],
7183
+ YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],
7184
+ YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],
7185
+ Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],
7186
+ RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],
7187
+ Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],
7188
+ YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],
7189
+ Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],
7190
+ GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],
7191
+ Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],
7192
+ YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],
7193
+ PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],
7194
+ Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],
7195
+ PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],
7196
+ Viridis: ['#440154', '#482777', '#3f4a8a', '#31678e', '#26838f', '#1f9d8a', '#6cce5a', '#b6de2b', '#fee825'],
7197
+
7198
+ // diverging
7199
+ Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],
7200
+ RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],
7201
+ RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],
7202
+ PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],
7203
+ PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],
7204
+ RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],
7205
+ BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],
7206
+ RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],
7207
+ PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],
7208
+
7209
+ // qualitative
7210
+ Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],
7211
+ Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],
7212
+ Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],
7213
+ Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],
7214
+ Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],
7215
+ Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],
7216
+ Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],
7217
+ Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2']
7218
+ };
7219
+
7220
+ var colorbrewerTypes = Object.keys(colorbrewer);
7221
+ var typeMap = new Map(colorbrewerTypes.map(function (key) { return [key.toLowerCase(), key]; }));
7222
+
7223
+ // use Proxy to allow case-insensitive access to palettes
7224
+ var colorbrewerProxy =
7225
+ typeof Proxy === 'function'
7226
+ ? new Proxy(colorbrewer, {
7227
+ get: function get(target, prop) {
7228
+ var lower = prop.toLowerCase();
7229
+ if (typeMap.has(lower)) {
7230
+ return target[typeMap.get(lower)];
7231
+ }
7232
+ },
7233
+ getOwnPropertyNames: function getOwnPropertyNames() {
7234
+ return Object.getOwnPropertyNames(colorbrewerTypes);
7235
+ }
7236
+ })
7237
+ : colorbrewer;
7238
+
7239
+ // feel free to comment out anything to rollup
7240
+ // a smaller chroma.js bundle
7241
+
7242
+ Object.assign(chroma, {
7243
+ analyze: analyze,
7244
+ average: average,
7245
+ bezier: bezier$1,
7246
+ blend: blend,
7247
+ brewer: colorbrewerProxy,
7248
+ Color: Color,
7249
+ colors: w3cx11,
7250
+ contrast: contrast,
7251
+ contrastAPCA: contrastAPCA,
7252
+ cubehelix: cubehelix,
7253
+ deltaE: deltaE,
7254
+ distance: distance,
7255
+ input: input,
7256
+ interpolate: mix,
7257
+ limits: limits,
7258
+ mix: mix,
7259
+ random: random$1,
7260
+ scale: scale,
7261
+ scales: scales,
7262
+ valid: valid,
7263
+ cmyk: cmyk,
7264
+ css: css,
7265
+ gl: gl,
7266
+ hcg: hcg$1,
7267
+ hex: hex,
7268
+ hsi: hsi$1,
7269
+ hsl: hsl$1,
7270
+ hsv: hsv$1,
7271
+ lab: lab$1,
7272
+ lch: lch$1,
7273
+ hcl: hcl,
7274
+ num: num$1,
7275
+ rgb: rgb$1,
7276
+ temp: temp,
7277
+ kelvin: temp,
7278
+ temperature: temp,
7279
+ oklab: oklab$1,
7280
+ oklch: oklch$1,
7281
+ getLabWhitePoint: getLabWhitePoint,
7282
+ setLabWhitePoint: setLabWhitePoint
7283
+ });
7284
+
7285
+ return chroma;
7286
+
7287
+ }));
7288
+
7289
+
3252
7290
  /***/ },
3253
7291
 
3254
7292
  /***/ "./node_modules/object-assign/index.js"
@@ -5194,12 +9232,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5194
9232
  Object.defineProperty(exports, "__esModule", ({ value: true }));
5195
9233
  exports.VerticalLayoutContext = void 0;
5196
9234
  var jsx_runtime_1 = __webpack_require__(/*! react/jsx-runtime */ "./node_modules/react/jsx-runtime.js");
5197
- var header1_jpg_1 = __importDefault(__webpack_require__(/*! ../../../assets/header1.jpg */ "./src/assets/header1.jpg"));
5198
- var header2_jpg_1 = __importDefault(__webpack_require__(/*! ../../../assets/header2.jpg */ "./src/assets/header2.jpg"));
5199
- var header3_jpg_1 = __importDefault(__webpack_require__(/*! ../../../assets/header3.jpg */ "./src/assets/header3.jpg"));
5200
- var body_png_1 = __importDefault(__webpack_require__(/*! ../../../assets/body.png */ "./src/assets/body.png"));
5201
- var body3_png_1 = __importDefault(__webpack_require__(/*! ../../../assets/body3.png */ "./src/assets/body3.png"));
5202
- var body2_png_1 = __importDefault(__webpack_require__(/*! ../../../assets/body2.png */ "./src/assets/body2.png"));
5203
9235
  var ts_pattern_1 = __webpack_require__(/*! ts-pattern */ "./node_modules/ts-pattern/dist/index.cjs");
5204
9236
  var react_1 = __webpack_require__(/*! react */ "react");
5205
9237
  var antd_1 = __webpack_require__(/*! antd */ "antd");
@@ -5213,20 +9245,7 @@ var VerticalHeader_1 = __importDefault(__webpack_require__(/*! ./VerticalHeader
5213
9245
  var VerticalContent_1 = __importDefault(__webpack_require__(/*! ./VerticalContent */ "./src/components/layout/VerticalLayout/VerticalContent.tsx"));
5214
9246
  var utils_1 = __webpack_require__(/*! ../utils */ "./src/components/layout/utils.ts");
5215
9247
  var antd_style_1 = __webpack_require__(/*! antd-style */ "antd-style");
5216
- var getThemedBackgroundPicture = function (theme) {
5217
- return (0, ts_pattern_1.match)(theme)
5218
- .with("classic", function () { return header1_jpg_1.default; })
5219
- .with("submarine", function () { return header2_jpg_1.default; })
5220
- .with("mystical", function () { return header3_jpg_1.default; })
5221
- .exhaustive();
5222
- };
5223
- var getThemedContentBackgroundPicture = function (theme) {
5224
- return (0, ts_pattern_1.match)(theme)
5225
- .with("classic", function () { return body_png_1.default; })
5226
- .with("submarine", function () { return body2_png_1.default; })
5227
- .with("mystical", function () { return body3_png_1.default; })
5228
- .exhaustive();
5229
- };
9248
+ var theming_util_1 = __webpack_require__(/*! ../../../utils/theming.util */ "./src/utils/theming.util.ts");
5230
9249
  exports.VerticalLayoutContext = (0, react_1.createContext)(null);
5231
9250
  var VerticalLayout = function (_a) {
5232
9251
  var _b;
@@ -5326,9 +9345,9 @@ var VerticalLayout = function (_a) {
5326
9345
  .with({ type: "theme" }, function (_a) {
5327
9346
  var theme = _a.theme;
5328
9347
  if (theme !== "classic") {
5329
- return getThemedBackgroundPicture(theme);
9348
+ return (0, theming_util_1.getThemedBackgroundPicture)(theme);
5330
9349
  }
5331
- return getThemedBackgroundPicture(defaultTheme);
9350
+ return (0, theming_util_1.getThemedBackgroundPicture)(defaultTheme);
5332
9351
  })
5333
9352
  .with({ type: "custom-image" }, function (_a) {
5334
9353
  var src = _a.src;
@@ -5342,9 +9361,9 @@ var VerticalLayout = function (_a) {
5342
9361
  .with({ type: "theme" }, function (_a) {
5343
9362
  var theme = _a.theme;
5344
9363
  if (theme !== "classic") {
5345
- return getThemedContentBackgroundPicture(theme);
9364
+ return (0, theming_util_1.getThemedContentBackgroundPicture)(theme);
5346
9365
  }
5347
- return getThemedContentBackgroundPicture(defaultTheme);
9366
+ return (0, theming_util_1.getThemedContentBackgroundPicture)(defaultTheme);
5348
9367
  })
5349
9368
  .with({ type: "custom-image" }, function (_a) {
5350
9369
  var src = _a.src;
@@ -6659,6 +10678,106 @@ exports["default"] = Menu;
6659
10678
  var templateObject_1;
6660
10679
 
6661
10680
 
10681
+ /***/ },
10682
+
10683
+ /***/ "./src/components/ui/Modal/Modal.tsx"
10684
+ /*!*******************************************!*\
10685
+ !*** ./src/components/ui/Modal/Modal.tsx ***!
10686
+ \*******************************************/
10687
+ (__unused_webpack_module, exports, __webpack_require__) {
10688
+
10689
+ "use strict";
10690
+
10691
+ var __assign = (this && this.__assign) || function () {
10692
+ __assign = Object.assign || function(t) {
10693
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
10694
+ s = arguments[i];
10695
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
10696
+ t[p] = s[p];
10697
+ }
10698
+ return t;
10699
+ };
10700
+ return __assign.apply(this, arguments);
10701
+ };
10702
+ var __rest = (this && this.__rest) || function (s, e) {
10703
+ var t = {};
10704
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
10705
+ t[p] = s[p];
10706
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
10707
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
10708
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
10709
+ t[p[i]] = s[p[i]];
10710
+ }
10711
+ return t;
10712
+ };
10713
+ var __importDefault = (this && this.__importDefault) || function (mod) {
10714
+ return (mod && mod.__esModule) ? mod : { "default": mod };
10715
+ };
10716
+ Object.defineProperty(exports, "__esModule", ({ value: true }));
10717
+ var jsx_runtime_1 = __webpack_require__(/*! react/jsx-runtime */ "./node_modules/react/jsx-runtime.js");
10718
+ /**
10719
+ * @description A long list can be divided into several pages using Pagination, and only one page will be loaded at a time.
10720
+ */
10721
+ var antd_1 = __webpack_require__(/*! antd */ "antd");
10722
+ var antd_style_1 = __webpack_require__(/*! antd-style */ "antd-style");
10723
+ var theming_util_1 = __webpack_require__(/*! ../../../utils/theming.util */ "./src/utils/theming.util.ts");
10724
+ var chroma_js_1 = __importDefault(__webpack_require__(/*! chroma-js */ "./node_modules/chroma-js/dist/chroma.cjs"));
10725
+ var Typography_1 = __importDefault(__webpack_require__(/*! ../Typography/Typography */ "./src/components/ui/Typography/Typography.tsx"));
10726
+ var Space_1 = __importDefault(__webpack_require__(/*! ../Space/Space */ "./src/components/ui/Space/Space.tsx"));
10727
+ var ts_pattern_1 = __webpack_require__(/*! ts-pattern */ "./node_modules/ts-pattern/dist/index.cjs");
10728
+ var Modal = function (_a) {
10729
+ var title = _a.title, subtitle = _a.subtitle, _b = _a.headerBgTheme, headerBgTheme = _b === void 0 ? "classic" : _b, _c = _a.iconPosition, iconPosition = _c === void 0 ? "start" : _c, props = __rest(_a, ["title", "subtitle", "headerBgTheme", "iconPosition"]);
10730
+ var useToken = antd_1.theme.useToken;
10731
+ var defaultTheme = (0, antd_style_1.useTheme)().appTheme; // get the app theme
10732
+ // get the header background theme - check global config and scoped config
10733
+ var getHeaderBackgroundTheme = function () {
10734
+ if (headerBgTheme !== "classic") {
10735
+ return (0, theming_util_1.getThemedTitleHeaderBackgroundPicture)(headerBgTheme);
10736
+ }
10737
+ return (0, theming_util_1.getThemedTitleHeaderBackgroundPicture)(defaultTheme);
10738
+ };
10739
+ var getLinearGradient = function (firstColor, secondColor) {
10740
+ return "linear-gradient(70deg, ".concat(firstColor, "CC 80%, ").concat(secondColor, "69 80%), url(").concat(getHeaderBackgroundTheme(), ")");
10741
+ };
10742
+ // account for dark mode
10743
+ var getHeaderBgGradient = function () {
10744
+ var darkerColor = chroma_js_1.default
10745
+ .scale([useToken().token.colorPrimary, "black"])(0.2)
10746
+ .hex();
10747
+ return (0, ts_pattern_1.match)((0, antd_style_1.useTheme)().appThemeMode)
10748
+ .with("light", function () {
10749
+ var lighterColor = chroma_js_1.default
10750
+ .scale([useToken().token.colorPrimary, "white"])(0.7)
10751
+ .hex();
10752
+ return getLinearGradient(lighterColor, darkerColor);
10753
+ })
10754
+ .with("dark", function () {
10755
+ var darkestColor = chroma_js_1.default
10756
+ .scale([useToken().token.colorPrimary, "black"])(0.7)
10757
+ .hex();
10758
+ return getLinearGradient(darkerColor, darkestColor);
10759
+ })
10760
+ .exhaustive();
10761
+ };
10762
+ return ((0, jsx_runtime_1.jsx)(antd_1.Modal, __assign({ styles: {
10763
+ container: {
10764
+ padding: 0,
10765
+ },
10766
+ header: {
10767
+ background: getHeaderBgGradient(),
10768
+ padding: "15px 24px",
10769
+ },
10770
+ body: {
10771
+ padding: "0px 24px",
10772
+ },
10773
+ footer: {
10774
+ padding: "0px 24px 15px 24px",
10775
+ },
10776
+ }, title: (0, jsx_runtime_1.jsxs)(Space_1.default, { orientation: "vertical", size: 0, children: [(0, jsx_runtime_1.jsxs)(Space_1.default, { orientation: "horizontal", children: [iconPosition === "start" && props.icon, title, iconPosition === "end" && props.icon] }), (0, jsx_runtime_1.jsx)(Typography_1.default.Overline, { children: subtitle })] }) }, props)));
10777
+ };
10778
+ exports["default"] = Modal;
10779
+
10780
+
6662
10781
  /***/ },
6663
10782
 
6664
10783
  /***/ "./src/components/ui/Pagination/Pagination.tsx"
@@ -7495,7 +11614,7 @@ var Title = function (_a) {
7495
11614
  return ((0, jsx_runtime_1.jsxs)(Space_1.default, { orientation: "horizontal", children: [iconPosition === "start" && props.icon, (0, jsx_runtime_1.jsx)(antd_1.Typography.Title, __assign({ className: "\n\t\t\t\t\t".concat(typoStyles.common, "\n\t\t\t\t\t").concat(typoStyles.title, "\n\t\t\t\t\t").concat(typoStyles["titleH".concat(level)], "\n\t\t\t\t\t").concat(showPointer ? "pointer" : "", "\n\t\t\t\t"), level: level }, props, { children: children })), iconPosition === "end" && props.icon] }));
7496
11615
  };
7497
11616
  var Text = function (_a) {
7498
- var children = _a.children, _b = _a.level, level = _b === void 0 ? 2 : _b, color = _a.color, antdProps = __rest(_a, ["children", "level", "color"]);
11617
+ var children = _a.children, _b = _a.level, level = _b === void 0 ? 1 : _b, color = _a.color, antdProps = __rest(_a, ["children", "level", "color"]);
7499
11618
  var typoStyles = (0, useTypographyStyles_1.useTypographyStyles)(color).styles;
7500
11619
  return ((0, jsx_runtime_1.jsx)(antd_1.Typography.Text, __assign({ className: "\n\t\t\t\t".concat(typoStyles.common, "\n\t\t\t\t").concat(typoStyles.text, " \n\t\t\t\t").concat(typoStyles["textBody".concat(level)], "\n\t\t\t") }, antdProps, { children: children })));
7501
11620
  };
@@ -7519,6 +11638,11 @@ var Paragraph = function (_a) {
7519
11638
  var typoStyles = (0, useTypographyStyles_1.useTypographyStyles)(color).styles;
7520
11639
  return ((0, jsx_runtime_1.jsx)(antd_1.Typography.Text, __assign({ className: "\n\t\t\t\t".concat(typoStyles.common, "\n\t\t\t\t").concat(typoStyles.textBody2, "\n\t\t\t\t").concat(typoStyles.paragraph, "\n\t\t\t") }, antdProps, { children: children })));
7521
11640
  };
11641
+ var Link = function (_a) {
11642
+ var children = _a.children, color = _a.color, antdProps = __rest(_a, ["children", "color"]);
11643
+ var typoStyles = (0, useTypographyStyles_1.useTypographyStyles)(color).styles;
11644
+ return ((0, jsx_runtime_1.jsx)(antd_1.Typography.Link, __assign({ className: "\n\t\t\t\t".concat(typoStyles.common, "\n\t\t\t\t").concat(typoStyles.textBody1, "\n\t\t\t\t").concat(typoStyles.link, "\n\t\t\t") }, antdProps, { children: children })));
11645
+ };
7522
11646
  /**
7523
11647
  * Basic text writing, including headings, body text, lists, and more.
7524
11648
  *
@@ -7535,6 +11659,7 @@ Typography.Caption = Caption;
7535
11659
  Typography.Overline = Overline;
7536
11660
  Typography.Paragraph = Paragraph;
7537
11661
  Typography.Emphasis = Emphasis;
11662
+ Typography.Link = Link;
7538
11663
  exports["default"] = Typography;
7539
11664
 
7540
11665
 
@@ -7577,11 +11702,12 @@ var useTypographyStyles = function (color) {
7577
11702
  paragraph: css(templateObject_12 || (templateObject_12 = __makeTemplateObject(["\n display: block;\n margin-bottom: 20px;\n "], ["\n display: block;\n margin-bottom: 20px;\n "]))),
7578
11703
  caption: css(templateObject_13 || (templateObject_13 = __makeTemplateObject(["\n letter-spacing: ", ";\n font-size: ", "px;\n font-weight: 500;\n "], ["\n letter-spacing: ", ";\n font-size: ", "px;\n font-weight: 500;\n "])), typographyUtil_1.typographyUtil.letterSpacing.caption, typographyUtil_1.typographyUtil.fontSize.caption),
7579
11704
  overline: css(templateObject_14 || (templateObject_14 = __makeTemplateObject(["\n letter-spacing: ", ";\n font-size: ", "px;\n font-weight: 600;\n opacity: 0.88;\n text-transform: uppercase;\n \n &&.", "-typography {\n margin-bottom: 0;\n }\n "], ["\n letter-spacing: ", ";\n font-size: ", "px;\n font-weight: 600;\n opacity: 0.88;\n text-transform: uppercase;\n \n &&.", "-typography {\n margin-bottom: 0;\n }\n "])), typographyUtil_1.typographyUtil.letterSpacing.overline, typographyUtil_1.typographyUtil.fontSize.overline, prefixCls),
11705
+ link: css(templateObject_15 || (templateObject_15 = __makeTemplateObject(["\n text-decoration: underline !important;\n text-underline-offset: 3px;\n \n &&.", "-typography {\n margin-bottom: 0;\n }\n "], ["\n text-decoration: underline !important;\n text-underline-offset: 3px;\n \n &&.", "-typography {\n margin-bottom: 0;\n }\n "])), prefixCls),
7580
11706
  });
7581
11707
  })();
7582
11708
  };
7583
11709
  exports.useTypographyStyles = useTypographyStyles;
7584
- var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10, templateObject_11, templateObject_12, templateObject_13, templateObject_14;
11710
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10, templateObject_11, templateObject_12, templateObject_13, templateObject_14, templateObject_15;
7585
11711
 
7586
11712
 
7587
11713
  /***/ },
@@ -7809,7 +11935,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
7809
11935
  return (mod && mod.__esModule) ? mod : { "default": mod };
7810
11936
  };
7811
11937
  Object.defineProperty(exports, "__esModule", ({ value: true }));
7812
- exports.useScreenSize = exports.useAcaciaConfig = exports.useFoucHandler = exports.useAcaciaColors = exports.VerticalContent = exports.VerticalHeader = exports.VerticalLayout = exports.Popconfirm = exports.Panel = exports.Space = exports.Menu = exports.Avatar = exports.Tabs = exports.Tag = exports.Card = exports.DatePicker = exports.TimePicker = exports.Typography = exports.Pagination = exports.Dropdown = exports.Input = exports.Switch = exports.Select = exports.Segmented = exports.Radio = exports.Checkbox = exports.Breadcrumb = exports.ConfigProvider = exports.Badge = exports.Button = void 0;
11938
+ exports.useScreenSize = exports.useAcaciaConfig = exports.useFoucHandler = exports.useAcaciaColors = exports.VerticalContent = exports.VerticalHeader = exports.VerticalLayout = exports.Modal = exports.Popconfirm = exports.Panel = exports.Space = exports.Menu = exports.Avatar = exports.Tabs = exports.Tag = exports.Card = exports.DatePicker = exports.TimePicker = exports.Typography = exports.Pagination = exports.Dropdown = exports.Input = exports.Switch = exports.Select = exports.Segmented = exports.Radio = exports.Checkbox = exports.Breadcrumb = exports.ConfigProvider = exports.Badge = exports.Button = void 0;
7813
11939
  var Button_1 = __webpack_require__(/*! ./components/ui/Button/Button */ "./src/components/ui/Button/Button.tsx");
7814
11940
  Object.defineProperty(exports, "Button", ({ enumerable: true, get: function () { return __importDefault(Button_1).default; } }));
7815
11941
  var Badge_1 = __webpack_require__(/*! ./components/ui/Badge/Badge */ "./src/components/ui/Badge/Badge.tsx");
@@ -7856,6 +11982,8 @@ var Panel_1 = __webpack_require__(/*! ./components/ui/Panel/Panel */ "./src/comp
7856
11982
  Object.defineProperty(exports, "Panel", ({ enumerable: true, get: function () { return __importDefault(Panel_1).default; } }));
7857
11983
  var Popconfirm_1 = __webpack_require__(/*! ./components/ui/Popconfirm/Popconfirm */ "./src/components/ui/Popconfirm/Popconfirm.tsx");
7858
11984
  Object.defineProperty(exports, "Popconfirm", ({ enumerable: true, get: function () { return __importDefault(Popconfirm_1).default; } }));
11985
+ var Modal_1 = __webpack_require__(/*! ./components/ui/Modal/Modal */ "./src/components/ui/Modal/Modal.tsx");
11986
+ Object.defineProperty(exports, "Modal", ({ enumerable: true, get: function () { return __importDefault(Modal_1).default; } }));
7859
11987
  var VerticalLayout_1 = __webpack_require__(/*! ./components/layout/VerticalLayout/VerticalLayout */ "./src/components/layout/VerticalLayout/VerticalLayout.tsx");
7860
11988
  Object.defineProperty(exports, "VerticalLayout", ({ enumerable: true, get: function () { return __importDefault(VerticalLayout_1).default; } }));
7861
11989
  var VerticalHeader_1 = __webpack_require__(/*! ./components/layout/VerticalLayout/VerticalHeader */ "./src/components/layout/VerticalLayout/VerticalHeader.tsx");
@@ -8132,6 +12260,59 @@ function parseBackgroundColors(css) {
8132
12260
  }
8133
12261
 
8134
12262
 
12263
+ /***/ },
12264
+
12265
+ /***/ "./src/utils/theming.util.ts"
12266
+ /*!***********************************!*\
12267
+ !*** ./src/utils/theming.util.ts ***!
12268
+ \***********************************/
12269
+ (__unused_webpack_module, exports, __webpack_require__) {
12270
+
12271
+ "use strict";
12272
+
12273
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12274
+ return (mod && mod.__esModule) ? mod : { "default": mod };
12275
+ };
12276
+ Object.defineProperty(exports, "__esModule", ({ value: true }));
12277
+ exports.getThemedTitleHeaderBackgroundPicture = exports.getThemedContentBackgroundPicture = exports.getThemedBackgroundPicture = void 0;
12278
+ var header1_jpg_1 = __importDefault(__webpack_require__(/*! ../assets/header1.jpg */ "./src/assets/header1.jpg"));
12279
+ var header2_jpg_1 = __importDefault(__webpack_require__(/*! ../assets/header2.jpg */ "./src/assets/header2.jpg"));
12280
+ var header3_jpg_1 = __importDefault(__webpack_require__(/*! ../assets/header3.jpg */ "./src/assets/header3.jpg"));
12281
+ var body_png_1 = __importDefault(__webpack_require__(/*! ../assets/body.png */ "./src/assets/body.png"));
12282
+ var body3_png_1 = __importDefault(__webpack_require__(/*! ../assets/body3.png */ "./src/assets/body3.png"));
12283
+ var body2_png_1 = __importDefault(__webpack_require__(/*! ../assets/body2.png */ "./src/assets/body2.png"));
12284
+ var cardheader_png_1 = __importDefault(__webpack_require__(/*! ../assets/cardheader.png */ "./src/assets/cardheader.png"));
12285
+ var cardheader2_png_1 = __importDefault(__webpack_require__(/*! ../assets/cardheader2.png */ "./src/assets/cardheader2.png"));
12286
+ var cardheader3_png_1 = __importDefault(__webpack_require__(/*! ../assets/cardheader3.png */ "./src/assets/cardheader3.png"));
12287
+ var ts_pattern_1 = __webpack_require__(/*! ts-pattern */ "./node_modules/ts-pattern/dist/index.cjs");
12288
+ // for vertical layout
12289
+ var getThemedBackgroundPicture = function (theme) {
12290
+ return (0, ts_pattern_1.match)(theme)
12291
+ .with("classic", function () { return header1_jpg_1.default; })
12292
+ .with("submarine", function () { return header2_jpg_1.default; })
12293
+ .with("mystical", function () { return header3_jpg_1.default; })
12294
+ .exhaustive();
12295
+ };
12296
+ exports.getThemedBackgroundPicture = getThemedBackgroundPicture;
12297
+ var getThemedContentBackgroundPicture = function (theme) {
12298
+ return (0, ts_pattern_1.match)(theme)
12299
+ .with("classic", function () { return body_png_1.default; })
12300
+ .with("submarine", function () { return body2_png_1.default; })
12301
+ .with("mystical", function () { return body3_png_1.default; })
12302
+ .exhaustive();
12303
+ };
12304
+ exports.getThemedContentBackgroundPicture = getThemedContentBackgroundPicture;
12305
+ // for title headers bg
12306
+ var getThemedTitleHeaderBackgroundPicture = function (theme) {
12307
+ return (0, ts_pattern_1.match)(theme)
12308
+ .with("classic", function () { return cardheader_png_1.default; })
12309
+ .with("submarine", function () { return cardheader2_png_1.default; })
12310
+ .with("mystical", function () { return cardheader3_png_1.default; })
12311
+ .exhaustive();
12312
+ };
12313
+ exports.getThemedTitleHeaderBackgroundPicture = getThemedTitleHeaderBackgroundPicture;
12314
+
12315
+
8135
12316
  /***/ },
8136
12317
 
8137
12318
  /***/ "antd"