@tbela99/css-parser 0.2.0 → 0.4.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.
Files changed (57) hide show
  1. package/{LICENSE → LICENSE.md} +1 -1
  2. package/README.md +250 -77
  3. package/dist/config.json.js +245 -1
  4. package/dist/index-umd-web.js +4241 -1583
  5. package/dist/index.cjs +4242 -1584
  6. package/dist/index.d.ts +71 -23
  7. package/dist/lib/ast/expand.js +1 -1
  8. package/dist/lib/ast/features/calc.js +31 -192
  9. package/dist/lib/ast/features/index.js +3 -3
  10. package/dist/lib/ast/features/inlinecssvariables.js +6 -6
  11. package/dist/lib/ast/features/shorthand.js +5 -6
  12. package/dist/lib/ast/math/expression.js +220 -0
  13. package/dist/lib/ast/{features/utils → math}/math.js +4 -4
  14. package/dist/lib/ast/minify.js +0 -1
  15. package/dist/lib/ast/types.js +31 -13
  16. package/dist/lib/ast/utils/minifyfeature.js +4 -3
  17. package/dist/lib/ast/walk.js +24 -4
  18. package/dist/lib/fs/resolve.js +4 -3
  19. package/dist/lib/parser/declaration/list.js +6 -2
  20. package/dist/lib/parser/declaration/map.js +158 -24
  21. package/dist/lib/parser/declaration/set.js +42 -22
  22. package/dist/lib/parser/parse.js +345 -349
  23. package/dist/lib/parser/tokenize.js +220 -223
  24. package/dist/lib/parser/utils/declaration.js +67 -0
  25. package/dist/lib/parser/utils/syntax.js +172 -6
  26. package/dist/lib/parser/utils/type.js +2 -2
  27. package/dist/lib/renderer/color/a98rgb.js +64 -0
  28. package/dist/lib/renderer/color/color.js +521 -0
  29. package/dist/lib/renderer/color/colormix.js +337 -0
  30. package/dist/lib/renderer/color/hex.js +92 -0
  31. package/dist/lib/renderer/color/hsl.js +118 -0
  32. package/dist/lib/renderer/color/hsv.js +20 -0
  33. package/dist/lib/renderer/color/hwb.js +101 -0
  34. package/dist/lib/renderer/color/lab.js +136 -0
  35. package/dist/lib/renderer/color/lch.js +79 -0
  36. package/dist/lib/renderer/color/oklab.js +121 -0
  37. package/dist/lib/renderer/color/oklch.js +65 -0
  38. package/dist/lib/renderer/color/p3.js +57 -0
  39. package/dist/lib/renderer/color/prophotorgb.js +56 -0
  40. package/dist/lib/renderer/color/rec2020.js +70 -0
  41. package/dist/lib/renderer/color/relativecolor.js +152 -0
  42. package/dist/lib/renderer/color/rgb.js +44 -0
  43. package/dist/lib/renderer/color/srgb.js +261 -0
  44. package/dist/lib/renderer/color/utils/components.js +20 -0
  45. package/dist/lib/renderer/color/utils/constants.js +191 -0
  46. package/dist/lib/renderer/color/utils/matrix.js +35 -0
  47. package/dist/lib/renderer/color/xyz.js +64 -0
  48. package/dist/lib/renderer/color/xyzd50.js +33 -0
  49. package/dist/lib/renderer/render.js +128 -30
  50. package/dist/node/index.js +1 -1
  51. package/dist/node/load.js +1 -1
  52. package/dist/web/index.js +1 -1
  53. package/package.json +19 -18
  54. package/quickjs.sh +1 -0
  55. package/dist/lib/iterable/weakmap.js +0 -53
  56. package/dist/lib/renderer/utils/color.js +0 -499
  57. /package/dist/lib/iterable/{set.js → weakset.js} +0 -0
