@shibui-ui/ui 1.24.1 → 1.25.1
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/dist/components/atoms/index.d.ts +45 -16
- package/dist/components/atoms/index.d.ts.map +1 -1
- package/dist/components/molecules/index.d.ts +20 -1
- package/dist/components/molecules/index.d.ts.map +1 -1
- package/dist/components/organisms/index.d.ts +17 -1
- package/dist/components/organisms/index.d.ts.map +1 -1
- package/dist/index.d.ts +3 -82
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +79 -80
- package/dist/index.js.map +1 -1
- package/dist/index10.js +82 -18
- package/dist/index10.js.map +1 -1
- package/dist/index11.js +84 -69
- package/dist/index11.js.map +1 -1
- package/dist/index12.js +40 -26
- package/dist/index12.js.map +1 -1
- package/dist/index13.js +16 -39
- package/dist/index13.js.map +1 -1
- package/dist/index14.js +29 -44
- package/dist/index14.js.map +1 -1
- package/dist/index15.js +16 -117
- package/dist/index15.js.map +1 -1
- package/dist/index16.js +48 -40
- package/dist/index16.js.map +1 -1
- package/dist/index17.js +41 -25
- package/dist/index17.js.map +1 -1
- package/dist/index18.js +76 -49
- package/dist/index18.js.map +1 -1
- package/dist/index19.js +19 -39
- package/dist/index19.js.map +1 -1
- package/dist/index194.js +94 -24
- package/dist/index194.js.map +1 -1
- package/dist/index195.js +2 -2
- package/dist/index197.js +2 -24
- package/dist/index197.js.map +1 -1
- package/dist/index198.js +74 -2
- package/dist/index198.js.map +1 -1
- package/dist/index199.js +64 -35
- package/dist/index199.js.map +1 -1
- package/dist/index20.js +21 -41
- package/dist/index20.js.map +1 -1
- package/dist/index200.js +2 -2
- package/dist/index201.js +54 -13
- package/dist/index201.js.map +1 -1
- package/dist/index202.js +2 -2
- package/dist/index203.js +2 -2
- package/dist/index204.js +143 -157
- package/dist/index204.js.map +1 -1
- package/dist/index205.js +43 -24
- package/dist/index205.js.map +1 -1
- package/dist/index206.js +51 -2
- package/dist/index206.js.map +1 -1
- package/dist/index207.js +2 -11
- package/dist/index207.js.map +1 -1
- package/dist/index208.js +33 -2
- package/dist/index208.js.map +1 -1
- package/dist/index209.js +2 -91
- package/dist/index209.js.map +1 -1
- package/dist/index21.js +90 -26
- package/dist/index21.js.map +1 -1
- package/dist/index210.js +6 -2
- package/dist/index210.js.map +1 -1
- package/dist/index211.js +2 -41
- package/dist/index211.js.map +1 -1
- package/dist/index212.js +260 -2
- package/dist/index212.js.map +1 -1
- package/dist/index213.js +16 -5
- package/dist/index213.js.map +1 -1
- package/dist/index214.js +2 -2
- package/dist/index215.js +2 -35
- package/dist/index215.js.map +1 -1
- package/dist/index216.js +59 -42
- package/dist/index216.js.map +1 -1
- package/dist/index217.js +32 -2
- package/dist/index217.js.map +1 -1
- package/dist/index218.js +2 -85
- package/dist/index218.js.map +1 -1
- package/dist/index219.js +2 -2
- package/dist/index22.js +41 -48
- package/dist/index22.js.map +1 -1
- package/dist/index220.js +73 -65
- package/dist/index220.js.map +1 -1
- package/dist/index221.js +81 -2
- package/dist/index221.js.map +1 -1
- package/dist/index222.js +2 -10
- package/dist/index222.js.map +1 -1
- package/dist/index223.js +133 -2
- package/dist/index223.js.map +1 -1
- package/dist/index224.js +2 -26
- package/dist/index224.js.map +1 -1
- package/dist/index225.js +2 -2
- package/dist/index226.js +66 -12
- package/dist/index226.js.map +1 -1
- package/dist/index227.js +97 -2
- package/dist/index227.js.map +1 -1
- package/dist/index228.js +2 -2
- package/dist/index229.js +62 -24
- package/dist/index229.js.map +1 -1
- package/dist/index23.js +50 -94
- package/dist/index23.js.map +1 -1
- package/dist/index230.js +2 -2
- package/dist/index231.js +2 -2
- package/dist/index232.js +12 -2
- package/dist/index232.js.map +1 -1
- package/dist/index233.js +5 -16
- package/dist/index233.js.map +1 -1
- package/dist/index234.js +2 -2
- package/dist/index235.js +11 -9
- package/dist/index235.js.map +1 -1
- package/dist/index236.js +2 -2
- package/dist/index237.js +76 -34
- package/dist/index237.js.map +1 -1
- package/dist/index238.js +2 -2
- package/dist/index239.js +2 -27
- package/dist/index239.js.map +1 -1
- package/dist/index24.js +37 -34
- package/dist/index24.js.map +1 -1
- package/dist/index240.js +39 -2
- package/dist/index240.js.map +1 -1
- package/dist/index241.js +2 -34
- package/dist/index241.js.map +1 -1
- package/dist/index242.js +235 -12
- package/dist/index242.js.map +1 -1
- package/dist/index243.js +82 -2
- package/dist/index243.js.map +1 -1
- package/dist/index244.js +2 -9
- package/dist/index244.js.map +1 -1
- package/dist/index245.js +94 -2
- package/dist/index245.js.map +1 -1
- package/dist/index246.js +2 -5
- package/dist/index246.js.map +1 -1
- package/dist/index247.js +268 -2
- package/dist/index247.js.map +1 -1
- package/dist/index248.js +2 -36
- package/dist/index248.js.map +1 -1
- package/dist/index249.js +21 -2
- package/dist/index249.js.map +1 -1
- package/dist/index25.js +51 -32
- package/dist/index25.js.map +1 -1
- package/dist/index250.js +2 -31
- package/dist/index250.js.map +1 -1
- package/dist/index251.js +9 -2
- package/dist/index251.js.map +1 -1
- package/dist/index252.js +2 -19
- package/dist/index252.js.map +1 -1
- package/dist/index253.js +15 -2
- package/dist/index253.js.map +1 -1
- package/dist/index254.js +2 -2
- package/dist/index255.js +135 -69
- package/dist/index255.js.map +1 -1
- package/dist/index256.js +2 -11
- package/dist/index256.js.map +1 -1
- package/dist/index257.js +5 -2
- package/dist/index257.js.map +1 -1
- package/dist/index258.js +2 -78
- package/dist/index258.js.map +1 -1
- package/dist/index259.js +9 -2
- package/dist/index259.js.map +1 -1
- package/dist/index26.js +31 -236
- package/dist/index26.js.map +1 -1
- package/dist/index260.js +2 -32
- package/dist/index260.js.map +1 -1
- package/dist/index261.js +2 -2
- package/dist/index262.js +92 -9
- package/dist/index262.js.map +1 -1
- package/dist/index263.js +59 -2
- package/dist/index263.js.map +1 -1
- package/dist/index264.js +2 -16
- package/dist/index264.js.map +1 -1
- package/dist/index265.js +41 -2
- package/dist/index265.js.map +1 -1
- package/dist/index266.js +2 -16
- package/dist/index266.js.map +1 -1
- package/dist/index267.js +34 -9
- package/dist/index267.js.map +1 -1
- package/dist/index268.js +8 -54
- package/dist/index268.js.map +1 -1
- package/dist/index269.js +2 -2
- package/dist/index27.js +27 -58
- package/dist/index27.js.map +1 -1
- package/dist/index270.js +42 -7
- package/dist/index270.js.map +1 -1
- package/dist/index271.js +2 -2
- package/dist/index272.js +2 -34
- package/dist/index272.js.map +1 -1
- package/dist/index273.js +16 -2
- package/dist/index273.js.map +1 -1
- package/dist/index274.js +9 -2
- package/dist/index274.js.map +1 -1
- package/dist/index275.js +6 -13
- package/dist/index275.js.map +1 -1
- package/dist/index276.js +2 -2
- package/dist/index277.js +8 -15
- package/dist/index277.js.map +1 -1
- package/dist/index278.js +2 -2
- package/dist/index279.js +55 -2
- package/dist/index279.js.map +1 -1
- package/dist/index28.js +247 -24
- package/dist/index28.js.map +1 -1
- package/dist/index280.js +2 -42
- package/dist/index280.js.map +1 -1
- package/dist/index281.js +2 -100
- package/dist/index281.js.map +1 -1
- package/dist/index282.js +20 -2
- package/dist/index282.js.map +1 -1
- package/dist/index283.js +2 -97
- package/dist/index283.js.map +1 -1
- package/dist/index284.js +33 -2
- package/dist/index284.js.map +1 -1
- package/dist/index285.js +6 -27
- package/dist/index285.js.map +1 -1
- package/dist/index286.js +2 -2
- package/dist/index287.js +9 -44
- package/dist/index287.js.map +1 -1
- package/dist/index288.js +2 -2
- package/dist/index289.js +2 -33
- package/dist/index289.js.map +1 -1
- package/dist/index29.js +249 -39
- package/dist/index29.js.map +1 -1
- package/dist/index290.js +36 -2
- package/dist/index290.js.map +1 -1
- package/dist/index291.js +2 -57
- package/dist/index291.js.map +1 -1
- package/dist/index292.js +24 -2
- package/dist/index292.js.map +1 -1
- package/dist/index293.js +2 -2
- package/dist/index294.js +26 -247
- package/dist/index294.js.map +1 -1
- package/dist/index295.js +2 -2
- package/dist/index296.js +2 -72
- package/dist/index296.js.map +1 -1
- package/dist/index297.js +42 -2
- package/dist/index297.js.map +1 -1
- package/dist/index298.js +7 -56
- package/dist/index298.js.map +1 -1
- package/dist/index299.js +2 -133
- package/dist/index299.js.map +1 -1
- package/dist/index30.js +32 -19
- package/dist/index30.js.map +1 -1
- package/dist/index300.js +30 -2
- package/dist/index300.js.map +1 -1
- package/dist/index301.js +2 -12
- package/dist/index301.js.map +1 -1
- package/dist/index302.js +34 -2
- package/dist/index302.js.map +1 -1
- package/dist/index303.js +2 -162
- package/dist/index303.js.map +1 -1
- package/dist/index304.js +26 -42
- package/dist/index304.js.map +1 -1
- package/dist/index305.js +2 -81
- package/dist/index305.js.map +1 -1
- package/dist/index306.js +10 -2
- package/dist/index306.js.map +1 -1
- package/dist/index307.js +2 -71
- package/dist/index307.js.map +1 -1
- package/dist/index308.js +2 -2
- package/dist/index309.js +19 -2
- package/dist/index309.js.map +1 -1
- package/dist/index31.js +96 -11
- package/dist/index31.js.map +1 -1
- package/dist/index310.js +2 -81
- package/dist/index310.js.map +1 -1
- package/dist/index311.js +2 -2
- package/dist/index312.js +42 -2
- package/dist/index312.js.map +1 -1
- package/dist/index313.js +2 -74
- package/dist/index313.js.map +1 -1
- package/dist/index314.js +25 -67
- package/dist/index314.js.map +1 -1
- package/dist/index315.js +2 -2
- package/dist/index316.js +9 -17
- package/dist/index316.js.map +1 -1
- package/dist/index317.js +2 -2
- package/dist/index318.js +84 -32
- package/dist/index318.js.map +1 -1
- package/dist/index319.js +2 -2
- package/dist/index32.js +40 -48
- package/dist/index32.js.map +1 -1
- package/dist/index320.js +68 -77
- package/dist/index320.js.map +1 -1
- package/dist/index321.js +2 -2
- package/dist/index322.js +12 -148
- package/dist/index322.js.map +1 -1
- package/dist/index323.js +1 -1
- package/dist/index324.js +28 -6
- package/dist/index324.js.map +1 -1
- package/dist/index325.js +2 -2
- package/dist/index326.js +78 -87
- package/dist/index326.js.map +1 -1
- package/dist/index327.js +2 -2
- package/dist/index328.js +78 -2
- package/dist/index328.js.map +1 -1
- package/dist/index329.js +2 -237
- package/dist/index329.js.map +1 -1
- package/dist/index33.js +20 -56
- package/dist/index33.js.map +1 -1
- package/dist/index330.js +11 -6
- package/dist/index330.js.map +1 -1
- package/dist/index331.js +2 -2
- package/dist/index332.js +18 -59
- package/dist/index332.js.map +1 -1
- package/dist/index333.js +2 -2
- package/dist/index334.js +12 -5
- package/dist/index334.js.map +1 -1
- package/dist/index335.js +2 -2
- package/dist/index336.js +2 -15
- package/dist/index336.js.map +1 -1
- package/dist/index337.js +88 -2
- package/dist/index337.js.map +1 -1
- package/dist/index338.js +24 -2
- package/dist/index338.js.map +1 -1
- package/dist/index339.js +2 -92
- package/dist/index339.js.map +1 -1
- package/dist/index34.js +59 -35
- package/dist/index34.js.map +1 -1
- package/dist/index340.js +42 -14
- package/dist/index340.js.map +1 -1
- package/dist/index341.js +2 -2
- package/dist/index342.js +22 -80
- package/dist/index342.js.map +1 -1
- package/dist/index343.js +2 -2
- package/dist/index344.js +2 -18
- package/dist/index344.js.map +1 -1
- package/dist/index345.js +16 -2
- package/dist/index345.js.map +1 -1
- package/dist/index346.js +2 -268
- package/dist/index346.js.map +1 -1
- package/dist/index347.js +176 -2
- package/dist/index347.js.map +1 -1
- package/dist/index348.js +2 -2
- package/dist/index349.js +35 -39
- package/dist/index349.js.map +1 -1
- package/dist/index35.js +101 -28
- package/dist/index35.js.map +1 -1
- package/dist/index350.js +3 -3
- package/dist/index350.js.map +1 -1
- package/dist/index351.js +2 -2
- package/dist/index352.js +19 -26
- package/dist/index352.js.map +1 -1
- package/dist/index357.js +26 -19
- package/dist/index357.js.map +1 -1
- package/dist/index36.js +115 -33
- package/dist/index36.js.map +1 -1
- package/dist/index37.js +41 -115
- package/dist/index37.js.map +1 -1
- package/dist/index38.js +34 -246
- package/dist/index38.js.map +1 -1
- package/dist/index39.js +30 -137
- package/dist/index39.js.map +1 -1
- package/dist/index4.js +26 -84
- package/dist/index4.js.map +1 -1
- package/dist/index40.js +26 -400
- package/dist/index40.js.map +1 -1
- package/dist/index41.js +28 -77
- package/dist/index41.js.map +1 -1
- package/dist/index42.js +23 -26
- package/dist/index42.js.map +1 -1
- package/dist/index43.js +36 -33
- package/dist/index43.js.map +1 -1
- package/dist/index44.js +62 -16
- package/dist/index44.js.map +1 -1
- package/dist/index45.js +138 -21
- package/dist/index45.js.map +1 -1
- package/dist/index46.js +129 -22
- package/dist/index46.js.map +1 -1
- package/dist/index47.js +41 -19
- package/dist/index47.js.map +1 -1
- package/dist/index48.js +11 -82
- package/dist/index48.js.map +1 -1
- package/dist/index49.js +56 -279
- package/dist/index49.js.map +1 -1
- package/dist/index5.js +21 -34
- package/dist/index5.js.map +1 -1
- package/dist/index50.js +280 -33
- package/dist/index50.js.map +1 -1
- package/dist/index51.js +74 -94
- package/dist/index51.js.map +1 -1
- package/dist/index52.js +66 -41
- package/dist/index52.js.map +1 -1
- package/dist/index53.js +333 -62
- package/dist/index53.js.map +1 -1
- package/dist/index54.js +96 -256
- package/dist/index54.js.map +1 -1
- package/dist/index55.js +38 -130
- package/dist/index55.js.map +1 -1
- package/dist/index56.js +251 -50
- package/dist/index56.js.map +1 -1
- package/dist/index57.js +144 -115
- package/dist/index57.js.map +1 -1
- package/dist/index58.js +93 -183
- package/dist/index58.js.map +1 -1
- package/dist/index59.js +33 -339
- package/dist/index59.js.map +1 -1
- package/dist/index6.js +2 -2
- package/dist/index60.js +102 -66
- package/dist/index60.js.map +1 -1
- package/dist/index61.js +73 -179
- package/dist/index61.js.map +1 -1
- package/dist/index62.js +117 -97
- package/dist/index62.js.map +1 -1
- package/dist/index63.js +113 -263
- package/dist/index63.js.map +1 -1
- package/dist/index64.js +258 -251
- package/dist/index64.js.map +1 -1
- package/dist/index65.js +177 -79
- package/dist/index65.js.map +1 -1
- package/dist/index66.js +261 -140
- package/dist/index66.js.map +1 -1
- package/dist/index67.js +183 -100
- package/dist/index67.js.map +1 -1
- package/dist/index68.js +28 -89
- package/dist/index68.js.map +1 -1
- package/dist/index69.js +20 -161
- package/dist/index69.js.map +1 -1
- package/dist/index7.js +394 -32
- package/dist/index7.js.map +1 -1
- package/dist/index70.js +190 -53
- package/dist/index70.js.map +1 -1
- package/dist/index71.js +204 -112
- package/dist/index71.js.map +1 -1
- package/dist/index72.js +2 -2
- package/dist/index73.js +89 -28
- package/dist/index73.js.map +1 -1
- package/dist/index74.js +126 -63
- package/dist/index74.js.map +1 -1
- package/dist/index75.js +122 -111
- package/dist/index75.js.map +1 -1
- package/dist/index76.js +67 -64
- package/dist/index76.js.map +1 -1
- package/dist/index77.js +112 -88
- package/dist/index77.js.map +1 -1
- package/dist/index78.js +87 -16
- package/dist/index78.js.map +1 -1
- package/dist/index79.js +151 -79
- package/dist/index79.js.map +1 -1
- package/dist/index8.js +25 -127
- package/dist/index8.js.map +1 -1
- package/dist/index80.js +104 -186
- package/dist/index80.js.map +1 -1
- package/dist/index81.js +59 -20
- package/dist/index81.js.map +1 -1
- package/dist/index82.js +17 -129
- package/dist/index82.js.map +1 -1
- package/dist/index83.js +88 -217
- package/dist/index83.js.map +1 -1
- package/dist/index84.js +64 -112
- package/dist/index84.js.map +1 -1
- package/dist/index9.js +30 -45
- package/dist/index9.js.map +1 -1
- package/dist/src/components/atoms/index.d.ts +45 -16
- package/dist/src/components/atoms/index.d.ts.map +1 -1
- package/dist/src/components/molecules/index.d.ts +20 -1
- package/dist/src/components/molecules/index.d.ts.map +1 -1
- package/dist/src/components/organisms/index.d.ts +17 -1
- package/dist/src/components/organisms/index.d.ts.map +1 -1
- package/dist/src/index.d.ts +3 -82
- package/dist/src/index.d.ts.map +1 -1
- package/dist/tokens.css +353 -7
- package/dist/vite.config.d.ts.map +1 -1
- package/package.json +4 -4
package/dist/index53.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { unsafeCSS, css, LitElement } from "lit";
|
|
2
|
-
import { property,
|
|
3
|
-
import
|
|
4
|
-
import chipCss from "./index292.js";
|
|
2
|
+
import { property, state, customElement } from "lit/decorators.js";
|
|
3
|
+
import pickerCss from "./index203.js";
|
|
5
4
|
import sharedTokens from "./index196.js";
|
|
5
|
+
import { colorPickerTemplate, swatchGridTemplate } from "./index204.js";
|
|
6
|
+
import { SHIBUI_SWATCHES } from "./index205.js";
|
|
6
7
|
var __defProp = Object.defineProperty;
|
|
7
8
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
8
9
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
@@ -13,88 +14,358 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
13
14
|
if (kind && result) __defProp(target, key, result);
|
|
14
15
|
return result;
|
|
15
16
|
};
|
|
16
|
-
|
|
17
|
+
function hslToHex(h, s, l) {
|
|
18
|
+
const sl = s / 100;
|
|
19
|
+
const ll = l / 100;
|
|
20
|
+
const k = (n) => (n + h / 30) % 12;
|
|
21
|
+
const a = sl * Math.min(ll, 1 - ll);
|
|
22
|
+
const f = (n) => ll - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)));
|
|
23
|
+
return "#" + [f(0), f(8), f(4)].map((x) => Math.round(x * 255).toString(16).padStart(2, "0")).join("").toUpperCase();
|
|
24
|
+
}
|
|
25
|
+
function hexToRgb(hex) {
|
|
26
|
+
const clean = hex.replace("#", "");
|
|
27
|
+
return {
|
|
28
|
+
r: parseInt(clean.slice(0, 2), 16),
|
|
29
|
+
g: parseInt(clean.slice(2, 4), 16),
|
|
30
|
+
b: parseInt(clean.slice(4, 6), 16)
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
function hexToHsl(hex) {
|
|
34
|
+
const { r, g, b } = hexToRgb(hex);
|
|
35
|
+
const rn = r / 255;
|
|
36
|
+
const gn = g / 255;
|
|
37
|
+
const bn = b / 255;
|
|
38
|
+
const max = Math.max(rn, gn, bn);
|
|
39
|
+
const min = Math.min(rn, gn, bn);
|
|
40
|
+
let h = 0;
|
|
41
|
+
let s = 0;
|
|
42
|
+
const l = (max + min) / 2;
|
|
43
|
+
if (max !== min) {
|
|
44
|
+
const d = max - min;
|
|
45
|
+
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
|
|
46
|
+
if (max === rn) h = ((gn - bn) / d + (gn < bn ? 6 : 0)) / 6;
|
|
47
|
+
else if (max === gn) h = ((bn - rn) / d + 2) / 6;
|
|
48
|
+
else h = ((rn - gn) / d + 4) / 6;
|
|
49
|
+
}
|
|
50
|
+
return {
|
|
51
|
+
h: Math.round(h * 360),
|
|
52
|
+
s: Math.round(s * 100),
|
|
53
|
+
l: Math.round(l * 100)
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
function isValidHex(v) {
|
|
57
|
+
return /^#[0-9A-Fa-f]{6}$/.test(v);
|
|
58
|
+
}
|
|
59
|
+
let LibColorPicker = class extends LitElement {
|
|
17
60
|
constructor() {
|
|
18
61
|
super(...arguments);
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
this.
|
|
29
|
-
this.
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
62
|
+
this.value = "#B85A1E";
|
|
63
|
+
this.variant = "inline";
|
|
64
|
+
this.showAlpha = false;
|
|
65
|
+
this.dark = false;
|
|
66
|
+
this.disabled = false;
|
|
67
|
+
this.label = "";
|
|
68
|
+
this.saved = "";
|
|
69
|
+
this._cs = { h: 25, s: 70, l: 36, alpha: 100 };
|
|
70
|
+
this._inputMode = "hex";
|
|
71
|
+
this._open = false;
|
|
72
|
+
this._savedColors = [];
|
|
73
|
+
this._prevCs = { ...this._cs };
|
|
74
|
+
this._dragging = false;
|
|
75
|
+
this._onDocMouseMove = (e) => {
|
|
76
|
+
if (!this._dragging) return;
|
|
77
|
+
this._updateFromCanvasEvent(e);
|
|
78
|
+
};
|
|
79
|
+
this._onDocMouseUp = () => {
|
|
80
|
+
this._dragging = false;
|
|
81
|
+
};
|
|
82
|
+
this._onDocClick = (e) => {
|
|
83
|
+
var _a;
|
|
84
|
+
if (this.variant !== "trigger" || !this._open) return;
|
|
85
|
+
if (!this.contains(e.target) && !(((_a = this.shadowRoot) == null ? void 0 : _a.contains(e.target)) ?? false)) {
|
|
86
|
+
this._cancel();
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
this._onKeyDown = (e) => {
|
|
90
|
+
if (e.key === "Escape" && this._open) this._cancel();
|
|
91
|
+
};
|
|
34
92
|
}
|
|
35
|
-
/* ──
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
if (
|
|
40
|
-
|
|
41
|
-
|
|
93
|
+
/* ── Lifecycle ── */
|
|
94
|
+
connectedCallback() {
|
|
95
|
+
super.connectedCallback();
|
|
96
|
+
this._initFromValue(this.value);
|
|
97
|
+
if (this.saved) {
|
|
98
|
+
try {
|
|
99
|
+
this._savedColors = JSON.parse(this.saved);
|
|
100
|
+
} catch {
|
|
101
|
+
}
|
|
42
102
|
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
103
|
+
document.addEventListener("mouseup", this._onDocMouseUp);
|
|
104
|
+
document.addEventListener("mousemove", this._onDocMouseMove);
|
|
105
|
+
document.addEventListener("click", this._onDocClick);
|
|
106
|
+
document.addEventListener("keydown", this._onKeyDown);
|
|
107
|
+
}
|
|
108
|
+
disconnectedCallback() {
|
|
109
|
+
super.disconnectedCallback();
|
|
110
|
+
document.removeEventListener("mouseup", this._onDocMouseUp);
|
|
111
|
+
document.removeEventListener("mousemove", this._onDocMouseMove);
|
|
112
|
+
document.removeEventListener("click", this._onDocClick);
|
|
113
|
+
document.removeEventListener("keydown", this._onKeyDown);
|
|
114
|
+
}
|
|
115
|
+
/* ── API pública ── */
|
|
116
|
+
/** Devuelve el color actual en todos los formatos */
|
|
117
|
+
getValue() {
|
|
118
|
+
return this._buildColorResult();
|
|
119
|
+
}
|
|
120
|
+
/** Establece el color desde hex */
|
|
121
|
+
setValue(hex) {
|
|
122
|
+
this._initFromValue(hex);
|
|
123
|
+
this.requestUpdate();
|
|
124
|
+
}
|
|
125
|
+
/* ── Render ── */
|
|
126
|
+
render() {
|
|
127
|
+
const res = this._buildColorResult();
|
|
128
|
+
return colorPickerTemplate({
|
|
129
|
+
variant: this.variant,
|
|
130
|
+
label: this.label || res.hex,
|
|
131
|
+
panelOpen: this._open,
|
|
132
|
+
hex: res.hex,
|
|
133
|
+
r: res.r,
|
|
134
|
+
g: res.g,
|
|
135
|
+
b: res.b,
|
|
136
|
+
h: res.h,
|
|
137
|
+
s: res.s,
|
|
138
|
+
l: res.l,
|
|
139
|
+
alpha: res.alpha,
|
|
140
|
+
inputMode: this._inputMode,
|
|
141
|
+
savedColors: this._savedColors,
|
|
142
|
+
showAlpha: this.showAlpha,
|
|
143
|
+
onTriggerClick: () => this._togglePanel(),
|
|
144
|
+
onCanvasMousedown: (e) => this._startCanvasDrag(e),
|
|
145
|
+
onHueInput: (e) => this._onHueInput(e),
|
|
146
|
+
onAlphaInput: (e) => this._onAlphaSliderInput(e),
|
|
147
|
+
onModeToggle: () => this._cycleMode(),
|
|
148
|
+
onHexInput: (e) => this._onHexInput(e),
|
|
149
|
+
onRgbInput: (idx, e) => this._onRgbInput(idx, e),
|
|
150
|
+
onHslInput: (idx, e) => this._onHslInput(idx, e),
|
|
151
|
+
onAlphaNumInput: (e) => this._onAlphaNumInput(e),
|
|
152
|
+
onSaveColor: () => this._saveCurrentColor(),
|
|
153
|
+
onSavedClick: (hex) => this._applySavedColor(hex),
|
|
154
|
+
onCancel: () => this._cancel(),
|
|
155
|
+
onApply: () => this._apply()
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
/* ── Canvas drag ── */
|
|
159
|
+
_startCanvasDrag(e) {
|
|
160
|
+
this._dragging = true;
|
|
161
|
+
this._updateFromCanvasEvent(e);
|
|
162
|
+
}
|
|
163
|
+
_updateFromCanvasEvent(e) {
|
|
164
|
+
var _a;
|
|
165
|
+
const canvas = (_a = this.shadowRoot) == null ? void 0 : _a.querySelector(".cp-canvas");
|
|
166
|
+
if (!canvas) return;
|
|
167
|
+
const rect = canvas.getBoundingClientRect();
|
|
168
|
+
const x = Math.max(0, Math.min(1, (e.clientX - rect.left) / rect.width));
|
|
169
|
+
const y = Math.max(0, Math.min(1, (e.clientY - rect.top) / rect.height));
|
|
170
|
+
this._cs = {
|
|
171
|
+
...this._cs,
|
|
172
|
+
s: Math.round(x * 100),
|
|
173
|
+
l: Math.round((1 - y) * 100)
|
|
174
|
+
};
|
|
175
|
+
this._emitChange();
|
|
176
|
+
}
|
|
177
|
+
/* ── Sliders ── */
|
|
178
|
+
_onHueInput(e) {
|
|
179
|
+
this._cs = { ...this._cs, h: parseInt(e.target.value) };
|
|
180
|
+
this._emitChange();
|
|
181
|
+
}
|
|
182
|
+
_onAlphaSliderInput(e) {
|
|
183
|
+
this._cs = { ...this._cs, alpha: parseInt(e.target.value) };
|
|
184
|
+
this._emitChange();
|
|
185
|
+
}
|
|
186
|
+
/* ── Input mode ── */
|
|
187
|
+
_cycleMode() {
|
|
188
|
+
const modes = ["hex", "rgb", "hsl"];
|
|
189
|
+
const i = modes.indexOf(this._inputMode);
|
|
190
|
+
this._inputMode = modes[(i + 1) % modes.length];
|
|
191
|
+
}
|
|
192
|
+
/* ── Text inputs ── */
|
|
193
|
+
_onHexInput(e) {
|
|
194
|
+
const v = e.target.value;
|
|
195
|
+
if (isValidHex(v)) {
|
|
196
|
+
const hsl = hexToHsl(v);
|
|
197
|
+
this._cs = { ...this._cs, ...hsl };
|
|
198
|
+
this._emitChange();
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
_onRgbInput(idx, e) {
|
|
202
|
+
const val = parseInt(e.target.value) || 0;
|
|
203
|
+
const clamped = Math.max(0, Math.min(255, val));
|
|
204
|
+
const { r, g, b } = hexToRgb(this._buildHex());
|
|
205
|
+
const rgb = [r, g, b];
|
|
206
|
+
rgb[idx] = clamped;
|
|
207
|
+
const hex = "#" + rgb.map((x) => x.toString(16).padStart(2, "0")).join("").toUpperCase();
|
|
208
|
+
const hsl = hexToHsl(hex);
|
|
209
|
+
this._cs = { ...this._cs, ...hsl };
|
|
210
|
+
this._emitChange();
|
|
211
|
+
}
|
|
212
|
+
_onHslInput(idx, e) {
|
|
213
|
+
const val = parseInt(e.target.value) || 0;
|
|
214
|
+
const maxes = [360, 100, 100];
|
|
215
|
+
const clamped = Math.max(0, Math.min(maxes[idx], val));
|
|
216
|
+
const next = { ...this._cs };
|
|
217
|
+
if (idx === 0) next.h = clamped;
|
|
218
|
+
else if (idx === 1) next.s = clamped;
|
|
219
|
+
else next.l = clamped;
|
|
220
|
+
this._cs = next;
|
|
221
|
+
this._emitChange();
|
|
222
|
+
}
|
|
223
|
+
_onAlphaNumInput(e) {
|
|
224
|
+
const val = parseInt(e.target.value) || 0;
|
|
225
|
+
this._cs = { ...this._cs, alpha: Math.max(0, Math.min(100, val)) };
|
|
226
|
+
this._emitChange();
|
|
227
|
+
}
|
|
228
|
+
/* ── Saved colors ── */
|
|
229
|
+
_saveCurrentColor() {
|
|
230
|
+
const hex = this._buildHex();
|
|
231
|
+
if (!this._savedColors.includes(hex)) {
|
|
232
|
+
this._savedColors = [...this._savedColors, hex];
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
_applySavedColor(hex) {
|
|
236
|
+
this._initFromValue(hex);
|
|
237
|
+
this._emitChange();
|
|
238
|
+
}
|
|
239
|
+
/* ── Panel (trigger mode) ── */
|
|
240
|
+
_togglePanel() {
|
|
241
|
+
if (this._open) {
|
|
242
|
+
this._cancel();
|
|
243
|
+
} else {
|
|
244
|
+
this._prevCs = { ...this._cs };
|
|
245
|
+
this._open = true;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
_cancel() {
|
|
249
|
+
this._cs = { ...this._prevCs };
|
|
250
|
+
this._open = false;
|
|
251
|
+
}
|
|
252
|
+
_apply() {
|
|
253
|
+
this._open = false;
|
|
254
|
+
this.dispatchEvent(new CustomEvent("ui-lib-apply", {
|
|
255
|
+
detail: this._buildColorResult(),
|
|
51
256
|
bubbles: true,
|
|
52
257
|
composed: true
|
|
53
258
|
}));
|
|
54
259
|
}
|
|
55
|
-
/* ──
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
const
|
|
59
|
-
|
|
60
|
-
el.classList.remove("is-entering");
|
|
61
|
-
void el.offsetWidth;
|
|
62
|
-
el.classList.add("is-entering");
|
|
63
|
-
el.addEventListener("animationend", () => el.classList.remove("is-entering"), { once: true });
|
|
260
|
+
/* ── Helpers ── */
|
|
261
|
+
_initFromValue(hex) {
|
|
262
|
+
if (!isValidHex(hex)) return;
|
|
263
|
+
const hsl = hexToHsl(hex);
|
|
264
|
+
this._cs = { ...this._cs, ...hsl };
|
|
64
265
|
}
|
|
65
|
-
|
|
66
|
-
return
|
|
266
|
+
_buildHex() {
|
|
267
|
+
return hslToHex(this._cs.h, this._cs.s, this._cs.l);
|
|
268
|
+
}
|
|
269
|
+
_buildColorResult() {
|
|
270
|
+
const hex = this._buildHex();
|
|
271
|
+
const { r, g, b } = hexToRgb(hex);
|
|
272
|
+
return { hex, r, g, b, ...this._cs };
|
|
273
|
+
}
|
|
274
|
+
_emitChange() {
|
|
275
|
+
this.dispatchEvent(new CustomEvent("ui-lib-change", {
|
|
276
|
+
detail: this._buildColorResult(),
|
|
277
|
+
bubbles: true,
|
|
278
|
+
composed: true
|
|
279
|
+
}));
|
|
67
280
|
}
|
|
68
281
|
};
|
|
69
|
-
|
|
282
|
+
LibColorPicker.styles = [
|
|
70
283
|
css`${unsafeCSS(sharedTokens)}`,
|
|
71
|
-
css`${unsafeCSS(
|
|
284
|
+
css`${unsafeCSS(pickerCss)}`
|
|
72
285
|
];
|
|
73
286
|
__decorateClass([
|
|
74
|
-
property({ type: String
|
|
75
|
-
],
|
|
287
|
+
property({ type: String })
|
|
288
|
+
], LibColorPicker.prototype, "value", 2);
|
|
76
289
|
__decorateClass([
|
|
77
290
|
property({ type: String, reflect: true })
|
|
78
|
-
],
|
|
291
|
+
], LibColorPicker.prototype, "variant", 2);
|
|
79
292
|
__decorateClass([
|
|
80
|
-
property({ type:
|
|
81
|
-
],
|
|
293
|
+
property({ type: Boolean, reflect: true, attribute: "show-alpha" })
|
|
294
|
+
], LibColorPicker.prototype, "showAlpha", 2);
|
|
295
|
+
__decorateClass([
|
|
296
|
+
property({ type: Boolean, reflect: true })
|
|
297
|
+
], LibColorPicker.prototype, "dark", 2);
|
|
82
298
|
__decorateClass([
|
|
83
299
|
property({ type: Boolean, reflect: true })
|
|
84
|
-
],
|
|
300
|
+
], LibColorPicker.prototype, "disabled", 2);
|
|
301
|
+
__decorateClass([
|
|
302
|
+
property({ type: String })
|
|
303
|
+
], LibColorPicker.prototype, "label", 2);
|
|
304
|
+
__decorateClass([
|
|
305
|
+
property({ type: String })
|
|
306
|
+
], LibColorPicker.prototype, "saved", 2);
|
|
307
|
+
__decorateClass([
|
|
308
|
+
state()
|
|
309
|
+
], LibColorPicker.prototype, "_cs", 2);
|
|
310
|
+
__decorateClass([
|
|
311
|
+
state()
|
|
312
|
+
], LibColorPicker.prototype, "_inputMode", 2);
|
|
313
|
+
__decorateClass([
|
|
314
|
+
state()
|
|
315
|
+
], LibColorPicker.prototype, "_open", 2);
|
|
316
|
+
__decorateClass([
|
|
317
|
+
state()
|
|
318
|
+
], LibColorPicker.prototype, "_savedColors", 2);
|
|
319
|
+
LibColorPicker = __decorateClass([
|
|
320
|
+
customElement("lib-color-picker")
|
|
321
|
+
], LibColorPicker);
|
|
322
|
+
let LibColorSwatches = class extends LitElement {
|
|
323
|
+
constructor() {
|
|
324
|
+
super(...arguments);
|
|
325
|
+
this.dark = false;
|
|
326
|
+
this.value = "";
|
|
327
|
+
this.rowsJson = "";
|
|
328
|
+
}
|
|
329
|
+
render() {
|
|
330
|
+
let rows = SHIBUI_SWATCHES;
|
|
331
|
+
if (this.rowsJson) {
|
|
332
|
+
try {
|
|
333
|
+
rows = JSON.parse(this.rowsJson);
|
|
334
|
+
} catch {
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
return swatchGridTemplate({
|
|
338
|
+
rows,
|
|
339
|
+
selected: this.value,
|
|
340
|
+
onSelect: (c) => {
|
|
341
|
+
this.value = c.value;
|
|
342
|
+
this.dispatchEvent(new CustomEvent("ui-lib-swatch-click", {
|
|
343
|
+
detail: c,
|
|
344
|
+
bubbles: true,
|
|
345
|
+
composed: true
|
|
346
|
+
}));
|
|
347
|
+
}
|
|
348
|
+
});
|
|
349
|
+
}
|
|
350
|
+
};
|
|
351
|
+
LibColorSwatches.styles = [
|
|
352
|
+
css`${unsafeCSS(sharedTokens)}`,
|
|
353
|
+
css`${unsafeCSS(pickerCss)}`
|
|
354
|
+
];
|
|
85
355
|
__decorateClass([
|
|
86
356
|
property({ type: Boolean, reflect: true })
|
|
87
|
-
],
|
|
357
|
+
], LibColorSwatches.prototype, "dark", 2);
|
|
88
358
|
__decorateClass([
|
|
89
|
-
property({ type: String
|
|
90
|
-
],
|
|
359
|
+
property({ type: String })
|
|
360
|
+
], LibColorSwatches.prototype, "value", 2);
|
|
91
361
|
__decorateClass([
|
|
92
|
-
|
|
93
|
-
],
|
|
94
|
-
|
|
95
|
-
customElement("lib-
|
|
96
|
-
],
|
|
362
|
+
property({ type: String })
|
|
363
|
+
], LibColorSwatches.prototype, "rowsJson", 2);
|
|
364
|
+
LibColorSwatches = __decorateClass([
|
|
365
|
+
customElement("lib-color-swatches")
|
|
366
|
+
], LibColorSwatches);
|
|
97
367
|
export {
|
|
98
|
-
|
|
368
|
+
LibColorPicker,
|
|
369
|
+
LibColorSwatches
|
|
99
370
|
};
|
|
100
371
|
//# sourceMappingURL=index53.js.map
|
package/dist/index53.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index53.js","sources":["../src/components/molecules/chip/lib-chip.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\nimport { chipTemplate } from './lib-chip.html';\nimport chipCss from './lib-chip.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport type { ChipKind, ChipSize, ChipColor } from './lib-chip.types';\n\n/**\n * lib-chip — Chip Shibui (SG-26)\n *\n * Tres familias semánticas controladas por `kind`:\n * - static → etiqueta read-only, taxonomía\n * - toggle → filtro seleccionable (aria-checkbox)\n * - input → tag removible con botón ×\n *\n * @prop kind — 'static' | 'toggle' | 'input'\n * @prop size — 'xs' | 'sm' | 'md' | 'lg'\n * @prop color — 'default' | 'kaki' | 'celadon' | 'error' | 'info' | 'dark'\n * @prop selected — Estado seleccionado (solo kind=toggle)\n * @prop dot — Dot de color antes del texto\n * @prop aria-label — Texto accesible del chip\n *\n * @fires ui-lib-chip-toggle — { detail: { selected: boolean } } (kind=toggle)\n * @fires ui-lib-chip-remove — { detail: {} } (kind=input)\n *\n * @slot — Texto/label del chip\n * @slot icon — Icono a la izquierda del texto\n * @slot avatar — Avatar circular (solo kind=input, opcionalmente static)\n */\n@customElement('lib-chip')\nexport class LibChip extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(chipCss)}`,\n ];\n\n @property({ type: String, reflect: true })\n kind: ChipKind = 'static';\n\n @property({ type: String, reflect: true })\n size: ChipSize = 'md';\n\n @property({ type: String, reflect: true })\n color: ChipColor = 'default';\n\n @property({ type: Boolean, reflect: true })\n selected = false;\n\n @property({ type: Boolean, reflect: true })\n dot = false;\n\n @property({ type: String, attribute: 'aria-label' })\n override ariaLabel = '';\n\n @query('.chip-input')\n declare private _inputEl: HTMLElement | null;\n\n /* ── Toggle ── */\n _handleToggle(): void {\n this.selected = !this.selected;\n this.dispatchEvent(new CustomEvent('ui-lib-chip-toggle', {\n detail: { selected: this.selected },\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Remove con animación de salida ── */\n _handleRemove(e: MouseEvent): void {\n e.stopPropagation();\n const el = this._inputEl;\n if (!el) {\n this._emitRemove();\n return;\n }\n el.classList.add('is-removing');\n el.addEventListener('animationend', (): void => {\n this._emitRemove();\n }, { once: true });\n }\n\n private _emitRemove(): void {\n this.dispatchEvent(new CustomEvent('ui-lib-chip-remove', {\n detail: {},\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Animación de entrada (llamar desde fuera si se crea dinámicamente) ── */\n animateIn(): void {\n const el = this._inputEl ?? this.shadowRoot?.querySelector('.chip, .chip-toggle') as HTMLElement | null;\n if (!el) return;\n el.classList.remove('is-entering');\n void el.offsetWidth; // reflow\n el.classList.add('is-entering');\n el.addEventListener('animationend', (): void => el.classList.remove('is-entering'), { once: true });\n }\n\n protected override render(): TemplateResult {\n return chipTemplate(this);\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-chip': LibChip;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AA8BO,IAAM,UAAN,cAAsB,WAAW;AAAA,EAAjC,cAAA;AAAA,UAAA,GAAA,SAAA;AAOL,SAAA,OAAiB;AAGjB,SAAA,OAAiB;AAGjB,SAAA,QAAmB;AAGnB,SAAA,WAAW;AAGX,SAAA,MAAM;AAGN,SAAS,YAAY;AAAA,EAAA;AAAA;AAAA,EAMrB,gBAAsB;AACpB,SAAK,WAAW,CAAC,KAAK;AACtB,SAAK,cAAc,IAAI,YAAY,sBAAsB;AAAA,MACvD,QAAQ,EAAE,UAAU,KAAK,SAAA;AAAA,MACzB,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA;AAAA,EAGA,cAAc,GAAqB;AACjC,MAAE,gBAAA;AACF,UAAM,KAAK,KAAK;AAChB,QAAI,CAAC,IAAI;AACP,WAAK,YAAA;AACL;AAAA,IACF;AACA,OAAG,UAAU,IAAI,aAAa;AAC9B,OAAG,iBAAiB,gBAAgB,MAAY;AAC9C,WAAK,YAAA;AAAA,IACP,GAAG,EAAE,MAAM,MAAM;AAAA,EACnB;AAAA,EAEQ,cAAoB;AAC1B,SAAK,cAAc,IAAI,YAAY,sBAAsB;AAAA,MACvD,QAAQ,CAAA;AAAA,MACR,SAAS;AAAA,MACT,UAAU;AAAA,IAAA,CACX,CAAC;AAAA,EACJ;AAAA;AAAA,EAGA,YAAkB;;AAChB,UAAM,KAAK,KAAK,cAAY,UAAK,eAAL,mBAAiB,cAAc;AAC3D,QAAI,CAAC,GAAI;AACT,OAAG,UAAU,OAAO,aAAa;AACjC,SAAK,GAAG;AACR,OAAG,UAAU,IAAI,aAAa;AAC9B,OAAG,iBAAiB,gBAAgB,MAAY,GAAG,UAAU,OAAO,aAAa,GAAG,EAAE,MAAM,KAAA,CAAM;AAAA,EACpG;AAAA,EAEmB,SAAyB;AAC1C,WAAO,aAAa,IAAI;AAAA,EAC1B;AACF;AAxEa,QACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,OAAO,CAAC;AAC1B;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAN9B,QAOX,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAT9B,QAUX,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAZ9B,QAaX,WAAA,SAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAf/B,QAgBX,WAAA,YAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAlB/B,QAmBX,WAAA,OAAA,CAAA;AAGS,gBAAA;AAAA,EADR,SAAS,EAAE,MAAM,QAAQ,WAAW,cAAc;AAAA,GArBxC,QAsBF,WAAA,aAAA,CAAA;AAGO,gBAAA;AAAA,EADf,MAAM,aAAa;AAAA,GAxBT,QAyBK,WAAA,YAAA,CAAA;AAzBL,UAAN,gBAAA;AAAA,EADN,cAAc,UAAU;AAAA,GACZ,OAAA;"}
|
|
1
|
+
{"version":3,"file":"index53.js","sources":["../src/components/molecules/color-picker/lib-color-picker.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport pickerCss from './lib-color-picker.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport { colorPickerTemplate, swatchGridTemplate } from './lib-color-picker.html';\nimport { SHIBUI_SWATCHES } from './lib-color-picker.types';\nimport type {\n ColorPickerVariant,\n ColorInputMode,\n SwatchRow,\n SwatchColor,\n ColorState,\n} from './lib-color-picker.types';\n\n/* ──────────────────────────────────────\n Color conversion utilities\n ────────────────────────────────────── */\nfunction hslToHex(h: number, s: number, l: number): string {\n const sl = s / 100;\n const ll = l / 100;\n const k = (n: number): number => (n + h / 30) % 12;\n const a = sl * Math.min(ll, 1 - ll);\n const f = (n: number): number =>\n ll - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)));\n return '#' + ([f(0), f(8), f(4)] as number[])\n .map(x => Math.round(x * 255).toString(16).padStart(2, '0'))\n .join('')\n .toUpperCase();\n}\n\nfunction hexToRgb(hex: string): { r: number; g: number; b: number } {\n const clean = hex.replace('#', '');\n return {\n r: parseInt(clean.slice(0, 2), 16),\n g: parseInt(clean.slice(2, 4), 16),\n b: parseInt(clean.slice(4, 6), 16),\n };\n}\n\nfunction hexToHsl(hex: string): { h: number; s: number; l: number } {\n const { r, g, b } = hexToRgb(hex);\n const rn = r / 255; const gn = g / 255; const bn = b / 255;\n const max = Math.max(rn, gn, bn);\n const min = Math.min(rn, gn, bn);\n let h = 0; let s = 0;\n const l = (max + min) / 2;\n\n if (max !== min) {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n if (max === rn) h = ((gn - bn) / d + (gn < bn ? 6 : 0)) / 6;\n else if (max === gn) h = ((bn - rn) / d + 2) / 6;\n else h = ((rn - gn) / d + 4) / 6;\n }\n return {\n h: Math.round(h * 360),\n s: Math.round(s * 100),\n l: Math.round(l * 100),\n };\n}\n\nfunction isValidHex(v: string): boolean {\n return /^#[0-9A-Fa-f]{6}$/.test(v);\n}\n\n/**\n * @element lib-color-picker\n *\n * Selector de color con canvas 2D (saturación/luminosidad), slider de tono,\n * slider de opacidad, inputs HEX/RGB/HSL intercambiables y colores guardados.\n *\n * @prop {string} value — Color inicial en HEX (#RRGGBB)\n * @prop {ColorPickerVariant} variant — inline · trigger (default: inline)\n * @prop {boolean} show-alpha— Mostrar slider y campo de opacidad\n * @prop {boolean} dark — Modo oscuro\n * @prop {boolean} disabled — Desactivado\n * @prop {string} label — Texto del trigger (variant=trigger)\n * @prop {string} saved — Colores guardados iniciales (JSON array)\n *\n * @fires ui-lib-change — {detail: {value: string, hex: string, r, g, b, h, s, l, alpha}}\n * @fires ui-lib-apply — Igual a change pero solo al pulsar \"Aplicar\"\n * @fires ui-lib-swatch-click — {detail: {value: string, name?: string}} al clickar un swatch\n *\n * @method getValue() — Devuelve el color actual como {hex, r, g, b, h, s, l, alpha}\n * @method setValue(hex)— Establece el color programáticamente\n */\n@customElement('lib-color-picker')\nexport class LibColorPicker extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(pickerCss)}`,\n ];\n\n /* ── Props ── */\n\n @property({ type: String })\n value = '#B85A1E';\n\n @property({ type: String, reflect: true })\n variant: ColorPickerVariant = 'inline';\n\n @property({ type: Boolean, reflect: true, attribute: 'show-alpha' })\n showAlpha = false;\n\n @property({ type: Boolean, reflect: true })\n dark = false;\n\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n @property({ type: String })\n label = '';\n\n /** Colores guardados iniciales — JSON array, e.g. '[\"#B85A1E\",\"#357164\"]' */\n @property({ type: String })\n saved = '';\n\n /* ── Internal state ── */\n\n @state() private _cs: ColorState = { h: 25, s: 70, l: 36, alpha: 100 };\n @state() private _inputMode: ColorInputMode = 'hex';\n @state() private _open = false;\n @state() private _savedColors: string[] = [];\n\n /** Color anterior al abrir, para cancelar */\n private _prevCs: ColorState = { ...this._cs };\n\n /** Dragging en el canvas */\n private _dragging = false;\n\n /* ── Lifecycle ── */\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._initFromValue(this.value);\n\n if (this.saved) {\n try { this._savedColors = JSON.parse(this.saved) as string[]; }\n catch { /* ignore */ }\n }\n\n document.addEventListener('mouseup', this._onDocMouseUp);\n document.addEventListener('mousemove', this._onDocMouseMove);\n document.addEventListener('click', this._onDocClick);\n document.addEventListener('keydown', this._onKeyDown);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n document.removeEventListener('mouseup', this._onDocMouseUp);\n document.removeEventListener('mousemove', this._onDocMouseMove);\n document.removeEventListener('click', this._onDocClick);\n document.removeEventListener('keydown', this._onKeyDown);\n }\n\n /* ── API pública ── */\n\n /** Devuelve el color actual en todos los formatos */\n public getValue(): { hex: string; r: number; g: number; b: number; h: number; s: number; l: number; alpha: number } {\n return this._buildColorResult();\n }\n\n /** Establece el color desde hex */\n public setValue(hex: string): void {\n this._initFromValue(hex);\n this.requestUpdate();\n }\n\n /* ── Render ── */\n\n protected override render(): TemplateResult {\n const res = this._buildColorResult();\n\n return colorPickerTemplate({\n variant: this.variant,\n label: this.label || res.hex,\n panelOpen: this._open,\n hex: res.hex, r: res.r, g: res.g, b: res.b,\n h: res.h, s: res.s, l: res.l,\n alpha: res.alpha,\n inputMode: this._inputMode,\n savedColors: this._savedColors,\n showAlpha: this.showAlpha,\n\n onTriggerClick: (): void => this._togglePanel(),\n onCanvasMousedown: (e: MouseEvent): void => this._startCanvasDrag(e),\n onHueInput: (e: Event): void => this._onHueInput(e),\n onAlphaInput: (e: Event): void => this._onAlphaSliderInput(e),\n onModeToggle: (): void => this._cycleMode(),\n onHexInput: (e: Event): void => this._onHexInput(e),\n onRgbInput: (idx: 0|1|2, e: Event): void => this._onRgbInput(idx, e),\n onHslInput: (idx: 0|1|2, e: Event): void => this._onHslInput(idx, e),\n onAlphaNumInput: (e: Event): void => this._onAlphaNumInput(e),\n onSaveColor: (): void => this._saveCurrentColor(),\n onSavedClick: (hex: string): void => this._applySavedColor(hex),\n onCancel: (): void => this._cancel(),\n onApply: (): void => this._apply(),\n });\n }\n\n /* ── Canvas drag ── */\n\n private _startCanvasDrag(e: MouseEvent): void {\n this._dragging = true;\n this._updateFromCanvasEvent(e);\n }\n\n private _onDocMouseMove = (e: MouseEvent): void => {\n if (!this._dragging) return;\n this._updateFromCanvasEvent(e);\n };\n\n private _onDocMouseUp = (): void => { this._dragging = false; };\n\n private _updateFromCanvasEvent(e: MouseEvent): void {\n const canvas = this.shadowRoot?.querySelector('.cp-canvas');\n if (!canvas) return;\n const rect = canvas.getBoundingClientRect();\n const x = Math.max(0, Math.min(1, (e.clientX - rect.left) / rect.width));\n const y = Math.max(0, Math.min(1, (e.clientY - rect.top) / rect.height));\n this._cs = {\n ...this._cs,\n s: Math.round(x * 100),\n l: Math.round((1 - y) * 100),\n };\n this._emitChange();\n }\n\n /* ── Sliders ── */\n\n private _onHueInput(e: Event): void {\n this._cs = { ...this._cs, h: parseInt((e.target as HTMLInputElement).value) };\n this._emitChange();\n }\n\n private _onAlphaSliderInput(e: Event): void {\n this._cs = { ...this._cs, alpha: parseInt((e.target as HTMLInputElement).value) };\n this._emitChange();\n }\n\n /* ── Input mode ── */\n\n private _cycleMode(): void {\n const modes: ColorInputMode[] = ['hex', 'rgb', 'hsl'];\n const i = modes.indexOf(this._inputMode);\n this._inputMode = modes[(i + 1) % modes.length]!;\n }\n\n /* ── Text inputs ── */\n\n private _onHexInput(e: Event): void {\n const v = (e.target as HTMLInputElement).value;\n if (isValidHex(v)) {\n const hsl = hexToHsl(v);\n this._cs = { ...this._cs, ...hsl };\n this._emitChange();\n }\n }\n\n private _onRgbInput(idx: 0|1|2, e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n const clamped = Math.max(0, Math.min(255, val));\n const { r, g, b } = hexToRgb(this._buildHex());\n const rgb: [number, number, number] = [r, g, b];\n rgb[idx] = clamped;\n const hex = '#' + (rgb as number[]).map(x => x.toString(16).padStart(2, '0')).join('').toUpperCase();\n const hsl = hexToHsl(hex);\n this._cs = { ...this._cs, ...hsl };\n this._emitChange();\n }\n\n private _onHslInput(idx: 0|1|2, e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n const maxes: [number, number, number] = [360, 100, 100];\n const clamped = Math.max(0, Math.min(maxes[idx]!, val));\n const next = { ...this._cs };\n if (idx === 0) next.h = clamped;\n else if (idx === 1) next.s = clamped;\n else next.l = clamped;\n this._cs = next;\n this._emitChange();\n }\n\n private _onAlphaNumInput(e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n this._cs = { ...this._cs, alpha: Math.max(0, Math.min(100, val)) };\n this._emitChange();\n }\n\n /* ── Saved colors ── */\n\n private _saveCurrentColor(): void {\n const hex = this._buildHex();\n if (!this._savedColors.includes(hex)) {\n this._savedColors = [...this._savedColors, hex];\n }\n }\n\n private _applySavedColor(hex: string): void {\n this._initFromValue(hex);\n this._emitChange();\n }\n\n /* ── Panel (trigger mode) ── */\n\n private _togglePanel(): void {\n if (this._open) {\n this._cancel();\n } else {\n this._prevCs = { ...this._cs };\n this._open = true;\n }\n }\n\n private _cancel(): void {\n this._cs = { ...this._prevCs };\n this._open = false;\n }\n\n private _apply(): void {\n this._open = false;\n this.dispatchEvent(new CustomEvent('ui-lib-apply', {\n detail: this._buildColorResult(),\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Close on outside click / Escape ── */\n\n private _onDocClick = (e: MouseEvent): void => {\n if (this.variant !== 'trigger' || !this._open) return;\n if (!this.contains(e.target as Node) && !(this.shadowRoot?.contains(e.target as Node) ?? false)) {\n this._cancel();\n }\n };\n\n private _onKeyDown = (e: KeyboardEvent): void => {\n if (e.key === 'Escape' && this._open) this._cancel();\n };\n\n /* ── Helpers ── */\n\n private _initFromValue(hex: string): void {\n if (!isValidHex(hex)) return;\n const hsl = hexToHsl(hex);\n this._cs = { ...this._cs, ...hsl };\n }\n\n private _buildHex(): string {\n return hslToHex(this._cs.h, this._cs.s, this._cs.l);\n }\n\n private _buildColorResult(): { hex: string; r: number; g: number; b: number; h: number; s: number; l: number; alpha: number } {\n const hex = this._buildHex();\n const { r, g, b } = hexToRgb(hex);\n return { hex, r, g, b, ...this._cs };\n }\n\n private _emitChange(): void {\n this.dispatchEvent(new CustomEvent('ui-lib-change', {\n detail: this._buildColorResult(),\n bubbles: true,\n composed: true,\n }));\n }\n}\n\n/* ──────────────────────────────────────\n Swatch-only component\n ────────────────────────────────────── */\n\n/**\n * @element lib-color-swatches\n *\n * Cuadrícula de swatches de color. Puede usarse de forma independiente o\n * para mostrar la paleta del design system.\n *\n * @prop {boolean} dark\n * @prop {string} value — Color seleccionado (hex)\n *\n * @fires ui-lib-swatch-click — {detail: {value, name}}\n */\n@customElement('lib-color-swatches')\nexport class LibColorSwatches extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(pickerCss)}`,\n ];\n\n @property({ type: Boolean, reflect: true }) dark = false;\n @property({ type: String }) value = '';\n @property({ type: String }) rowsJson = '';\n\n protected override render(): TemplateResult {\n let rows: SwatchRow[] = SHIBUI_SWATCHES;\n if (this.rowsJson) {\n try { rows = JSON.parse(this.rowsJson) as SwatchRow[]; } catch { /* ignore */ }\n }\n return swatchGridTemplate({\n rows,\n selected: this.value,\n onSelect: (c: SwatchColor): void => {\n this.value = c.value;\n this.dispatchEvent(new CustomEvent('ui-lib-swatch-click', {\n detail: c, bubbles: true, composed: true,\n }));\n },\n });\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-color-picker': LibColorPicker;\n 'lib-color-swatches': LibColorSwatches;\n }\n}"],"names":[],"mappings":"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"}
|