chroma-js 0.0.1 → 1.0.7

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: 5f0b20b20011078c4d989060e5ee8e2593ac7580
4
- data.tar.gz: ef73aa3b5747e1cc7304337c12b8c8dc85c0bf59
2
+ SHA256:
3
+ metadata.gz: a07c97159a0a8059edaeba27882f924ff5e2d48329fff2b7c65899a2fc87bced
4
+ data.tar.gz: c3feb17ddd1c4e543aa6145e985fdfc46c4e32c9ccc56576d3de1c1399dcd859
5
5
  SHA512:
6
- metadata.gz: 9495053968fa39790d2c525b3e1710d2d901083dd2f6b3cec2ef6f58bc8ed8d2319026afa6043ce2d339e32b88a269ffc9c1594c5c44ec96612b1b690fb769bf
7
- data.tar.gz: ca5be78de3abf108977fbc41b54504b12c582e162173d9f935eab06446577212bca4e0a8b4675aa24643e0dee3f877a6ff5e4d1d3496cec7196dac9bf8341f5e
6
+ metadata.gz: 320bb126ff33ceeb0ec0c261a78ea2aeb6539cd8dcac0bfb9f56dc22459a401e2e6a60d39a62b5e8f4d38e5cbaab51376cdf043c195f086eee5c75ef9564707a
7
+ data.tar.gz: 2bbc46d90d6f2a4c2ca645f2f152ae2654929b86492cd664356f0fd52fb90c15913e3d1776f1ba4928ae6f3bd1a892e42289be81387fd975e7728f363f53c6ad
@@ -0,0 +1,42 @@
1
+ name: Ruby Gem
2
+
3
+ on:
4
+ push:
5
+ branches: [ master ]
6
+ pull_request:
7
+ branches: [ master ]
8
+
9
+ jobs:
10
+ build:
11
+ name: Build + Publish
12
+ runs-on: ubuntu-latest
13
+
14
+ steps:
15
+ - uses: actions/checkout@v2
16
+ - name: Set up Ruby 2.6
17
+ uses: actions/setup-ruby@v1
18
+ with:
19
+ ruby-version: 2.6.x
20
+
21
+ - name: Publish to GPR
22
+ run: |
23
+ mkdir -p $HOME/.gem
24
+ touch $HOME/.gem/credentials
25
+ chmod 0600 $HOME/.gem/credentials
26
+ printf -- "---\n:github: ${GEM_HOST_API_KEY}\n" > $HOME/.gem/credentials
27
+ gem build chroma.js-rails.gemspec
28
+ gem push chroma.js-rails-*.gem --KEY github --host https://rubygems.pkg.github.com/${OWNER}
29
+ env:
30
+ GEM_HOST_API_KEY: "Bearer ${{secrets.GITHUB_TOKEN}}"
31
+ OWNER: ${{ github.repository_owner }}
32
+
33
+ - name: Publish to RubyGems
34
+ run: |
35
+ mkdir -p $HOME/.gem
36
+ touch $HOME/.gem/credentials
37
+ chmod 0600 $HOME/.gem/credentials
38
+ printf -- "---\n:rubygems_api_key: ${GEM_HOST_API_KEY}\n" > $HOME/.gem/credentials
39
+ gem build chroma-js.gemspec
40
+ gem push chroma-js-*.gem
41
+ env:
42
+ GEM_HOST_API_KEY: "${{secrets.RUBYGEMS_AUTH_TOKEN}}"
data/.gitignore CHANGED
@@ -20,3 +20,4 @@ tmp
20
20
  *.o
21
21
  *.a
22
22
  mkmf.log
23
+ bin/
data/Gemfile CHANGED
@@ -1,4 +1,3 @@
1
- source 'https://rubygems.org'
1
+ source 'https://rubygems.org/'
2
2
 
3
- # Specify your gem's dependencies in chroma.js-rails.gemspec
4
3
  gemspec
data/README.md CHANGED
@@ -1,4 +1,4 @@
1
- # Chroma.js::Rails
1
+ # Chroma.js::Rails [![Gem Version](https://badge.fury.io/rb/chroma-js.svg)](http://badge.fury.io/rb/chroma-js)
2
2
 
3
3
  A Gem for Chroma.js library<br>
4
4
  This Gem is made to support the use of Chroma.js library with Rails Assets
@@ -20,10 +20,14 @@ Or install it yourself as:
20
20
  ## Usage
21
21
 
22
22
  ### CoffeScript
23
- #= require chroma-js
23
+ #= require chroma
24
24
 
25
25
  ### JavaScript
