@muxima-ui/color-picker 1.0.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.
@@ -0,0 +1,301 @@
1
+ import * as i0 from '@angular/core';
2
+ import { EventEmitter, forwardRef, Component, Input, Output } from '@angular/core';
3
+ import * as i1 from '@angular/common';
4
+ import { CommonModule } from '@angular/common';
5
+ import * as i2 from '@angular/forms';
6
+ import { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
7
+
8
+ class ColorPickerComponent {
9
+ constructor() {
10
+ this.format = 'hex';
11
+ this.showPalettes = true;
12
+ this.showGradient = false;
13
+ this.customPalettes = [];
14
+ this.disabled = false;
15
+ this.size = 'medium';
16
+ this.showAlpha = false;
17
+ this.inline = false;
18
+ this.colorChange = new EventEmitter();
19
+ this.formatChange = new EventEmitter();
20
+ this.currentColor = '#667eea';
21
+ this.isOpen = false;
22
+ this.hue = 240;
23
+ this.saturation = 76;
24
+ this.lightness = 72;
25
+ this.alpha = 1;
26
+ this.defaultPalettes = [
27
+ {
28
+ name: 'Material',
29
+ colors: ['#f44336', '#e91e63', '#9c27b0', '#673ab7', '#3f51b5', '#2196f3', '#03a9f4', '#00bcd4']
30
+ },
31
+ {
32
+ name: 'Pastéis',
33
+ colors: ['#ffc1cc', '#ffabab', '#ffd4a3', '#fff9a3', '#c1ffc1', '#a3d4ff', '#c1a3ff', '#ffa3ff']
34
+ },
35
+ {
36
+ name: 'Neutros',
37
+ colors: ['#ffffff', '#f5f5f5', '#e0e0e0', '#bdbdbd', '#9e9e9e', '#757575', '#424242', '#212121']
38
+ }
39
+ ];
40
+ this.gradientStart = '#667eea';
41
+ this.gradientEnd = '#764ba2';
42
+ this.gradientAngle = 135;
43
+ this.onChange = () => { };
44
+ this.onTouched = () => { };
45
+ }
46
+ ngOnInit() {
47
+ if (this.inline) {
48
+ this.isOpen = true;
49
+ }
50
+ this.updateFromHex(this.currentColor);
51
+ }
52
+ writeValue(value) {
53
+ if (value) {
54
+ this.currentColor = value;
55
+ this.updateFromHex(value);
56
+ }
57
+ }
58
+ registerOnChange(fn) {
59
+ this.onChange = fn;
60
+ }
61
+ registerOnTouched(fn) {
62
+ this.onTouched = fn;
63
+ }
64
+ setDisabledState(isDisabled) {
65
+ this.disabled = isDisabled;
66
+ }
67
+ togglePicker() {
68
+ if (!this.disabled && !this.inline) {
69
+ this.isOpen = !this.isOpen;
70
+ if (this.isOpen) {
71
+ this.onTouched();
72
+ }
73
+ }
74
+ }
75
+ closePicker() {
76
+ if (!this.inline) {
77
+ this.isOpen = false;
78
+ }
79
+ }
80
+ onHueChange(event) {
81
+ this.hue = +event.target.value;
82
+ this.updateColorFromHSL();
83
+ }
84
+ onSaturationChange(event) {
85
+ this.saturation = +event.target.value;
86
+ this.updateColorFromHSL();
87
+ }
88
+ onLightnessChange(event) {
89
+ this.lightness = +event.target.value;
90
+ this.updateColorFromHSL();
91
+ }
92
+ onAlphaChange(event) {
93
+ this.alpha = +event.target.value;
94
+ this.updateColorFromHSL();
95
+ }
96
+ selectPaletteColor(color) {
97
+ this.currentColor = color;
98
+ this.updateFromHex(color);
99
+ this.emitColor();
100
+ }
101
+ onHexInput(event) {
102
+ const hex = event.target.value;
103
+ if (this.isValidHex(hex)) {
104
+ this.currentColor = hex;
105
+ this.updateFromHex(hex);
106
+ this.emitColor();
107
+ }
108
+ }
109
+ updateColorFromHSL() {
110
+ const rgb = this.hslToRgb(this.hue, this.saturation, this.lightness);
111
+ this.currentColor = this.rgbToHex(rgb.r, rgb.g, rgb.b);
112
+ this.emitColor();
113
+ }
114
+ updateFromHex(hex) {
115
+ const rgb = this.hexToRgb(hex);
116
+ if (rgb) {
117
+ const hsl = this.rgbToHsl(rgb.r, rgb.g, rgb.b);
118
+ this.hue = hsl.h;
119
+ this.saturation = hsl.s;
120
+ this.lightness = hsl.l;
121
+ }
122
+ }
123
+ emitColor() {
124
+ const rgb = this.hexToRgb(this.currentColor);
125
+ const colorFormat = {
126
+ hex: this.currentColor,
127
+ rgb: rgb || { r: 0, g: 0, b: 0 },
128
+ hsl: { h: this.hue, s: this.saturation, l: this.lightness }
129
+ };
130
+ this.onChange(this.currentColor);
131
+ this.colorChange.emit(colorFormat);
132
+ }
133
+ changeFormat(newFormat) {
134
+ this.format = newFormat;
135
+ this.formatChange.emit(newFormat);
136
+ }
137
+ getFormattedColor() {
138
+ switch (this.format) {
139
+ case 'hex':
140
+ return this.currentColor;
141
+ case 'rgb':
142
+ const rgb = this.hexToRgb(this.currentColor);
143
+ return rgb ? `rgb(${rgb.r}, ${rgb.g}, ${rgb.b})` : '';
144
+ case 'hsl':
145
+ return `hsl(${this.hue}, ${this.saturation}%, ${this.lightness}%)`;
146
+ default:
147
+ return this.currentColor;
148
+ }
149
+ }
150
+ // Gradient methods
151
+ onGradientStartChange(color) {
152
+ this.gradientStart = color;
153
+ }
154
+ onGradientEndChange(color) {
155
+ this.gradientEnd = color;
156
+ }
157
+ onGradientAngleChange(event) {
158
+ this.gradientAngle = +event.target.value;
159
+ }
160
+ getGradientStyle() {
161
+ return `linear-gradient(${this.gradientAngle}deg, ${this.gradientStart}, ${this.gradientEnd})`;
162
+ }
163
+ copyGradientCSS() {
164
+ const css = `background: ${this.getGradientStyle()};`;
165
+ navigator.clipboard.writeText(css);
166
+ }
167
+ // Color conversion utilities
168
+ hexToRgb(hex) {
169
+ const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
170
+ return result ? {
171
+ r: parseInt(result[1], 16),
172
+ g: parseInt(result[2], 16),
173
+ b: parseInt(result[3], 16)
174
+ } : null;
175
+ }
176
+ rgbToHex(r, g, b) {
177
+ return '#' + [r, g, b].map(x => {
178
+ const hex = x.toString(16);
179
+ return hex.length === 1 ? '0' + hex : hex;
180
+ }).join('');
181
+ }
182
+ rgbToHsl(r, g, b) {
183
+ r /= 255;
184
+ g /= 255;
185
+ b /= 255;
186
+ const max = Math.max(r, g, b);
187
+ const min = Math.min(r, g, b);
188
+ let h = 0, s = 0;
189
+ const l = (max + min) / 2;
190
+ if (max !== min) {
191
+ const d = max - min;
192
+ s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
193
+ switch (max) {
194
+ case r:
195
+ h = ((g - b) / d + (g < b ? 6 : 0)) / 6;
196
+ break;
197
+ case g:
198
+ h = ((b - r) / d + 2) / 6;
199
+ break;
200
+ case b:
201
+ h = ((r - g) / d + 4) / 6;
202
+ break;
203
+ }
204
+ }
205
+ return {
206
+ h: Math.round(h * 360),
207
+ s: Math.round(s * 100),
208
+ l: Math.round(l * 100)
209
+ };
210
+ }
211
+ hslToRgb(h, s, l) {
212
+ h /= 360;
213
+ s /= 100;
214
+ l /= 100;
215
+ let r, g, b;
216
+ if (s === 0) {
217
+ r = g = b = l;
218
+ }
219
+ else {
220
+ const hue2rgb = (p, q, t) => {
221
+ if (t < 0)
222
+ t += 1;
223
+ if (t > 1)
224
+ t -= 1;
225
+ if (t < 1 / 6)
226
+ return p + (q - p) * 6 * t;
227
+ if (t < 1 / 2)
228
+ return q;
229
+ if (t < 2 / 3)
230
+ return p + (q - p) * (2 / 3 - t) * 6;
231
+ return p;
232
+ };
233
+ const q = l < 0.5 ? l * (1 + s) : l + s - l * s;
234
+ const p = 2 * l - q;
235
+ r = hue2rgb(p, q, h + 1 / 3);
236
+ g = hue2rgb(p, q, h);
237
+ b = hue2rgb(p, q, h - 1 / 3);
238
+ }
239
+ return {
240
+ r: Math.round(r * 255),
241
+ g: Math.round(g * 255),
242
+ b: Math.round(b * 255)
243
+ };
244
+ }
245
+ isValidHex(hex) {
246
+ return /^#?([a-f\d]{6}|[a-f\d]{3})$/i.test(hex);
247
+ }
248
+ getPalettes() {
249
+ return this.customPalettes.length > 0 ? this.customPalettes : this.defaultPalettes;
250
+ }
251
+ asFormat(fmt) {
252
+ if (fmt === 'hex' || fmt === 'rgb' || fmt === 'hsl')
253
+ return fmt;
254
+ return 'hex';
255
+ }
256
+ }
257
+ ColorPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
258
+ ColorPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ColorPickerComponent, isStandalone: true, selector: "muxima-color-picker", inputs: { format: "format", showPalettes: "showPalettes", showGradient: "showGradient", customPalettes: "customPalettes", disabled: "disabled", size: "size", showAlpha: "showAlpha", inline: "inline" }, outputs: { colorChange: "colorChange", formatChange: "formatChange" }, providers: [
259
+ {
260
+ provide: NG_VALUE_ACCESSOR,
261
+ useExisting: forwardRef(() => ColorPickerComponent),
262
+ multi: true
263
+ }
264
+ ], ngImport: i0, template: "<div class=\"color-picker-wrapper\" [attr.data-size]=\"size\" [class.disabled]=\"disabled\">\r\n <!-- Trigger Button -->\r\n <button \r\n *ngIf=\"!inline\"\r\n class=\"color-trigger\"\r\n [style.background]=\"currentColor\"\r\n [disabled]=\"disabled\"\r\n (click)=\"togglePicker()\"\r\n type=\"button\">\r\n <span class=\"color-value\">{{ getFormattedColor() }}</span>\r\n </button>\r\n\r\n <!-- Picker Dropdown/Inline -->\r\n <div class=\"color-picker-panel\" [class.open]=\"isOpen\" [class.inline]=\"inline\">\r\n <div class=\"picker-header\">\r\n <div class=\"format-tabs\">\r\n <button \r\n *ngFor=\"let fmt of ['hex', 'rgb', 'hsl']\"\r\n [class.active]=\"format === fmt\"\r\n (click)=\"changeFormat(asFormat(fmt))\"\r\n type=\"button\">\r\n {{ fmt.toUpperCase() }}\r\n </button>\r\n </div>\r\n <button *ngIf=\"!inline\" class=\"close-btn\" (click)=\"closePicker()\" type=\"button\">\u00D7</button>\r\n </div>\r\n\r\n <!-- Color Preview -->\r\n <div class=\"color-preview\">\r\n <div class=\"preview-box\" [style.background]=\"currentColor\"></div>\r\n <input \r\n type=\"text\" \r\n class=\"color-input\"\r\n [value]=\"getFormattedColor()\"\r\n (input)=\"onHexInput($event)\"\r\n [disabled]=\"disabled\"\r\n />\r\n </div>\r\n\r\n <!-- HSL Sliders -->\r\n <div class=\"color-sliders\">\r\n <div class=\"slider-group\">\r\n <label>Matiz</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"360\" \r\n [value]=\"hue\"\r\n (input)=\"onHueChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider hue-slider\"\r\n />\r\n <span class=\"slider-value\">{{ hue }}\u00B0</span>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Satura\u00E7\u00E3o</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"100\" \r\n [value]=\"saturation\"\r\n (input)=\"onSaturationChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider saturation-slider\"\r\n [style.--base-color]=\"'hsl(' + hue + ', 100%, 50%)'\"\r\n />\r\n <span class=\"slider-value\">{{ saturation }}%</span>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Luminosidade</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"100\" \r\n [value]=\"lightness\"\r\n (input)=\"onLightnessChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider lightness-slider\"\r\n [style.--base-color]=\"'hsl(' + hue + ', ' + saturation + '%, 50%)'\"\r\n />\r\n <span class=\"slider-value\">{{ lightness }}%</span>\r\n </div>\r\n\r\n <div class=\"slider-group\" *ngIf=\"showAlpha\">\r\n <label>Opacidade</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"1\" \r\n step=\"0.01\"\r\n [value]=\"alpha\"\r\n (input)=\"onAlphaChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider alpha-slider\"\r\n />\r\n <span class=\"slider-value\">{{ (alpha * 100).toFixed(0) }}%</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Color Palettes -->\r\n <div class=\"palettes-section\" *ngIf=\"showPalettes\">\r\n <div class=\"palette\" *ngFor=\"let palette of getPalettes()\">\r\n <h4>{{ palette.name }}</h4>\r\n <div class=\"palette-colors\">\r\n <button\r\n *ngFor=\"let color of palette.colors\"\r\n class=\"palette-color\"\r\n [style.background]=\"color\"\r\n [class.selected]=\"currentColor === color\"\r\n (click)=\"selectPaletteColor(color)\"\r\n [disabled]=\"disabled\"\r\n type=\"button\"\r\n ></button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Gradient Section -->\r\n <div class=\"gradient-section\" *ngIf=\"showGradient\">\r\n <h4>Criador de Gradiente</h4>\r\n \r\n <div class=\"gradient-preview\" [style.background]=\"getGradientStyle()\"></div>\r\n \r\n <div class=\"gradient-controls\">\r\n <div class=\"gradient-colors\">\r\n <div class=\"gradient-color-input\">\r\n <label>In\u00EDcio</label>\r\n <input \r\n type=\"color\" \r\n [(ngModel)]=\"gradientStart\"\r\n (change)=\"onGradientStartChange(gradientStart)\"\r\n [disabled]=\"disabled\"\r\n />\r\n <span>{{ gradientStart }}</span>\r\n </div>\r\n \r\n <div class=\"gradient-color-input\">\r\n <label>Fim</label>\r\n <input \r\n type=\"color\" \r\n [(ngModel)]=\"gradientEnd\"\r\n (change)=\"onGradientEndChange(gradientEnd)\"\r\n [disabled]=\"disabled\"\r\n />\r\n <span>{{ gradientEnd }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>\u00C2ngulo</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"360\" \r\n [value]=\"gradientAngle\"\r\n (input)=\"onGradientAngleChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider\"\r\n />\r\n <span class=\"slider-value\">{{ gradientAngle }}\u00B0</span>\r\n </div>\r\n\r\n <button class=\"copy-btn\" (click)=\"copyGradientCSS()\" [disabled]=\"disabled\" type=\"button\">\r\n \uD83D\uDCCB Copiar CSS\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".color-picker-wrapper{position:relative;display:inline-block}.color-picker-wrapper[data-size=small] .color-trigger{height:32px;font-size:.875rem}.color-picker-wrapper[data-size=large] .color-trigger{height:48px;font-size:1.125rem}.color-picker-wrapper.disabled{opacity:.5;cursor:not-allowed}.color-trigger{display:flex;align-items:center;gap:.5rem;height:40px;padding:.5rem 1rem;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:Courier New,monospace;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.color-trigger:hover:not(:disabled){border-color:#667eea;box-shadow:0 4px 12px #667eea33}.color-trigger:disabled{cursor:not-allowed}.color-trigger .color-value{flex:1;text-align:center}.color-picker-panel{position:absolute;top:calc(100% + 8px);left:0;background:white;border-radius:16px;box-shadow:0 10px 40px #00000026;padding:1.5rem;width:320px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease}.color-picker-panel.open{opacity:1;visibility:visible;transform:translateY(0)}.color-picker-panel.inline{position:relative;top:0;left:0;opacity:1;visibility:visible;transform:none;box-shadow:0 2px 8px #0000001a}.picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.picker-header .format-tabs{display:flex;gap:.5rem}.picker-header .format-tabs button{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:6px;background:white;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.875rem;color:#6b7280}.picker-header .format-tabs button:hover{background:#f9fafb;border-color:#667eea}.picker-header .format-tabs button.active{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-color:transparent}.picker-header .close-btn{width:32px;height:32px;border:none;border-radius:50%;background:#f3f4f6;cursor:pointer;font-size:1.5rem;line-height:1;color:#6b7280;transition:all .2s ease}.picker-header .close-btn:hover{background:#ef4444;color:#fff}.color-preview{display:flex;gap:1rem;margin-bottom:1.5rem}.color-preview .preview-box{width:60px;height:60px;border-radius:12px;border:3px solid #e5e7eb;box-shadow:0 2px 8px #0000001a}.color-preview .color-input{flex:1;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-family:Courier New,monospace;font-size:.875rem;font-weight:500;text-align:center;transition:border-color .2s ease}.color-preview .color-input:focus{outline:none;border-color:#667eea}.color-sliders{margin-bottom:1.5rem}.color-sliders .slider-group{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;margin-bottom:1rem}.color-sliders .slider-group label{font-size:.875rem;font-weight:500;color:#374151;min-width:90px}.color-sliders .slider-group .slider-value{font-size:.875rem;font-weight:600;color:#667eea;font-family:Courier New,monospace;min-width:45px;text-align:right}.color-sliders .slider{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;outline:none;cursor:pointer}.color-sliders .slider::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:white;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 6px #0003;-webkit-transition:all .2s ease;transition:all .2s ease}.color-sliders .slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.color-sliders .slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:white;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 6px #0003}.color-sliders .slider.hue-slider{background:linear-gradient(to right,hsl(0,100%,50%),hsl(60,100%,50%),hsl(120,100%,50%),hsl(180,100%,50%),hsl(240,100%,50%),hsl(300,100%,50%),hsl(0,100%,50%))}.color-sliders .slider.saturation-slider{background:linear-gradient(to right,hsl(var(--hue, 240),0%,50%),var(--base-color, hsl(240, 100%, 50%)))}.color-sliders .slider.lightness-slider{background:linear-gradient(to right,hsl(var(--hue, 240),var(--sat, 100%),0%),var(--base-color, hsl(240, 100%, 50%)),hsl(var(--hue, 240),var(--sat, 100%),100%))}.color-sliders .slider.alpha-slider{background:linear-gradient(to right,transparent,currentColor),repeating-conic-gradient(#ccc 0% 25%,white 0% 50%) 0 0/10px 10px}.color-sliders .slider:disabled{opacity:.5;cursor:not-allowed}.palettes-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f3f4f6}.palettes-section .palette{margin-bottom:1.5rem}.palettes-section .palette:last-child{margin-bottom:0}.palettes-section .palette h4{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.palettes-section .palette .palette-colors{display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem}.palettes-section .palette .palette-colors .palette-color{width:100%;aspect-ratio:1;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease}.palettes-section .palette .palette-colors .palette-color:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.palettes-section .palette .palette-colors .palette-color.selected{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.palettes-section .palette .palette-colors .palette-color:disabled{opacity:.5;cursor:not-allowed}.gradient-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f3f4f6}.gradient-section h4{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:1rem}.gradient-section .gradient-preview{height:100px;border-radius:12px;margin-bottom:1rem;box-shadow:0 4px 12px #0000001a}.gradient-section .gradient-controls .gradient-colors{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.gradient-section .gradient-controls .gradient-colors .gradient-color-input{display:flex;flex-direction:column;gap:.5rem}.gradient-section .gradient-controls .gradient-colors .gradient-color-input label{font-size:.875rem;font-weight:500;color:#374151}.gradient-section .gradient-controls .gradient-colors .gradient-color-input input[type=color]{width:100%;height:40px;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer}.gradient-section .gradient-controls .gradient-colors .gradient-color-input input[type=color]::-webkit-color-swatch-wrapper{padding:0}.gradient-section .gradient-controls .gradient-colors .gradient-color-input input[type=color]::-webkit-color-swatch{border:none;border-radius:6px}.gradient-section .gradient-controls .gradient-colors .gradient-color-input span{font-size:.75rem;font-family:Courier New,monospace;color:#6b7280;text-align:center}.gradient-section .gradient-controls .copy-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:1rem}.gradient-section .gradient-controls .copy-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.gradient-section .gradient-controls .copy-btn:active:not(:disabled){transform:translateY(0)}.gradient-section .gradient-controls .copy-btn:disabled{opacity:.5;cursor:not-allowed}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
265
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ColorPickerComponent, decorators: [{
266
+ type: Component,
267
+ args: [{ selector: 'muxima-color-picker', standalone: true, imports: [CommonModule, FormsModule], providers: [
268
+ {
269
+ provide: NG_VALUE_ACCESSOR,
270
+ useExisting: forwardRef(() => ColorPickerComponent),
271
+ multi: true
272
+ }
273
+ ], template: "<div class=\"color-picker-wrapper\" [attr.data-size]=\"size\" [class.disabled]=\"disabled\">\r\n <!-- Trigger Button -->\r\n <button \r\n *ngIf=\"!inline\"\r\n class=\"color-trigger\"\r\n [style.background]=\"currentColor\"\r\n [disabled]=\"disabled\"\r\n (click)=\"togglePicker()\"\r\n type=\"button\">\r\n <span class=\"color-value\">{{ getFormattedColor() }}</span>\r\n </button>\r\n\r\n <!-- Picker Dropdown/Inline -->\r\n <div class=\"color-picker-panel\" [class.open]=\"isOpen\" [class.inline]=\"inline\">\r\n <div class=\"picker-header\">\r\n <div class=\"format-tabs\">\r\n <button \r\n *ngFor=\"let fmt of ['hex', 'rgb', 'hsl']\"\r\n [class.active]=\"format === fmt\"\r\n (click)=\"changeFormat(asFormat(fmt))\"\r\n type=\"button\">\r\n {{ fmt.toUpperCase() }}\r\n </button>\r\n </div>\r\n <button *ngIf=\"!inline\" class=\"close-btn\" (click)=\"closePicker()\" type=\"button\">\u00D7</button>\r\n </div>\r\n\r\n <!-- Color Preview -->\r\n <div class=\"color-preview\">\r\n <div class=\"preview-box\" [style.background]=\"currentColor\"></div>\r\n <input \r\n type=\"text\" \r\n class=\"color-input\"\r\n [value]=\"getFormattedColor()\"\r\n (input)=\"onHexInput($event)\"\r\n [disabled]=\"disabled\"\r\n />\r\n </div>\r\n\r\n <!-- HSL Sliders -->\r\n <div class=\"color-sliders\">\r\n <div class=\"slider-group\">\r\n <label>Matiz</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"360\" \r\n [value]=\"hue\"\r\n (input)=\"onHueChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider hue-slider\"\r\n />\r\n <span class=\"slider-value\">{{ hue }}\u00B0</span>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Satura\u00E7\u00E3o</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"100\" \r\n [value]=\"saturation\"\r\n (input)=\"onSaturationChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider saturation-slider\"\r\n [style.--base-color]=\"'hsl(' + hue + ', 100%, 50%)'\"\r\n />\r\n <span class=\"slider-value\">{{ saturation }}%</span>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Luminosidade</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"100\" \r\n [value]=\"lightness\"\r\n (input)=\"onLightnessChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider lightness-slider\"\r\n [style.--base-color]=\"'hsl(' + hue + ', ' + saturation + '%, 50%)'\"\r\n />\r\n <span class=\"slider-value\">{{ lightness }}%</span>\r\n </div>\r\n\r\n <div class=\"slider-group\" *ngIf=\"showAlpha\">\r\n <label>Opacidade</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"1\" \r\n step=\"0.01\"\r\n [value]=\"alpha\"\r\n (input)=\"onAlphaChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider alpha-slider\"\r\n />\r\n <span class=\"slider-value\">{{ (alpha * 100).toFixed(0) }}%</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Color Palettes -->\r\n <div class=\"palettes-section\" *ngIf=\"showPalettes\">\r\n <div class=\"palette\" *ngFor=\"let palette of getPalettes()\">\r\n <h4>{{ palette.name }}</h4>\r\n <div class=\"palette-colors\">\r\n <button\r\n *ngFor=\"let color of palette.colors\"\r\n class=\"palette-color\"\r\n [style.background]=\"color\"\r\n [class.selected]=\"currentColor === color\"\r\n (click)=\"selectPaletteColor(color)\"\r\n [disabled]=\"disabled\"\r\n type=\"button\"\r\n ></button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Gradient Section -->\r\n <div class=\"gradient-section\" *ngIf=\"showGradient\">\r\n <h4>Criador de Gradiente</h4>\r\n \r\n <div class=\"gradient-preview\" [style.background]=\"getGradientStyle()\"></div>\r\n \r\n <div class=\"gradient-controls\">\r\n <div class=\"gradient-colors\">\r\n <div class=\"gradient-color-input\">\r\n <label>In\u00EDcio</label>\r\n <input \r\n type=\"color\" \r\n [(ngModel)]=\"gradientStart\"\r\n (change)=\"onGradientStartChange(gradientStart)\"\r\n [disabled]=\"disabled\"\r\n />\r\n <span>{{ gradientStart }}</span>\r\n </div>\r\n \r\n <div class=\"gradient-color-input\">\r\n <label>Fim</label>\r\n <input \r\n type=\"color\" \r\n [(ngModel)]=\"gradientEnd\"\r\n (change)=\"onGradientEndChange(gradientEnd)\"\r\n [disabled]=\"disabled\"\r\n />\r\n <span>{{ gradientEnd }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>\u00C2ngulo</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"360\" \r\n [value]=\"gradientAngle\"\r\n (input)=\"onGradientAngleChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider\"\r\n />\r\n <span class=\"slider-value\">{{ gradientAngle }}\u00B0</span>\r\n </div>\r\n\r\n <button class=\"copy-btn\" (click)=\"copyGradientCSS()\" [disabled]=\"disabled\" type=\"button\">\r\n \uD83D\uDCCB Copiar CSS\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".color-picker-wrapper{position:relative;display:inline-block}.color-picker-wrapper[data-size=small] .color-trigger{height:32px;font-size:.875rem}.color-picker-wrapper[data-size=large] .color-trigger{height:48px;font-size:1.125rem}.color-picker-wrapper.disabled{opacity:.5;cursor:not-allowed}.color-trigger{display:flex;align-items:center;gap:.5rem;height:40px;padding:.5rem 1rem;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:Courier New,monospace;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.color-trigger:hover:not(:disabled){border-color:#667eea;box-shadow:0 4px 12px #667eea33}.color-trigger:disabled{cursor:not-allowed}.color-trigger .color-value{flex:1;text-align:center}.color-picker-panel{position:absolute;top:calc(100% + 8px);left:0;background:white;border-radius:16px;box-shadow:0 10px 40px #00000026;padding:1.5rem;width:320px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease}.color-picker-panel.open{opacity:1;visibility:visible;transform:translateY(0)}.color-picker-panel.inline{position:relative;top:0;left:0;opacity:1;visibility:visible;transform:none;box-shadow:0 2px 8px #0000001a}.picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.picker-header .format-tabs{display:flex;gap:.5rem}.picker-header .format-tabs button{padding:.5rem 1rem;border:1px solid #e5e7eb;border-radius:6px;background:white;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.875rem;color:#6b7280}.picker-header .format-tabs button:hover{background:#f9fafb;border-color:#667eea}.picker-header .format-tabs button.active{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-color:transparent}.picker-header .close-btn{width:32px;height:32px;border:none;border-radius:50%;background:#f3f4f6;cursor:pointer;font-size:1.5rem;line-height:1;color:#6b7280;transition:all .2s ease}.picker-header .close-btn:hover{background:#ef4444;color:#fff}.color-preview{display:flex;gap:1rem;margin-bottom:1.5rem}.color-preview .preview-box{width:60px;height:60px;border-radius:12px;border:3px solid #e5e7eb;box-shadow:0 2px 8px #0000001a}.color-preview .color-input{flex:1;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-family:Courier New,monospace;font-size:.875rem;font-weight:500;text-align:center;transition:border-color .2s ease}.color-preview .color-input:focus{outline:none;border-color:#667eea}.color-sliders{margin-bottom:1.5rem}.color-sliders .slider-group{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;margin-bottom:1rem}.color-sliders .slider-group label{font-size:.875rem;font-weight:500;color:#374151;min-width:90px}.color-sliders .slider-group .slider-value{font-size:.875rem;font-weight:600;color:#667eea;font-family:Courier New,monospace;min-width:45px;text-align:right}.color-sliders .slider{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;outline:none;cursor:pointer}.color-sliders .slider::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:white;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 6px #0003;-webkit-transition:all .2s ease;transition:all .2s ease}.color-sliders .slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.color-sliders .slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:white;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 6px #0003}.color-sliders .slider.hue-slider{background:linear-gradient(to right,hsl(0,100%,50%),hsl(60,100%,50%),hsl(120,100%,50%),hsl(180,100%,50%),hsl(240,100%,50%),hsl(300,100%,50%),hsl(0,100%,50%))}.color-sliders .slider.saturation-slider{background:linear-gradient(to right,hsl(var(--hue, 240),0%,50%),var(--base-color, hsl(240, 100%, 50%)))}.color-sliders .slider.lightness-slider{background:linear-gradient(to right,hsl(var(--hue, 240),var(--sat, 100%),0%),var(--base-color, hsl(240, 100%, 50%)),hsl(var(--hue, 240),var(--sat, 100%),100%))}.color-sliders .slider.alpha-slider{background:linear-gradient(to right,transparent,currentColor),repeating-conic-gradient(#ccc 0% 25%,white 0% 50%) 0 0/10px 10px}.color-sliders .slider:disabled{opacity:.5;cursor:not-allowed}.palettes-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f3f4f6}.palettes-section .palette{margin-bottom:1.5rem}.palettes-section .palette:last-child{margin-bottom:0}.palettes-section .palette h4{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.palettes-section .palette .palette-colors{display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem}.palettes-section .palette .palette-colors .palette-color{width:100%;aspect-ratio:1;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease}.palettes-section .palette .palette-colors .palette-color:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.palettes-section .palette .palette-colors .palette-color.selected{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.palettes-section .palette .palette-colors .palette-color:disabled{opacity:.5;cursor:not-allowed}.gradient-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #f3f4f6}.gradient-section h4{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:1rem}.gradient-section .gradient-preview{height:100px;border-radius:12px;margin-bottom:1rem;box-shadow:0 4px 12px #0000001a}.gradient-section .gradient-controls .gradient-colors{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.gradient-section .gradient-controls .gradient-colors .gradient-color-input{display:flex;flex-direction:column;gap:.5rem}.gradient-section .gradient-controls .gradient-colors .gradient-color-input label{font-size:.875rem;font-weight:500;color:#374151}.gradient-section .gradient-controls .gradient-colors .gradient-color-input input[type=color]{width:100%;height:40px;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer}.gradient-section .gradient-controls .gradient-colors .gradient-color-input input[type=color]::-webkit-color-swatch-wrapper{padding:0}.gradient-section .gradient-controls .gradient-colors .gradient-color-input input[type=color]::-webkit-color-swatch{border:none;border-radius:6px}.gradient-section .gradient-controls .gradient-colors .gradient-color-input span{font-size:.75rem;font-family:Courier New,monospace;color:#6b7280;text-align:center}.gradient-section .gradient-controls .copy-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:1rem}.gradient-section .gradient-controls .copy-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.gradient-section .gradient-controls .copy-btn:active:not(:disabled){transform:translateY(0)}.gradient-section .gradient-controls .copy-btn:disabled{opacity:.5;cursor:not-allowed}\n"] }]
274
+ }], propDecorators: { format: [{
275
+ type: Input
276
+ }], showPalettes: [{
277
+ type: Input
278
+ }], showGradient: [{
279
+ type: Input
280
+ }], customPalettes: [{
281
+ type: Input
282
+ }], disabled: [{
283
+ type: Input
284
+ }], size: [{
285
+ type: Input
286
+ }], showAlpha: [{
287
+ type: Input
288
+ }], inline: [{
289
+ type: Input
290
+ }], colorChange: [{
291
+ type: Output
292
+ }], formatChange: [{
293
+ type: Output
294
+ }] } });
295
+
296
+ /**
297
+ * Generated bundle index. Do not edit.
298
+ */
299
+
300
+ export { ColorPickerComponent };
301
+ //# sourceMappingURL=muxima-ui-color-picker.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"muxima-ui-color-picker.mjs","sources":["../../../../form/color-picker/src/lib/color-picker/color-picker.component.ts","../../../../form/color-picker/src/lib/color-picker/color-picker.component.html","../../../../form/color-picker/src/muxima-ui-color-picker.ts"],"sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, OnInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\r\n\r\nexport interface ColorFormat {\r\n hex: string;\r\n rgb: { r: number; g: number; b: number };\r\n hsl: { h: number; s: number; l: number };\r\n}\r\n\r\nexport interface ColorPalette {\r\n name: string;\r\n colors: string[];\r\n}\r\n\r\n@Component({\r\n selector: 'muxima-color-picker',\r\n standalone: true,\r\n imports: [CommonModule, FormsModule],\r\n templateUrl: './color-picker.component.html',\r\n styleUrls: ['./color-picker.component.scss'],\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: forwardRef(() => ColorPickerComponent),\r\n multi: true\r\n }\r\n ]\r\n})\r\nexport class ColorPickerComponent implements ControlValueAccessor, OnInit {\r\n @Input() format: 'hex' | 'rgb' | 'hsl' = 'hex';\r\n @Input() showPalettes: boolean = true;\r\n @Input() showGradient: boolean = false;\r\n @Input() customPalettes: ColorPalette[] = [];\r\n @Input() disabled: boolean = false;\r\n @Input() size: 'small' | 'medium' | 'large' = 'medium';\r\n @Input() showAlpha: boolean = false;\r\n @Input() inline: boolean = false;\r\n\r\n @Output() colorChange = new EventEmitter<ColorFormat>();\r\n @Output() formatChange = new EventEmitter<'hex' | 'rgb' | 'hsl'>();\r\n\r\n currentColor: string = '#667eea';\r\n isOpen: boolean = false;\r\n hue: number = 240;\r\n saturation: number = 76;\r\n lightness: number = 72;\r\n alpha: number = 1;\r\n\r\n defaultPalettes: ColorPalette[] = [\r\n {\r\n name: 'Material',\r\n colors: ['#f44336', '#e91e63', '#9c27b0', '#673ab7', '#3f51b5', '#2196f3', '#03a9f4', '#00bcd4']\r\n },\r\n {\r\n name: 'Pastéis',\r\n colors: ['#ffc1cc', '#ffabab', '#ffd4a3', '#fff9a3', '#c1ffc1', '#a3d4ff', '#c1a3ff', '#ffa3ff']\r\n },\r\n {\r\n name: 'Neutros',\r\n colors: ['#ffffff', '#f5f5f5', '#e0e0e0', '#bdbdbd', '#9e9e9e', '#757575', '#424242', '#212121']\r\n }\r\n ];\r\n\r\n gradientStart: string = '#667eea';\r\n gradientEnd: string = '#764ba2';\r\n gradientAngle: number = 135;\r\n\r\n private onChange: (value: string) => void = () => {};\r\n private onTouched: () => void = () => {};\r\n\r\n ngOnInit() {\r\n if (this.inline) {\r\n this.isOpen = true;\r\n }\r\n this.updateFromHex(this.currentColor);\r\n }\r\n\r\n writeValue(value: string): void {\r\n if (value) {\r\n this.currentColor = value;\r\n this.updateFromHex(value);\r\n }\r\n }\r\n\r\n registerOnChange(fn: any): void {\r\n this.onChange = fn;\r\n }\r\n\r\n registerOnTouched(fn: any): void {\r\n this.onTouched = fn;\r\n }\r\n\r\n setDisabledState(isDisabled: boolean): void {\r\n this.disabled = isDisabled;\r\n }\r\n\r\n togglePicker(): void {\r\n if (!this.disabled && !this.inline) {\r\n this.isOpen = !this.isOpen;\r\n if (this.isOpen) {\r\n this.onTouched();\r\n }\r\n }\r\n }\r\n\r\n closePicker(): void {\r\n if (!this.inline) {\r\n this.isOpen = false;\r\n }\r\n }\r\n\r\n onHueChange(event: Event): void {\r\n this.hue = +(event.target as HTMLInputElement).value;\r\n this.updateColorFromHSL();\r\n }\r\n\r\n onSaturationChange(event: Event): void {\r\n this.saturation = +(event.target as HTMLInputElement).value;\r\n this.updateColorFromHSL();\r\n }\r\n\r\n onLightnessChange(event: Event): void {\r\n this.lightness = +(event.target as HTMLInputElement).value;\r\n this.updateColorFromHSL();\r\n }\r\n\r\n onAlphaChange(event: Event): void {\r\n this.alpha = +(event.target as HTMLInputElement).value;\r\n this.updateColorFromHSL();\r\n }\r\n\r\n selectPaletteColor(color: string): void {\r\n this.currentColor = color;\r\n this.updateFromHex(color);\r\n this.emitColor();\r\n }\r\n\r\n onHexInput(event: Event): void {\r\n const hex = (event.target as HTMLInputElement).value;\r\n if (this.isValidHex(hex)) {\r\n this.currentColor = hex;\r\n this.updateFromHex(hex);\r\n this.emitColor();\r\n }\r\n }\r\n\r\n updateColorFromHSL(): void {\r\n const rgb = this.hslToRgb(this.hue, this.saturation, this.lightness);\r\n this.currentColor = this.rgbToHex(rgb.r, rgb.g, rgb.b);\r\n this.emitColor();\r\n }\r\n\r\n updateFromHex(hex: string): void {\r\n const rgb = this.hexToRgb(hex);\r\n if (rgb) {\r\n const hsl = this.rgbToHsl(rgb.r, rgb.g, rgb.b);\r\n this.hue = hsl.h;\r\n this.saturation = hsl.s;\r\n this.lightness = hsl.l;\r\n }\r\n }\r\n\r\n emitColor(): void {\r\n const rgb = this.hexToRgb(this.currentColor);\r\n const colorFormat: ColorFormat = {\r\n hex: this.currentColor,\r\n rgb: rgb || { r: 0, g: 0, b: 0 },\r\n hsl: { h: this.hue, s: this.saturation, l: this.lightness }\r\n };\r\n\r\n this.onChange(this.currentColor);\r\n this.colorChange.emit(colorFormat);\r\n }\r\n\r\n changeFormat(newFormat: 'hex' | 'rgb' | 'hsl'): void {\r\n this.format = newFormat;\r\n this.formatChange.emit(newFormat);\r\n }\r\n\r\n getFormattedColor(): string {\r\n switch (this.format) {\r\n case 'hex':\r\n return this.currentColor;\r\n case 'rgb':\r\n const rgb = this.hexToRgb(this.currentColor);\r\n return rgb ? `rgb(${rgb.r}, ${rgb.g}, ${rgb.b})` : '';\r\n case 'hsl':\r\n return `hsl(${this.hue}, ${this.saturation}%, ${this.lightness}%)`;\r\n default:\r\n return this.currentColor;\r\n }\r\n }\r\n\r\n // Gradient methods\r\n onGradientStartChange(color: string): void {\r\n this.gradientStart = color;\r\n }\r\n\r\n onGradientEndChange(color: string): void {\r\n this.gradientEnd = color;\r\n }\r\n\r\n onGradientAngleChange(event: Event): void {\r\n this.gradientAngle = +(event.target as HTMLInputElement).value;\r\n }\r\n\r\n getGradientStyle(): string {\r\n return `linear-gradient(${this.gradientAngle}deg, ${this.gradientStart}, ${this.gradientEnd})`;\r\n }\r\n\r\n copyGradientCSS(): void {\r\n const css = `background: ${this.getGradientStyle()};`;\r\n navigator.clipboard.writeText(css);\r\n }\r\n\r\n // Color conversion utilities\r\n hexToRgb(hex: string): { r: number; g: number; b: number } | null {\r\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\r\n return result ? {\r\n r: parseInt(result[1], 16),\r\n g: parseInt(result[2], 16),\r\n b: parseInt(result[3], 16)\r\n } : null;\r\n }\r\n\r\n rgbToHex(r: number, g: number, b: number): string {\r\n return '#' + [r, g, b].map(x => {\r\n const hex = x.toString(16);\r\n return hex.length === 1 ? '0' + hex : hex;\r\n }).join('');\r\n }\r\n\r\n rgbToHsl(r: number, g: number, b: number): { h: number; s: number; l: number } {\r\n r /= 255;\r\n g /= 255;\r\n b /= 255;\r\n\r\n const max = Math.max(r, g, b);\r\n const min = Math.min(r, g, b);\r\n let h = 0, s = 0;\r\n const l = (max + min) / 2;\r\n\r\n if (max !== min) {\r\n const d = max - min;\r\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\r\n\r\n switch (max) {\r\n case r: h = ((g - b) / d + (g < b ? 6 : 0)) / 6; break;\r\n case g: h = ((b - r) / d + 2) / 6; break;\r\n case b: h = ((r - g) / d + 4) / 6; break;\r\n }\r\n }\r\n\r\n return {\r\n h: Math.round(h * 360),\r\n s: Math.round(s * 100),\r\n l: Math.round(l * 100)\r\n };\r\n }\r\n\r\n hslToRgb(h: number, s: number, l: number): { r: number; g: number; b: number } {\r\n h /= 360;\r\n s /= 100;\r\n l /= 100;\r\n\r\n let r, g, b;\r\n\r\n if (s === 0) {\r\n r = g = b = l;\r\n } else {\r\n const hue2rgb = (p: number, q: number, t: number) => {\r\n if (t < 0) t += 1;\r\n if (t > 1) t -= 1;\r\n if (t < 1/6) return p + (q - p) * 6 * t;\r\n if (t < 1/2) return q;\r\n if (t < 2/3) return p + (q - p) * (2/3 - t) * 6;\r\n return p;\r\n };\r\n\r\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\r\n const p = 2 * l - q;\r\n\r\n r = hue2rgb(p, q, h + 1/3);\r\n g = hue2rgb(p, q, h);\r\n b = hue2rgb(p, q, h - 1/3);\r\n }\r\n\r\n return {\r\n r: Math.round(r * 255),\r\n g: Math.round(g * 255),\r\n b: Math.round(b * 255)\r\n };\r\n }\r\n\r\n isValidHex(hex: string): boolean {\r\n return /^#?([a-f\\d]{6}|[a-f\\d]{3})$/i.test(hex);\r\n }\r\n\r\n\r\n getPalettes(): ColorPalette[] {\r\n return this.customPalettes.length > 0 ? this.customPalettes : this.defaultPalettes;\r\n }\r\n\r\n asFormat(fmt: string): 'hex' | 'rgb' | 'hsl' {\r\n if (fmt === 'hex' || fmt === 'rgb' || fmt === 'hsl') return fmt;\r\n return 'hex';\r\n }\r\n}\r\n","<div class=\"color-picker-wrapper\" [attr.data-size]=\"size\" [class.disabled]=\"disabled\">\r\n <!-- Trigger Button -->\r\n <button \r\n *ngIf=\"!inline\"\r\n class=\"color-trigger\"\r\n [style.background]=\"currentColor\"\r\n [disabled]=\"disabled\"\r\n (click)=\"togglePicker()\"\r\n type=\"button\">\r\n <span class=\"color-value\">{{ getFormattedColor() }}</span>\r\n </button>\r\n\r\n <!-- Picker Dropdown/Inline -->\r\n <div class=\"color-picker-panel\" [class.open]=\"isOpen\" [class.inline]=\"inline\">\r\n <div class=\"picker-header\">\r\n <div class=\"format-tabs\">\r\n <button \r\n *ngFor=\"let fmt of ['hex', 'rgb', 'hsl']\"\r\n [class.active]=\"format === fmt\"\r\n (click)=\"changeFormat(asFormat(fmt))\"\r\n type=\"button\">\r\n {{ fmt.toUpperCase() }}\r\n </button>\r\n </div>\r\n <button *ngIf=\"!inline\" class=\"close-btn\" (click)=\"closePicker()\" type=\"button\">×</button>\r\n </div>\r\n\r\n <!-- Color Preview -->\r\n <div class=\"color-preview\">\r\n <div class=\"preview-box\" [style.background]=\"currentColor\"></div>\r\n <input \r\n type=\"text\" \r\n class=\"color-input\"\r\n [value]=\"getFormattedColor()\"\r\n (input)=\"onHexInput($event)\"\r\n [disabled]=\"disabled\"\r\n />\r\n </div>\r\n\r\n <!-- HSL Sliders -->\r\n <div class=\"color-sliders\">\r\n <div class=\"slider-group\">\r\n <label>Matiz</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"360\" \r\n [value]=\"hue\"\r\n (input)=\"onHueChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider hue-slider\"\r\n />\r\n <span class=\"slider-value\">{{ hue }}°</span>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Saturação</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"100\" \r\n [value]=\"saturation\"\r\n (input)=\"onSaturationChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider saturation-slider\"\r\n [style.--base-color]=\"'hsl(' + hue + ', 100%, 50%)'\"\r\n />\r\n <span class=\"slider-value\">{{ saturation }}%</span>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Luminosidade</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"100\" \r\n [value]=\"lightness\"\r\n (input)=\"onLightnessChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider lightness-slider\"\r\n [style.--base-color]=\"'hsl(' + hue + ', ' + saturation + '%, 50%)'\"\r\n />\r\n <span class=\"slider-value\">{{ lightness }}%</span>\r\n </div>\r\n\r\n <div class=\"slider-group\" *ngIf=\"showAlpha\">\r\n <label>Opacidade</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"1\" \r\n step=\"0.01\"\r\n [value]=\"alpha\"\r\n (input)=\"onAlphaChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider alpha-slider\"\r\n />\r\n <span class=\"slider-value\">{{ (alpha * 100).toFixed(0) }}%</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Color Palettes -->\r\n <div class=\"palettes-section\" *ngIf=\"showPalettes\">\r\n <div class=\"palette\" *ngFor=\"let palette of getPalettes()\">\r\n <h4>{{ palette.name }}</h4>\r\n <div class=\"palette-colors\">\r\n <button\r\n *ngFor=\"let color of palette.colors\"\r\n class=\"palette-color\"\r\n [style.background]=\"color\"\r\n [class.selected]=\"currentColor === color\"\r\n (click)=\"selectPaletteColor(color)\"\r\n [disabled]=\"disabled\"\r\n type=\"button\"\r\n ></button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Gradient Section -->\r\n <div class=\"gradient-section\" *ngIf=\"showGradient\">\r\n <h4>Criador de Gradiente</h4>\r\n \r\n <div class=\"gradient-preview\" [style.background]=\"getGradientStyle()\"></div>\r\n \r\n <div class=\"gradient-controls\">\r\n <div class=\"gradient-colors\">\r\n <div class=\"gradient-color-input\">\r\n <label>Início</label>\r\n <input \r\n type=\"color\" \r\n [(ngModel)]=\"gradientStart\"\r\n (change)=\"onGradientStartChange(gradientStart)\"\r\n [disabled]=\"disabled\"\r\n />\r\n <span>{{ gradientStart }}</span>\r\n </div>\r\n \r\n <div class=\"gradient-color-input\">\r\n <label>Fim</label>\r\n <input \r\n type=\"color\" \r\n [(ngModel)]=\"gradientEnd\"\r\n (change)=\"onGradientEndChange(gradientEnd)\"\r\n [disabled]=\"disabled\"\r\n />\r\n <span>{{ gradientEnd }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"slider-group\">\r\n <label>Ângulo</label>\r\n <input \r\n type=\"range\" \r\n min=\"0\" \r\n max=\"360\" \r\n [value]=\"gradientAngle\"\r\n (input)=\"onGradientAngleChange($event)\"\r\n [disabled]=\"disabled\"\r\n class=\"slider\"\r\n />\r\n <span class=\"slider-value\">{{ gradientAngle }}°</span>\r\n </div>\r\n\r\n <button class=\"copy-btn\" (click)=\"copyGradientCSS()\" [disabled]=\"disabled\" type=\"button\">\r\n 📋 Copiar CSS\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}