@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/index63.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { unsafeCSS, css, LitElement } from "lit";
|
|
2
|
-
import { property, state, customElement } from "lit/decorators.js";
|
|
3
|
-
import
|
|
2
|
+
import { property, state, queryAll, customElement } from "lit/decorators.js";
|
|
3
|
+
import segmentedCss from "./index225.js";
|
|
4
4
|
import sharedTokens from "./index196.js";
|
|
5
|
-
import {
|
|
5
|
+
import { segmentedTemplate } from "./index226.js";
|
|
6
6
|
var __defProp = Object.defineProperty;
|
|
7
7
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
8
8
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
@@ -13,305 +13,155 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
13
13
|
if (kind && result) __defProp(target, key, result);
|
|
14
14
|
return result;
|
|
15
15
|
};
|
|
16
|
-
let
|
|
16
|
+
let LibSegmentedControl = class extends LitElement {
|
|
17
17
|
constructor() {
|
|
18
18
|
super(...arguments);
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
19
|
+
this.options = [];
|
|
20
|
+
this.value = "";
|
|
21
|
+
this.variant = "outline";
|
|
22
|
+
this.size = "md";
|
|
23
|
+
this.full = false;
|
|
24
|
+
this.iconOnly = false;
|
|
24
25
|
this.disabled = false;
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
27
|
-
this._nodeStates = /* @__PURE__ */ new Map();
|
|
28
|
-
this._search = "";
|
|
29
|
-
this._parentMap = /* @__PURE__ */ new Map();
|
|
26
|
+
this.glitch = false;
|
|
27
|
+
this._thumbStyle = "";
|
|
30
28
|
}
|
|
31
29
|
/* ── Ciclo de vida ── */
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
this._boundDocumentClick = (e) => this._onDocumentClick(e);
|
|
35
|
-
document.addEventListener("click", this._boundDocumentClick, true);
|
|
30
|
+
firstUpdated() {
|
|
31
|
+
this._updateThumb();
|
|
36
32
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
}
|
|
41
|
-
willUpdate(changed) {
|
|
42
|
-
if (changed.has("nodes")) {
|
|
43
|
-
this._initState();
|
|
33
|
+
updated(changed) {
|
|
34
|
+
if (changed.has("value") || changed.has("variant") || changed.has("options")) {
|
|
35
|
+
Promise.resolve().then(() => this._updateThumb());
|
|
44
36
|
}
|
|
45
37
|
}
|
|
46
|
-
/* ──
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
this.
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
_getAllNodes(nodes, acc = []) {
|
|
62
|
-
nodes.forEach((n) => {
|
|
63
|
-
var _a;
|
|
64
|
-
acc.push(n);
|
|
65
|
-
if ((_a = n.children) == null ? void 0 : _a.length) this._getAllNodes(n.children, acc);
|
|
66
|
-
});
|
|
67
|
-
return acc;
|
|
68
|
-
}
|
|
69
|
-
_getLeaves(nodes, acc = []) {
|
|
70
|
-
nodes.forEach((n) => {
|
|
71
|
-
var _a;
|
|
72
|
-
if (!((_a = n.children) == null ? void 0 : _a.length)) acc.push(n);
|
|
73
|
-
else this._getLeaves(n.children, acc);
|
|
74
|
-
});
|
|
75
|
-
return acc;
|
|
76
|
-
}
|
|
77
|
-
_getSelectedLeaves() {
|
|
78
|
-
return this._getLeaves(this.nodes).filter(
|
|
79
|
-
(n) => {
|
|
80
|
-
var _a;
|
|
81
|
-
return ((_a = this._nodeStates.get(n.id)) == null ? void 0 : _a.selected) === true;
|
|
82
|
-
}
|
|
83
|
-
);
|
|
38
|
+
/* ── Thumb engine ── */
|
|
39
|
+
_updateThumb() {
|
|
40
|
+
const idx = this.options.findIndex((o) => o.value === this.value);
|
|
41
|
+
if (idx === -1) return;
|
|
42
|
+
const el = this._optionEls[idx];
|
|
43
|
+
if (!el) return;
|
|
44
|
+
const isUnderline = this.variant === "underline" || this.variant === "dark-underline";
|
|
45
|
+
const w = el.offsetWidth;
|
|
46
|
+
const x = isUnderline ? el.offsetLeft : el.offsetLeft - this._getTrackPadding();
|
|
47
|
+
this._thumbStyle = `width:${w}px;transform:translateX(${x}px)`;
|
|
48
|
+
}
|
|
49
|
+
_getTrackPadding() {
|
|
50
|
+
const track = this.renderRoot.querySelector(".seg");
|
|
51
|
+
if (!track) return 3;
|
|
52
|
+
return parseInt(getComputedStyle(track).paddingLeft, 10) || 3;
|
|
84
53
|
}
|
|
85
54
|
/* ── Selección ── */
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
const
|
|
89
|
-
if (
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
var _a;
|
|
98
|
-
if (!((_a = n.children) == null ? void 0 : _a.length)) return;
|
|
99
|
-
this._recalcAll(n.children);
|
|
100
|
-
const allSel = n.children.every(
|
|
101
|
-
(c) => {
|
|
102
|
-
var _a2, _b;
|
|
103
|
-
return ((_a2 = this._nodeStates.get(c.id)) == null ? void 0 : _a2.selected) === true && !((_b = this._nodeStates.get(c.id)) == null ? void 0 : _b.indeterminate);
|
|
104
|
-
}
|
|
105
|
-
);
|
|
106
|
-
const someSel = n.children.some(
|
|
107
|
-
(c) => {
|
|
108
|
-
var _a2, _b;
|
|
109
|
-
return ((_a2 = this._nodeStates.get(c.id)) == null ? void 0 : _a2.selected) === true || ((_b = this._nodeStates.get(c.id)) == null ? void 0 : _b.indeterminate) === true;
|
|
110
|
-
}
|
|
111
|
-
);
|
|
112
|
-
const st = this._nodeStates.get(n.id);
|
|
113
|
-
if (st) {
|
|
114
|
-
st.selected = allSel;
|
|
115
|
-
st.indeterminate = !allSel && someSel;
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
_handleSelect(node) {
|
|
120
|
-
var _a, _b;
|
|
121
|
-
if (this.disabled) return;
|
|
122
|
-
const hasKids = (((_a = node.children) == null ? void 0 : _a.length) ?? 0) > 0;
|
|
123
|
-
if (!this.multi) {
|
|
124
|
-
if (hasKids) {
|
|
125
|
-
this._handleToggle(node.id);
|
|
126
|
-
return;
|
|
55
|
+
_handleSelect(option, evt) {
|
|
56
|
+
if (this.disabled || option.disabled) return;
|
|
57
|
+
const previousValue = this.value;
|
|
58
|
+
if (option.value === previousValue) return;
|
|
59
|
+
this.value = option.value;
|
|
60
|
+
if (this.glitch) {
|
|
61
|
+
const idx = this.options.findIndex((o) => o.value === this.value);
|
|
62
|
+
const node = this._optionEls[idx];
|
|
63
|
+
if (node) {
|
|
64
|
+
node.classList.add("glitch-on");
|
|
65
|
+
setTimeout(() => node.classList.remove("glitch-on"), 340);
|
|
127
66
|
}
|
|
128
|
-
this._getAllNodes(this.nodes).forEach((n) => {
|
|
129
|
-
const st2 = this._nodeStates.get(n.id);
|
|
130
|
-
if (st2) {
|
|
131
|
-
st2.selected = false;
|
|
132
|
-
st2.indeterminate = false;
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
const st = this._nodeStates.get(node.id);
|
|
136
|
-
if (st) st.selected = true;
|
|
137
|
-
this._nodeStates = new Map(this._nodeStates);
|
|
138
|
-
this.open = false;
|
|
139
|
-
this._emitChange();
|
|
140
|
-
return;
|
|
141
67
|
}
|
|
142
|
-
|
|
143
|
-
this.
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
if (!st) return;
|
|
151
|
-
st.expanded = !st.expanded;
|
|
152
|
-
this._nodeStates = new Map(this._nodeStates);
|
|
153
|
-
}
|
|
154
|
-
_handleClear() {
|
|
155
|
-
this._nodeStates.forEach((st) => {
|
|
156
|
-
st.selected = false;
|
|
157
|
-
st.indeterminate = false;
|
|
158
|
-
});
|
|
159
|
-
this._nodeStates = new Map(this._nodeStates);
|
|
160
|
-
this._emitChange();
|
|
161
|
-
}
|
|
162
|
-
_handleConfirm() {
|
|
163
|
-
this.open = false;
|
|
164
|
-
const sel = this._getSelectedLeaves();
|
|
165
|
-
const detail = { selected: sel, ids: sel.map((n) => n.id) };
|
|
166
|
-
this.dispatchEvent(new CustomEvent("ui-lib-tree-confirm", {
|
|
167
|
-
detail,
|
|
168
|
-
bubbles: true,
|
|
169
|
-
composed: true
|
|
170
|
-
}));
|
|
171
|
-
}
|
|
172
|
-
_handleTagRemove(id) {
|
|
173
|
-
const node = this._getAllNodes(this.nodes).find((n) => n.id === id);
|
|
174
|
-
if (!node) return;
|
|
175
|
-
const st = this._nodeStates.get(id);
|
|
176
|
-
if (st) st.selected = false;
|
|
177
|
-
this._recalcAll(this.nodes);
|
|
178
|
-
this._nodeStates = new Map(this._nodeStates);
|
|
179
|
-
this._emitChange();
|
|
180
|
-
}
|
|
181
|
-
_emitChange() {
|
|
182
|
-
const sel = this._getSelectedLeaves();
|
|
183
|
-
const detail = { selected: sel, ids: sel.map((n) => n.id) };
|
|
184
|
-
this.dispatchEvent(new CustomEvent("ui-lib-tree-change", {
|
|
185
|
-
detail,
|
|
186
|
-
bubbles: true,
|
|
187
|
-
composed: true
|
|
188
|
-
}));
|
|
68
|
+
this._triggerRipple(evt);
|
|
69
|
+
this.dispatchEvent(
|
|
70
|
+
new CustomEvent("ui-lib-change", {
|
|
71
|
+
detail: { value: this.value, previousValue },
|
|
72
|
+
bubbles: true,
|
|
73
|
+
composed: true
|
|
74
|
+
})
|
|
75
|
+
);
|
|
189
76
|
}
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
if (
|
|
193
|
-
|
|
194
|
-
if (
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
}, 60);
|
|
77
|
+
_triggerRipple(evt) {
|
|
78
|
+
const target = evt.currentTarget;
|
|
79
|
+
if (!target) return;
|
|
80
|
+
let wrap = target.querySelector(".seg-ripple");
|
|
81
|
+
if (!wrap) {
|
|
82
|
+
wrap = document.createElement("div");
|
|
83
|
+
wrap.className = "seg-ripple";
|
|
84
|
+
target.appendChild(wrap);
|
|
199
85
|
}
|
|
86
|
+
const dot = document.createElement("div");
|
|
87
|
+
dot.className = "seg-ripple-dot";
|
|
88
|
+
dot.style.left = "50%";
|
|
89
|
+
dot.style.top = "50%";
|
|
90
|
+
dot.style.marginLeft = "-2px";
|
|
91
|
+
dot.style.marginTop = "-2px";
|
|
92
|
+
wrap.appendChild(dot);
|
|
93
|
+
setTimeout(() => dot.remove(), 400);
|
|
200
94
|
}
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
}
|
|
95
|
+
/* ── API pública ── */
|
|
96
|
+
/** Selecciona un valor programáticamente */
|
|
97
|
+
select(value) {
|
|
98
|
+
const opt = this.options.find((o) => o.value === value);
|
|
99
|
+
if (opt && !opt.disabled) {
|
|
100
|
+
const prev = this.value;
|
|
101
|
+
this.value = value;
|
|
102
|
+
this.dispatchEvent(
|
|
103
|
+
new CustomEvent("ui-lib-change", {
|
|
104
|
+
detail: { value, previousValue: prev },
|
|
105
|
+
bubbles: true,
|
|
106
|
+
composed: true
|
|
107
|
+
})
|
|
214
108
|
);
|
|
215
|
-
return (sel == null ? void 0 : sel.label) ?? "";
|
|
216
109
|
}
|
|
217
|
-
const count = this._getSelectionCount();
|
|
218
|
-
if (count === 0) return "";
|
|
219
|
-
if (count === 1) return ((_a = this._getSelectedLeaves()[0]) == null ? void 0 : _a.label) ?? "";
|
|
220
|
-
return `${count} seleccionados`;
|
|
221
|
-
}
|
|
222
|
-
_getSelectionCount() {
|
|
223
|
-
return this._getSelectedLeaves().length;
|
|
224
|
-
}
|
|
225
|
-
_getFooterInfo() {
|
|
226
|
-
const count = this._getSelectionCount();
|
|
227
|
-
if (count === 0) return "0 seleccionados";
|
|
228
|
-
return `${count} seleccionado${count !== 1 ? "s" : ""}`;
|
|
229
|
-
}
|
|
230
|
-
_getTags() {
|
|
231
|
-
return this._getSelectedLeaves().slice(0, 8).map((n) => ({ id: n.id, label: n.label }));
|
|
232
|
-
}
|
|
233
|
-
/* ── API pública ── */
|
|
234
|
-
openPanel() {
|
|
235
|
-
if (!this.inline && !this.disabled) this.open = true;
|
|
236
|
-
}
|
|
237
|
-
closePanel() {
|
|
238
|
-
this.open = false;
|
|
239
|
-
}
|
|
240
|
-
clear() {
|
|
241
|
-
this._handleClear();
|
|
242
|
-
}
|
|
243
|
-
getSelected() {
|
|
244
|
-
return this._getSelectedLeaves();
|
|
245
110
|
}
|
|
246
111
|
/* ── Render ── */
|
|
247
112
|
render() {
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
open: this.open,
|
|
113
|
+
return segmentedTemplate({
|
|
114
|
+
options: this.options,
|
|
115
|
+
value: this.value,
|
|
116
|
+
variant: this.variant,
|
|
117
|
+
size: this.size,
|
|
118
|
+
full: this.full,
|
|
119
|
+
iconOnly: this.iconOnly,
|
|
256
120
|
disabled: this.disabled,
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
triggerLabel,
|
|
261
|
-
isPlaceholder: triggerLabel === "",
|
|
262
|
-
selectionCount: this._getSelectionCount(),
|
|
263
|
-
footerInfo: this._getFooterInfo(),
|
|
264
|
-
tags: this._getTags(),
|
|
265
|
-
onTriggerClick: () => this._toggleOpen(),
|
|
266
|
-
onSearch: (v) => {
|
|
267
|
-
this._search = v;
|
|
268
|
-
},
|
|
269
|
-
onClear: () => this._handleClear(),
|
|
270
|
-
onConfirm: () => this._handleConfirm(),
|
|
271
|
-
onTagRemove: (id) => this._handleTagRemove(id),
|
|
272
|
-
onToggle: (id) => this._handleToggle(id),
|
|
273
|
-
onSelect: (node) => this._handleSelect(node)
|
|
121
|
+
glitch: this.glitch,
|
|
122
|
+
thumbStyle: this._thumbStyle,
|
|
123
|
+
onSelect: (opt, evt) => this._handleSelect(opt, evt)
|
|
274
124
|
});
|
|
275
125
|
}
|
|
276
126
|
};
|
|
277
|
-
|
|
127
|
+
LibSegmentedControl.styles = [
|
|
278
128
|
css`${unsafeCSS(sharedTokens)}`,
|
|
279
|
-
css`${unsafeCSS(
|
|
129
|
+
css`${unsafeCSS(segmentedCss)}`
|
|
280
130
|
];
|
|
281
131
|
__decorateClass([
|
|
282
132
|
property({ type: Array })
|
|
283
|
-
],
|
|
133
|
+
], LibSegmentedControl.prototype, "options", 2);
|
|
284
134
|
__decorateClass([
|
|
285
|
-
property({ type:
|
|
286
|
-
],
|
|
135
|
+
property({ type: String, reflect: true })
|
|
136
|
+
], LibSegmentedControl.prototype, "value", 2);
|
|
287
137
|
__decorateClass([
|
|
288
|
-
property({ type:
|
|
289
|
-
],
|
|
138
|
+
property({ type: String, reflect: true })
|
|
139
|
+
], LibSegmentedControl.prototype, "variant", 2);
|
|
290
140
|
__decorateClass([
|
|
291
|
-
property({ type:
|
|
292
|
-
],
|
|
141
|
+
property({ type: String, reflect: true })
|
|
142
|
+
], LibSegmentedControl.prototype, "size", 2);
|
|
293
143
|
__decorateClass([
|
|
294
144
|
property({ type: Boolean, reflect: true })
|
|
295
|
-
],
|
|
145
|
+
], LibSegmentedControl.prototype, "full", 2);
|
|
296
146
|
__decorateClass([
|
|
297
|
-
property({ type: Boolean, reflect: true })
|
|
298
|
-
],
|
|
147
|
+
property({ type: Boolean, reflect: true, attribute: "icon-only" })
|
|
148
|
+
], LibSegmentedControl.prototype, "iconOnly", 2);
|
|
299
149
|
__decorateClass([
|
|
300
|
-
property({ type:
|
|
301
|
-
],
|
|
150
|
+
property({ type: Boolean, reflect: true })
|
|
151
|
+
], LibSegmentedControl.prototype, "disabled", 2);
|
|
302
152
|
__decorateClass([
|
|
303
|
-
property({ type:
|
|
304
|
-
],
|
|
153
|
+
property({ type: Boolean, reflect: true })
|
|
154
|
+
], LibSegmentedControl.prototype, "glitch", 2);
|
|
305
155
|
__decorateClass([
|
|
306
156
|
state()
|
|
307
|
-
],
|
|
157
|
+
], LibSegmentedControl.prototype, "_thumbStyle", 2);
|
|
308
158
|
__decorateClass([
|
|
309
|
-
|
|
310
|
-
],
|
|
311
|
-
|
|
312
|
-
customElement("lib-
|
|
313
|
-
],
|
|
159
|
+
queryAll(".seg-option")
|
|
160
|
+
], LibSegmentedControl.prototype, "_optionEls", 2);
|
|
161
|
+
LibSegmentedControl = __decorateClass([
|
|
162
|
+
customElement("lib-segmented-control")
|
|
163
|
+
], LibSegmentedControl);
|
|
314
164
|
export {
|
|
315
|
-
|
|
165
|
+
LibSegmentedControl
|
|
316
166
|
};
|
|
317
167
|
//# sourceMappingURL=index63.js.map
|
package/dist/index63.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index63.js","sources":["../src/components/molecules/tree-select/lib-tree-node.component.ts"],"sourcesContent":["import { LitElement, TemplateResult, css, unsafeCSS } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport treeSelectCss from './lib-tree-select.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport type {\n TreeNode,\n TreeNodeState,\n TreeSelectChangeDetail,\n TreeSelectConfirmDetail,\n} from './lib-tree-node.types';\nimport { treeSelectTemplate } from './lib-tree-select.component.html';\n\n/**\n * @element lib-tree-select\n *\n * Selector jerárquico con soporte multi-nivel, propagación bidireccional\n * de selección, búsqueda y variantes dropdown / inline / single / multi.\n *\n * @prop {TreeNode[]} nodes — Árbol de datos\n * @prop {boolean} multi — Selección múltiple (con checkboxes)\n * @prop {boolean} inline — Sin dropdown, árbol directo en layout\n * @prop {boolean} searchable — Mostrar barra de búsqueda\n * @prop {boolean} open — Estado del dropdown (reflected)\n * @prop {boolean} disabled — Deshabilitado (reflected)\n * @prop {string} placeholder — Texto cuando no hay selección\n * @prop {string} empty-text — Texto sin resultados de búsqueda\n *\n * @fires ui-lib-tree-change — Cada vez que cambia la selección\n * Detail: { selected: TreeNode[], ids: string[] }\n * @fires ui-lib-tree-confirm — Al pulsar \"Aplicar\" (solo multi dropdown)\n * Detail: { selected: TreeNode[], ids: string[] }\n */\n@customElement('lib-tree-select')\nexport class LibTreeSelect extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(treeSelectCss)}`,\n ];\n\n /* ── Propiedades públicas ── */\n @property({ type: Array }) nodes: TreeNode[] = [];\n @property({ type: Boolean, reflect: true }) multi = false;\n @property({ type: Boolean, reflect: true }) inline = false;\n @property({ type: Boolean, reflect: true }) searchable = true;\n @property({ type: Boolean, reflect: true }) open = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: String }) placeholder = 'Seleccionar…';\n @property({ type: String, attribute: 'empty-text' }) emptyText = 'Sin resultados';\n\n /* ── Estado interno ── */\n @state() private _nodeStates: Map<string, TreeNodeState> = new Map();\n @state() private _search = '';\n\n private _parentMap: Map<string, string | null> = new Map();\n private _boundDocumentClick!: (e: Event) => void;\n\n /* ── Ciclo de vida ── */\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._boundDocumentClick = (e: Event): void => this._onDocumentClick(e);\n document.addEventListener('click', this._boundDocumentClick, true);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n document.removeEventListener('click', this._boundDocumentClick, true);\n }\n\n protected override willUpdate(changed: Map<PropertyKey, unknown>): void {\n if (changed.has('nodes')) {\n this._initState();\n }\n }\n\n /* ── Inicialización ── */\n\n private _initState(): void {\n this._nodeStates = new Map();\n this._parentMap = new Map();\n this._walkNodes(this.nodes, null);\n }\n\n private _walkNodes(nodes: TreeNode[], parentId: string | null): void {\n nodes.forEach(node => {\n this._nodeStates.set(node.id, { selected: false, indeterminate: false, expanded: false });\n this._parentMap.set(node.id, parentId);\n if (node.children?.length) this._walkNodes(node.children, node.id);\n });\n }\n\n /* ── Traversal ── */\n\n private _getAllNodes(nodes: TreeNode[], acc: TreeNode[] = []): TreeNode[] {\n nodes.forEach(n => {\n acc.push(n);\n if (n.children?.length) this._getAllNodes(n.children, acc);\n });\n return acc;\n }\n\n private _getLeaves(nodes: TreeNode[], acc: TreeNode[] = []): TreeNode[] {\n nodes.forEach(n => {\n if (!n.children?.length) acc.push(n);\n else this._getLeaves(n.children, acc);\n });\n return acc;\n }\n\n private _getSelectedLeaves(): TreeNode[] {\n return this._getLeaves(this.nodes).filter(\n n => this._nodeStates.get(n.id)?.selected === true\n );\n }\n\n /* ── Selección ── */\n\n private _selectDown(node: TreeNode, selected: boolean): void {\n const st = this._nodeStates.get(node.id);\n if (st) { st.selected = selected; st.indeterminate = false; }\n node.children?.forEach(c => this._selectDown(c, selected));\n }\n\n private _recalcAll(nodes: TreeNode[]): void {\n nodes.forEach(n => {\n if (!n.children?.length) return;\n this._recalcAll(n.children);\n const allSel = n.children.every(c =>\n this._nodeStates.get(c.id)?.selected === true &&\n !this._nodeStates.get(c.id)?.indeterminate\n );\n const someSel = n.children.some(c =>\n this._nodeStates.get(c.id)?.selected === true ||\n this._nodeStates.get(c.id)?.indeterminate === true\n );\n const st = this._nodeStates.get(n.id);\n if (st) { st.selected = allSel; st.indeterminate = !allSel && someSel; }\n });\n }\n\n private _handleSelect(node: TreeNode): void {\n if (this.disabled) return;\n const hasKids = (node.children?.length ?? 0) > 0;\n\n if (!this.multi) {\n // Single — los nodos padre solo expanden/colapsan, NUNCA seleccionan\n if (hasKids) {\n this._handleToggle(node.id);\n return;\n }\n // Hoja → limpiar todo, seleccionar, cerrar dropdown\n this._getAllNodes(this.nodes).forEach(n => {\n const st = this._nodeStates.get(n.id);\n if (st) { st.selected = false; st.indeterminate = false; }\n });\n const st = this._nodeStates.get(node.id);\n if (st) st.selected = true;\n this._nodeStates = new Map(this._nodeStates);\n this.open = false;\n this._emitChange();\n return;\n }\n\n // Multi — toggle + propagación bidireccional (padres e hijos seleccionables)\n const newSelected = !this._nodeStates.get(node.id)?.selected;\n this._selectDown(node, newSelected);\n this._recalcAll(this.nodes);\n this._nodeStates = new Map(this._nodeStates);\n this._emitChange();\n }\n\n private _handleToggle(id: string): void {\n const st = this._nodeStates.get(id);\n if (!st) return;\n st.expanded = !st.expanded;\n this._nodeStates = new Map(this._nodeStates);\n }\n\n private _handleClear(): void {\n this._nodeStates.forEach(st => { st.selected = false; st.indeterminate = false; });\n this._nodeStates = new Map(this._nodeStates);\n this._emitChange();\n }\n\n private _handleConfirm(): void {\n this.open = false;\n const sel = this._getSelectedLeaves();\n const detail: TreeSelectConfirmDetail = { selected: sel, ids: sel.map(n => n.id) };\n this.dispatchEvent(new CustomEvent<TreeSelectConfirmDetail>('ui-lib-tree-confirm', {\n detail, bubbles: true, composed: true,\n }));\n }\n\n private _handleTagRemove(id: string): void {\n const node = this._getAllNodes(this.nodes).find(n => n.id === id);\n if (!node) return;\n const st = this._nodeStates.get(id);\n if (st) st.selected = false;\n this._recalcAll(this.nodes);\n this._nodeStates = new Map(this._nodeStates);\n this._emitChange();\n }\n\n private _emitChange(): void {\n const sel = this._getSelectedLeaves();\n const detail: TreeSelectChangeDetail = { selected: sel, ids: sel.map(n => n.id) };\n this.dispatchEvent(new CustomEvent<TreeSelectChangeDetail>('ui-lib-tree-change', {\n detail, bubbles: true, composed: true,\n }));\n }\n\n /* ── Dropdown ── */\n\n private _toggleOpen(): void {\n if (this.disabled) return;\n this.open = !this.open;\n if (this.open) {\n setTimeout((): void => {\n (this.renderRoot.querySelector('.ts-search') as HTMLInputElement | null)?.focus();\n }, 60);\n }\n }\n\n private _onDocumentClick(e: Event): void {\n if (this.inline || !this.open) return;\n if (!e.composedPath().includes(this)) this.open = false;\n }\n\n /* ── Valores derivados ── */\n\n private _getTriggerLabel(): string {\n if (!this.multi) {\n const sel = this._getLeaves(this.nodes).find(\n n => this._nodeStates.get(n.id)?.selected === true\n );\n return sel?.label ?? '';\n }\n const count = this._getSelectionCount();\n if (count === 0) return '';\n if (count === 1) return this._getSelectedLeaves()[0]?.label ?? '';\n return `${count} seleccionados`;\n }\n\n private _getSelectionCount(): number {\n return this._getSelectedLeaves().length;\n }\n\n private _getFooterInfo(): string {\n const count = this._getSelectionCount();\n if (count === 0) return '0 seleccionados';\n return `${count} seleccionado${count !== 1 ? 's' : ''}`;\n }\n\n private _getTags(): Array<{ id: string; label: string }> {\n return this._getSelectedLeaves().slice(0, 8).map(n => ({ id: n.id, label: n.label }));\n }\n\n /* ── API pública ── */\n\n public openPanel(): void { if (!this.inline && !this.disabled) this.open = true; }\n public closePanel(): void { this.open = false; }\n public clear(): void { this._handleClear(); }\n public getSelected(): TreeNode[] { return this._getSelectedLeaves(); }\n\n /* ── Render ── */\n\n protected override render(): TemplateResult {\n const triggerLabel = this._getTriggerLabel();\n return treeSelectTemplate({\n nodes: this.nodes,\n nodeStates: this._nodeStates,\n multi: this.multi,\n inline: this.inline,\n searchable: this.searchable,\n open: this.open,\n disabled: this.disabled,\n placeholder: this.placeholder,\n emptyText: this.emptyText,\n searchValue: this._search,\n triggerLabel,\n isPlaceholder: triggerLabel === '',\n selectionCount: this._getSelectionCount(),\n footerInfo: this._getFooterInfo(),\n tags: this._getTags(),\n onTriggerClick: (): void => this._toggleOpen(),\n onSearch: (v: string): void => { this._search = v; },\n onClear: (): void => this._handleClear(),\n onConfirm: (): void => this._handleConfirm(),\n onTagRemove: (id: string): void => this._handleTagRemove(id),\n onToggle: (id: string): void => this._handleToggle(id),\n onSelect: (node: TreeNode): void => this._handleSelect(node),\n });\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-tree-select': LibTreeSelect;\n }\n}"],"names":["_a","st"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index63.js","sources":["../src/components/molecules/segmented-control/lib-segmented-control.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, state, queryAll } from 'lit/decorators.js';\nimport segmentedCss from './lib-segmented-control.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport { segmentedTemplate } from './lib-segmented-control.html';\nimport type {\n SegmentedOption,\n SegmentedVariant,\n SegmentedSize,\n SegmentedChangeDetail,\n} from './lib-segmented-control.types';\n\n/**\n * @element lib-segmented-control\n *\n * Control de selección exclusiva entre N opciones.\n * El thumb se desplaza con `transform: translateX` calculado sobre\n * el `offsetLeft` / `offsetWidth` del option activo.\n *\n * @prop {SegmentedOption[]} options — Array de opciones\n * @prop {string} value — Valor activo (reflected)\n * @prop {SegmentedVariant} variant — Superficie visual (reflected)\n * @prop {SegmentedSize} size — Tamaño (reflected)\n * @prop {boolean} full — Ocupa el 100% del ancho (reflected)\n * @prop {boolean} icon-only — Solo iconos, sin texto (reflected)\n * @prop {boolean} disabled — Deshabilitado (reflected)\n * @prop {boolean} glitch — Efecto de corrupción al cambiar (reflected)\n *\n * @fires ui-lib-change — Al cambiar la selección\n * Detail: { value: string, previousValue: string }\n *\n * @slot — No usa slots; las opciones se pasan vía `.options`\n */\n@customElement('lib-segmented-control')\nexport class LibSegmentedControl extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(segmentedCss)}`,\n ];\n\n /* ── Props públicas ── */\n\n @property({ type: Array })\n options: SegmentedOption[] = [];\n\n @property({ type: String, reflect: true })\n value = '';\n\n @property({ type: String, reflect: true })\n variant: SegmentedVariant = 'outline';\n\n @property({ type: String, reflect: true })\n size: SegmentedSize = 'md';\n\n @property({ type: Boolean, reflect: true })\n full = false;\n\n @property({ type: Boolean, reflect: true, attribute: 'icon-only' })\n iconOnly = false;\n\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n @property({ type: Boolean, reflect: true })\n glitch = false;\n\n /* ── Estado interno ── */\n\n @state() private _thumbStyle = '';\n\n /** Referencia a los nodos .seg-option en el Shadow DOM */\n @queryAll('.seg-option')\n private declare _optionEls: NodeListOf<HTMLElement>;\n\n /* ── Ciclo de vida ── */\n\n protected override firstUpdated(): void {\n this._updateThumb();\n }\n\n protected override updated(changed: Map<PropertyKey, unknown>): void {\n if (changed.has('value') || changed.has('variant') || changed.has('options')) {\n // next microtask — el DOM ya refleja el nuevo estado\n Promise.resolve().then((): void => this._updateThumb());\n }\n }\n\n /* ── Thumb engine ── */\n\n private _updateThumb(): void {\n const idx = this.options.findIndex(o => o.value === this.value);\n if (idx === -1) return;\n\n // Acceso seguro con ! — el índice está dentro de los límites de options\n const el = this._optionEls[idx];\n if (!el) return;\n\n const isUnderline =\n this.variant === 'underline' || this.variant === 'dark-underline';\n\n const w = el.offsetWidth;\n // Para underline el offset no necesita corrección de padding del track\n const x = isUnderline\n ? el.offsetLeft\n : el.offsetLeft - this._getTrackPadding();\n\n this._thumbStyle = `width:${w}px;transform:translateX(${x}px)`;\n }\n\n private _getTrackPadding(): number {\n const track = this.renderRoot.querySelector<HTMLElement>('.seg');\n if (!track) return 3;\n return parseInt(getComputedStyle(track).paddingLeft, 10) || 3;\n }\n\n /* ── Selección ── */\n\n private _handleSelect(option: SegmentedOption, evt: MouseEvent): void {\n if (this.disabled || option.disabled) return;\n const previousValue = this.value;\n if (option.value === previousValue) return;\n\n this.value = option.value;\n\n // Glitch flash\n if (this.glitch) {\n const idx = this.options.findIndex(o => o.value === this.value);\n const node = this._optionEls[idx];\n if (node) {\n node.classList.add('glitch-on');\n setTimeout((): void => node.classList.remove('glitch-on'), 340);\n }\n }\n\n // Ripple\n this._triggerRipple(evt);\n\n this.dispatchEvent(\n new CustomEvent<SegmentedChangeDetail>('ui-lib-change', {\n detail: { value: this.value, previousValue },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _triggerRipple(evt: MouseEvent): void {\n const target = evt.currentTarget as HTMLElement | null;\n if (!target) return;\n\n let wrap = target.querySelector<HTMLElement>('.seg-ripple');\n if (!wrap) {\n wrap = document.createElement('div');\n wrap.className = 'seg-ripple';\n target.appendChild(wrap);\n }\n\n const dot = document.createElement('div');\n dot.className = 'seg-ripple-dot';\n dot.style.left = '50%';\n dot.style.top = '50%';\n dot.style.marginLeft = '-2px';\n dot.style.marginTop = '-2px';\n wrap.appendChild(dot);\n setTimeout((): void => dot.remove(), 400);\n }\n\n /* ── API pública ── */\n\n /** Selecciona un valor programáticamente */\n public select(value: string): void {\n const opt = this.options.find(o => o.value === value);\n if (opt && !opt.disabled) {\n const prev = this.value;\n this.value = value;\n this.dispatchEvent(\n new CustomEvent<SegmentedChangeDetail>('ui-lib-change', {\n detail: { value, previousValue: prev },\n bubbles: true,\n composed: true,\n })\n );\n }\n }\n\n /* ── Render ── */\n\n protected override render(): TemplateResult {\n return segmentedTemplate({\n options: this.options,\n value: this.value,\n variant: this.variant,\n size: this.size,\n full: this.full,\n iconOnly: this.iconOnly,\n disabled: this.disabled,\n glitch: this.glitch,\n thumbStyle: this._thumbStyle,\n onSelect: (opt, evt): void => this._handleSelect(opt, evt),\n });\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-segmented-control': LibSegmentedControl;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AAkCO,IAAM,sBAAN,cAAkC,WAAW;AAAA,EAA7C,cAAA;AAAA,UAAA,GAAA,SAAA;AASL,SAAA,UAA6B,CAAA;AAG7B,SAAA,QAAQ;AAGR,SAAA,UAA4B;AAG5B,SAAA,OAAsB;AAGtB,SAAA,OAAO;AAGP,SAAA,WAAW;AAGX,SAAA,WAAW;AAGX,SAAA,SAAS;AAIA,SAAQ,cAAc;AAAA,EAAA;AAAA;AAAA,EAQZ,eAAqB;AACtC,SAAK,aAAA;AAAA,EACP;AAAA,EAEmB,QAAQ,SAA0C;AACnE,QAAI,QAAQ,IAAI,OAAO,KAAK,QAAQ,IAAI,SAAS,KAAK,QAAQ,IAAI,SAAS,GAAG;AAE5E,cAAQ,UAAU,KAAK,MAAY,KAAK,cAAc;AAAA,IACxD;AAAA,EACF;AAAA;AAAA,EAIQ,eAAqB;AAC3B,UAAM,MAAM,KAAK,QAAQ,UAAU,OAAK,EAAE,UAAU,KAAK,KAAK;AAC9D,QAAI,QAAQ,GAAI;AAGhB,UAAM,KAAK,KAAK,WAAW,GAAG;AAC9B,QAAI,CAAC,GAAI;AAET,UAAM,cACJ,KAAK,YAAY,eAAe,KAAK,YAAY;AAEnD,UAAM,IAAI,GAAG;AAEb,UAAM,IAAI,cACN,GAAG,aACH,GAAG,aAAa,KAAK,iBAAA;AAEzB,SAAK,cAAc,SAAS,CAAC,2BAA2B,CAAC;AAAA,EAC3D;AAAA,EAEQ,mBAA2B;AACjC,UAAM,QAAQ,KAAK,WAAW,cAA2B,MAAM;AAC/D,QAAI,CAAC,MAAO,QAAO;AACnB,WAAO,SAAS,iBAAiB,KAAK,EAAE,aAAa,EAAE,KAAK;AAAA,EAC9D;AAAA;AAAA,EAIQ,cAAc,QAAyB,KAAuB;AACpE,QAAI,KAAK,YAAY,OAAO,SAAU;AACtC,UAAM,gBAAgB,KAAK;AAC3B,QAAI,OAAO,UAAU,cAAe;AAEpC,SAAK,QAAQ,OAAO;AAGpB,QAAI,KAAK,QAAQ;AACf,YAAM,MAAO,KAAK,QAAQ,UAAU,OAAK,EAAE,UAAU,KAAK,KAAK;AAC/D,YAAM,OAAO,KAAK,WAAW,GAAG;AAChC,UAAI,MAAM;AACR,aAAK,UAAU,IAAI,WAAW;AAC9B,mBAAW,MAAY,KAAK,UAAU,OAAO,WAAW,GAAG,GAAG;AAAA,MAChE;AAAA,IACF;AAGA,SAAK,eAAe,GAAG;AAEvB,SAAK;AAAA,MACH,IAAI,YAAmC,iBAAiB;AAAA,QACtD,QAAQ,EAAE,OAAO,KAAK,OAAO,cAAA;AAAA,QAC7B,SAAS;AAAA,QACT,UAAU;AAAA,MAAA,CACX;AAAA,IAAA;AAAA,EAEL;AAAA,EAEQ,eAAe,KAAuB;AAC5C,UAAM,SAAS,IAAI;AACnB,QAAI,CAAC,OAAQ;AAEb,QAAI,OAAO,OAAO,cAA2B,aAAa;AAC1D,QAAI,CAAC,MAAM;AACT,aAAO,SAAS,cAAc,KAAK;AACnC,WAAK,YAAY;AACjB,aAAO,YAAY,IAAI;AAAA,IACzB;AAEA,UAAM,MAAM,SAAS,cAAc,KAAK;AACxC,QAAI,YAAY;AAChB,QAAI,MAAM,OAAY;AACtB,QAAI,MAAM,MAAY;AACtB,QAAI,MAAM,aAAa;AACvB,QAAI,MAAM,YAAa;AACvB,SAAK,YAAY,GAAG;AACpB,eAAW,MAAY,IAAI,OAAA,GAAU,GAAG;AAAA,EAC1C;AAAA;AAAA;AAAA,EAKO,OAAO,OAAqB;AACjC,UAAM,MAAM,KAAK,QAAQ,KAAK,CAAA,MAAK,EAAE,UAAU,KAAK;AACpD,QAAI,OAAO,CAAC,IAAI,UAAU;AACxB,YAAM,OAAO,KAAK;AAClB,WAAK,QAAQ;AACb,WAAK;AAAA,QACH,IAAI,YAAmC,iBAAiB;AAAA,UACtD,QAAQ,EAAE,OAAO,eAAe,KAAA;AAAA,UAChC,SAAS;AAAA,UACT,UAAU;AAAA,QAAA,CACX;AAAA,MAAA;AAAA,IAEL;AAAA,EACF;AAAA;AAAA,EAImB,SAAyB;AAC1C,WAAO,kBAAkB;AAAA,MACvB,SAAY,KAAK;AAAA,MACjB,OAAY,KAAK;AAAA,MACjB,SAAY,KAAK;AAAA,MACjB,MAAY,KAAK;AAAA,MACjB,MAAY,KAAK;AAAA,MACjB,UAAY,KAAK;AAAA,MACjB,UAAY,KAAK;AAAA,MACjB,QAAY,KAAK;AAAA,MACjB,YAAY,KAAK;AAAA,MACjB,UAAY,CAAC,KAAK,QAAc,KAAK,cAAc,KAAK,GAAG;AAAA,IAAA,CAC5D;AAAA,EACH;AACF;AAvKa,oBACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,YAAY,CAAC;AAC/B;AAKA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,MAAA,CAAO;AAAA,GARd,oBASX,WAAA,WAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAX9B,oBAYX,WAAA,SAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAd9B,oBAeX,WAAA,WAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAjB9B,oBAkBX,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GApB/B,oBAqBX,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM,WAAW,aAAa;AAAA,GAvBvD,oBAwBX,WAAA,YAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GA1B/B,oBA2BX,WAAA,YAAA,CAAA;AAGA,gBAAA;AAAA,EADC,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GA7B/B,oBA8BX,WAAA,UAAA,CAAA;AAIiB,gBAAA;AAAA,EAAhB,MAAA;AAAM,GAlCI,oBAkCM,WAAA,eAAA,CAAA;AAID,gBAAA;AAAA,EADf,SAAS,aAAa;AAAA,GArCZ,oBAsCK,WAAA,cAAA,CAAA;AAtCL,sBAAN,gBAAA;AAAA,EADN,cAAc,uBAAuB;AAAA,GACzB,mBAAA;"}
|