@thednp/color-picker 0.0.1 → 0.0.2-alpha1
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/README.md +1 -0
- package/dist/css/color-picker.css +1 -1
- package/dist/css/color-picker.min.css +1 -1
- package/dist/css/color-picker.rtl.css +1 -1
- package/dist/css/color-picker.rtl.min.css +1 -1
- package/dist/js/color-esm.js +1178 -0
- package/dist/js/color-esm.min.js +2 -0
- package/dist/js/color-palette-esm.js +1252 -0
- package/dist/js/color-palette-esm.min.js +2 -0
- package/dist/js/color-palette.js +1260 -0
- package/dist/js/color-palette.min.js +2 -0
- package/dist/js/color-picker-element-esm.js +287 -319
- package/dist/js/color-picker-element-esm.min.js +2 -2
- package/dist/js/color-picker-element.js +289 -321
- package/dist/js/color-picker-element.min.js +2 -2
- package/dist/js/color-picker-esm.js +520 -552
- package/dist/js/color-picker-esm.min.js +2 -2
- package/dist/js/color-picker.js +522 -554
- package/dist/js/color-picker.min.js +2 -2
- package/dist/js/color.js +1186 -0
- package/dist/js/color.min.js +2 -0
- package/package.json +19 -3
- package/src/js/color-palette.js +10 -3
- package/src/js/color-picker-element.js +1 -1
- package/src/js/color-picker.js +7 -120
- package/src/js/color.js +88 -91
- package/src/js/util/getColorMenu.js +12 -7
- package/src/js/util/setMarkup.js +122 -0
- package/src/js/util/version.js +6 -0
- package/types/cp.d.ts +47 -17
- package/src/js/util/templates.js +0 -10
@@ -43,7 +43,8 @@ export default function getColorMenu(self, colorsSource, menuClass) {
|
|
43
43
|
optionSize = fit > 5 && isMultiLine ? 1.5 : optionSize;
|
44
44
|
const menuHeight = `${(rowCount || 1) * optionSize}rem`;
|
45
45
|
const menuHeightHover = `calc(${rowCountHover} * ${optionSize}rem + ${rowCountHover - 1} * ${gap})`;
|
46
|
-
|
46
|
+
/** @type {HTMLUListElement} */
|
47
|
+
// @ts-ignore -- <UL> is an `HTMLElement`
|
47
48
|
const menu = createElement({
|
48
49
|
tagName: 'ul',
|
49
50
|
className: finalClass,
|
@@ -51,7 +52,7 @@ export default function getColorMenu(self, colorsSource, menuClass) {
|
|
51
52
|
setAttribute(menu, 'role', 'listbox');
|
52
53
|
setAttribute(menu, ariaLabel, menuLabel);
|
53
54
|
|
54
|
-
if (isScrollable) {
|
55
|
+
if (isScrollable) {
|
55
56
|
setCSSProperties(menu, {
|
56
57
|
'--grid-item-size': `${optionSize}rem`,
|
57
58
|
'--grid-fit': fit,
|
@@ -62,15 +63,19 @@ export default function getColorMenu(self, colorsSource, menuClass) {
|
|
62
63
|
}
|
63
64
|
|
64
65
|
colorsArray.forEach((x) => {
|
65
|
-
|
66
|
-
|
67
|
-
|
66
|
+
let [value, label] = typeof x === 'string' ? x.trim().split(':') : [];
|
67
|
+
if (x instanceof Color) {
|
68
|
+
value = x.toHexString();
|
69
|
+
label = value;
|
70
|
+
}
|
71
|
+
const color = new Color(x instanceof Color ? x : value, format);
|
72
|
+
const isActive = color.toString() === getAttribute(input, 'value');
|
68
73
|
const active = isActive ? ' active' : '';
|
69
74
|
|
70
75
|
const option = createElement({
|
71
76
|
tagName: 'li',
|
72
77
|
className: `color-option${active}`,
|
73
|
-
innerText: `${label ||
|
78
|
+
innerText: `${label || value}`,
|
74
79
|
});
|
75
80
|
|
76
81
|
setAttribute(option, tabIndex, '0');
|
@@ -79,7 +84,7 @@ export default function getColorMenu(self, colorsSource, menuClass) {
|
|
79
84
|
setAttribute(option, ariaSelected, isActive ? 'true' : 'false');
|
80
85
|
|
81
86
|
if (isOptionsMenu) {
|
82
|
-
setElementStyle(option, { backgroundColor:
|
87
|
+
setElementStyle(option, { backgroundColor: value });
|
83
88
|
}
|
84
89
|
|
85
90
|
menu.append(option);
|
@@ -0,0 +1,122 @@
|
|
1
|
+
import getAttribute from 'shorter-js/src/attr/getAttribute';
|
2
|
+
import setAttribute from 'shorter-js/src/attr/setAttribute';
|
3
|
+
import toUpperCase from 'shorter-js/src/misc/toUpperCase';
|
4
|
+
// import ariaLabel from 'shorter-js/src/strings/ariaLabel';
|
5
|
+
import ariaExpanded from 'shorter-js/src/strings/ariaExpanded';
|
6
|
+
import ariaHasPopup from 'shorter-js/src/strings/ariaHasPopup';
|
7
|
+
import ariaHidden from 'shorter-js/src/strings/ariaHidden';
|
8
|
+
import ariaLabelledBy from 'shorter-js/src/strings/ariaLabelledBy';
|
9
|
+
import createElement from 'shorter-js/src/misc/createElement';
|
10
|
+
import createElementNS from 'shorter-js/src/misc/createElementNS';
|
11
|
+
|
12
|
+
import getColorForm from './getColorForm';
|
13
|
+
import getColorControls from './getColorControls';
|
14
|
+
import getColorMenu from './getColorMenu';
|
15
|
+
import nonColors from './nonColors';
|
16
|
+
import vHidden from './vHidden';
|
17
|
+
import tabIndex from './tabindex';
|
18
|
+
|
19
|
+
import Color from '../color';
|
20
|
+
import ColorPalette from '../color-palette';
|
21
|
+
|
22
|
+
/**
|
23
|
+
* Generate HTML markup and update instance properties.
|
24
|
+
* @param {CP.ColorPicker} self
|
25
|
+
*/
|
26
|
+
export default function setMarkup(self) {
|
27
|
+
const {
|
28
|
+
input, parent, format, id, componentLabels, colorKeywords, colorPresets,
|
29
|
+
} = self;
|
30
|
+
const colorValue = getAttribute(input, 'value') || '#fff';
|
31
|
+
|
32
|
+
const {
|
33
|
+
toggleLabel, pickerLabel, formatLabel, hexLabel,
|
34
|
+
} = componentLabels;
|
35
|
+
|
36
|
+
// update color
|
37
|
+
const color = nonColors.includes(colorValue) ? '#fff' : colorValue;
|
38
|
+
self.color = new Color(color, format);
|
39
|
+
|
40
|
+
// set initial controls dimensions
|
41
|
+
const formatString = format === 'hex' ? hexLabel : toUpperCase(format);
|
42
|
+
|
43
|
+
const pickerBtn = createElement({
|
44
|
+
id: `picker-btn-${id}`,
|
45
|
+
tagName: 'button',
|
46
|
+
className: 'picker-toggle btn-appearance',
|
47
|
+
});
|
48
|
+
setAttribute(pickerBtn, ariaExpanded, 'false');
|
49
|
+
setAttribute(pickerBtn, ariaHasPopup, 'true');
|
50
|
+
pickerBtn.append(createElement({
|
51
|
+
tagName: 'span',
|
52
|
+
className: vHidden,
|
53
|
+
innerText: `${pickerLabel}. ${formatLabel}: ${formatString}`,
|
54
|
+
}));
|
55
|
+
|
56
|
+
const pickerDropdown = createElement({
|
57
|
+
tagName: 'div',
|
58
|
+
className: 'color-dropdown picker',
|
59
|
+
});
|
60
|
+
setAttribute(pickerDropdown, ariaLabelledBy, `picker-btn-${id}`);
|
61
|
+
setAttribute(pickerDropdown, 'role', 'group');
|
62
|
+
|
63
|
+
const colorControls = getColorControls(self);
|
64
|
+
const colorForm = getColorForm(self);
|
65
|
+
|
66
|
+
pickerDropdown.append(colorControls, colorForm);
|
67
|
+
input.before(pickerBtn);
|
68
|
+
parent.append(pickerDropdown);
|
69
|
+
|
70
|
+
// set colour key menu template
|
71
|
+
if (colorKeywords || colorPresets) {
|
72
|
+
const presetsDropdown = createElement({
|
73
|
+
tagName: 'div',
|
74
|
+
className: 'color-dropdown scrollable menu',
|
75
|
+
});
|
76
|
+
|
77
|
+
// color presets
|
78
|
+
if ((colorPresets instanceof Array && colorPresets.length)
|
79
|
+
|| (colorPresets instanceof ColorPalette && colorPresets.colors)) {
|
80
|
+
const presetsMenu = getColorMenu(self, colorPresets, 'color-options');
|
81
|
+
presetsDropdown.append(presetsMenu);
|
82
|
+
}
|
83
|
+
|
84
|
+
// explicit defaults [reset, initial, inherit, transparent, currentColor]
|
85
|
+
if (colorKeywords && colorKeywords.length) {
|
86
|
+
const keywordsMenu = getColorMenu(self, colorKeywords, 'color-defaults');
|
87
|
+
presetsDropdown.append(keywordsMenu);
|
88
|
+
}
|
89
|
+
|
90
|
+
const presetsBtn = createElement({
|
91
|
+
tagName: 'button',
|
92
|
+
className: 'menu-toggle btn-appearance',
|
93
|
+
});
|
94
|
+
setAttribute(presetsBtn, tabIndex, '-1');
|
95
|
+
setAttribute(presetsBtn, ariaExpanded, 'false');
|
96
|
+
setAttribute(presetsBtn, ariaHasPopup, 'true');
|
97
|
+
|
98
|
+
const xmlns = encodeURI('http://www.w3.org/2000/svg');
|
99
|
+
const presetsIcon = createElementNS(xmlns, { tagName: 'svg' });
|
100
|
+
setAttribute(presetsIcon, 'xmlns', xmlns);
|
101
|
+
setAttribute(presetsIcon, 'viewBox', '0 0 512 512');
|
102
|
+
setAttribute(presetsIcon, ariaHidden, 'true');
|
103
|
+
|
104
|
+
const path = createElementNS(xmlns, { tagName: 'path' });
|
105
|
+
setAttribute(path, 'd', 'M98,158l157,156L411,158l27,27L255,368L71,185L98,158z');
|
106
|
+
setAttribute(path, 'fill', '#fff');
|
107
|
+
presetsIcon.append(path);
|
108
|
+
presetsBtn.append(createElement({
|
109
|
+
tagName: 'span',
|
110
|
+
className: vHidden,
|
111
|
+
innerText: `${toggleLabel}`,
|
112
|
+
}), presetsIcon);
|
113
|
+
|
114
|
+
parent.append(presetsBtn, presetsDropdown);
|
115
|
+
}
|
116
|
+
|
117
|
+
// solve non-colors after settings save
|
118
|
+
if (colorKeywords && nonColors.includes(colorValue)) {
|
119
|
+
self.value = colorValue;
|
120
|
+
}
|
121
|
+
setAttribute(input, tabIndex, '-1');
|
122
|
+
}
|
package/types/cp.d.ts
CHANGED
@@ -5,14 +5,21 @@ declare module "color-picker/src/js/util/nonColors" {
|
|
5
5
|
*/
|
6
6
|
const nonColors: string[];
|
7
7
|
}
|
8
|
+
declare module "color-picker/src/js/util/roundPart" {
|
9
|
+
/**
|
10
|
+
* Round colour components, for all formats except HEX.
|
11
|
+
* @param {number} v one of the colour components
|
12
|
+
* @returns {number} the rounded number
|
13
|
+
*/
|
14
|
+
export default function roundPart(v: number): number;
|
15
|
+
}
|
8
16
|
declare module "color-picker/src/js/color" {
|
9
|
-
export default Color;
|
10
17
|
/**
|
11
18
|
* @class
|
12
19
|
* Returns a new `Color` instance.
|
13
20
|
* @see https://github.com/bgrins/TinyColor
|
14
21
|
*/
|
15
|
-
class Color {
|
22
|
+
export default class Color {
|
16
23
|
/**
|
17
24
|
* @constructor
|
18
25
|
* @param {CP.ColorInput} input the given colour value
|
@@ -202,15 +209,16 @@ declare module "color-picker/src/js/color-palette" {
|
|
202
209
|
* The `hue` parameter is optional, which would be set to 0.
|
203
210
|
* @param {number[]} args represeinting hue, hueSteps, lightSteps
|
204
211
|
* * `args.hue` the starting Hue [0, 360]
|
205
|
-
* * `args.hueSteps` Hue Steps Count [5,
|
206
|
-
* * `args.lightSteps` Lightness Steps Count [
|
212
|
+
* * `args.hueSteps` Hue Steps Count [5, 24]
|
213
|
+
* * `args.lightSteps` Lightness Steps Count [5, 12]
|
207
214
|
*/
|
208
215
|
constructor(...args: number[]);
|
209
216
|
hue: number;
|
210
217
|
hueSteps: number;
|
211
218
|
lightSteps: number;
|
212
|
-
colors:
|
219
|
+
colors: Color[];
|
213
220
|
}
|
221
|
+
import Color from "color-picker/src/js/color";
|
214
222
|
}
|
215
223
|
declare module "color-picker/src/js/util/colorPickerLabels" {
|
216
224
|
export default colorPickerLabels;
|
@@ -225,6 +233,22 @@ declare module "color-picker/src/js/util/colorNames" {
|
|
225
233
|
*/
|
226
234
|
const colorNames: string[];
|
227
235
|
}
|
236
|
+
declare module "color-picker/src/js/util/tabindex" {
|
237
|
+
export default tabIndex;
|
238
|
+
const tabIndex: "tabindex";
|
239
|
+
}
|
240
|
+
declare module "color-picker/src/js/util/isValidJSON" {
|
241
|
+
/**
|
242
|
+
* Check if a string is valid JSON string.
|
243
|
+
* @param {string} str the string input
|
244
|
+
* @returns {boolean} the query result
|
245
|
+
*/
|
246
|
+
export default function isValidJSON(str: string): boolean;
|
247
|
+
}
|
248
|
+
declare module "color-picker/src/js/version" {
|
249
|
+
export default Version;
|
250
|
+
const Version: string;
|
251
|
+
}
|
228
252
|
declare module "color-picker/src/js/util/vHidden" {
|
229
253
|
export default vHidden;
|
230
254
|
const vHidden: "v-hidden";
|
@@ -247,6 +271,14 @@ declare module "color-picker/src/js/util/getColorControls" {
|
|
247
271
|
*/
|
248
272
|
export default function getColorControls(self: CP.ColorPicker): HTMLElement | Element;
|
249
273
|
}
|
274
|
+
declare module "color-picker/src/js/util/setCSSProperties" {
|
275
|
+
/**
|
276
|
+
* Helps setting CSS variables to the color-menu.
|
277
|
+
* @param {HTMLElement} element
|
278
|
+
* @param {Record<string,any>} props
|
279
|
+
*/
|
280
|
+
export default function setCSSProperties(element: HTMLElement, props: Record<string, any>): void;
|
281
|
+
}
|
250
282
|
declare module "color-picker/src/js/util/getColorMenu" {
|
251
283
|
/**
|
252
284
|
* Returns a color-defaults with given values and class.
|
@@ -257,19 +289,16 @@ declare module "color-picker/src/js/util/getColorMenu" {
|
|
257
289
|
*/
|
258
290
|
export default function getColorMenu(self: CP.ColorPicker, colorsSource: CP.ColorPalette | string[], menuClass: string): HTMLElement | Element;
|
259
291
|
}
|
260
|
-
declare module "color-picker/src/js/util/
|
292
|
+
declare module "color-picker/src/js/util/setMarkup" {
|
261
293
|
/**
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
export default function isValidJSON(str: string): boolean;
|
267
|
-
}
|
268
|
-
declare module "color-picker/src/js/version" {
|
269
|
-
export default Version;
|
270
|
-
const Version: string;
|
294
|
+
* Generate HTML markup and update instance properties.
|
295
|
+
* @param {CP.ColorPicker} self
|
296
|
+
*/
|
297
|
+
export default function setMarkup(self: CP.ColorPicker): void;
|
271
298
|
}
|
272
299
|
declare module "color-picker/src/js/color-picker" {
|
300
|
+
/** @type {CP.GetInstance<ColorPicker>} */
|
301
|
+
export const getColorPickerInstance: CP.GetInstance<ColorPicker>;
|
273
302
|
/**
|
274
303
|
* Color Picker Web Component
|
275
304
|
* @see http://thednp.github.io/color-picker
|
@@ -482,8 +511,9 @@ declare module "color-picker/src/js/color-picker-element" {
|
|
482
511
|
/**
|
483
512
|
* `ColorPickerElement` Web Component.
|
484
513
|
* @example
|
485
|
-
* <
|
486
|
-
*
|
514
|
+
* <label for="UNIQUE_ID">Label</label>
|
515
|
+
* <color-picker data-format="hex" data-value="#075">
|
516
|
+
* <input id="UNIQUE_ID" type="text" class="color-preview btn-appearance">
|
487
517
|
* </color-picker>
|
488
518
|
*/
|
489
519
|
class ColorPickerElement extends HTMLElement {
|