26
- //= require chroma-js
26
+ //= require chroma
27
+
28
+ ## Info
29
+
30
+ To contribute with Chroma.JS and or to get any informations about it, see the [Chroma.JS Repo](https://github.com/gka/chroma.js).
27
31
 
28
32
  ## Contributing
29
33
 
data/Rakefile CHANGED
@@ -1,2 +1,2 @@
1
- require "bundler/gem_tasks"
2
-
1
+ require 'bundler'
2
+ Bundler::GemHelper.install_tasks
@@ -0,0 +1,1863 @@
1
+ // Generated by CoffeeScript 1.6.2
2
+ /** echo * @license echo * while read i do echo * done echo
3
+ */
4
+
5
+
6
+ (function() {
7
+ var Color, K, PITHIRD, TWOPI, X, Y, Z, bezier, brewer, chroma, clip_rgb, colors, cos, css2rgb, hex2rgb, hsi2rgb, hsl2rgb, hsv2rgb, lab2lch, lab2rgb, lab_xyz, lch2lab, lch2rgb, limit, luminance, luminance_x, rgb2hex, rgb2hsi, rgb2hsl, rgb2hsv, rgb2lab, rgb2lch, rgb_xyz, root, type, unpack, xyz_lab, xyz_rgb, _ref;
8
+
9
+ chroma = function(x, y, z, m) {
10
+ return new Color(x, y, z, m);
11
+ };
12
+
13
+ if ((typeof module !== "undefined" && module !== null) && (module.exports != null)) {
14
+ module.exports = chroma;
15
+ }
16
+
17
+ if (typeof define === 'function' && define.amd) {
18
+ define([], function() {
19
+ return chroma;
20
+ });
21
+ } else {
22
+ root = typeof exports !== "undefined" && exports !== null ? exports : this;
23
+ root.chroma = chroma;
24
+ }
25
+
26
+ chroma.color = function(x, y, z, m) {
27
+ return new Color(x, y, z, m);
28
+ };
29
+
30
+ chroma.hsl = function(h, s, l, a) {
31
+ return new Color(h, s, l, a, 'hsl');
32
+ };
33
+
34
+ chroma.hsv = function(h, s, v, a) {
35
+ return new Color(h, s, v, a, 'hsv');
36
+ };
37
+
38
+ chroma.rgb = function(r, g, b, a) {
39
+ return new Color(r, g, b, a, 'rgb');
40
+ };
41
+
42
+ chroma.hex = function(x) {
43
+ return new Color(x);
44
+ };
45
+
46
+ chroma.css = function(x) {
47
+ return new Color(x);
48
+ };
49
+
50
+ chroma.lab = function(l, a, b) {
51
+ return new Color(l, a, b, 'lab');
52
+ };
53
+
54
+ chroma.lch = function(l, c, h) {
55
+ return new Color(l, c, h, 'lch');
56
+ };
57
+
58
+ chroma.hsi = function(h, s, i) {
59
+ return new Color(h, s, i, 'hsi');
60
+ };
61
+
62
+ chroma.gl = function(r, g, b, a) {
63
+ return new Color(r * 255, g * 255, b * 255, a, 'gl');
64
+ };
65
+
66
+ chroma.interpolate = function(a, b, f, m) {
67
+ if ((a == null) || (b == null)) {
68
+ return '#000';
69
+ }
70
+ if (type(a) === 'string') {
71
+ a = new Color(a);
72
+ }
73
+ if (type(b) === 'string') {
74
+ b = new Color(b);
75
+ }
76
+ return a.interpolate(f, b, m);
77
+ };
78
+
79
+ chroma.mix = chroma.interpolate;
80
+
81
+ chroma.contrast = function(a, b) {
82
+ var l1, l2;
83
+
84
+ if (type(a) === 'string') {
85
+ a = new Color(a);
86
+ }
87
+ if (type(b) === 'string') {
88
+ b = new Color(b);
89
+ }
90
+ l1 = a.luminance();
91
+ l2 = b.luminance();
92
+ if (l1 > l2) {
93
+ return (l1 + 0.05) / (l2 + 0.05);
94
+ } else {
95
+ return (l2 + 0.05) / (l1 + 0.05);
96
+ }
97
+ };
98
+
99
+ chroma.luminance = function(color) {
100
+ return chroma(color).luminance();
101
+ };
102
+
103
+ chroma._Color = Color;
104
+
105
+ /**
106
+ chroma.js
107
+
108
+ Copyright (c) 2011-2013, Gregor Aisch
109
+ All rights reserved.
110
+
111
+ Redistribution and use in source and binary forms, with or without
112
+ modification, are permitted provided that the following conditions are met:
113
+
114
+ * Redistributions of source code must retain the above copyright notice, this
115
+ list of conditions and the following disclaimer.
116
+
117
+ * Redistributions in binary form must reproduce the above copyright notice,
118
+ this list of conditions and the following disclaimer in the documentation
119
+ and/or other materials provided with the distribution.
120
+
121
+ * The name Gregor Aisch may not be used to endorse or promote products
122
+ derived from this software without specific prior written permission.
123
+
124
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
125
+ AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
126
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
127
+ DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
128
+ INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
129
+ BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
130
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
131
+ OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
132
+ NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
133
+ EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
134
+
135
+ @source: https://github.com/gka/chroma.js
136
+ */
137
+
138
+
139
+ Color = (function() {
140
+ function Color() {
141
+ var a, arg, args, m, me, me_rgb, x, y, z, _i, _len, _ref, _ref1, _ref2, _ref3, _ref4;
142
+
143
+ me = this;
144
+ args = [];
145
+ for (_i = 0, _len = arguments.length; _i < _len; _i++) {
146
+ arg = arguments[_i];
147
+ if (arg != null) {
148
+ args.push(arg);
149
+ }
150
+ }
151
+ if (args.length === 0) {
152
+ _ref = [255, 0, 255, 1, 'rgb'], x = _ref[0], y = _ref[1], z = _ref[2], a = _ref[3], m = _ref[4];
153
+ } else if (type(args[0]) === "array") {
154
+ if (args[0].length === 3) {
155
+ _ref1 = args[0], x = _ref1[0], y = _ref1[1], z = _ref1[2];
156
+ a = 1;
157
+ } else if (args[0].length === 4) {
158
+ _ref2 = args[0], x = _ref2[0], y = _ref2[1], z = _ref2[2], a = _ref2[3];
159
+ } else {
160
+ throw 'unknown input argument';
161
+ }
162
+ m = (_ref3 = args[1]) != null ? _ref3 : 'rgb';
163
+ } else if (type(args[0]) === "string") {
164
+ x = args[0];
165
+ m = 'hex';
166
+ } else if (type(args[0]) === "object") {
167
+ _ref4 = args[0]._rgb, x = _ref4[0], y = _ref4[1], z = _ref4[2], a = _ref4[3];
168
+ m = 'rgb';
169
+ } else if (args.length >= 3) {
170
+ x = args[0];
171
+ y = args[1];
172
+ z = args[2];
173
+ }
174
+ if (args.length === 3) {
175
+ m = 'rgb';
176
+ a = 1;
177
+ } else if (args.length === 4) {
178
+ if (type(args[3]) === "string") {
179
+ m = args[3];
180
+ a = 1;
181
+ } else if (type(args[3]) === "number") {
182
+ m = 'rgb';
183
+ a = args[3];
184
+ }
185
+ } else if (args.length === 5) {
186
+ a = args[3];
187
+ m = args[4];
188
+ }
189
+ if (a == null) {
190
+ a = 1;
191
+ }
192
+ if (m === 'rgb') {
193
+ me._rgb = [x, y, z, a];
194
+ } else if (m === 'gl') {
195
+ me._rgb = [x * 255, y * 255, z * 255, a];
196
+ } else if (m === 'hsl') {
197
+ me._rgb = hsl2rgb(x, y, z);
198
+ me._rgb[3] = a;
199
+ } else if (m === 'hsv') {
200
+ me._rgb = hsv2rgb(x, y, z);
201
+ me._rgb[3] = a;
202
+ } else if (m === 'hex') {
203
+ me._rgb = hex2rgb(x);
204
+ } else if (m === 'lab') {
205
+ me._rgb = lab2rgb(x, y, z);
206
+ me._rgb[3] = a;
207
+ } else if (m === 'lch') {
208
+ me._rgb = lch2rgb(x, y, z);
209
+ me._rgb[3] = a;
210
+ } else if (m === 'hsi') {
211
+ me._rgb = hsi2rgb(x, y, z);
212
+ me._rgb[3] = a;
213
+ }
214
+ me_rgb = clip_rgb(me._rgb);
215
+ }
216
+
217
+ Color.prototype.rgb = function() {
218
+ return this._rgb.slice(0, 3);
219
+ };
220
+
221
+ Color.prototype.rgba = function() {
222
+ return this._rgb;
223
+ };
224
+
225
+ Color.prototype.hex = function() {
226
+ return rgb2hex(this._rgb);
227
+ };
228
+
229
+ Color.prototype.toString = function() {
230
+ return this.name();
231
+ };
232
+
233
+ Color.prototype.hsl = function() {
234
+ return rgb2hsl(this._rgb);
235
+ };
236
+
237
+ Color.prototype.hsv = function() {
238
+ return rgb2hsv(this._rgb);
239
+ };
240
+
241
+ Color.prototype.lab = function() {
242
+ return rgb2lab(this._rgb);
243
+ };
244
+
245
+ Color.prototype.lch = function() {
246
+ return rgb2lch(this._rgb);
247
+ };
248
+
249
+ Color.prototype.hsi = function() {
250
+ return rgb2hsi(this._rgb);
251
+ };
252
+
253
+ Color.prototype.gl = function() {
254
+ return [this._rgb[0] / 255, this._rgb[1] / 255, this._rgb[2] / 255, this._rgb[3]];
255
+ };
256
+
257
+ Color.prototype.luminance = function() {
258
+ return luminance(this._rgb);
259
+ };
260
+
261
+ Color.prototype.name = function() {
262
+ var h, k;
263
+
264
+ h = this.hex();
265
+ for (k in chroma.colors) {
266
+ if (h === chroma.colors[k]) {
267
+ return k;
268
+ }
269
+ }
270
+ return h;
271
+ };
272
+
273
+ Color.prototype.alpha = function(alpha) {
274
+ if (arguments.length) {
275
+ this._rgb[3] = alpha;
276
+ return this;
277
+ }
278
+ return this._rgb[3];
279
+ };
280
+
281
+ Color.prototype.css = function(mode) {
282
+ var hsl, me, rgb, rnd;
283
+
284
+ if (mode == null) {
285
+ mode = 'rgb';
286
+ }
287
+ me = this;
288
+ rgb = me._rgb;
289
+ if (mode.length === 3 && rgb[3] < 1) {
290
+ mode += 'a';
291
+ }
292
+ if (mode === 'rgb') {
293
+ return mode + '(' + rgb.slice(0, 3).map(Math.round).join(',') + ')';
294
+ } else if (mode === 'rgba') {
295
+ return mode + '(' + rgb.slice(0, 3).map(Math.round).join(',') + ',' + rgb[3] + ')';
296
+ } else if (mode === 'hsl' || mode === 'hsla') {
297
+ hsl = me.hsl();
298
+ rnd = function(a) {
299
+ return Math.round(a * 100) / 100;
300
+ };
301
+ hsl[0] = rnd(hsl[0]);
302
+ hsl[1] = rnd(hsl[1] * 100) + '%';
303
+ hsl[2] = rnd(hsl[2] * 100) + '%';
304
+ if (mode.length === 4) {
305
+ hsl[3] = rgb[3];
306
+ }
307
+ return mode + '(' + hsl.join(',') + ')';
308
+ }
309
+ };
310
+
311
+ Color.prototype.interpolate = function(f, col, m) {
312
+ /*
313
+ interpolates between colors
314
+ f = 0 --> me
315
+ f = 1 --> col
316
+ */
317
+
318
+ var dh, hue, hue0, hue1, lbv, lbv0, lbv1, me, res, sat, sat0, sat1, xyz0, xyz1;
319
+
320
+ me = this;
321
+ if (m == null) {
322
+ m = 'rgb';
323
+ }
324
+ if (type(col) === "string") {
325
+ col = new Color(col);
326
+ }
327
+ if (m === 'hsl' || m === 'hsv' || m === 'lch' || m === 'hsi') {
328
+ if (m === 'hsl') {
329
+ xyz0 = me.hsl();
330
+ xyz1 = col.hsl();
331
+ } else if (m === 'hsv') {
332
+ xyz0 = me.hsv();
333
+ xyz1 = col.hsv();
334
+ } else if (m === 'hsi') {
335
+ xyz0 = me.hsi();
336
+ xyz1 = col.hsi();
337
+ } else if (m === 'lch') {
338
+ xyz0 = me.lch();
339
+ xyz1 = col.lch();
340
+ }
341
+ if (m.substr(0, 1) === 'h') {
342
+ hue0 = xyz0[0], sat0 = xyz0[1], lbv0 = xyz0[2];
343
+ hue1 = xyz1[0], sat1 = xyz1[1], lbv1 = xyz1[2];
344
+ } else {
345
+ lbv0 = xyz0[0], sat0 = xyz0[1], hue0 = xyz0[2];
346
+ lbv1 = xyz1[0], sat1 = xyz1[1], hue1 = xyz1[2];
347
+ }
348
+ if (!isNaN(hue0) && !isNaN(hue1)) {
349
+ if (hue1 > hue0 && hue1 - hue0 > 180) {
350
+ dh = hue1 - (hue0 + 360);
351
+ } else if (hue1 < hue0 && hue0 - hue1 > 180) {
352
+ dh = hue1 + 360 - hue0;
353
+ } else {
354
+ dh = hue1 - hue0;
355
+ }
356
+ hue = hue0 + f * dh;
357
+ } else if (!isNaN(hue0)) {
358
+ hue = hue0;
359
+ if ((lbv1 === 1 || lbv1 === 0) && m !== 'hsv') {
360
+ sat = sat0;
361
+ }
362
+ } else if (!isNaN(hue1)) {
363
+ hue = hue1;
364
+ if ((lbv0 === 1 || lbv0 === 0) && m !== 'hsv') {
365
+ sat = sat1;
366
+ }
367
+ } else {
368
+ hue = Number.NaN;
369
+ }
370
+ if (sat == null) {
371
+ sat = sat0 + f * (sat1 - sat0);
372
+ }
373
+ lbv = lbv0 + f * (lbv1 - lbv0);
374
+ if (m.substr(0, 1) === 'h') {
375
+ res = new Color(hue, sat, lbv, m);
376
+ } else {
377
+ res = new Color(lbv, sat, hue, m);
378
+ }
379
+ } else if (m === 'rgb') {
380
+ xyz0 = me._rgb;
381
+ xyz1 = col._rgb;
382
+ res = new Color(xyz0[0] + f * (xyz1[0] - xyz0[0]), xyz0[1] + f * (xyz1[1] - xyz0[1]), xyz0[2] + f * (xyz1[2] - xyz0[2]), m);
383
+ } else if (m === 'lab') {
384
+ xyz0 = me.lab();
385
+ xyz1 = col.lab();
386
+ res = new Color(xyz0[0] + f * (xyz1[0] - xyz0[0]), xyz0[1] + f * (xyz1[1] - xyz0[1]), xyz0[2] + f * (xyz1[2] - xyz0[2]), m);
387
+ } else {
388
+ throw "color mode " + m + " is not supported";
389
+ }
390
+ res.alpha(me.alpha() + f * (col.alpha() - me.alpha()));
391
+ return res;
392
+ };
393
+
394
+ Color.prototype.premultiply = function() {
395
+ var a, rgb;
396
+
397
+ rgb = this.rgb();
398
+ a = this.alpha();
399
+ return chroma(rgb[0] * a, rgb[1] * a, rgb[2] * a, a);
400
+ };
401
+
402
+ Color.prototype.darken = function(amount) {
403
+ var lch, me;
404
+
405
+ if (amount == null) {
406
+ amount = 20;
407
+ }
408
+ me = this;
409
+ lch = me.lch();
410
+ lch[0] -= amount;
411
+ return chroma.lch(lch).alpha(me.alpha());
412
+ };
413
+
414
+ Color.prototype.darker = function(amount) {
415
+ return this.darken(amount);
416
+ };
417
+
418
+ Color.prototype.brighten = function(amount) {
419
+ if (amount == null) {
420
+ amount = 20;
421
+ }
422
+ return this.darken(-amount);
423
+ };
424
+
425
+ Color.prototype.brighter = function(amount) {
426
+ return this.brighten(amount);
427
+ };
428
+
429
+ Color.prototype.saturate = function(amount) {
430
+ var lch, me;
431
+
432
+ if (amount == null) {
433
+ amount = 20;
434
+ }
435
+ me = this;
436
+ lch = me.lch();
437
+ lch[1] += amount;
438
+ return chroma.lch(lch).alpha(me.alpha());
439
+ };
440
+
441
+ Color.prototype.desaturate = function(amount) {
442
+ if (amount == null) {
443
+ amount = 20;
444
+ }
445
+ return this.saturate(-amount);
446
+ };
447
+
448
+ return Color;
449
+
450
+ })();
451
+
452
+ clip_rgb = function(rgb) {
453
+ var i;
454
+
455
+ for (i in rgb) {
456
+ if (i < 3) {
457
+ if (rgb[i] < 0) {
458
+ rgb[i] = 0;
459
+ }
460
+ if (rgb[i] > 255) {
461
+ rgb[i] = 255;
462
+ }
463
+ } else if (i === 3) {
464
+ if (rgb[i] < 0) {
465
+ rgb[i] = 0;
466
+ }
467
+ if (rgb[i] > 1) {
468
+ rgb[i] = 1;
469
+ }
470
+ }
471
+ }
472
+ return rgb;
473
+ };
474
+
475
+ css2rgb = function(css) {
476
+ var hsl, i, m, rgb, _i, _j, _k, _l;
477
+
478
+ css = css.toLowerCase();
479
+ if ((chroma.colors != null) && chroma.colors[css]) {
480
+ return hex2rgb(chroma.colors[css]);
481
+ }
482
+ if (m = css.match(/rgb\(\s*(\-?\d+),\s*(\-?\d+)\s*,\s*(\-?\d+)\s*\)/)) {
483
+ rgb = m.slice(1, 4);
484
+ for (i = _i = 0; _i <= 2; i = ++_i) {
485
+ rgb[i] = +rgb[i];
486
+ }
487
+ rgb[3] = 1;
488
+ } else if (m = css.match(/rgba\(\s*(\-?\d+),\s*(\-?\d+)\s*,\s*(\-?\d+)\s*,\s*([01]|[01]?\.\d+)\)/)) {
489
+ rgb = m.slice(1, 5);
490
+ for (i = _j = 0; _j <= 3; i = ++_j) {
491
+ rgb[i] = +rgb[i];
492
+ }
493
+ } else if (m = css.match(/rgb\(\s*(\-?\d+(?:\.\d+)?)%,\s*(\-?\d+(?:\.\d+)?)%\s*,\s*(\-?\d+(?:\.\d+)?)%\s*\)/)) {
494
+ rgb = m.slice(1, 4);
495
+ for (i = _k = 0; _k <= 2; i = ++_k) {
496
+ rgb[i] = Math.round(rgb[i] * 2.55);
497
+ }
498
+ rgb[3] = 1;
499
+ } else if (m = css.match(/rgba\(\s*(\-?\d+(?:\.\d+)?)%,\s*(\-?\d+(?:\.\d+)?)%\s*,\s*(\-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)/)) {
500
+ rgb = m.slice(1, 5);
501
+ for (i = _l = 0; _l <= 2; i = ++_l) {
502
+ rgb[i] = Math.round(rgb[i] * 2.55);
503
+ }
504
+ rgb[3] = +rgb[3];
505
+ } else if (m = css.match(/hsl\(\s*(\-?\d+(?:\.\d+)?),\s*(\-?\d+(?:\.\d+)?)%\s*,\s*(\-?\d+(?:\.\d+)?)%\s*\)/)) {
506
+ hsl = m.slice(1, 4);
507
+ hsl[1] *= 0.01;
508
+ hsl[2] *= 0.01;
509
+ rgb = hsl2rgb(hsl);
510
+ rgb[3] = 1;
511
+ } else if (m = css.match(/hsla\(\s*(\-?\d+(?:\.\d+)?),\s*(\-?\d+(?:\.\d+)?)%\s*,\s*(\-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)/)) {
512
+ hsl = m.slice(1, 4);
513
+ hsl[1] *= 0.01;
514
+ hsl[2] *= 0.01;
515
+ rgb = hsl2rgb(hsl);
516
+ rgb[3] = +m[4];
517
+ }
518
+ return rgb;
519
+ };
520
+
521
+ hex2rgb = function(hex) {
522
+ var a, b, g, r, rgb, u;
523
+
524
+ if (hex.match(/^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/)) {
525
+ if (hex.length === 4 || hex.length === 7) {
526
+ hex = hex.substr(1);
527
+ }
528
+ if (hex.length === 3) {
529
+ hex = hex.split("");
530
+ hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2];
531
+ }
532
+ u = parseInt(hex, 16);
533
+ r = u >> 16;
534
+ g = u >> 8 & 0xFF;
535
+ b = u & 0xFF;
536
+ return [r, g, b, 1];
537
+ }
538
+ if (hex.match(/^#?([A-Fa-f0-9]{8})$/)) {
539
+ if (hex.length === 9) {
540
+ hex = hex.substr(1);
541
+ }
542
+ u = parseInt(hex, 16);
543
+ r = u >> 24 & 0xFF;
544
+ g = u >> 16 & 0xFF;
545
+ b = u >> 8 & 0xFF;
546
+ a = u & 0xFF;
547
+ return [r, g, b, a];
548
+ }
549
+ if (rgb = css2rgb(hex)) {
550
+ return rgb;
551
+ }
552
+ throw "unknown color: " + hex;
553
+ };
554
+
555
+ hsi2rgb = function(h, s, i) {
556
+ /*
557
+ borrowed from here:
558
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp
559
+ */
560
+
561
+ var b, g, r, _ref;
562
+
563
+ _ref = unpack(arguments), h = _ref[0], s = _ref[1], i = _ref[2];
564
+ h /= 360;
565
+ if (h < 1 / 3) {
566
+ b = (1 - s) / 3;
567
+ r = (1 + s * cos(TWOPI * h) / cos(PITHIRD - TWOPI * h)) / 3;
568
+ g = 1 - (b + r);
569
+ } else if (h < 2 / 3) {
570
+ h -= 1 / 3;
571
+ r = (1 - s) / 3;
572
+ g = (1 + s * cos(TWOPI * h) / cos(PITHIRD - TWOPI * h)) / 3;
573
+ b = 1 - (r + g);
574
+ } else {
575
+ h -= 2 / 3;
576
+ g = (1 - s) / 3;
577
+ b = (1 + s * cos(TWOPI * h) / cos(PITHIRD - TWOPI * h)) / 3;
578
+ r = 1 - (g + b);
579
+ }
580
+ r = limit(i * r * 3);
581
+ g = limit(i * g * 3);
582
+ b = limit(i * b * 3);
583
+ return [r * 255, g * 255, b * 255];
584
+ };
585
+
586
+ hsl2rgb = function() {
587
+ var b, c, g, h, i, l, r, s, t1, t2, t3, _i, _ref, _ref1;
588
+
589
+ _ref = unpack(arguments), h = _ref[0], s = _ref[1], l = _ref[2];
590
+ if (s === 0) {
591
+ r = g = b = l * 255;
592
+ } else {
593
+ t3 = [0, 0, 0];
594
+ c = [0, 0, 0];
595
+ t2 = l < 0.5 ? l * (1 + s) : l + s - l * s;
596
+ t1 = 2 * l - t2;
597
+ h /= 360;
598
+ t3[0] = h + 1 / 3;
599
+ t3[1] = h;
600
+ t3[2] = h - 1 / 3;
601
+ for (i = _i = 0; _i <= 2; i = ++_i) {
602
+ if (t3[i] < 0) {
603
+ t3[i] += 1;
604
+ }
605
+ if (t3[i] > 1) {
606
+ t3[i] -= 1;
607
+ }
608
+ if (6 * t3[i] < 1) {
609
+ c[i] = t1 + (t2 - t1) * 6 * t3[i];
610
+ } else if (2 * t3[i] < 1) {
611
+ c[i] = t2;
612
+ } else if (3 * t3[i] < 2) {
613
+ c[i] = t1 + (t2 - t1) * ((2 / 3) - t3[i]) * 6;
614
+ } else {
615
+ c[i] = t1;
616
+ }
617
+ }
618
+ _ref1 = [Math.round(c[0] * 255), Math.round(c[1] * 255), Math.round(c[2] * 255)], r = _ref1[0], g = _ref1[1], b = _ref1[2];
619
+ }
620
+ return [r, g, b];
621
+ };
622
+
623
+ hsv2rgb = function() {
624
+ var b, f, g, h, i, p, q, r, s, t, v, _ref, _ref1, _ref2, _ref3, _ref4, _ref5, _ref6;
625
+
626
+ _ref = unpack(arguments), h = _ref[0], s = _ref[1], v = _ref[2];
627
+ v *= 255;
628
+ if (s === 0) {
629
+ r = g = b = v;
630
+ } else {
631
+ if (h === 360) {
632
+ h = 0;
633
+ }
634
+ if (h > 360) {
635
+ h -= 360;
636
+ }
637
+ if (h < 0) {
638
+ h += 360;
639
+ }
640
+ h /= 60;
641
+ i = Math.floor(h);
642
+ f = h - i;
643
+ p = v * (1 - s);
644
+ q = v * (1 - s * f);
645
+ t = v * (1 - s * (1 - f));
646
+ switch (i) {
647
+ case 0:
648
+ _ref1 = [v, t, p], r = _ref1[0], g = _ref1[1], b = _ref1[2];
649
+ break;
650
+ case 1:
651
+ _ref2 = [q, v, p], r = _ref2[0], g = _ref2[1], b = _ref2[2];
652
+ break;
653
+ case 2:
654
+ _ref3 = [p, v, t], r = _ref3[0], g = _ref3[1], b = _ref3[2];
655
+ break;
656
+ case 3:
657
+ _ref4 = [p, q, v], r = _ref4[0], g = _ref4[1], b = _ref4[2];
658
+ break;
659
+ case 4:
660
+ _ref5 = [t, p, v], r = _ref5[0], g = _ref5[1], b = _ref5[2];
661
+ break;
662
+ case 5:
663
+ _ref6 = [v, p, q], r = _ref6[0], g = _ref6[1], b = _ref6[2];
664
+ }
665
+ }
666
+ r = Math.round(r);
667
+ g = Math.round(g);
668
+ b = Math.round(b);
669
+ return [r, g, b];
670
+ };
671
+
672
+ K = 18;
673
+
674
+ X = 0.950470;
675
+
676
+ Y = 1;
677
+
678
+ Z = 1.088830;
679
+
680
+ lab2lch = function() {
681
+ var a, b, c, h, l, _ref;
682
+
683
+ _ref = unpack(arguments), l = _ref[0], a = _ref[1], b = _ref[2];
684
+ c = Math.sqrt(a * a + b * b);
685
+ h = Math.atan2(b, a) / Math.PI * 180;
686
+ return [l, c, h];
687
+ };
688
+
689
+ lab2rgb = function(l, a, b) {
690
+ /*
691
+ adapted to match d3 implementation
692
+ */
693
+
694
+ var g, r, x, y, z, _ref, _ref1;
695
+
696
+ if (l !== void 0 && l.length === 3) {
697
+ _ref = l, l = _ref[0], a = _ref[1], b = _ref[2];
698
+ }
699
+ if (l !== void 0 && l.length === 3) {
700
+ _ref1 = l, l = _ref1[0], a = _ref1[1], b = _ref1[2];
701
+ }
702
+ y = (l + 16) / 116;
703
+ x = y + a / 500;
704
+ z = y - b / 200;
705
+ x = lab_xyz(x) * X;
706
+ y = lab_xyz(y) * Y;
707
+ z = lab_xyz(z) * Z;
708
+ r = xyz_rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z);
709
+ g = xyz_rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z);
710
+ b = xyz_rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z);
711
+ return [limit(r, 0, 255), limit(g, 0, 255), limit(b, 0, 255), 1];
712
+ };
713
+
714
+ lab_xyz = function(x) {
715
+ if (x > 0.206893034) {
716
+ return x * x * x;
717
+ } else {
718
+ return (x - 4 / 29) / 7.787037;
719
+ }
720
+ };
721
+
722
+ xyz_rgb = function(r) {
723
+ return Math.round(255 * (r <= 0.00304 ? 12.92 * r : 1.055 * Math.pow(r, 1 / 2.4) - 0.055));
724
+ };
725
+
726
+ lch2lab = function() {
727
+ /*
728
+ Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel. These formulas were invented by David Dalrymple to obtain maximum contrast without going out of gamut if the parameters are in the range 0-1.
729
+ A saturation multiplier was added by Gregor Aisch
730
+ */
731
+
732
+ var c, h, l, _ref;
733
+
734
+ _ref = unpack(arguments), l = _ref[0], c = _ref[1], h = _ref[2];
735
+ h = h * Math.PI / 180;
736
+ return [l, Math.cos(h) * c, Math.sin(h) * c];
737
+ };
738
+
739
+ lch2rgb = function(l, c, h) {
740
+ var L, a, b, g, r, _ref, _ref1;
741
+
742
+ _ref = lch2lab(l, c, h), L = _ref[0], a = _ref[1], b = _ref[2];
743
+ _ref1 = lab2rgb(L, a, b), r = _ref1[0], g = _ref1[1], b = _ref1[2];
744
+ return [limit(r, 0, 255), limit(g, 0, 255), limit(b, 0, 255)];
745
+ };
746
+
747
+ luminance = function(r, g, b) {
748
+ var _ref;
749
+
750
+ _ref = unpack(arguments), r = _ref[0], g = _ref[1], b = _ref[2];
751
+ r = luminance_x(r);
752
+ g = luminance_x(g);
753
+ b = luminance_x(b);
754
+ return 0.2126 * r + 0.7152 * g + 0.0722 * b;
755
+ };
756
+
757
+ luminance_x = function(x) {
758
+ x /= 255;
759
+ if (x <= 0.03928) {
760
+ return x / 12.92;
761
+ } else {
762
+ return Math.pow((x + 0.055) / 1.055, 2.4);
763
+ }
764
+ };
765
+
766
+ rgb2hex = function() {
767
+ var b, g, r, str, u, _ref;
768
+
769
+ _ref = unpack(arguments), r = _ref[0], g = _ref[1], b = _ref[2];
770
+ u = r << 16 | g << 8 | b;
771
+ str = "000000" + u.toString(16);
772
+ return "#" + str.substr(str.length - 6);
773
+ };
774
+
775
+ rgb2hsi = function() {
776
+ /*
777
+ borrowed from here:
778
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp
779
+ */
780
+
781
+ var TWOPI, b, g, h, i, min, r, s, _ref;
782
+
783
+ _ref = unpack(arguments), r = _ref[0], g = _ref[1], b = _ref[2];
784
+ TWOPI = Math.PI * 2;
785
+ r /= 255;
786
+ g /= 255;
787
+ b /= 255;
788
+ min = Math.min(r, g, b);
789
+ i = (r + g + b) / 3;
790
+ s = 1 - min / i;
791
+ if (s === 0) {
792
+ h = 0;
793
+ } else {
794
+ h = ((r - g) + (r - b)) / 2;
795
+ h /= Math.sqrt((r - g) * (r - g) + (r - b) * (g - b));
796
+ h = Math.acos(h);
797
+ if (b > g) {
798
+ h = TWOPI - h;
799
+ }
800
+ h /= TWOPI;
801
+ }
802
+ return [h * 360, s, i];
803
+ };
804
+
805
+ rgb2hsl = function(r, g, b) {
806
+ var h, l, max, min, s, _ref;
807
+
808
+ if (r !== void 0 && r.length >= 3) {
809
+ _ref = r, r = _ref[0], g = _ref[1], b = _ref[2];
810
+ }
811
+ r /= 255;
812
+ g /= 255;
813
+ b /= 255;
814
+ min = Math.min(r, g, b);
815
+ max = Math.max(r, g, b);
816
+ l = (max + min) / 2;
817
+ if (max === min) {
818
+ s = 0;
819
+ h = Number.NaN;
820
+ } else {
821
+ s = l < 0.5 ? (max - min) / (max + min) : (max - min) / (2 - max - min);
822
+ }
823
+ if (r === max) {
824
+ h = (g - b) / (max - min);
825
+ } else if (g === max) {
826
+ h = 2 + (b - r) / (max - min);
827
+ } else if (b === max) {
828
+ h = 4 + (r - g) / (max - min);
829
+ }
830
+ h *= 60;
831
+ if (h < 0) {
832
+ h += 360;
833
+ }
834
+ return [h, s, l];
835
+ };
836
+
837
+ rgb2hsv = function() {
838
+ var b, delta, g, h, max, min, r, s, v, _ref;
839
+
840
+ _ref = unpack(arguments), r = _ref[0], g = _ref[1], b = _ref[2];
841
+ min = Math.min(r, g, b);
842
+ max = Math.max(r, g, b);
843
+ delta = max - min;
844
+ v = max / 255.0;
845
+ if (max === 0) {
846
+ h = Number.NaN;
847
+ s = 0;
848
+ } else {
849
+ s = delta / max;
850
+ if (r === max) {
851
+ h = (g - b) / delta;
852
+ }
853
+ if (g === max) {
854
+ h = 2 + (b - r) / delta;
855
+ }
856
+ if (b === max) {
857
+ h = 4 + (r - g) / delta;
858
+ }
859
+ h *= 60;
860
+ if (h < 0) {
861
+ h += 360;
862
+ }
863
+ }
864
+ return [h, s, v];
865
+ };
866
+
867
+ rgb2lab = function() {
868
+ var b, g, r, x, y, z, _ref;
869
+
870
+ _ref = unpack(arguments), r = _ref[0], g = _ref[1], b = _ref[2];
871
+ r = rgb_xyz(r);
872
+ g = rgb_xyz(g);
873
+ b = rgb_xyz(b);
874
+ x = xyz_lab((0.4124564 * r + 0.3575761 * g + 0.1804375 * b) / X);
875
+ y = xyz_lab((0.2126729 * r + 0.7151522 * g + 0.0721750 * b) / Y);
876
+ z = xyz_lab((0.0193339 * r + 0.1191920 * g + 0.9503041 * b) / Z);
877
+ return [116 * y - 16, 500 * (x - y), 200 * (y - z)];
878
+ };
879
+
880
+ rgb_xyz = function(r) {
881
+ if ((r /= 255) <= 0.04045) {
882
+ return r / 12.92;
883
+ } else {
884
+ return Math.pow((r + 0.055) / 1.055, 2.4);
885
+ }
886
+ };
887
+
888
+ xyz_lab = function(x) {
889
+ if (x > 0.008856) {
890
+ return Math.pow(x, 1 / 3);
891
+ } else {
892
+ return 7.787037 * x + 4 / 29;
893
+ }
894
+ };
895
+
896
+ rgb2lch = function() {
897
+ var a, b, g, l, r, _ref, _ref1;
898
+
899
+ _ref = unpack(arguments), r = _ref[0], g = _ref[1], b = _ref[2];
900
+ _ref1 = rgb2lab(r, g, b), l = _ref1[0], a = _ref1[1], b = _ref1[2];
901
+ return lab2lch(l, a, b);
902
+ };
903
+
904
+ /*
905
+ chroma.js
906
+
907
+ Copyright (c) 2011-2013, Gregor Aisch
908
+ All rights reserved.
909
+
910
+ Redistribution and use in source and binary forms, with or without
911
+ modification, are permitted provided that the following conditions are met:
912
+
913
+ * Redistributions of source code must retain the above copyright notice, this
914
+ list of conditions and the following disclaimer.
915
+
916
+ * Redistributions in binary form must reproduce the above copyright notice,
917
+ this list of conditions and the following disclaimer in the documentation
918
+ and/or other materials provided with the distribution.
919
+
920
+ * The name Gregor Aisch may not be used to endorse or promote products
921
+ derived from this software without specific prior written permission.
922
+
923
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
924
+ AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
925
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
926
+ DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
927
+ INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
928
+ BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
929
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
930
+ OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
931
+ NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
932
+ EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
933
+
934
+ @source: https://github.com/gka/chroma.js
935
+ */
936
+
937
+
938
+ chroma.scale = function(colors, positions) {
939
+ var classifyValue, f, getClass, getColor, resetCache, setColors, setDomain, tmap, _colorCache, _colors, _correctLightness, _domain, _fixed, _max, _min, _mode, _nacol, _numClasses, _out, _pos, _spread;
940
+
941
+ _mode = 'rgb';
942
+ _nacol = chroma('#ccc');
943
+ _spread = 0;
944
+ _fixed = false;
945
+ _domain = [0, 1];
946
+ _colors = [];
947
+ _out = false;
948
+ _pos = [];
949
+ _min = 0;
950
+ _max = 1;
951
+ _correctLightness = false;
952
+ _numClasses = 0;
953
+ _colorCache = {};
954
+ setColors = function(colors, positions) {
955
+ var c, col, _i, _j, _ref, _ref1, _ref2;
956
+
957
+ if (colors == null) {
958
+ colors = ['#ddd', '#222'];
959
+ }
960
+ if ((colors != null) && type(colors) === 'string' && (((_ref = chroma.brewer) != null ? _ref[colors] : void 0) != null)) {
961
+ colors = chroma.brewer[colors];
962
+ }
963
+ if (type(colors) === 'array') {
964
+ colors = colors.slice(0);
965
+ for (c = _i = 0, _ref1 = colors.length - 1; 0 <= _ref1 ? _i <= _ref1 : _i >= _ref1; c = 0 <= _ref1 ? ++_i : --_i) {
966
+ col = colors[c];
967
+ if (type(col) === "string") {
968
+ colors[c] = chroma(col);
969
+ }
970
+ }
971
+ if (positions != null) {
972
+ _pos = positions;
973
+ } else {
974
+ _pos = [];
975
+ for (c = _j = 0, _ref2 = colors.length - 1; 0 <= _ref2 ? _j <= _ref2 : _j >= _ref2; c = 0 <= _ref2 ? ++_j : --_j) {
976
+ _pos.push(c / (colors.length - 1));
977
+ }
978
+ }
979
+ }
980
+ resetCache();
981
+ return _colors = colors;
982
+ };
983
+ setDomain = function(domain) {
984
+ if (domain == null) {
985
+ domain = [];
986
+ }
987
+ /*
988
+ # use this if you want to display a limited number of data classes
989
+ # possible methods are "equalinterval", "quantiles", "custom"
990
+ */
991
+
992
+ _domain = domain;
993
+ _min = domain[0];
994
+ _max = domain[domain.length - 1];
995
+ resetCache();
996
+ if (domain.length === 2) {
997
+ return _numClasses = 0;
998
+ } else {
999
+ return _numClasses = domain.length - 1;
1000
+ }
1001
+ };
1002
+ getClass = function(value) {
1003
+ var i, n;
1004
+
1005
+ if (_domain != null) {
1006
+ n = _domain.length - 1;
1007
+ i = 0;
1008
+ while (i < n && value >= _domain[i]) {
1009
+ i++;
1010
+ }
1011
+ return i - 1;
1012
+ }
1013
+ return 0;
1014
+ };
1015
+ tmap = function(t) {
1016
+ return t;
1017
+ };
1018
+ classifyValue = function(value) {
1019
+ var i, maxc, minc, n, val;
1020
+
1021
+ val = value;
1022
+ if (_domain.length > 2) {
1023
+ n = _domain.length - 1;
1024
+ i = getClass(value);
1025
+ minc = _domain[0] + (_domain[1] - _domain[0]) * (0 + _spread * 0.5);
1026
+ maxc = _domain[n - 1] + (_domain[n] - _domain[n - 1]) * (1 - _spread * 0.5);
1027
+ val = _min + ((_domain[i] + (_domain[i + 1] - _domain[i]) * 0.5 - minc) / (maxc - minc)) * (_max - _min);
1028
+ }
1029
+ return val;
1030
+ };
1031
+ getColor = function(val, bypassMap) {
1032
+ var c, col, f0, i, k, p, t, _i, _ref;
1033
+
1034
+ if (bypassMap == null) {
1035
+ bypassMap = false;
1036
+ }
1037
+ if (isNaN(val)) {
1038
+ return _nacol;
1039
+ }
1040
+ if (!bypassMap) {
1041
+ if (_domain.length > 2) {
1042
+ c = getClass(val);
1043
+ t = c / (_numClasses - 1);
1044
+ } else {
1045
+ t = f0 = (val - _min) / (_max - _min);
1046
+ t = Math.min(1, Math.max(0, t));
1047
+ }
1048
+ } else {
1049
+ t = val;
1050
+ }
1051
+ if (!bypassMap) {
1052
+ t = tmap(t);
1053
+ }
1054
+ k = Math.floor(t * 10000);
1055
+ if (_colorCache[k]) {
1056
+ col = _colorCache[k];
1057
+ } else {
1058
+ if (type(_colors) === 'array') {
1059
+ for (i = _i = 0, _ref = _pos.length - 1; 0 <= _ref ? _i <= _ref : _i >= _ref; i = 0 <= _ref ? ++_i : --_i) {
1060
+ p = _pos[i];
1061
+ if (t <= p) {
1062
+ col = _colors[i];
1063
+ break;
1064
+ }
1065
+ if (t >= p && i === _pos.length - 1) {
1066
+ col = _colors[i];
1067
+ break;
1068
+ }
1069
+ if (t > p && t < _pos[i + 1]) {
1070
+ t = (t - p) / (_pos[i + 1] - p);
1071
+ col = chroma.interpolate(_colors[i], _colors[i + 1], t, _mode);
1072
+ break;
1073
+ }
1074
+ }
1075
+ } else if (type(_colors) === 'function') {
1076
+ col = _colors(t);
1077
+ }
1078
+ _colorCache[k] = col;
1079
+ }
1080
+ return col;
1081
+ };
1082
+ resetCache = function() {
1083
+ return _colorCache = {};
1084
+ };
1085
+ setColors(colors, positions);
1086
+ f = function(v) {
1087
+ var c;
1088
+
1089
+ c = getColor(v);
1090
+ if (_out && c[_out]) {
1091
+ return c[_out]();
1092
+ } else {
1093
+ return c;
1094
+ }
1095
+ };
1096
+ f.domain = function(domain, classes, mode, key) {
1097
+ var d;
1098
+
1099
+ if (mode == null) {
1100
+ mode = 'e';
1101
+ }
1102
+ if (!arguments.length) {
1103
+ return _domain;
1104
+ }
1105
+ if (classes != null) {
1106
+ d = chroma.analyze(domain, key);
1107
+ if (classes === 0) {
1108
+ domain = [d.min, d.max];
1109
+ } else {
1110
+ domain = chroma.limits(d, mode, classes);
1111
+ }
1112
+ }
1113
+ setDomain(domain);
1114
+ return f;
1115
+ };
1116
+ f.mode = function(_m) {
1117
+ if (!arguments.length) {
1118
+ return _mode;
1119
+ }
1120
+ _mode = _m;
1121
+ resetCache();
1122
+ return f;
1123
+ };
1124
+ f.range = function(colors, _pos) {
1125
+ setColors(colors, _pos);
1126
+ return f;
1127
+ };
1128
+ f.out = function(_o) {
1129
+ _out = _o;
1130
+ return f;
1131
+ };
1132
+ f.spread = function(val) {
1133
+ if (!arguments.length) {
1134
+ return _spread;
1135
+ }
1136
+ _spread = val;
1137
+ return f;
1138
+ };
1139
+ f.correctLightness = function(v) {
1140
+ if (!arguments.length) {
1141
+ return _correctLightness;
1142
+ }
1143
+ _correctLightness = v;
1144
+ resetCache();
1145
+ if (_correctLightness) {
1146
+ tmap = function(t) {
1147
+ var L0, L1, L_actual, L_diff, L_ideal, max_iter, pol, t0, t1;
1148
+
1149
+ L0 = getColor(0, true).lab()[0];
1150
+ L1 = getColor(1, true).lab()[0];
1151
+ pol = L0 > L1;
1152
+ L_actual = getColor(t, true).lab()[0];
1153
+ L_ideal = L0 + (L1 - L0) * t;
1154
+ L_diff = L_actual - L_ideal;
1155
+ t0 = 0;
1156
+ t1 = 1;
1157
+ max_iter = 20;
1158
+ while (Math.abs(L_diff) > 1e-2 && max_iter-- > 0) {
1159
+ (function() {
1160
+ if (pol) {
1161
+ L_diff *= -1;
1162
+ }
1163
+ if (L_diff < 0) {
1164
+ t0 = t;
1165
+ t += (t1 - t) * 0.5;
1166
+ } else {
1167
+ t1 = t;
1168
+ t += (t0 - t) * 0.5;
1169
+ }
1170
+ L_actual = getColor(t, true).lab()[0];
1171
+ return L_diff = L_actual - L_ideal;
1172
+ })();
1173
+ }
1174
+ return t;
1175
+ };
1176
+ } else {
1177
+ tmap = function(t) {
1178
+ return t;
1179
+ };
1180
+ }
1181
+ return f;
1182
+ };
1183
+ f.colors = function(out) {
1184
+ var i, samples, _i, _j, _len, _ref;
1185
+
1186
+ if (out == null) {
1187
+ out = 'hex';
1188
+ }
1189
+ colors = [];
1190
+ samples = [];
1191
+ if (_domain.length > 2) {
1192
+ for (i = _i = 1, _ref = _domain.length; 1 <= _ref ? _i < _ref : _i > _ref; i = 1 <= _ref ? ++_i : --_i) {
1193
+ samples.push((_domain[i - 1] + _domain[i]) * 0.5);
1194
+ }
1195
+ } else {
1196
+ samples = _domain;
1197
+ }
1198
+ for (_j = 0, _len = samples.length; _j < _len; _j++) {
1199
+ i = samples[_j];
1200
+ colors.push(f(i)[out]());
1201
+ }
1202
+ return colors;
1203
+ };
1204
+ return f;
1205
+ };
1206
+
1207
+ if ((_ref = chroma.scales) == null) {
1208
+ chroma.scales = {};
1209
+ }
1210
+
1211
+ chroma.scales.cool = function() {
1212
+ return chroma.scale([chroma.hsl(180, 1, .9), chroma.hsl(250, .7, .4)]);
1213
+ };
1214
+
1215
+ chroma.scales.hot = function() {
1216
+ return chroma.scale(['#000', '#f00', '#ff0', '#fff'], [0, .25, .75, 1]).mode('rgb');
1217
+ };
1218
+
1219
+ /*
1220
+ chroma.js
1221
+
1222
+ Copyright (c) 2011-2013, Gregor Aisch
1223
+ All rights reserved.
1224
+
1225
+ Redistribution and use in source and binary forms, with or without
1226
+ modification, are permitted provided that the following conditions are met:
1227
+
1228
+ * Redistributions of source code must retain the above copyright notice, this
1229
+ list of conditions and the following disclaimer.
1230
+
1231
+ * Redistributions in binary form must reproduce the above copyright notice,
1232
+ this list of conditions and the following disclaimer in the documentation
1233
+ and/or other materials provided with the distribution.
1234
+
1235
+ * The name Gregor Aisch may not be used to endorse or promote products
1236
+ derived from this software without specific prior written permission.
1237
+
1238
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1239
+ AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1240
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
1241
+ DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
1242
+ INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
1243
+ BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
1244
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
1245
+ OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
1246
+ NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
1247
+ EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1248
+
1249
+ @source: https://github.com/gka/chroma.js
1250
+ */
1251
+
1252
+
1253
+ chroma.analyze = function(data, key, filter) {
1254
+ var add, k, r, val, visit, _i, _len;
1255
+
1256
+ r = {
1257
+ min: Number.MAX_VALUE,
1258
+ max: Number.MAX_VALUE * -1,
1259
+ sum: 0,
1260
+ values: [],
1261
+ count: 0
1262
+ };
1263
+ if (filter == null) {
1264
+ filter = function() {
1265
+ return true;
1266
+ };
1267
+ }
1268
+ add = function(val) {
1269
+ if ((val != null) && !isNaN(val)) {
1270
+ r.values.push(val);
1271
+ r.sum += val;
1272
+ if (val < r.min) {
1273
+ r.min = val;
1274
+ }
1275
+ if (val > r.max) {
1276
+ r.max = val;
1277
+ }
1278
+ r.count += 1;
1279
+ }
1280
+ };
1281
+ visit = function(val, k) {
1282
+ if (filter(val, k)) {
1283
+ if ((key != null) && type(key) === 'function') {
1284
+ return add(key(val));
1285
+ } else if ((key != null) && type(key) === 'string' || type(key) === 'number') {
1286
+ return add(val[key]);
1287
+ } else {
1288
+ return add(val);
1289
+ }
1290
+ }
1291
+ };
1292
+ if (type(data) === 'array') {
1293
+ for (_i = 0, _len = data.length; _i < _len; _i++) {
1294
+ val = data[_i];
1295
+ visit(val);
1296
+ }
1297
+ } else {
1298
+ for (k in data) {
1299
+ val = data[k];
1300
+ visit(val, k);
1301
+ }
1302
+ }
1303
+ r.domain = [r.min, r.max];
1304
+ r.limits = function(mode, num) {
1305
+ return chroma.limits(r, mode, num);
1306
+ };
1307
+ return r;
1308
+ };
1309
+
1310
+ chroma.limits = function(data, mode, num) {
1311
+ var assignments, best, centroids, cluster, clusterSizes, dist, i, j, kClusters, limits, max, max_log, min, min_log, mindist, n, nb_iters, newCentroids, p, pb, pr, repeat, sum, tmpKMeansBreaks, value, values, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _ref1, _ref10, _ref11, _ref12, _ref13, _ref14, _ref15, _ref2, _ref3, _ref4, _ref5, _ref6, _ref7, _ref8, _ref9, _s, _t, _u, _v, _w;
1312
+
1313
+ if (mode == null) {
1314
+ mode = 'equal';
1315
+ }
1316
+ if (num == null) {
1317
+ num = 7;
1318
+ }
1319
+ if (type(data) === 'array') {
1320
+ data = chroma.analyze(data);
1321
+ }
1322
+ min = data.min;
1323
+ max = data.max;
1324
+ sum = data.sum;
1325
+ values = data.values.sort(function(a, b) {
1326
+ return a - b;
1327
+ });
1328
+ limits = [];
1329
+ if (mode.substr(0, 1) === 'c') {
1330
+ limits.push(min);
1331
+ limits.push(max);
1332
+ }
1333
+ if (mode.substr(0, 1) === 'e') {
1334
+ limits.push(min);
1335
+ for (i = _i = 1, _ref1 = num - 1; 1 <= _ref1 ? _i <= _ref1 : _i >= _ref1; i = 1 <= _ref1 ? ++_i : --_i) {
1336
+ limits.push(min + (i / num) * (max - min));
1337
+ }
1338
+ limits.push(max);
1339
+ } else if (mode.substr(0, 1) === 'l') {
1340
+ if (min <= 0) {
1341
+ throw 'Logarithmic scales are only possible for values > 0';
1342
+ }
1343
+ min_log = Math.LOG10E * Math.log(min);
1344
+ max_log = Math.LOG10E * Math.log(max);
1345
+ limits.push(min);
1346
+ for (i = _j = 1, _ref2 = num - 1; 1 <= _ref2 ? _j <= _ref2 : _j >= _ref2; i = 1 <= _ref2 ? ++_j : --_j) {
1347
+ limits.push(Math.pow(10, min_log + (i / num) * (max_log - min_log)));
1348
+ }
1349
+ limits.push(max);
1350
+ } else if (mode.substr(0, 1) === 'q') {
1351
+ limits.push(min);
1352
+ for (i = _k = 1, _ref3 = num - 1; 1 <= _ref3 ? _k <= _ref3 : _k >= _ref3; i = 1 <= _ref3 ? ++_k : --_k) {
1353
+ p = values.length * i / num;
1354
+ pb = Math.floor(p);
1355
+ if (pb === p) {
1356
+ limits.push(values[pb]);
1357
+ } else {
1358
+ pr = p - pb;
1359
+ limits.push(values[pb] * pr + values[pb + 1] * (1 - pr));
1360
+ }
1361
+ }
1362
+ limits.push(max);
1363
+ } else if (mode.substr(0, 1) === 'k') {
1364
+ /*
1365
+ implementation based on
1366
+ http://code.google.com/p/figue/source/browse/trunk/figue.js#336
1367
+ simplified for 1-d input values
1368
+ */
1369
+
1370
+ n = values.length;
1371
+ assignments = new Array(n);
1372
+ clusterSizes = new Array(num);
1373
+ repeat = true;
1374
+ nb_iters = 0;
1375
+ centroids = null;
1376
+ centroids = [];
1377
+ centroids.push(min);
1378
+ for (i = _l = 1, _ref4 = num - 1; 1 <= _ref4 ? _l <= _ref4 : _l >= _ref4; i = 1 <= _ref4 ? ++_l : --_l) {
1379
+ centroids.push(min + (i / num) * (max - min));
1380
+ }
1381
+ centroids.push(max);
1382
+ while (repeat) {
1383
+ for (j = _m = 0, _ref5 = num - 1; 0 <= _ref5 ? _m <= _ref5 : _m >= _ref5; j = 0 <= _ref5 ? ++_m : --_m) {
1384
+ clusterSizes[j] = 0;
1385
+ }
1386
+ for (i = _n = 0, _ref6 = n - 1; 0 <= _ref6 ? _n <= _ref6 : _n >= _ref6; i = 0 <= _ref6 ? ++_n : --_n) {
1387
+ value = values[i];
1388
+ mindist = Number.MAX_VALUE;
1389
+ for (j = _o = 0, _ref7 = num - 1; 0 <= _ref7 ? _o <= _ref7 : _o >= _ref7; j = 0 <= _ref7 ? ++_o : --_o) {
1390
+ dist = Math.abs(centroids[j] - value);
1391
+ if (dist < mindist) {
1392
+ mindist = dist;
1393
+ best = j;
1394
+ }
1395
+ }
1396
+ clusterSizes[best]++;
1397
+ assignments[i] = best;
1398
+ }
1399
+ newCentroids = new Array(num);
1400
+ for (j = _p = 0, _ref8 = num - 1; 0 <= _ref8 ? _p <= _ref8 : _p >= _ref8; j = 0 <= _ref8 ? ++_p : --_p) {
1401
+ newCentroids[j] = null;
1402
+ }
1403
+ for (i = _q = 0, _ref9 = n - 1; 0 <= _ref9 ? _q <= _ref9 : _q >= _ref9; i = 0 <= _ref9 ? ++_q : --_q) {
1404
+ cluster = assignments[i];
1405
+ if (newCentroids[cluster] === null) {
1406
+ newCentroids[cluster] = values[i];
1407
+ } else {
1408
+ newCentroids[cluster] += values[i];
1409
+ }
1410
+ }
1411
+ for (j = _r = 0, _ref10 = num - 1; 0 <= _ref10 ? _r <= _ref10 : _r >= _ref10; j = 0 <= _ref10 ? ++_r : --_r) {
1412
+ newCentroids[j] *= 1 / clusterSizes[j];
1413
+ }
1414
+ repeat = false;
1415
+ for (j = _s = 0, _ref11 = num - 1; 0 <= _ref11 ? _s <= _ref11 : _s >= _ref11; j = 0 <= _ref11 ? ++_s : --_s) {
1416
+ if (newCentroids[j] !== centroids[i]) {
1417
+ repeat = true;
1418
+ break;
1419
+ }
1420
+ }
1421
+ centroids = newCentroids;
1422
+ nb_iters++;
1423
+ if (nb_iters > 200) {
1424
+ repeat = false;
1425
+ }
1426
+ }
1427
+ kClusters = {};
1428
+ for (j = _t = 0, _ref12 = num - 1; 0 <= _ref12 ? _t <= _ref12 : _t >= _ref12; j = 0 <= _ref12 ? ++_t : --_t) {
1429
+ kClusters[j] = [];
1430
+ }
1431
+ for (i = _u = 0, _ref13 = n - 1; 0 <= _ref13 ? _u <= _ref13 : _u >= _ref13; i = 0 <= _ref13 ? ++_u : --_u) {
1432
+ cluster = assignments[i];
1433
+ kClusters[cluster].push(values[i]);
1434
+ }
1435
+ tmpKMeansBreaks = [];
1436
+ for (j = _v = 0, _ref14 = num - 1; 0 <= _ref14 ? _v <= _ref14 : _v >= _ref14; j = 0 <= _ref14 ? ++_v : --_v) {
1437
+ tmpKMeansBreaks.push(kClusters[j][0]);
1438
+ tmpKMeansBreaks.push(kClusters[j][kClusters[j].length - 1]);
1439
+ }
1440
+ tmpKMeansBreaks = tmpKMeansBreaks.sort(function(a, b) {
1441
+ return a - b;
1442
+ });
1443
+ limits.push(tmpKMeansBreaks[0]);
1444
+ for (i = _w = 1, _ref15 = tmpKMeansBreaks.length - 1; _w <= _ref15; i = _w += 2) {
1445
+ if (!isNaN(tmpKMeansBreaks[i])) {
1446
+ limits.push(tmpKMeansBreaks[i]);
1447
+ }
1448
+ }
1449
+ }
1450
+ return limits;
1451
+ };
1452
+
1453
+ /**
1454
+ ColorBrewer colors for chroma.js
1455
+
1456
+ Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The
1457
+ Pennsylvania State University.
1458
+
1459
+ Licensed under the Apache License, Version 2.0 (the "License");
1460
+ you may not use this file except in compliance with the License.
1461
+ You may obtain a copy of the License at
1462
+ http://www.apache.org/licenses/LICENSE-2.0
1463
+
1464
+ Unless required by applicable law or agreed to in writing, software distributed
1465
+ under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
1466
+ CONDITIONS OF ANY KIND, either express or implied. See the License for the
1467
+ specific language governing permissions and limitations under the License.
1468
+
1469
+ @preserve
1470
+ */
1471
+
1472
+
1473
+ chroma.brewer = brewer = {
1474
+ OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],
1475
+ PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],
1476
+ BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],
1477
+ Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],
1478
+ BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],
1479
+ YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],
1480
+ YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],
1481
+ Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],
1482
+ RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],
1483
+ Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],
1484
+ YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],
1485
+ Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],
1486
+ GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],
1487
+ Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],
1488
+ YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],
1489
+ PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],
1490
+ Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],
1491
+ PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],
1492
+ Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],
1493
+ RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],
1494
+ RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],
1495
+ PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],
1496
+ PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],
1497
+ RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],
1498
+ BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],
1499
+ RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],
1500
+ PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],
1501
+ Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],
1502
+ Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],
1503
+ Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],
1504
+ Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],
1505
+ Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],
1506
+ Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],
1507
+ Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],
1508
+ Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2']
1509
+ };
1510
+
1511
+ /**
1512
+ X11 color names
1513
+
1514
+ http://www.w3.org/TR/css3-color/#svg-color
1515
+ */
1516
+
1517
+
1518
+ chroma.colors = colors = {
1519
+ indigo: "#4b0082",
1520
+ gold: "#ffd700",
1521
+ hotpink: "#ff69b4",
1522
+ firebrick: "#b22222",
1523
+ indianred: "#cd5c5c",
1524
+ yellow: "#ffff00",
1525
+ mistyrose: "#ffe4e1",
1526
+ darkolivegreen: "#556b2f",
1527
+ olive: "#808000",
1528
+ darkseagreen: "#8fbc8f",
1529
+ pink: "#ffc0cb",
1530
+ tomato: "#ff6347",
1531
+ lightcoral: "#f08080",
1532
+ orangered: "#ff4500",
1533
+ navajowhite: "#ffdead",
1534
+ lime: "#00ff00",
1535
+ palegreen: "#98fb98",
1536
+ darkslategrey: "#2f4f4f",
1537
+ greenyellow: "#adff2f",
1538
+ burlywood: "#deb887",
1539
+ seashell: "#fff5ee",
1540
+ mediumspringgreen: "#00fa9a",
1541
+ fuchsia: "#ff00ff",
1542
+ papayawhip: "#ffefd5",
1543
+ blanchedalmond: "#ffebcd",
1544
+ chartreuse: "#7fff00",
1545
+ dimgray: "#696969",
1546
+ black: "#000000",
1547
+ peachpuff: "#ffdab9",
1548
+ springgreen: "#00ff7f",
1549
+ aquamarine: "#7fffd4",
1550
+ white: "#ffffff",
1551
+ orange: "#ffa500",
1552
+ lightsalmon: "#ffa07a",
1553
+ darkslategray: "#2f4f4f",
1554
+ brown: "#a52a2a",
1555
+ ivory: "#fffff0",
1556
+ dodgerblue: "#1e90ff",
1557
+ peru: "#cd853f",
1558
+ lawngreen: "#7cfc00",
1559
+ chocolate: "#d2691e",
1560
+ crimson: "#dc143c",
1561
+ forestgreen: "#228b22",
1562
+ darkgrey: "#a9a9a9",
1563
+ lightseagreen: "#20b2aa",
1564
+ cyan: "#00ffff",
1565
+ mintcream: "#f5fffa",
1566
+ silver: "#c0c0c0",
1567
+ antiquewhite: "#faebd7",
1568
+ mediumorchid: "#ba55d3",
1569
+ skyblue: "#87ceeb",
1570
+ gray: "#808080",
1571
+ darkturquoise: "#00ced1",
1572
+ goldenrod: "#daa520",
1573
+ darkgreen: "#006400",
1574
+ floralwhite: "#fffaf0",
1575
+ darkviolet: "#9400d3",
1576
+ darkgray: "#a9a9a9",
1577
+ moccasin: "#ffe4b5",
1578
+ saddlebrown: "#8b4513",
1579
+ grey: "#808080",
1580
+ darkslateblue: "#483d8b",
1581
+ lightskyblue: "#87cefa",
1582
+ lightpink: "#ffb6c1",
1583
+ mediumvioletred: "#c71585",
1584
+ slategrey: "#708090",
1585
+ red: "#ff0000",
1586
+ deeppink: "#ff1493",
1587
+ limegreen: "#32cd32",
1588
+ darkmagenta: "#8b008b",
1589
+ palegoldenrod: "#eee8aa",
1590
+ plum: "#dda0dd",
1591
+ turquoise: "#40e0d0",
1592
+ lightgrey: "#d3d3d3",
1593
+ lightgoldenrodyellow: "#fafad2",
1594
+ darkgoldenrod: "#b8860b",
1595
+ lavender: "#e6e6fa",
1596
+ maroon: "#800000",
1597
+ yellowgreen: "#9acd32",
1598
+ sandybrown: "#f4a460",
1599
+ thistle: "#d8bfd8",
1600
+ violet: "#ee82ee",
1601
+ navy: "#000080",
1602
+ magenta: "#ff00ff",
1603
+ dimgrey: "#696969",
1604
+ tan: "#d2b48c",
1605
+ rosybrown: "#bc8f8f",
1606
+ olivedrab: "#6b8e23",
1607
+ blue: "#0000ff",
1608
+ lightblue: "#add8e6",
1609
+ ghostwhite: "#f8f8ff",
1610
+ honeydew: "#f0fff0",
1611
+ cornflowerblue: "#6495ed",
1612
+ slateblue: "#6a5acd",
1613
+ linen: "#faf0e6",
1614
+ darkblue: "#00008b",
1615
+ powderblue: "#b0e0e6",
1616
+ seagreen: "#2e8b57",
1617
+ darkkhaki: "#bdb76b",
1618
+ snow: "#fffafa",
1619
+ sienna: "#a0522d",
1620
+ mediumblue: "#0000cd",
1621
+ royalblue: "#4169e1",
1622
+ lightcyan: "#e0ffff",
1623
+ green: "#008000",
1624
+ mediumpurple: "#9370db",
1625
+ midnightblue: "#191970",
1626
+ cornsilk: "#fff8dc",
1627
+ paleturquoise: "#afeeee",
1628
+ bisque: "#ffe4c4",
1629
+ slategray: "#708090",
1630
+ darkcyan: "#008b8b",
1631
+ khaki: "#f0e68c",
1632
+ wheat: "#f5deb3",
1633
+ teal: "#008080",
1634
+ darkorchid: "#9932cc",
1635
+ deepskyblue: "#00bfff",
1636
+ salmon: "#fa8072",
1637
+ darkred: "#8b0000",
1638
+ steelblue: "#4682b4",
1639
+ palevioletred: "#db7093",
1640
+ lightslategray: "#778899",
1641
+ aliceblue: "#f0f8ff",
1642
+ lightslategrey: "#778899",
1643
+ lightgreen: "#90ee90",
1644
+ orchid: "#da70d6",
1645
+ gainsboro: "#dcdcdc",
1646
+ mediumseagreen: "#3cb371",
1647
+ lightgray: "#d3d3d3",
1648
+ mediumturquoise: "#48d1cc",
1649
+ lemonchiffon: "#fffacd",
1650
+ cadetblue: "#5f9ea0",
1651
+ lightyellow: "#ffffe0",
1652
+ lavenderblush: "#fff0f5",
1653
+ coral: "#ff7f50",
1654
+ purple: "#800080",
1655
+ aqua: "#00ffff",
1656
+ whitesmoke: "#f5f5f5",
1657
+ mediumslateblue: "#7b68ee",
1658
+ darkorange: "#ff8c00",
1659
+ mediumaquamarine: "#66cdaa",
1660
+ darksalmon: "#e9967a",
1661
+ beige: "#f5f5dc",
1662
+ blueviolet: "#8a2be2",
1663
+ azure: "#f0ffff",
1664
+ lightsteelblue: "#b0c4de",
1665
+ oldlace: "#fdf5e6"
1666
+ };
1667
+
1668
+ /*
1669
+ chroma.js
1670
+
1671
+ Copyright (c) 2011-2013, Gregor Aisch
1672
+ All rights reserved.
1673
+
1674
+ Redistribution and use in source and binary forms, with or without
1675
+ modification, are permitted provided that the following conditions are met:
1676
+
1677
+ * Redistributions of source code must retain the above copyright notice, this
1678
+ list of conditions and the following disclaimer.
1679
+
1680
+ * Redistributions in binary form must reproduce the above copyright notice,
1681
+ this list of conditions and the following disclaimer in the documentation
1682
+ and/or other materials provided with the distribution.
1683
+
1684
+ * The name Gregor Aisch may not be used to endorse or promote products
1685
+ derived from this software without specific prior written permission.
1686
+
1687
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1688
+ AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1689
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
1690
+ DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
1691
+ INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
1692
+ BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
1693
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
1694
+ OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
1695
+ NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
1696
+ EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1697
+
1698
+ @source: https://github.com/gka/chroma.js
1699
+ */
1700
+
1701
+
1702
+ type = (function() {
1703
+ /*
1704
+ for browser-safe type checking+
1705
+ ported from jQuery's $.type
1706
+ */
1707
+
1708
+ var classToType, name, _i, _len, _ref1;
1709
+
1710
+ classToType = {};
1711
+ _ref1 = "Boolean Number String Function Array Date RegExp Undefined Null".split(" ");
1712
+ for (_i = 0, _len = _ref1.length; _i < _len; _i++) {
1713
+ name = _ref1[_i];
1714
+ classToType["[object " + name + "]"] = name.toLowerCase();
1715
+ }
1716
+ return function(obj) {
1717
+ var strType;
1718
+
1719
+ strType = Object.prototype.toString.call(obj);
1720
+ return classToType[strType] || "object";
1721
+ };
1722
+ })();
1723
+
1724
+ limit = function(x, min, max) {
1725
+ if (min == null) {
1726
+ min = 0;
1727
+ }
1728
+ if (max == null) {
1729
+ max = 1;
1730
+ }
1731
+ if (x < min) {
1732
+ x = min;
1733
+ }
1734
+ if (x > max) {
1735
+ x = max;
1736
+ }
1737
+ return x;
1738
+ };
1739
+
1740
+ unpack = function(args) {
1741
+ if (args.length >= 3) {
1742
+ return args;
1743
+ } else {
1744
+ return args[0];
1745
+ }
1746
+ };
1747
+
1748
+ TWOPI = Math.PI * 2;
1749
+
1750
+ PITHIRD = Math.PI / 3;
1751
+
1752
+ cos = Math.cos;
1753
+
1754
+ /*
1755
+ interpolates between a set of colors uzing a bezier spline
1756
+ */
1757
+
1758
+
1759
+ bezier = function(colors) {
1760
+ var I, I0, I1, c, lab0, lab1, lab2, lab3, _ref1, _ref2, _ref3;
1761
+
1762
+ colors = (function() {
1763
+ var _i, _len, _results;
1764
+
1765
+ _results = [];
1766
+ for (_i = 0, _len = colors.length; _i < _len; _i++) {
1767
+ c = colors[_i];
1768
+ _results.push(chroma(c));
1769
+ }
1770
+ return _results;
1771
+ })();
1772
+ if (colors.length === 2) {
1773
+ _ref1 = (function() {
1774
+ var _i, _len, _results;
1775
+
1776
+ _results = [];
1777
+ for (_i = 0, _len = colors.length; _i < _len; _i++) {
1778
+ c = colors[_i];
1779
+ _results.push(c.lab());
1780
+ }
1781
+ return _results;
1782
+ })(), lab0 = _ref1[0], lab1 = _ref1[1];
1783
+ I = function(t) {
1784
+ var i, lab;
1785
+
1786
+ lab = (function() {
1787
+ var _i, _results;
1788
+
1789
+ _results = [];
1790
+ for (i = _i = 0; _i <= 2; i = ++_i) {
1791
+ _results.push(lab0[i] + t * (lab1[i] - lab0[i]));
1792
+ }
1793
+ return _results;
1794
+ })();
1795
+ return chroma.lab.apply(chroma, lab);
1796
+ };
1797
+ } else if (colors.length === 3) {
1798
+ _ref2 = (function() {
1799
+ var _i, _len, _results;
1800
+
1801
+ _results = [];
1802
+ for (_i = 0, _len = colors.length; _i < _len; _i++) {
1803
+ c = colors[_i];
1804
+ _results.push(c.lab());
1805
+ }
1806
+ return _results;
1807
+ })(), lab0 = _ref2[0], lab1 = _ref2[1], lab2 = _ref2[2];
1808
+ I = function(t) {
1809
+ var i, lab;
1810
+
1811
+ lab = (function() {
1812
+ var _i, _results;
1813
+
1814
+ _results = [];
1815
+ for (i = _i = 0; _i <= 2; i = ++_i) {
1816
+ _results.push((1 - t) * (1 - t) * lab0[i] + 2 * (1 - t) * t * lab1[i] + t * t * lab2[i]);
1817
+ }
1818
+ return _results;
1819
+ })();
1820
+ return chroma.lab.apply(chroma, lab);
1821
+ };
1822
+ } else if (colors.length === 4) {
1823
+ _ref3 = (function() {
1824
+ var _i, _len, _results;
1825
+
1826
+ _results = [];
1827
+ for (_i = 0, _len = colors.length; _i < _len; _i++) {
1828
+ c = colors[_i];
1829
+ _results.push(c.lab());
1830
+ }
1831
+ return _results;
1832
+ })(), lab0 = _ref3[0], lab1 = _ref3[1], lab2 = _ref3[2], lab3 = _ref3[3];
1833
+ I = function(t) {
1834
+ var i, lab;
1835
+
1836
+ lab = (function() {
1837
+ var _i, _results;
1838
+
1839
+ _results = [];
1840
+ for (i = _i = 0; _i <= 2; i = ++_i) {
1841
+ _results.push((1 - t) * (1 - t) * (1 - t) * lab0[i] + 3 * (1 - t) * (1 - t) * t * lab1[i] + 3 * (1 - t) * t * t * lab2[i] + t * t * t * lab3[i]);
1842
+ }
1843
+ return _results;
1844
+ })();
1845
+ return chroma.lab.apply(chroma, lab);
1846
+ };
1847
+ } else if (colors.length === 5) {
1848
+ I0 = bezier(colors.slice(0, 3));
1849
+ I1 = bezier(colors.slice(2, 5));
1850
+ I = function(t) {
1851
+ if (t < 0.5) {
1852
+ return I0(t * 2);
1853
+ } else {
1854
+ return I1((t - 0.5) * 2);
1855
+ }
1856
+ };
1857
+ }
1858
+ return I;
1859
+ };
1860
+
1861
+ chroma.interpolate.bezier = bezier;
1862
+
1863
+ }).call(this);