@@ -1,499 +0,0 @@
1
- import { EnumToken } from '../../ast/types.js';
2
- import '../../ast/minify.js';
3
- import '../../parser/parse.js';
4
- import '../sourcemap/lib/encode.js';
5
-
6
- // name to color
7
- const COLORS_NAMES = Object.seal({
8
- 'aliceblue': '#f0f8ff',
9
- 'antiquewhite': '#faebd7',
10
- 'aqua': '#00ffff',
11
- 'aquamarine': '#7fffd4',
12
- 'azure': '#f0ffff',
13
- 'beige': '#f5f5dc',
14
- 'bisque': '#ffe4c4',
15
- 'black': '#000000',
16
- 'blanchedalmond': '#ffebcd',
17
- 'blue': '#0000ff',
18
- 'blueviolet': '#8a2be2',
19
- 'brown': '#a52a2a',
20
- 'burlywood': '#deb887',
21
- 'cadetblue': '#5f9ea0',
22
- 'chartreuse': '#7fff00',
23
- 'chocolate': '#d2691e',
24
- 'coral': '#ff7f50',
25
- 'cornflowerblue': '#6495ed',
26
- 'cornsilk': '#fff8dc',
27
- 'crimson': '#dc143c',
28
- 'cyan': '#00ffff',
29
- 'darkblue': '#00008b',
30
- 'darkcyan': '#008b8b',
31
- 'darkgoldenrod': '#b8860b',
32
- 'darkgray': '#a9a9a9',
33
- 'darkgrey': '#a9a9a9',
34
- 'darkgreen': '#006400',
35
- 'darkkhaki': '#bdb76b',
36
- 'darkmagenta': '#8b008b',
37
- 'darkolivegreen': '#556b2f',
38
- 'darkorange': '#ff8c00',
39
- 'darkorchid': '#9932cc',
40
- 'darkred': '#8b0000',
41
- 'darksalmon': '#e9967a',
42
- 'darkseagreen': '#8fbc8f',
43
- 'darkslateblue': '#483d8b',
44
- 'darkslategray': '#2f4f4f',
45
- 'darkslategrey': '#2f4f4f',
46
- 'darkturquoise': '#00ced1',
47
- 'darkviolet': '#9400d3',
48
- 'deeppink': '#ff1493',
49
- 'deepskyblue': '#00bfff',
50
- 'dimgray': '#696969',
51
- 'dimgrey': '#696969',
52
- 'dodgerblue': '#1e90ff',
53
- 'firebrick': '#b22222',
54
- 'floralwhite': '#fffaf0',
55
- 'forestgreen': '#228b22',
56
- 'fuchsia': '#ff00ff',
57
- 'gainsboro': '#dcdcdc',
58
- 'ghostwhite': '#f8f8ff',
59
- 'gold': '#ffd700',
60
- 'goldenrod': '#daa520',
61
- 'gray': '#808080',
62
- 'grey': '#808080',
63
- 'green': '#008000',
64
- 'greenyellow': '#adff2f',
65
- 'honeydew': '#f0fff0',
66
- 'hotpink': '#ff69b4',
67
- 'indianred': '#cd5c5c',
68
- 'indigo': '#4b0082',
69
- 'ivory': '#fffff0',
70
- 'khaki': '#f0e68c',
71
- 'lavender': '#e6e6fa',
72
- 'lavenderblush': '#fff0f5',
73
- 'lawngreen': '#7cfc00',
74
- 'lemonchiffon': '#fffacd',
75
- 'lightblue': '#add8e6',
76
- 'lightcoral': '#f08080',
77
- 'lightcyan': '#e0ffff',
78
- 'lightgoldenrodyellow': '#fafad2',
79
- 'lightgray': '#d3d3d3',
80
- 'lightgrey': '#d3d3d3',
81
- 'lightgreen': '#90ee90',
82
- 'lightpink': '#ffb6c1',
83
- 'lightsalmon': '#ffa07a',
84
- 'lightseagreen': '#20b2aa',
85
- 'lightskyblue': '#87cefa',
86
- 'lightslategray': '#778899',
87
- 'lightslategrey': '#778899',
88
- 'lightsteelblue': '#b0c4de',
89
- 'lightyellow': '#ffffe0',
90
- 'lime': '#00ff00',
91
- 'limegreen': '#32cd32',
92
- 'linen': '#faf0e6',
93
- 'magenta': '#ff00ff',
94
- 'maroon': '#800000',
95
- 'mediumaquamarine': '#66cdaa',
96
- 'mediumblue': '#0000cd',
97
- 'mediumorchid': '#ba55d3',
98
- 'mediumpurple': '#9370d8',
99
- 'mediumseagreen': '#3cb371',
100
- 'mediumslateblue': '#7b68ee',
101
- 'mediumspringgreen': '#00fa9a',
102
- 'mediumturquoise': '#48d1cc',
103
- 'mediumvioletred': '#c71585',
104
- 'midnightblue': '#191970',
105
- 'mintcream': '#f5fffa',
106
- 'mistyrose': '#ffe4e1',
107
- 'moccasin': '#ffe4b5',
108
- 'navajowhite': '#ffdead',
109
- 'navy': '#000080',
110
- 'oldlace': '#fdf5e6',
111
- 'olive': '#808000',
112
- 'olivedrab': '#6b8e23',
113
- 'orange': '#ffa500',
114
- 'orangered': '#ff4500',
115
- 'orchid': '#da70d6',
116
- 'palegoldenrod': '#eee8aa',
117
- 'palegreen': '#98fb98',
118
- 'paleturquoise': '#afeeee',
119
- 'palevioletred': '#d87093',
120
- 'papayawhip': '#ffefd5',
121
- 'peachpuff': '#ffdab9',
122
- 'peru': '#cd853f',
123
- 'pink': '#ffc0cb',
124
- 'plum': '#dda0dd',
125
- 'powderblue': '#b0e0e6',
126
- 'purple': '#800080',
127
- 'red': '#ff0000',
128
- 'rosybrown': '#bc8f8f',
129
- 'royalblue': '#4169e1',
130
- 'saddlebrown': '#8b4513',
131
- 'salmon': '#fa8072',
132
- 'sandybrown': '#f4a460',
133
- 'seagreen': '#2e8b57',
134
- 'seashell': '#fff5ee',
135
- 'sienna': '#a0522d',
136
- 'silver': '#c0c0c0',
137
- 'skyblue': '#87ceeb',
138
- 'slateblue': '#6a5acd',
139
- 'slategray': '#708090',
140
- 'slategrey': '#708090',
141
- 'snow': '#fffafa',
142
- 'springgreen': '#00ff7f',
143
- 'steelblue': '#4682b4',
144
- 'tan': '#d2b48c',
145
- 'teal': '#008080',
146
- 'thistle': '#d8bfd8',
147
- 'tomato': '#ff6347',
148
- 'turquoise': '#40e0d0',
149
- 'violet': '#ee82ee',
150
- 'wheat': '#f5deb3',
151
- 'white': '#ffffff',
152
- 'whitesmoke': '#f5f5f5',
153
- 'yellow': '#ffff00',
154
- 'yellowgreen': '#9acd32',
155
- 'rebeccapurple': '#663399',
156
- 'transparent': '#00000000'
157
- });
158
- // color to name
159
- const NAMES_COLORS = Object.seal({
160
- '#f0f8ff': 'aliceblue',
161
- '#faebd7': 'antiquewhite',
162
- // '#00ffff': 'aqua',
163
- '#7fffd4': 'aquamarine',
164
- '#f0ffff': 'azure',
165
- '#f5f5dc': 'beige',
166
- '#ffe4c4': 'bisque',
167
- '#000000': 'black',
168
- '#ffebcd': 'blanchedalmond',
169
- '#0000ff': 'blue',
170
- '#8a2be2': 'blueviolet',
171
- '#a52a2a': 'brown',
172
- '#deb887': 'burlywood',
173
- '#5f9ea0': 'cadetblue',
174
- '#7fff00': 'chartreuse',
175
- '#d2691e': 'chocolate',
176
- '#ff7f50': 'coral',
177
- '#6495ed': 'cornflowerblue',
178
- '#fff8dc': 'cornsilk',
179
- '#dc143c': 'crimson',
180
- '#00ffff': 'cyan',
181
- '#00008b': 'darkblue',
182
- '#008b8b': 'darkcyan',
183
- '#b8860b': 'darkgoldenrod',
184
- // '#a9a9a9': 'darkgray',
185
- '#a9a9a9': 'darkgrey',
186
- '#006400': 'darkgreen',
187
- '#bdb76b': 'darkkhaki',
188
- '#8b008b': 'darkmagenta',
189
- '#556b2f': 'darkolivegreen',
190
- '#ff8c00': 'darkorange',
191
- '#9932cc': 'darkorchid',
192
- '#8b0000': 'darkred',
193
- '#e9967a': 'darksalmon',
194
- '#8fbc8f': 'darkseagreen',
195
- '#483d8b': 'darkslateblue',
196
- // '#2f4f4f': 'darkslategray',
197
- '#2f4f4f': 'darkslategrey',
198
- '#00ced1': 'darkturquoise',
199
- '#9400d3': 'darkviolet',
200
- '#ff1493': 'deeppink',
201
- '#00bfff': 'deepskyblue',
202
- // '#696969': 'dimgray',
203
- '#696969': 'dimgrey',
204
- '#1e90ff': 'dodgerblue',
205
- '#b22222': 'firebrick',
206
- '#fffaf0': 'floralwhite',
207
- '#228b22': 'forestgreen',
208
- // '#ff00ff': 'fuchsia',
209
- '#dcdcdc': 'gainsboro',
210
- '#f8f8ff': 'ghostwhite',
211
- '#ffd700': 'gold',
212
- '#daa520': 'goldenrod',
213
- // '#808080': 'gray',
214
- '#808080': 'grey',
215
- '#008000': 'green',
216
- '#adff2f': 'greenyellow',
217
- '#f0fff0': 'honeydew',
218
- '#ff69b4': 'hotpink',
219
- '#cd5c5c': 'indianred',
220
- '#4b0082': 'indigo',
221
- '#fffff0': 'ivory',
222
- '#f0e68c': 'khaki',
223
- '#e6e6fa': 'lavender',
224
- '#fff0f5': 'lavenderblush',
225
- '#7cfc00': 'lawngreen',
226
- '#fffacd': 'lemonchiffon',
227
- '#add8e6': 'lightblue',
228
- '#f08080': 'lightcoral',
229
- '#e0ffff': 'lightcyan',
230
- '#fafad2': 'lightgoldenrodyellow',
231
- // '#d3d3d3': 'lightgray',
232
- '#d3d3d3': 'lightgrey',
233
- '#90ee90': 'lightgreen',
234
- '#ffb6c1': 'lightpink',
235
- '#ffa07a': 'lightsalmon',
236
- '#20b2aa': 'lightseagreen',
237
- '#87cefa': 'lightskyblue',
238
- // '#778899': 'lightslategray',
239
- '#778899': 'lightslategrey',
240
- '#b0c4de': 'lightsteelblue',
241
- '#ffffe0': 'lightyellow',
242
- '#00ff00': 'lime',
243
- '#32cd32': 'limegreen',
244
- '#faf0e6': 'linen',
245
- '#ff00ff': 'magenta',
246
- '#800000': 'maroon',
247
- '#66cdaa': 'mediumaquamarine',
248
- '#0000cd': 'mediumblue',
249
- '#ba55d3': 'mediumorchid',
250
- '#9370d8': 'mediumpurple',
251
- '#3cb371': 'mediumseagreen',
252
- '#7b68ee': 'mediumslateblue',
253
- '#00fa9a': 'mediumspringgreen',
254
- '#48d1cc': 'mediumturquoise',
255
- '#c71585': 'mediumvioletred',
256
- '#191970': 'midnightblue',
257
- '#f5fffa': 'mintcream',
258
- '#ffe4e1': 'mistyrose',
259
- '#ffe4b5': 'moccasin',
260
- '#ffdead': 'navajowhite',
261
- '#000080': 'navy',
262
- '#fdf5e6': 'oldlace',
263
- '#808000': 'olive',
264
- '#6b8e23': 'olivedrab',
265
- '#ffa500': 'orange',
266
- '#ff4500': 'orangered',
267
- '#da70d6': 'orchid',
268
- '#eee8aa': 'palegoldenrod',
269
- '#98fb98': 'palegreen',
270
- '#afeeee': 'paleturquoise',
271
- '#d87093': 'palevioletred',
272
- '#ffefd5': 'papayawhip',
273
- '#ffdab9': 'peachpuff',
274
- '#cd853f': 'peru',
275
- '#ffc0cb': 'pink',
276
- '#dda0dd': 'plum',
277
- '#b0e0e6': 'powderblue',
278
- '#800080': 'purple',
279
- '#ff0000': 'red',
280
- '#bc8f8f': 'rosybrown',
281
- '#4169e1': 'royalblue',
282
- '#8b4513': 'saddlebrown',
283
- '#fa8072': 'salmon',
284
- '#f4a460': 'sandybrown',
285
- '#2e8b57': 'seagreen',
286
- '#fff5ee': 'seashell',
287
- '#a0522d': 'sienna',
288
- '#c0c0c0': 'silver',
289
- '#87ceeb': 'skyblue',
290
- '#6a5acd': 'slateblue',
291
- // '#708090': 'slategray',
292
- '#708090': 'slategrey',
293
- '#fffafa': 'snow',
294
- '#00ff7f': 'springgreen',
295
- '#4682b4': 'steelblue',
296
- '#d2b48c': 'tan',
297
- '#008080': 'teal',
298
- '#d8bfd8': 'thistle',
299
- '#ff6347': 'tomato',
300
- '#40e0d0': 'turquoise',
301
- '#ee82ee': 'violet',
302
- '#f5deb3': 'wheat',
303
- '#ffffff': 'white',
304
- '#f5f5f5': 'whitesmoke',
305
- '#ffff00': 'yellow',
306
- '#9acd32': 'yellowgreen',
307
- '#663399': 'rebeccapurple',
308
- '#00000000': 'transparent'
309
- });
310
- function rgb2Hex(token) {
311
- let value = '#';
312
- let t;
313
- // @ts-ignore
314
- for (let i = 0; i < 6; i += 2) {
315
- // @ts-ignore
316
- t = token.chi[i];
317
- // @ts-ignore
318
- value += Math.round(t.typ == EnumToken.PercentageTokenType ? 255 * t.val / 100 : t.val).toString(16).padStart(2, '0');
319
- }
320
- // @ts-ignore
321
- if (token.chi.length == 7) {
322
- // @ts-ignore
323
- t = token.chi[6];
324
- // @ts-ignore
325
- if ((t.typ == EnumToken.NumberTokenType && t.val < 1) ||
326
- // @ts-ignore
327
- (t.typ == EnumToken.PercentageTokenType && t.val < 100)) {
328
- // @ts-ignore
329
- value += Math.round(255 * (t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val)).toString(16).padStart(2, '0');
330
- }
331
- }
332
- return value;
333
- }
334
- function hsl2Hex(token) {
335
- let t;
336
- // @ts-ignore
337
- let h = getAngle(token.chi[0]);
338
- // @ts-ignore
339
- t = token.chi[2];
340
- // @ts-ignore
341
- let s = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
342
- // @ts-ignore
343
- t = token.chi[4];
344
- // @ts-ignore
345
- let l = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
346
- let a = null;
347
- if (token.chi?.length == 7) {
348
- // @ts-ignore
349
- t = token.chi[6];
350
- // @ts-ignore
351
- if ((t.typ == EnumToken.PercentageTokenType && t.val < 100) ||
352
- // @ts-ignore
353
- (t.typ == EnumToken.NumberTokenType && t.val < 1)) {
354
- // @ts-ignore
355
- a = (t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val);
356
- }
357
- }
358
- return `#${hsl2rgb(h, s, l, a).reduce((acc, curr) => acc + curr.toString(16).padStart(2, '0'), '')}`;
359
- }
360
- function hwb2hex(token) {
361
- let t;
362
- // @ts-ignore
363
- let h = getAngle(token.chi[0]);
364
- // @ts-ignore
365
- t = token.chi[2];
366
- // @ts-ignore
367
- let white = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
368
- // @ts-ignore
369
- t = token.chi[4];
370
- // @ts-ignore
371
- let black = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
372
- let a = null;
373
- if (token.chi?.length == 7) {
374
- // @ts-ignore
375
- t = token.chi[6];
376
- // @ts-ignore
377
- if ((t.typ == EnumToken.PercentageTokenType && t.val < 100) ||
378
- // @ts-ignore
379
- (t.typ == EnumToken.NumberTokenType && t.val < 1)) {
380
- // @ts-ignore
381
- a = (t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val);
382
- }
383
- }
384
- const rgb = hsl2rgb(h, 1, .5, a);
385
- let value;
386
- for (let i = 0; i < 3; i++) {
387
- value = rgb[i] / 255;
388
- value *= (1 - white - black);
389
- value += white;
390
- rgb[i] = Math.round(value * 255);
391
- }
392
- return `#${rgb.reduce((acc, curr) => acc + curr.toString(16).padStart(2, '0'), '')}`;
393
- }
394
- function cmyk2hex(token) {
395
- // @ts-ignore
396
- let t = token.chi[0];
397
- // @ts-ignore
398
- const c = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
399
- // @ts-ignore
400
- t = token.chi[2];
401
- // @ts-ignore
402
- const m = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
403
- // @ts-ignore
404
- t = token.chi[4];
405
- // @ts-ignore
406
- const y = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
407
- // @ts-ignore
408
- t = token.chi[6];
409
- // @ts-ignore
410
- const k = t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val;
411
- const rgb = [
412
- Math.round(255 * (1 - Math.min(1, c * (1 - k) + k))),
413
- Math.round(255 * (1 - Math.min(1, m * (1 - k) + k))),
414
- Math.round(255 * (1 - Math.min(1, y * (1 - k) + k)))
415
- ];
416
- // @ts-ignore
417
- if (token.chi.length >= 9) {
418
- // @ts-ignore
419
- t = token.chi[8];
420
- // @ts-ignore
421
- rgb.push(Math.round(255 * (t.typ == EnumToken.PercentageTokenType ? t.val / 100 : t.val)));
422
- }
423
- return `#${rgb.reduce((acc, curr) => acc + curr.toString(16).padStart(2, '0'), '')}`;
424
- }
425
- function getAngle(token) {
426
- if (token.typ == EnumToken.AngleTokenType) {
427
- switch (token.unit) {
428
- case 'deg':
429
- // @ts-ignore
430
- return token.val / 360;
431
- case 'rad':
432
- // @ts-ignore
433
- return token.val / (2 * Math.PI);
434
- case 'grad':
435
- // @ts-ignore
436
- return token.val / 400;
437
- case 'turn':
438
- // @ts-ignore
439
- return +token.val;
440
- }
441
- }
442
- // @ts-ignore
443
- return token.val / 360;
444
- }
445
- function hsl2rgb(h, s, l, a = null) {
446
- let v = l <= .5 ? l * (1.0 + s) : l + s - l * s;
447
- let r = l;
448
- let g = l;
449
- let b = l;
450
- if (v > 0) {
451
- let m = l + l - v;
452
- let sv = (v - m) / v;
453
- h *= 6.0;
454
- let sextant = Math.floor(h);
455
- let fract = h - sextant;
456
- let vsf = v * sv * fract;
457
- let mid1 = m + vsf;
458
- let mid2 = v - vsf;
459
- switch (sextant) {
460
- case 0:
461
- r = v;
462
- g = mid1;
463
- b = m;
464
- break;
465
- case 1:
466
- r = mid2;
467
- g = v;
468
- b = m;
469
- break;
470
- case 2:
471
- r = m;
472
- g = v;
473
- b = mid1;
474
- break;
475
- case 3:
476
- r = m;
477
- g = mid2;
478
- b = v;
479
- break;
480
- case 4:
481
- r = mid1;
482
- g = m;
483
- b = v;
484
- break;
485
- case 5:
486
- r = v;
487
- g = m;
488
- b = mid2;
489
- break;
490
- }
491
- }
492
- const values = [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)];
493
- if (a != null && a != 1) {
494
- values.push(Math.round(a * 255));
495
- }
496
- return values;
497
- }
498
-
499
- export { COLORS_NAMES, NAMES_COLORS, cmyk2hex, getAngle, hsl2Hex, hwb2hex, rgb2Hex };
File without changes