@nuralyui/colorpicker 0.0.4 → 0.0.6

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.
@@ -1,134 +1,321 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2023 Nuraly, Laabidi Aymen
4
+ * SPDX-License-Identifier: MIT
5
+ */
1
6
  var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
7
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
8
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
9
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
10
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
11
  };
7
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
8
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
9
- return new (P || (P = Promise))(function (resolve, reject) {
10
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
11
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
12
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
13
- step((generator = generator.apply(thisArg, _arguments || [])).next());
14
- });
15
- };
16
12
  import { LitElement, html, nothing } from 'lit';
17
13
  import { customElement, property, state } from 'lit/decorators.js';
14
+ import { classMap } from 'lit/directives/class-map.js';
15
+ import { NuralyUIBaseMixin } from '@nuralyui/common/mixins';
16
+ import '../input/index.js';
17
+ // Import child components
18
18
  import './color-holder.component.js';
19
19
  import './default-color-sets.component.js';
20
+ // Import styles and types
20
21
  import styles from './color-picker.style.js';
21
- let ColorPicker = class ColorPicker extends LitElement {
22
+ // Import controllers
23
+ import { ColorPickerDropdownController, ColorPickerEventController, } from './controllers/index.js';
24
+ /**
25
+ * Advanced color picker component with dropdown positioning, validation, and accessibility.
26
+ *
27
+ * Supports multiple color formats, default color sets, custom triggers, keyboard navigation,
28
+ * and various display configurations.
29
+ *
30
+ * @example
31
+ * ```html
32
+ * <!-- Basic color picker -->
33
+ * <nr-color-picker color="#3498db"></nr-color-picker>
34
+ *
35
+ * <!-- With default colors -->
36
+ * <nr-color-picker
37
+ * color="#3498db"
38
+ * .defaultColorSets="${['#3498db', '#e74c3c', '#2ecc71']}">
39
+ * </nr-color-picker>
40
+ *
41
+ * <!-- With custom configuration -->
42
+ * <nr-color-picker
43
+ * color="#3498db"
44
+ * trigger="click"
45
+ * placement="top"
46
+ * size="large"
47
+ * show-input="true"
48
+ * show-copy-button="true">
49
+ * </nr-color-picker>
50
+ *
51
+ * <!-- Disabled -->
52
+ * <nr-color-picker color="#3498db" disabled></nr-color-picker>
53
+ * ```
54
+ *
55
+ * @fires hy-color-change - Color value changed
56
+ * @fires nr-colorpicker-open - Dropdown opened
57
+ * @fires nr-colorpicker-close - Dropdown closed
58
+ * @fires color-changed - Legacy event for backwards compatibility
59
+ *
60
+ * @slot - Default slot for custom content
61
+ *
62
+ * @cssproperty --colorpicker-trigger-size - Size of the color trigger box
63
+ * @cssproperty --colorpicker-dropdown-width - Width of the dropdown panel
64
+ * @cssproperty --colorpicker-dropdown-background - Background color of dropdown
65
+ * @cssproperty --colorpicker-dropdown-shadow - Shadow of dropdown panel
66
+ * @cssproperty --colorpicker-dropdown-border-radius - Border radius of dropdown
67
+ */
68
+ let ColorPicker = class ColorPicker extends NuralyUIBaseMixin(LitElement) {
22
69
  constructor() {
23
70
  super();
24
- this.color = 'transparent';
71
+ this.requiredComponents = ['nr-input', 'nr-icon'];
72
+ /** Current color value */
73
+ this.color = '#3498db';
74
+ /** Controls dropdown visibility */
25
75
  this.show = false;
76
+ /** Array of preset colors to display */
26
77
  this.defaultColorSets = [];
78
+ /** Disables the color picker */
27
79
  this.disabled = false;
80
+ /** Color picker size (small, default, large) */
28
81
  this.size = "default" /* ColorPickerSize.Default */;
82
+ /** Trigger mode for opening dropdown */
83
+ this.trigger = "click" /* ColorPickerTrigger.Click */;
84
+ /** Dropdown placement */
85
+ this.placement = "auto" /* ColorPickerPlacement.Auto */;
86
+ /** Animation style for dropdown */
87
+ this.animation = "fade" /* ColorPickerAnimation.Fade */;
88
+ /** Close dropdown when a color is selected */
89
+ this.closeOnSelect = false;
90
+ /** Close dropdown on outside click */
91
+ this.closeOnOutsideClick = true;
92
+ /** Close dropdown on escape key */
93
+ this.closeOnEscape = true;
94
+ /** Show color input field */
95
+ this.showInput = true;
96
+ /** Show copy button on input */
97
+ this.showCopyButton = true;
98
+ /** Color format (hex, rgb, rgba, hsl, hsla) */
99
+ this.format = "hex" /* ColorFormat.Hex */;
100
+ /** Placeholder text for color input */
101
+ this.inputPlaceholder = 'Enter color';
102
+ /** Label text */
103
+ this.label = '';
104
+ /** Helper text */
105
+ this.helperText = '';
106
+ /** Validation state for color value */
29
107
  this.isValidColor = true;
30
- this.onClickOutside = (onClickEvent) => {
31
- const outsideClick = !onClickEvent.composedPath().includes(this);
32
- if (outsideClick)
33
- this.show = false;
108
+ /** Manages dropdown visibility and positioning */
109
+ this.dropdownController = new ColorPickerDropdownController(this);
110
+ /** Handles all event management */
111
+ this.eventController = new ColorPickerEventController(this);
112
+ /**
113
+ * Handles trigger click to toggle dropdown
114
+ */
115
+ this.handleTriggerClick = (event) => {
116
+ this.eventController.handleTriggerClick(event);
34
117
  };
35
- this.calculateDropDownPosition = () => {
36
- var _a, _b;
37
- const dropdownContainer = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.dropdown-container');
38
- const colorHolder = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.color-holder');
39
- if (dropdownContainer && colorHolder) {
40
- const dropdownRect = dropdownContainer.getBoundingClientRect();
41
- const colorHolderRect = colorHolder.getBoundingClientRect();
42
- const viewportHeight = window.innerHeight;
43
- const viewportWidth = window.innerWidth;
44
- // Check if the dropdown is going out of the viewport vertically
45
- if (colorHolderRect.bottom + dropdownRect.height > viewportHeight) {
46
- // Move the dropdown upwards if it goes out of the viewport
47
- dropdownContainer.style.top = `${colorHolderRect.top - dropdownRect.height}px`;
48
- }
49
- else {
50
- // Otherwise, position it below the color holder
51
- dropdownContainer.style.top = `${colorHolderRect.bottom}px`;
52
- }
53
- // Check if the dropdown is going out of the viewport horizontally
54
- if (colorHolderRect.right + dropdownRect.width > viewportWidth) {
55
- // Move the dropdown to the left if it goes out of the viewport
56
- dropdownContainer.style.left = `${viewportWidth - dropdownRect.width}px`;
57
- }
58
- else {
59
- // Otherwise, position it to the right of the color holder
60
- dropdownContainer.style.left = `${colorHolderRect.left}px`;
61
- }
118
+ /**
119
+ * Handles color selection from hex-color-picker or default colors
120
+ */
121
+ this.handleColorChanged = (event) => {
122
+ const newColor = event.detail.value;
123
+ this.eventController.handleColorChange(newColor);
124
+ if (this.closeOnSelect) {
125
+ this.dropdownController.close();
62
126
  }
63
127
  };
128
+ /**
129
+ * Handles input change from text input
130
+ */
131
+ this.handleInputChange = (event) => {
132
+ this.eventController.handleInputChange(event);
133
+ };
134
+ // Dynamically import vanilla-colorful for color picker UI
64
135
  if (typeof window !== 'undefined') {
65
136
  import('vanilla-colorful');
66
137
  }
67
138
  }
139
+ /**
140
+ * Component connected to DOM - initialize base functionality
141
+ */
68
142
  connectedCallback() {
69
143
  super.connectedCallback();
70
- // Mark the scroll listener as passive:
71
- document.addEventListener('scroll', this.calculateDropDownPosition, {
72
- passive: true,
73
- });
74
- document.addEventListener('click', this.onClickOutside);
75
144
  }
145
+ /**
146
+ * Component disconnected from DOM - cleanup event listeners
147
+ */
148
+ disconnectedCallback() {
149
+ super.disconnectedCallback();
150
+ }
151
+ /**
152
+ * Called after component updates
153
+ */
76
154
  updated(changedProperties) {
155
+ super.updated(changedProperties);
77
156
  if (changedProperties.has('color')) {
78
- this.checkIsValidColor();
157
+ this.validateColor();
79
158
  }
80
159
  }
81
- toggleColorHolder() {
82
- return __awaiter(this, void 0, void 0, function* () {
83
- this.show = !this.show;
84
- yield this.updateComplete;
85
- this.calculateDropDownPosition();
86
- });
87
- }
88
- handleColorChanged(colorChangedEvent) {
89
- if (this.color != colorChangedEvent.detail.value) {
90
- this.color = colorChangedEvent.detail.value;
91
- this.dispatchColorChange();
92
- }
160
+ // === Public API Methods ===
161
+ /**
162
+ * Opens the color picker dropdown
163
+ */
164
+ open() {
165
+ this.dropdownController.open();
93
166
  }
94
- onInputChange(inputChangedEvent) {
95
- if (this.color != inputChangedEvent.detail.value) {
96
- this.color = inputChangedEvent.detail.value;
97
- this.dispatchColorChange();
98
- }
167
+ /**
168
+ * Closes the color picker dropdown
169
+ */
170
+ close() {
171
+ this.dropdownController.close();
99
172
  }
100
- dispatchColorChange() {
101
- this.dispatchEvent(new CustomEvent('color-changed', {
102
- detail: {
103
- value: this.color,
104
- },
105
- }));
173
+ /**
174
+ * Toggles the color picker dropdown
175
+ */
176
+ toggle() {
177
+ this.dropdownController.toggle();
106
178
  }
107
- checkIsValidColor() {
108
- this.isValidColor = CSS.supports('color', this.color);
179
+ /**
180
+ * Validates the current color value
181
+ */
182
+ validateColor() {
183
+ this.isValidColor = this.eventController.isValidColor(this.color);
184
+ return this.isValidColor;
109
185
  }
110
- disconnectedCallback() {
111
- document.removeEventListener('click', this.onClickOutside);
112
- document.removeEventListener('scroll', this.calculateDropDownPosition);
186
+ /**
187
+ * Sets up global event listeners (called by dropdown controller)
188
+ */
189
+ setupEventListeners() {
190
+ if (this.closeOnOutsideClick || this.closeOnEscape) {
191
+ this.eventController.setupEventListeners();
192
+ }
113
193
  }
194
+ /**
195
+ * Removes global event listeners (called by dropdown controller)
196
+ */
197
+ removeEventListeners() {
198
+ this.eventController.removeEventListeners();
199
+ }
200
+ /**
201
+ * Main render method
202
+ */
114
203
  render() {
115
- return html `<div class="color-picker-container">
116
- <hy-colorholder-box
117
- class="color-holder"
118
- color="${this.color}"
119
- .size=${this.size}
120
- @click=${!this.disabled ? this.toggleColorHolder : nothing}
121
- ></hy-colorholder-box>
122
- <div class='dropdown-container'>
123
- <hy-default-color-sets .defaultColorSets=${this.defaultColorSets} @color-click="${this.handleColorChanged}">
124
- </hy-default-color-sets>
125
- <hex-color-picker
204
+ const containerClasses = {
205
+ 'color-picker-container': true,
206
+ 'color-picker-container--disabled': this.disabled,
207
+ 'color-picker-container--open': this.show,
208
+ [`color-picker-container--${this.size}`]: true,
209
+ };
210
+ return html `
211
+ <div class="${classMap(containerClasses)}" data-theme="${this.currentTheme}">
212
+ ${this.renderLabel()}
213
+
214
+ <nr-colorholder-box
215
+ class="color-holder"
126
216
  color="${this.color}"
127
- @color-changed="${(colorChangedEvent) => this.handleColorChanged(colorChangedEvent)}"
128
- ></hex-color-picker>
129
- <hy-input type="text" .value="${this.color}" @valueChange="${this.onInputChange}" withCopy=${true} .state=${!this.isValidColor ? 'error' : nothing}> </hy-input>
217
+ .size=${this.size}
218
+ ?disabled="${this.disabled}"
219
+ @click=${this.disabled ? nothing : this.handleTriggerClick}
220
+ role="button"
221
+ aria-label="Select color"
222
+ aria-expanded="${this.show}"
223
+ aria-haspopup="dialog"
224
+ tabindex="${this.disabled ? -1 : 0}"
225
+ ></nr-colorholder-box>
226
+
227
+ ${this.renderDropdown()}
228
+ ${this.renderHelperText()}
229
+ </div>
230
+ `;
231
+ }
232
+ /**
233
+ * Renders the label if provided
234
+ */
235
+ renderLabel() {
236
+ if (!this.label)
237
+ return nothing;
238
+ return html `
239
+ <label class="color-picker-label">
240
+ ${this.label}
241
+ </label>
242
+ `;
243
+ }
244
+ /**
245
+ * Renders the dropdown panel with color picker
246
+ */
247
+ renderDropdown() {
248
+ if (!this.show)
249
+ return nothing;
250
+ return html `
251
+ <div
252
+ class="dropdown-container"
253
+ role="dialog"
254
+ aria-label="Color picker"
255
+ >
256
+ ${this.renderDefaultColorSets()}
257
+ ${this.renderColorPicker()}
258
+ ${this.renderColorInput()}
259
+ </div>
260
+ `;
261
+ }
262
+ /**
263
+ * Renders default color sets if provided
264
+ */
265
+ renderDefaultColorSets() {
266
+ if (!this.defaultColorSets || this.defaultColorSets.length === 0) {
267
+ return nothing;
268
+ }
269
+ return html `
270
+ <nr-default-color-sets
271
+ .defaultColorSets=${this.defaultColorSets}
272
+ @color-click="${this.handleColorChanged}"
273
+ aria-label="Preset colors">
274
+ </nr-default-color-sets>
275
+ `;
276
+ }
277
+ /**
278
+ * Renders the hex color picker
279
+ */
280
+ renderColorPicker() {
281
+ return html `
282
+ <hex-color-picker
283
+ color="${this.color}"
284
+ @color-changed="${this.handleColorChanged}"
285
+ aria-label="Color gradient picker">
286
+ </hex-color-picker>
287
+ `;
288
+ }
289
+ /**
290
+ * Renders the color input field
291
+ */
292
+ renderColorInput() {
293
+ if (!this.showInput)
294
+ return nothing;
295
+ return html `
296
+ <nr-input
297
+ type="text"
298
+ .value="${this.color}"
299
+ placeholder="${this.inputPlaceholder}"
300
+ @nr-input="${this.handleInputChange}"
301
+ ?withCopy=${this.showCopyButton}
302
+ .state="${!this.isValidColor ? "error" /* INPUT_STATE.Error */ : "default" /* INPUT_STATE.Default */}"
303
+ aria-label="Color value input"
304
+ aria-invalid="${!this.isValidColor}">
305
+ </nr-input>
306
+ `;
307
+ }
308
+ /**
309
+ * Renders helper text if provided
310
+ */
311
+ renderHelperText() {
312
+ if (!this.helperText)
313
+ return nothing;
314
+ return html `
315
+ <div class="color-picker-helper-text">
316
+ ${this.helperText}
130
317
  </div>
131
- </div> `;
318
+ `;
132
319
  }
133
320
  };
134
321
  ColorPicker.styles = styles;
@@ -139,7 +326,7 @@ __decorate([
139
326
  property({ type: Boolean, reflect: true })
140
327
  ], ColorPicker.prototype, "show", void 0);
141
328
  __decorate([
142
- property({ type: Array })
329
+ property({ type: Array, attribute: 'default-color-sets' })
143
330
  ], ColorPicker.prototype, "defaultColorSets", void 0);
144
331
  __decorate([
145
332
  property({ type: Boolean, reflect: true })
@@ -147,11 +334,47 @@ __decorate([
147
334
  __decorate([
148
335
  property({ type: String, reflect: true })
149
336
  ], ColorPicker.prototype, "size", void 0);
337
+ __decorate([
338
+ property({ type: String, reflect: true })
339
+ ], ColorPicker.prototype, "trigger", void 0);
340
+ __decorate([
341
+ property({ type: String, reflect: true })
342
+ ], ColorPicker.prototype, "placement", void 0);
343
+ __decorate([
344
+ property({ type: String, reflect: true })
345
+ ], ColorPicker.prototype, "animation", void 0);
346
+ __decorate([
347
+ property({ type: Boolean, attribute: 'close-on-select' })
348
+ ], ColorPicker.prototype, "closeOnSelect", void 0);
349
+ __decorate([
350
+ property({ type: Boolean, attribute: 'close-on-outside-click' })
351
+ ], ColorPicker.prototype, "closeOnOutsideClick", void 0);
352
+ __decorate([
353
+ property({ type: Boolean, attribute: 'close-on-escape' })
354
+ ], ColorPicker.prototype, "closeOnEscape", void 0);
355
+ __decorate([
356
+ property({ type: Boolean, attribute: 'show-input' })
357
+ ], ColorPicker.prototype, "showInput", void 0);
358
+ __decorate([
359
+ property({ type: Boolean, attribute: 'show-copy-button' })
360
+ ], ColorPicker.prototype, "showCopyButton", void 0);
361
+ __decorate([
362
+ property({ type: String, reflect: true })
363
+ ], ColorPicker.prototype, "format", void 0);
364
+ __decorate([
365
+ property({ type: String, attribute: 'input-placeholder' })
366
+ ], ColorPicker.prototype, "inputPlaceholder", void 0);
367
+ __decorate([
368
+ property({ type: String })
369
+ ], ColorPicker.prototype, "label", void 0);
370
+ __decorate([
371
+ property({ type: String, attribute: 'helper-text' })
372
+ ], ColorPicker.prototype, "helperText", void 0);
150
373
  __decorate([
151
374
  state()
152
375
  ], ColorPicker.prototype, "isValidColor", void 0);
153
376
  ColorPicker = __decorate([
154
- customElement('hy-color-picker')
377
+ customElement('nr-color-picker')
155
378
  ], ColorPicker);
156
379
  export { ColorPicker };
157
380
  //# sourceMappingURL=color-picker.component.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../src/components/colorpicker/color-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {LitElement, PropertyValues, html, nothing} from 'lit';\nimport {customElement, property, state} from 'lit/decorators.js';\nimport './color-holder.component.js';\nimport './default-color-sets.component.js';\nimport styles from './color-picker.style.js';\nimport {ColorPickerSize} from './color-picker.types.js';\n\n@customElement('hy-color-picker')\nexport class ColorPicker extends LitElement {\n @property({type: String})\n color = 'transparent';\n\n @property({type: Boolean, reflect: true})\n show = false;\n\n @property({type: Array})\n defaultColorSets: Array<string> = [];\n\n @property({type: Boolean, reflect: true})\n disabled = false;\n\n @property({type: String, reflect: true})\n size = ColorPickerSize.Default;\n\n @state()\n isValidColor=true\n\n static override styles = styles;\n\n constructor() {\n super();\n if (typeof window !== 'undefined') {\n import('vanilla-colorful');\n }\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n // Mark the scroll listener as passive:\n document.addEventListener('scroll', this.calculateDropDownPosition, {\n passive: true,\n });\n document.addEventListener('click', this.onClickOutside);\n }\n\n override updated(changedProperties: PropertyValues): void {\n if (changedProperties.has('color')) {\n this.checkIsValidColor()\n }\n }\n private async toggleColorHolder() {\n this.show = !this.show;\n await this.updateComplete;\n this.calculateDropDownPosition();\n }\n private onClickOutside = (onClickEvent: Event) => {\n const outsideClick = !onClickEvent.composedPath().includes(this)\n if(outsideClick)\n this.show =false\n };\n private calculateDropDownPosition = () => {\n const dropdownContainer = this.shadowRoot?.querySelector('.dropdown-container') as HTMLElement;\n const colorHolder = this.shadowRoot?.querySelector('.color-holder') as HTMLElement;\n\n if (dropdownContainer && colorHolder) {\n const dropdownRect = dropdownContainer.getBoundingClientRect();\n const colorHolderRect = colorHolder.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n const viewportWidth = window.innerWidth;\n\n // Check if the dropdown is going out of the viewport vertically\n if (colorHolderRect.bottom + dropdownRect.height > viewportHeight) {\n // Move the dropdown upwards if it goes out of the viewport\n dropdownContainer.style.top = `${colorHolderRect.top - dropdownRect.height}px`;\n } else {\n // Otherwise, position it below the color holder\n dropdownContainer.style.top = `${colorHolderRect.bottom}px`;\n }\n\n // Check if the dropdown is going out of the viewport horizontally\n if (colorHolderRect.right + dropdownRect.width > viewportWidth) {\n // Move the dropdown to the left if it goes out of the viewport\n dropdownContainer.style.left = `${viewportWidth - dropdownRect.width}px`;\n } else {\n // Otherwise, position it to the right of the color holder\n dropdownContainer.style.left = `${colorHolderRect.left}px`;\n }\n }\n };\n\n private handleColorChanged(colorChangedEvent: CustomEvent) {\n if(this.color !=colorChangedEvent.detail.value){\n this.color = colorChangedEvent.detail.value;\n this.dispatchColorChange()\n }\n }\n\n private onInputChange(inputChangedEvent: CustomEvent) {\n if(this.color != inputChangedEvent.detail.value){\n this.color = inputChangedEvent.detail.value;\n this.dispatchColorChange()\n }\n }\n private dispatchColorChange(){\n this.dispatchEvent(\n new CustomEvent('color-changed', {\n detail: {\n value: this.color,\n },\n })\n );\n\n }\n\n private checkIsValidColor(){\n this.isValidColor = CSS.supports('color',this.color)\n }\n\n override disconnectedCallback(): void {\n document.removeEventListener('click', this.onClickOutside);\n document.removeEventListener('scroll', this.calculateDropDownPosition);\n }\n\n override render() {\n return html`<div class=\"color-picker-container\">\n <hy-colorholder-box\n class=\"color-holder\"\n color=\"${this.color}\"\n .size=${this.size}\n @click=${!this.disabled ? this.toggleColorHolder : nothing}\n ></hy-colorholder-box>\n <div class='dropdown-container'>\n <hy-default-color-sets .defaultColorSets=${this.defaultColorSets} @color-click=\"${this.handleColorChanged}\">\n </hy-default-color-sets>\n <hex-color-picker\n color=\"${this.color}\"\n @color-changed=\"${(colorChangedEvent: CustomEvent) => this.handleColorChanged(colorChangedEvent)}\"\n ></hex-color-picker>\n <hy-input type=\"text\" .value=\"${this.color}\" @valueChange=\"${this.onInputChange}\" withCopy=${true} .state=${!this.isValidColor?'error':nothing}> </hy-input>\n </div>\n </div> `;\n }\n}\n"]}
1
+ {"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../src/components/colorpicker/color-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2023 Nuraly, Laabidi Aymen\n * SPDX-License-Identifier: MIT\n */\n\nimport { LitElement, PropertyValues, html, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { NuralyUIBaseMixin } from '@nuralyui/common/mixins';\nimport { INPUT_STATE } from '../input/input.types.js';\nimport '../input/index.js';\n\n// Import child components\nimport './color-holder.component.js';\nimport './default-color-sets.component.js';\n\n// Import styles and types\nimport styles from './color-picker.style.js';\nimport {\n ColorPickerSize,\n ColorPickerTrigger,\n ColorPickerPlacement,\n ColorPickerAnimation,\n ColorFormat\n} from './color-picker.types.js';\n\n// Import controllers\nimport {\n ColorPickerDropdownController,\n ColorPickerEventController,\n} from './controllers/index.js';\n\n// Import interfaces\nimport type { ColorPickerHost } from './interfaces/index.js';\n\n/**\n * Advanced color picker component with dropdown positioning, validation, and accessibility.\n * \n * Supports multiple color formats, default color sets, custom triggers, keyboard navigation,\n * and various display configurations.\n * \n * @example\n * ```html\n * <!-- Basic color picker -->\n * <nr-color-picker color=\"#3498db\"></nr-color-picker>\n * \n * <!-- With default colors -->\n * <nr-color-picker \n * color=\"#3498db\"\n * .defaultColorSets=\"${['#3498db', '#e74c3c', '#2ecc71']}\">\n * </nr-color-picker>\n * \n * <!-- With custom configuration -->\n * <nr-color-picker\n * color=\"#3498db\"\n * trigger=\"click\"\n * placement=\"top\"\n * size=\"large\"\n * show-input=\"true\"\n * show-copy-button=\"true\">\n * </nr-color-picker>\n * \n * <!-- Disabled -->\n * <nr-color-picker color=\"#3498db\" disabled></nr-color-picker>\n * ```\n * \n * @fires hy-color-change - Color value changed\n * @fires nr-colorpicker-open - Dropdown opened\n * @fires nr-colorpicker-close - Dropdown closed\n * @fires color-changed - Legacy event for backwards compatibility\n * \n * @slot - Default slot for custom content\n * \n * @cssproperty --colorpicker-trigger-size - Size of the color trigger box\n * @cssproperty --colorpicker-dropdown-width - Width of the dropdown panel\n * @cssproperty --colorpicker-dropdown-background - Background color of dropdown\n * @cssproperty --colorpicker-dropdown-shadow - Shadow of dropdown panel\n * @cssproperty --colorpicker-dropdown-border-radius - Border radius of dropdown\n */\n@customElement('nr-color-picker')\nexport class ColorPicker extends NuralyUIBaseMixin(LitElement) implements ColorPickerHost {\n static override styles = styles;\n\n override requiredComponents = ['nr-input', 'nr-icon'];\n\n /** Current color value */\n @property({ type: String }) \n color = '#3498db';\n\n /** Controls dropdown visibility */\n @property({ type: Boolean, reflect: true }) \n show = false;\n\n /** Array of preset colors to display */\n @property({ type: Array, attribute: 'default-color-sets' }) \n defaultColorSets: string[] = [];\n\n /** Disables the color picker */\n @property({ type: Boolean, reflect: true }) \n disabled = false;\n\n /** Color picker size (small, default, large) */\n @property({ type: String, reflect: true }) \n size: ColorPickerSize = ColorPickerSize.Default;\n\n /** Trigger mode for opening dropdown */\n @property({ type: String, reflect: true }) \n trigger: ColorPickerTrigger = ColorPickerTrigger.Click;\n\n /** Dropdown placement */\n @property({ type: String, reflect: true }) \n placement: ColorPickerPlacement = ColorPickerPlacement.Auto;\n\n /** Animation style for dropdown */\n @property({ type: String, reflect: true }) \n animation: ColorPickerAnimation = ColorPickerAnimation.Fade;\n\n /** Close dropdown when a color is selected */\n @property({ type: Boolean, attribute: 'close-on-select' }) \n closeOnSelect = false;\n\n /** Close dropdown on outside click */\n @property({ type: Boolean, attribute: 'close-on-outside-click' }) \n closeOnOutsideClick = true;\n\n /** Close dropdown on escape key */\n @property({ type: Boolean, attribute: 'close-on-escape' }) \n closeOnEscape = true;\n\n /** Show color input field */\n @property({ type: Boolean, attribute: 'show-input' }) \n showInput = true;\n\n /** Show copy button on input */\n @property({ type: Boolean, attribute: 'show-copy-button' }) \n showCopyButton = true;\n\n /** Color format (hex, rgb, rgba, hsl, hsla) */\n @property({ type: String, reflect: true }) \n format: ColorFormat = ColorFormat.Hex;\n\n /** Placeholder text for color input */\n @property({ type: String, attribute: 'input-placeholder' }) \n inputPlaceholder = 'Enter color';\n\n /** Label text */\n @property({ type: String }) \n label = '';\n\n /** Helper text */\n @property({ type: String, attribute: 'helper-text' }) \n helperText = '';\n\n /** Validation state for color value */\n @state() \n private isValidColor = true;\n\n /** Manages dropdown visibility and positioning */\n private dropdownController = new ColorPickerDropdownController(this);\n\n /** Handles all event management */\n private eventController = new ColorPickerEventController(this);\n\n constructor() {\n super();\n // Dynamically import vanilla-colorful for color picker UI\n if (typeof window !== 'undefined') {\n import('vanilla-colorful');\n }\n }\n\n /**\n * Component connected to DOM - initialize base functionality\n */\n override connectedCallback(): void {\n super.connectedCallback();\n }\n\n /**\n * Component disconnected from DOM - cleanup event listeners\n */\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n }\n\n /**\n * Called after component updates\n */\n override updated(changedProperties: PropertyValues): void {\n super.updated(changedProperties);\n \n if (changedProperties.has('color')) {\n this.validateColor();\n }\n }\n\n // === Public API Methods ===\n\n /**\n * Opens the color picker dropdown\n */\n open(): void {\n this.dropdownController.open();\n }\n\n /**\n * Closes the color picker dropdown\n */\n close(): void {\n this.dropdownController.close();\n }\n\n /**\n * Toggles the color picker dropdown\n */\n toggle(): void {\n this.dropdownController.toggle();\n }\n\n /**\n * Validates the current color value\n */\n validateColor(): boolean {\n this.isValidColor = this.eventController.isValidColor(this.color);\n return this.isValidColor;\n }\n\n /**\n * Sets up global event listeners (called by dropdown controller)\n */\n setupEventListeners(): void {\n if (this.closeOnOutsideClick || this.closeOnEscape) {\n this.eventController.setupEventListeners();\n }\n }\n\n /**\n * Removes global event listeners (called by dropdown controller)\n */\n removeEventListeners(): void {\n this.eventController.removeEventListeners();\n }\n\n /**\n * Handles trigger click to toggle dropdown\n */\n private handleTriggerClick = (event: Event): void => {\n this.eventController.handleTriggerClick(event);\n };\n\n /**\n * Handles color selection from hex-color-picker or default colors\n */\n private handleColorChanged = (event: CustomEvent): void => {\n const newColor = event.detail.value;\n this.eventController.handleColorChange(newColor);\n \n if (this.closeOnSelect) {\n this.dropdownController.close();\n }\n };\n\n /**\n * Handles input change from text input\n */\n private handleInputChange = (event: CustomEvent): void => {\n this.eventController.handleInputChange(event);\n };\n\n /**\n * Main render method\n */\n override render() {\n const containerClasses = {\n 'color-picker-container': true,\n 'color-picker-container--disabled': this.disabled,\n 'color-picker-container--open': this.show,\n [`color-picker-container--${this.size}`]: true,\n };\n\n return html`\n <div class=\"${classMap(containerClasses)}\" data-theme=\"${this.currentTheme}\">\n ${this.renderLabel()}\n \n <nr-colorholder-box\n class=\"color-holder\"\n color=\"${this.color}\"\n .size=${this.size}\n ?disabled=\"${this.disabled}\"\n @click=${this.disabled ? nothing : this.handleTriggerClick}\n role=\"button\"\n aria-label=\"Select color\"\n aria-expanded=\"${this.show}\"\n aria-haspopup=\"dialog\"\n tabindex=\"${this.disabled ? -1 : 0}\"\n ></nr-colorholder-box>\n \n ${this.renderDropdown()}\n ${this.renderHelperText()}\n </div>\n `;\n }\n\n /**\n * Renders the label if provided\n */\n private renderLabel() {\n if (!this.label) return nothing;\n \n return html`\n <label class=\"color-picker-label\">\n ${this.label}\n </label>\n `;\n }\n\n /**\n * Renders the dropdown panel with color picker\n */\n private renderDropdown() {\n if (!this.show) return nothing;\n\n return html`\n <div \n class=\"dropdown-container\"\n role=\"dialog\"\n aria-label=\"Color picker\"\n >\n ${this.renderDefaultColorSets()}\n ${this.renderColorPicker()}\n ${this.renderColorInput()}\n </div>\n `;\n }\n\n /**\n * Renders default color sets if provided\n */\n private renderDefaultColorSets() {\n if (!this.defaultColorSets || this.defaultColorSets.length === 0) {\n return nothing;\n }\n\n return html`\n <nr-default-color-sets \n .defaultColorSets=${this.defaultColorSets} \n @color-click=\"${this.handleColorChanged}\"\n aria-label=\"Preset colors\">\n </nr-default-color-sets>\n `;\n }\n\n /**\n * Renders the hex color picker\n */\n private renderColorPicker() {\n return html`\n <hex-color-picker\n color=\"${this.color}\"\n @color-changed=\"${this.handleColorChanged}\"\n aria-label=\"Color gradient picker\">\n </hex-color-picker>\n `;\n }\n\n /**\n * Renders the color input field\n */\n private renderColorInput() {\n if (!this.showInput) return nothing;\n\n return html`\n <nr-input \n type=\"text\" \n .value=\"${this.color}\" \n placeholder=\"${this.inputPlaceholder}\"\n @nr-input=\"${this.handleInputChange}\" \n ?withCopy=${this.showCopyButton} \n .state=\"${!this.isValidColor ? INPUT_STATE.Error : INPUT_STATE.Default}\"\n aria-label=\"Color value input\"\n aria-invalid=\"${!this.isValidColor}\">\n </nr-input>\n `;\n }\n\n /**\n * Renders helper text if provided\n */\n private renderHelperText() {\n if (!this.helperText) return nothing;\n \n return html`\n <div class=\"color-picker-helper-text\">\n ${this.helperText}\n </div>\n `;\n }\n}\n"]}
@@ -1,3 +1,10 @@
1
+ /**
2
+ * Color Picker component styles for the Hybrid UI Library
3
+ * Using shared CSS variables from /src/shared/themes/
4
+ *
5
+ * This file contains all the styling for the nr-colorpicker component with
6
+ * clean CSS variable usage without local fallbacks and proper theme switching support.
7
+ */
1
8
  declare const _default: import("lit").CSSResult;
2
9
  export default _default;
3
10
  //# sourceMappingURL=color-picker.style.d.ts.map
@@ -1,75 +1,86 @@
1
1
  import { css } from 'lit';
2
+ /**
3
+ * Color Picker component styles for the Hybrid UI Library
4
+ * Using shared CSS variables from /src/shared/themes/
5
+ *
6
+ * This file contains all the styling for the nr-colorpicker component with
7
+ * clean CSS variable usage without local fallbacks and proper theme switching support.
8
+ */
2
9
  export default css `
10
+ :host {
11
+ display: inline-block;
12
+ vertical-align: middle;
13
+
14
+ /* Force CSS custom property inheritance to ensure theme switching works properly */
15
+ color: var(--nuraly-color-text);
16
+ background-color: var(--nuraly-color-background);
17
+
18
+ /* Ensure clean state transitions when theme changes */
19
+ * {
20
+ transition: all var(--nuraly-transition-fast, 0.15s) ease;
21
+ }
22
+ }
23
+
24
+ /* Force re-evaluation of theme-dependent properties on theme change */
25
+ :host([data-theme]) {
26
+ color: inherit;
27
+ background-color: inherit;
28
+ }
29
+
3
30
  .color-picker-container {
4
31
  display: inline-flex;
5
32
  flex-direction: column;
6
33
  }
34
+
7
35
  hex-color-picker {
8
36
  width: 100%;
9
37
  }
38
+
10
39
  .dropdown-container {
11
40
  display: none;
12
41
  }
42
+
13
43
  hex-color-picker::part(saturation) {
14
44
  border-radius: 0px;
15
45
  }
46
+
16
47
  hex-color-picker::part(hue) {
17
48
  border-radius: 0px;
18
49
  }
50
+
19
51
  hex-color-picker::part(saturation-pointer),
20
52
  hex-color-picker::part(hue-pointer) {
21
53
  cursor: pointer;
22
54
  }
55
+
23
56
  .color-holder {
24
57
  cursor: pointer;
25
58
  }
59
+
26
60
  :host([disabled]) .color-holder {
27
- opacity: var(--hybrid-colorpicker-disabled-opacity);
61
+ opacity: var(--nuraly-opacity-disabled, 0.5);
28
62
  cursor: not-allowed;
29
63
  }
30
- :host(:not([disabled])) .color-holder {
31
- border: var(--hybrid-colorpicker-border-color);
32
- }
33
- :host(:not([disabled])) .color-holder:hover {
34
- opacity: var(--hybrid-colorpicker-hover-opacity);
35
- }
36
- :host(:not([disabled])) .color-holder:active {
37
- border:var(--hybrid-colorpicker-active-border)
38
- }
39
-
40
64
 
41
- :host([show]) .dropdown-container{
65
+ :host([show]) .dropdown-container {
42
66
  display: block;
43
67
  position: fixed;
44
68
  width: 180px;
45
- z-index: 1;
46
- padding: 5px;
47
- background-color: var(--hybrid-colorpicker-background-color);
48
- box-shadow: 1px -1px 5px 1px rgba(0, 0, 0, 0.14);
49
- -webkit-box-shadow: 1px -1px 5px 1px rgba(0, 0, 0, 0.14);
50
- -moz-box-shadow: 1px -1px 5px 1px rgba(0, 0, 0, 0.14);
69
+ z-index: var(--nuraly-z-index-dropdown, 1000);
70
+ padding: var(--nuraly-spacing-2, 0.5rem);
71
+ background-color: var(--nuraly-color-surface, #ffffff);
72
+ border: 1px solid var(--nuraly-color-border, rgba(0, 0, 0, 0.1));
73
+ border-radius: var(--nuraly-border-radius-medium, 4px);
74
+ box-shadow: var(--nuraly-shadow-dropdown, 0 2px 8px rgba(0, 0, 0, 0.15));
75
+ opacity: 0;
76
+ visibility: hidden;
77
+ transition: opacity var(--nuraly-transition-fast, 0.15s) ease-in-out,
78
+ visibility var(--nuraly-transition-fast, 0.15s) ease-in-out;
51
79
  }
52
80
 
53
- :host {
54
- --hybrid-colorpicker-background-color: #f4f4f4;
55
- --hybrid-colorpicker-border-color: 1px solid gray;
56
- --hybrid-colorpicker-active-border: 1px solid #0f62fe;
57
- --hybrid-colorpicker-disabled-opacity: 0.5;
58
- --hybrid-colorpicker-hover-opacity: 0.8;
59
- --hybrid-colorpicker-default-width: 30px;
60
- --hybrid-colorpicker-default-height: 25px;
61
- --hybrid-colorpicker-small-width: 20px;
62
- --hybrid-colorpicker-small-height: 15px;
63
- --hybrid-colorpicker-large-width: 35px;
64
- --hybrid-colorpicker-large-height: 30px;
65
- }
66
-
67
- @media (prefers-color-scheme: dark) {
68
- :host {
69
- --hybrid-colorpicker-background-color: #393939;
70
- --hybrid-colorpicker-border-color: 1px solid #f4f4f4;
71
- --hybrid-colorpicker-disabled-opacity: 0.2;
72
- }
81
+ :host([show]) .dropdown-container.positioned {
82
+ opacity: 1;
83
+ visibility: visible;
73
84
  }
74
85
  `;
75
86
  //# sourceMappingURL=color-picker.style.js.map