@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.
- package/README.md +120 -0
- package/esm2020/index.mjs +2 -0
- package/esm2020/lib/color-picker/color-picker.component.mjs +294 -0
- package/esm2020/muxima-ui-color-picker.mjs +5 -0
- package/fesm2015/muxima-ui-color-picker.mjs +301 -0
- package/fesm2015/muxima-ui-color-picker.mjs.map +1 -0
- package/fesm2020/muxima-ui-color-picker.mjs +301 -0
- package/fesm2020/muxima-ui-color-picker.mjs.map +1 -0
- package/index.d.ts +1 -0
- package/lib/color-picker/color-picker.component.d.ts +88 -0
- package/package.json +57 -0
package/README.md
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
# Color Picker Component
|
|
2
|
+
|
|
3
|
+
Seletor de cores avançado com suporte a múltiplos formatos, paletas predefinidas e criador de gradientes.
|
|
4
|
+
|
|
5
|
+
## 🎨 Recursos
|
|
6
|
+
|
|
7
|
+
- ✅ Sliders HSL interativos (Matiz, Saturação, Luminosidade)
|
|
8
|
+
- ✅ Formatos: HEX, RGB, HSL
|
|
9
|
+
- ✅ 3 paletas predefinidas (Material, Pastéis, Neutros)
|
|
10
|
+
- ✅ Criador de gradientes com ângulo ajustável
|
|
11
|
+
- ✅ Suporte a opacidade (alpha)
|
|
12
|
+
- ✅ Modo inline ou dropdown
|
|
13
|
+
- ✅ 3 tamanhos: small, medium, large
|
|
14
|
+
- ✅ Integração com Angular Forms (ngModel / FormControl)
|
|
15
|
+
|
|
16
|
+
## 📦 Instalação
|
|
17
|
+
|
|
18
|
+
```typescript
|
|
19
|
+
import { ColorPickerComponent } from '@muxima-ui/color-picker';
|
|
20
|
+
|
|
21
|
+
@Component({
|
|
22
|
+
imports: [ColorPickerComponent]
|
|
23
|
+
})
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
## 🚀 Uso Básico
|
|
27
|
+
|
|
28
|
+
```html
|
|
29
|
+
<!-- Dropdown -->
|
|
30
|
+
<muxima-color-picker
|
|
31
|
+
[(ngModel)]="selectedColor"
|
|
32
|
+
(colorChange)="onColorChange($event)"
|
|
33
|
+
></muxima-color-picker>
|
|
34
|
+
|
|
35
|
+
<!-- Inline -->
|
|
36
|
+
<muxima-color-picker
|
|
37
|
+
[inline]="true"
|
|
38
|
+
[format]="'hex'"
|
|
39
|
+
[(ngModel)]="color"
|
|
40
|
+
></muxima-color-picker>
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## 📝 Propriedades
|
|
44
|
+
|
|
45
|
+
| Propriedade | Tipo | Padrão | Descrição |
|
|
46
|
+
|------------|------|---------|-----------|
|
|
47
|
+
| `format` | `'hex' \| 'rgb' \| 'hsl'` | `'hex'` | Formato de exibição da cor |
|
|
48
|
+
| `showPalettes` | `boolean` | `true` | Mostrar paletas de cores |
|
|
49
|
+
| `showGradient` | `boolean` | `false` | Mostrar criador de gradientes |
|
|
50
|
+
| `showAlpha` | `boolean` | `false` | Mostrar controle de opacidade |
|
|
51
|
+
| `inline` | `boolean` | `false` | Exibir sempre aberto |
|
|
52
|
+
| `disabled` | `boolean` | `false` | Desabilitar o componente |
|
|
53
|
+
| `size` | `'small' \| 'medium' \| 'large'` | `'medium'` | Tamanho do botão trigger |
|
|
54
|
+
| `customPalettes` | `ColorPalette[]` | `[]` | Paletas personalizadas |
|
|
55
|
+
|
|
56
|
+
## 🎯 Eventos
|
|
57
|
+
|
|
58
|
+
| Evento | Tipo | Descrição |
|
|
59
|
+
|--------|------|-----------|
|
|
60
|
+
| `colorChange` | `ColorFormat` | Emitido quando a cor muda |
|
|
61
|
+
| `formatChange` | `'hex' \| 'rgb' \| 'hsl'` | Emitido quando o formato muda |
|
|
62
|
+
|
|
63
|
+
## 💡 Exemplos Avançados
|
|
64
|
+
|
|
65
|
+
### Com Gradientes
|
|
66
|
+
|
|
67
|
+
```html
|
|
68
|
+
<muxima-color-picker
|
|
69
|
+
[showGradient]="true"
|
|
70
|
+
[inline]="true"
|
|
71
|
+
></muxima-color-picker>
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
### Com Opacidade
|
|
75
|
+
|
|
76
|
+
```html
|
|
77
|
+
<muxima-color-picker
|
|
78
|
+
[showAlpha]="true"
|
|
79
|
+
[(ngModel)]="colorWithAlpha"
|
|
80
|
+
></muxima-color-picker>
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
### Paletas Personalizadas
|
|
84
|
+
|
|
85
|
+
```typescript
|
|
86
|
+
customPalettes: ColorPalette[] = [
|
|
87
|
+
{
|
|
88
|
+
name: 'Meu Tema',
|
|
89
|
+
colors: ['#667eea', '#764ba2', '#f093fb', '#4facfe']
|
|
90
|
+
}
|
|
91
|
+
];
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
```html
|
|
95
|
+
<muxima-color-picker
|
|
96
|
+
[customPalettes]="customPalettes"
|
|
97
|
+
></muxima-color-picker>
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
## 🎨 Interface ColorFormat
|
|
101
|
+
|
|
102
|
+
```typescript
|
|
103
|
+
interface ColorFormat {
|
|
104
|
+
hex: string; // '#667eea'
|
|
105
|
+
rgb: { // { r: 102, g: 126, b: 234 }
|
|
106
|
+
r: number;
|
|
107
|
+
g: number;
|
|
108
|
+
b: number;
|
|
109
|
+
};
|
|
110
|
+
hsl: { // { h: 240, s: 76, l: 72 }
|
|
111
|
+
h: number;
|
|
112
|
+
s: number;
|
|
113
|
+
l: number;
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
## 🎨 Tema Muxima UI
|
|
119
|
+
|
|
120
|
+
Usa o gradiente característico: `linear-gradient(135deg, #667eea 0%, #764ba2 100%)`
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './lib/color-picker/color-picker.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9mb3JtL2NvbG9yLXBpY2tlci9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQ0FBMkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NvbG9yLXBpY2tlci9jb2xvci1waWNrZXIuY29tcG9uZW50JztcclxuIl19
|
|
@@ -0,0 +1,294 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, forwardRef } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/forms";
|
|
7
|
+
export class ColorPickerComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.format = 'hex';
|
|
10
|
+
this.showPalettes = true;
|
|
11
|
+
this.showGradient = false;
|
|
12
|
+
this.customPalettes = [];
|
|
13
|
+
this.disabled = false;
|
|
14
|
+
this.size = 'medium';
|
|
15
|
+
this.showAlpha = false;
|
|
16
|
+
this.inline = false;
|
|
17
|
+
this.colorChange = new EventEmitter();
|
|
18
|
+
this.formatChange = new EventEmitter();
|
|
19
|
+
this.currentColor = '#667eea';
|
|
20
|
+
this.isOpen = false;
|
|
21
|
+
this.hue = 240;
|
|
22
|
+
this.saturation = 76;
|
|
23
|
+
this.lightness = 72;
|
|
24
|
+
this.alpha = 1;
|
|
25
|
+
this.defaultPalettes = [
|
|
26
|
+
{
|
|
27
|
+
name: 'Material',
|
|
28
|
+
colors: ['#f44336', '#e91e63', '#9c27b0', '#673ab7', '#3f51b5', '#2196f3', '#03a9f4', '#00bcd4']
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
name: 'Pastéis',
|
|
32
|
+
colors: ['#ffc1cc', '#ffabab', '#ffd4a3', '#fff9a3', '#c1ffc1', '#a3d4ff', '#c1a3ff', '#ffa3ff']
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
name: 'Neutros',
|
|
36
|
+
colors: ['#ffffff', '#f5f5f5', '#e0e0e0', '#bdbdbd', '#9e9e9e', '#757575', '#424242', '#212121']
|
|
37
|
+
}
|
|
38
|
+
];
|
|
39
|
+
this.gradientStart = '#667eea';
|
|
40
|
+
this.gradientEnd = '#764ba2';
|
|
41
|
+
this.gradientAngle = 135;
|
|
42
|
+
this.onChange = () => { };
|
|
43
|
+
this.onTouched = () => { };
|
|
44
|
+
}
|
|
45
|
+
ngOnInit() {
|
|
46
|
+
if (this.inline) {
|
|
47
|
+
this.isOpen = true;
|
|
48
|
+
}
|
|
49
|
+
this.updateFromHex(this.currentColor);
|
|
50
|
+
}
|
|
51
|
+
writeValue(value) {
|
|
52
|
+
if (value) {
|
|
53
|
+
this.currentColor = value;
|
|
54
|
+
this.updateFromHex(value);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
registerOnChange(fn) {
|
|
58
|
+
this.onChange = fn;
|
|
59
|
+
}
|
|
60
|
+
registerOnTouched(fn) {
|
|
61
|
+
this.onTouched = fn;
|
|
62
|
+
}
|
|
63
|
+
setDisabledState(isDisabled) {
|
|
64
|
+
this.disabled = isDisabled;
|
|
65
|
+
}
|
|
66
|
+
togglePicker() {
|
|
67
|
+
if (!this.disabled && !this.inline) {
|
|
68
|
+
this.isOpen = !this.isOpen;
|
|
69
|
+
if (this.isOpen) {
|
|
70
|
+
this.onTouched();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
closePicker() {
|
|
75
|
+
if (!this.inline) {
|
|
76
|
+
this.isOpen = false;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
onHueChange(event) {
|
|
80
|
+
this.hue = +event.target.value;
|
|
81
|
+
this.updateColorFromHSL();
|
|
82
|
+
}
|
|
83
|
+
onSaturationChange(event) {
|
|
84
|
+
this.saturation = +event.target.value;
|
|
85
|
+
this.updateColorFromHSL();
|
|
86
|
+
}
|
|
87
|
+
onLightnessChange(event) {
|
|
88
|
+
this.lightness = +event.target.value;
|
|
89
|
+
this.updateColorFromHSL();
|
|
90
|
+
}
|
|
91
|
+
onAlphaChange(event) {
|
|
92
|
+
this.alpha = +event.target.value;
|
|
93
|
+
this.updateColorFromHSL();
|
|
94
|
+
}
|
|
95
|
+
selectPaletteColor(color) {
|
|
96
|
+
this.currentColor = color;
|
|
97
|
+
this.updateFromHex(color);
|
|
98
|
+
this.emitColor();
|
|
99
|
+
}
|
|
100
|
+
onHexInput(event) {
|
|
101
|
+
const hex = event.target.value;
|
|
102
|
+
if (this.isValidHex(hex)) {
|
|
103
|
+
this.currentColor = hex;
|
|
104
|
+
this.updateFromHex(hex);
|
|
105
|
+
this.emitColor();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
updateColorFromHSL() {
|
|
109
|
+
const rgb = this.hslToRgb(this.hue, this.saturation, this.lightness);
|
|
110
|
+
this.currentColor = this.rgbToHex(rgb.r, rgb.g, rgb.b);
|
|
111
|
+
this.emitColor();
|
|
112
|
+
}
|
|
113
|
+
updateFromHex(hex) {
|
|
114
|
+
const rgb = this.hexToRgb(hex);
|
|
115
|
+
if (rgb) {
|
|
116
|
+
const hsl = this.rgbToHsl(rgb.r, rgb.g, rgb.b);
|
|
117
|
+
this.hue = hsl.h;
|
|
118
|
+
this.saturation = hsl.s;
|
|
119
|
+
this.lightness = hsl.l;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
emitColor() {
|
|
123
|
+
const rgb = this.hexToRgb(this.currentColor);
|
|
124
|
+
const colorFormat = {
|
|
125
|
+
hex: this.currentColor,
|
|
126
|
+
rgb: rgb || { r: 0, g: 0, b: 0 },
|
|
127
|
+
hsl: { h: this.hue, s: this.saturation, l: this.lightness }
|
|
128
|
+
};
|
|
129
|
+
this.onChange(this.currentColor);
|
|
130
|
+
this.colorChange.emit(colorFormat);
|
|
131
|
+
}
|
|
132
|
+
changeFormat(newFormat) {
|
|
133
|
+
this.format = newFormat;
|
|
134
|
+
this.formatChange.emit(newFormat);
|
|
135
|
+
}
|
|
136
|
+
getFormattedColor() {
|
|
137
|
+
switch (this.format) {
|
|
138
|
+
case 'hex':
|
|
139
|
+
return this.currentColor;
|
|
140
|
+
case 'rgb':
|
|
141
|
+
const rgb = this.hexToRgb(this.currentColor);
|
|
142
|
+
return rgb ? `rgb(${rgb.r}, ${rgb.g}, ${rgb.b})` : '';
|
|
143
|
+
case 'hsl':
|
|
144
|
+
return `hsl(${this.hue}, ${this.saturation}%, ${this.lightness}%)`;
|
|
145
|
+
default:
|
|
146
|
+
return this.currentColor;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
// Gradient methods
|
|
150
|
+
onGradientStartChange(color) {
|
|
151
|
+
this.gradientStart = color;
|
|
152
|
+
}
|
|
153
|
+
onGradientEndChange(color) {
|
|
154
|
+
this.gradientEnd = color;
|
|
155
|
+
}
|
|
156
|
+
onGradientAngleChange(event) {
|
|
157
|
+
this.gradientAngle = +event.target.value;
|
|
158
|
+
}
|
|
159
|
+
getGradientStyle() {
|
|
160
|
+
return `linear-gradient(${this.gradientAngle}deg, ${this.gradientStart}, ${this.gradientEnd})`;
|
|
161
|
+
}
|
|
162
|
+
copyGradientCSS() {
|
|
163
|
+
const css = `background: ${this.getGradientStyle()};`;
|
|
164
|
+
navigator.clipboard.writeText(css);
|
|
165
|
+
}
|
|
166
|
+
// Color conversion utilities
|
|
167
|
+
hexToRgb(hex) {
|
|
168
|
+
const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
|
|
169
|
+
return result ? {
|
|
170
|
+
r: parseInt(result[1], 16),
|
|
171
|
+
g: parseInt(result[2], 16),
|
|
172
|
+
b: parseInt(result[3], 16)
|
|
173
|
+
} : null;
|
|
174
|
+
}
|
|
175
|
+
rgbToHex(r, g, b) {
|
|
176
|
+
return '#' + [r, g, b].map(x => {
|
|
177
|
+
const hex = x.toString(16);
|
|
178
|
+
return hex.length === 1 ? '0' + hex : hex;
|
|
179
|
+
}).join('');
|
|
180
|
+
}
|
|
181
|
+
rgbToHsl(r, g, b) {
|
|
182
|
+
r /= 255;
|
|
183
|
+
g /= 255;
|
|
184
|
+
b /= 255;
|
|
185
|
+
const max = Math.max(r, g, b);
|
|
186
|
+
const min = Math.min(r, g, b);
|
|
187
|
+
let h = 0, s = 0;
|
|
188
|
+
const l = (max + min) / 2;
|
|
189
|
+
if (max !== min) {
|
|
190
|
+
const d = max - min;
|
|
191
|
+
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
|
|
192
|
+
switch (max) {
|
|
193
|
+
case r:
|
|
194
|
+
h = ((g - b) / d + (g < b ? 6 : 0)) / 6;
|
|
195
|
+
break;
|
|
196
|
+
case g:
|
|
197
|
+
h = ((b - r) / d + 2) / 6;
|
|
198
|
+
break;
|
|
199
|
+
case b:
|
|
200
|
+
h = ((r - g) / d + 4) / 6;
|
|
201
|
+
break;
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
return {
|
|
205
|
+
h: Math.round(h * 360),
|
|
206
|
+
s: Math.round(s * 100),
|
|
207
|
+
l: Math.round(l * 100)
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
hslToRgb(h, s, l) {
|
|
211
|
+
h /= 360;
|
|
212
|
+
s /= 100;
|
|
213
|
+
l /= 100;
|
|
214
|
+
let r, g, b;
|
|
215
|
+
if (s === 0) {
|
|
216
|
+
r = g = b = l;
|
|
217
|
+
}
|
|
218
|
+
else {
|
|
219
|
+
const hue2rgb = (p, q, t) => {
|
|
220
|
+
if (t < 0)
|
|
221
|
+
t += 1;
|
|
222
|
+
if (t > 1)
|
|
223
|
+
t -= 1;
|
|
224
|
+
if (t < 1 / 6)
|
|
225
|
+
return p + (q - p) * 6 * t;
|
|
226
|
+
if (t < 1 / 2)
|
|
227
|
+
return q;
|
|
228
|
+
if (t < 2 / 3)
|
|
229
|
+
return p + (q - p) * (2 / 3 - t) * 6;
|
|
230
|
+
return p;
|
|
231
|
+
};
|
|
232
|
+
const q = l < 0.5 ? l * (1 + s) : l + s - l * s;
|
|
233
|
+
const p = 2 * l - q;
|
|
234
|
+
r = hue2rgb(p, q, h + 1 / 3);
|
|
235
|
+
g = hue2rgb(p, q, h);
|
|
236
|
+
b = hue2rgb(p, q, h - 1 / 3);
|
|
237
|
+
}
|
|
238
|
+
return {
|
|
239
|
+
r: Math.round(r * 255),
|
|
240
|
+
g: Math.round(g * 255),
|
|
241
|
+
b: Math.round(b * 255)
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
isValidHex(hex) {
|
|
245
|
+
return /^#?([a-f\d]{6}|[a-f\d]{3})$/i.test(hex);
|
|
246
|
+
}
|
|
247
|
+
getPalettes() {
|
|
248
|
+
return this.customPalettes.length > 0 ? this.customPalettes : this.defaultPalettes;
|
|
249
|
+
}
|
|
250
|
+
asFormat(fmt) {
|
|
251
|
+
if (fmt === 'hex' || fmt === 'rgb' || fmt === 'hsl')
|
|
252
|
+
return fmt;
|
|
253
|
+
return 'hex';
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
ColorPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
257
|
+
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: [
|
|
258
|
+
{
|
|
259
|
+
provide: NG_VALUE_ACCESSOR,
|
|
260
|
+
useExisting: forwardRef(() => ColorPickerComponent),
|
|
261
|
+
multi: true
|
|
262
|
+
}
|
|
263
|
+
], 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"] }] });
|
|
264
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ColorPickerComponent, decorators: [{
|
|
265
|
+
type: Component,
|
|
266
|
+
args: [{ selector: 'muxima-color-picker', standalone: true, imports: [CommonModule, FormsModule], providers: [
|
|
267
|
+
{
|
|
268
|
+
provide: NG_VALUE_ACCESSOR,
|
|
269
|
+
useExisting: forwardRef(() => ColorPickerComponent),
|
|
270
|
+
multi: true
|
|
271
|
+
}
|
|
272
|
+
], 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"] }]
|
|
273
|
+
}], propDecorators: { format: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], showPalettes: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], showGradient: [{
|
|
278
|
+
type: Input
|
|
279
|
+
}], customPalettes: [{
|
|
280
|
+
type: Input
|
|
281
|
+
}], disabled: [{
|
|
282
|
+
type: Input
|
|
283
|
+
}], size: [{
|
|
284
|
+
type: Input
|
|
285
|
+
}], showAlpha: [{
|
|
286
|
+
type: Input
|
|
287
|
+
}], inline: [{
|
|
288
|
+
type: Input
|
|
289
|
+
}], colorChange: [{
|
|
290
|
+
type: Output
|
|
291
|
+
}], formatChange: [{
|
|
292
|
+
type: Output
|
|
293
|
+
}] } });
|
|
294
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../../form/color-picker/src/lib/color-picker/color-picker.component.ts","../../../../../../form/color-picker/src/lib/color-picker/color-picker.component.html"],"names":[],"mappings":"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","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"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXV4aW1hLXVpLWNvbG9yLXBpY2tlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2Zvcm0vY29sb3ItcGlja2VyL3NyYy9tdXhpbWEtdWktY29sb3ItcGlja2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|