asterui 0.11.0 → 0.12.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/README.md +1 -103
- package/dist/components/Anchor.d.ts +45 -0
- package/dist/components/Diff.d.ts +12 -0
- package/dist/components/Form.d.ts +27 -2
- package/dist/components/Kbd.d.ts +8 -0
- package/dist/components/Radio.d.ts +7 -1
- package/dist/components/Status.d.ts +18 -0
- package/dist/components/TextRotate.d.ts +13 -0
- package/dist/index.d.ts +12 -2
- package/dist/index.js +210 -200
- package/dist/index.js.map +1 -1
- package/dist/index10.js +92 -30
- package/dist/index10.js.map +1 -1
- package/dist/index100.js +8 -5
- package/dist/index100.js.map +1 -1
- package/dist/index101.js +12 -41
- package/dist/index101.js.map +1 -1
- package/dist/index102.js +31 -2
- package/dist/index102.js.map +1 -1
- package/dist/index103.js +17 -6
- package/dist/index103.js.map +1 -1
- package/dist/index104.js +10788 -147
- package/dist/index104.js.map +1 -1
- package/dist/index105.js +5 -30
- package/dist/index105.js.map +1 -1
- package/dist/index106.js +39 -27
- package/dist/index106.js.map +1 -1
- package/dist/index108.js +6 -71
- package/dist/index108.js.map +1 -1
- package/dist/index109.js +147 -34
- package/dist/index109.js.map +1 -1
- package/dist/index11.js +28 -263
- package/dist/index11.js.map +1 -1
- package/dist/index110.js +28 -24
- package/dist/index110.js.map +1 -1
- package/dist/index111.js +28 -19
- package/dist/index111.js.map +1 -1
- package/dist/index112.js +2 -24
- package/dist/index112.js.map +1 -1
- package/dist/index113.js +71 -19
- package/dist/index113.js.map +1 -1
- package/dist/index114.js +33 -94
- package/dist/index114.js.map +1 -1
- package/dist/index115.js +24 -358
- package/dist/index115.js.map +1 -1
- package/dist/index116.js +19 -23
- package/dist/index116.js.map +1 -1
- package/dist/index117.js +22 -71
- package/dist/index117.js.map +1 -1
- package/dist/index118.js +17 -13
- package/dist/index118.js.map +1 -1
- package/dist/index119.js +91 -57
- package/dist/index119.js.map +1 -1
- package/dist/index12.js +259 -89
- package/dist/index12.js.map +1 -1
- package/dist/index120.js +357 -141
- package/dist/index120.js.map +1 -1
- package/dist/index121.js +25 -2
- package/dist/index121.js.map +1 -1
- package/dist/index122.js +70 -53
- package/dist/index122.js.map +1 -1
- package/dist/index123.js +16 -2
- package/dist/index123.js.map +1 -1
- package/dist/index124.js +66 -2
- package/dist/index124.js.map +1 -1
- package/dist/index125.js +144 -2
- package/dist/index125.js.map +1 -1
- package/dist/index126.js +2 -2
- package/dist/index127.js +56 -2
- package/dist/index127.js.map +1 -1
- package/dist/index13.js +90 -153
- package/dist/index13.js.map +1 -1
- package/dist/index130.js +2 -32
- package/dist/index130.js.map +1 -1
- package/dist/index132.js +2 -8
- package/dist/index132.js.map +1 -1
- package/dist/index133.js +2 -2
- package/dist/index134.js +2 -2
- package/dist/index135.js +2 -21
- package/dist/index135.js.map +1 -1
- package/dist/index136.js +32 -2
- package/dist/index136.js.map +1 -1
- package/dist/index137.js +2 -24
- package/dist/index137.js.map +1 -1
- package/dist/index138.js +7 -70
- package/dist/index138.js.map +1 -1
- package/dist/index139.js +2 -21
- package/dist/index139.js.map +1 -1
- package/dist/index14.js +154 -146
- package/dist/index14.js.map +1 -1
- package/dist/index140.js +2 -34
- package/dist/index140.js.map +1 -1
- package/dist/index141.js +20 -69
- package/dist/index141.js.map +1 -1
- package/dist/index142.js +2 -2
- package/dist/index143.js +24 -2
- package/dist/index143.js.map +1 -1
- package/dist/index144.js +70 -21
- package/dist/index144.js.map +1 -1
- package/dist/index145.js +21 -2
- package/dist/index145.js.map +1 -1
- package/dist/index146.js +34 -2
- package/dist/index146.js.map +1 -1
- package/dist/index147.js +70 -2
- package/dist/index147.js.map +1 -1
- package/dist/index148.js +2 -2
- package/dist/index149.js +21 -3
- package/dist/index149.js.map +1 -1
- package/dist/index15.js +150 -5
- package/dist/index15.js.map +1 -1
- package/dist/index150.js +5 -0
- package/dist/index150.js.map +1 -0
- package/dist/index151.js +5 -0
- package/dist/index151.js.map +1 -0
- package/dist/index152.js +5 -0
- package/dist/index152.js.map +1 -0
- package/dist/index153.js +5 -0
- package/dist/index153.js.map +1 -0
- package/dist/index154.js +7 -0
- package/dist/index154.js.map +1 -0
- package/dist/index16.js +5 -71
- package/dist/index16.js.map +1 -1
- package/dist/index17.js +71 -17
- package/dist/index17.js.map +1 -1
- package/dist/index18.js +15 -96
- package/dist/index18.js.map +1 -1
- package/dist/index19.js +89 -105
- package/dist/index19.js.map +1 -1
- package/dist/index20.js +107 -177
- package/dist/index20.js.map +1 -1
- package/dist/index21.js +181 -107
- package/dist/index21.js.map +1 -1
- package/dist/index22.js +107 -29
- package/dist/index22.js.map +1 -1
- package/dist/index23.js +19 -41
- package/dist/index23.js.map +1 -1
- package/dist/index24.js +31 -11
- package/dist/index24.js.map +1 -1
- package/dist/index25.js +41 -33
- package/dist/index25.js.map +1 -1
- package/dist/index26.js +12 -63
- package/dist/index26.js.map +1 -1
- package/dist/index27.js +33 -80
- package/dist/index27.js.map +1 -1
- package/dist/index28.js +63 -18
- package/dist/index28.js.map +1 -1
- package/dist/index29.js +78 -159
- package/dist/index29.js.map +1 -1
- package/dist/index3.js +96 -27
- package/dist/index3.js.map +1 -1
- package/dist/index30.js +16 -1080
- package/dist/index30.js.map +1 -1
- package/dist/index31.js +218 -16
- package/dist/index31.js.map +1 -1
- package/dist/index32.js +1081 -121
- package/dist/index32.js.map +1 -1
- package/dist/index33.js +17 -39
- package/dist/index33.js.map +1 -1
- package/dist/index34.js +121 -190
- package/dist/index34.js.map +1 -1
- package/dist/index35.js +37 -94
- package/dist/index35.js.map +1 -1
- package/dist/index36.js +186 -157
- package/dist/index36.js.map +1 -1
- package/dist/index37.js +89 -138
- package/dist/index37.js.map +1 -1
- package/dist/index38.js +161 -14
- package/dist/index38.js.map +1 -1
- package/dist/index39.js +146 -21
- package/dist/index39.js.map +1 -1
- package/dist/index4.js +26 -99
- package/dist/index4.js.map +1 -1
- package/dist/index40.js +12 -116
- package/dist/index40.js.map +1 -1
- package/dist/index41.js +18 -13
- package/dist/index41.js.map +1 -1
- package/dist/index42.js +21 -35
- package/dist/index42.js.map +1 -1
- package/dist/index43.js +117 -114
- package/dist/index43.js.map +1 -1
- package/dist/index44.js +13 -176
- package/dist/index44.js.map +1 -1
- package/dist/index45.js +34 -146
- package/dist/index45.js.map +1 -1
- package/dist/index46.js +116 -12
- package/dist/index46.js.map +1 -1
- package/dist/index47.js +176 -22
- package/dist/index47.js.map +1 -1
- package/dist/index48.js +147 -14
- package/dist/index48.js.map +1 -1
- package/dist/index49.js +10 -5
- package/dist/index49.js.map +1 -1
- package/dist/index5.js +100 -60
- package/dist/index5.js.map +1 -1
- package/dist/index50.js +21 -265
- package/dist/index50.js.map +1 -1
- package/dist/index51.js +10 -13
- package/dist/index51.js.map +1 -1
- package/dist/index52.js +7 -122
- package/dist/index52.js.map +1 -1
- package/dist/index53.js +262 -106
- package/dist/index53.js.map +1 -1
- package/dist/index54.js +14 -167
- package/dist/index54.js.map +1 -1
- package/dist/index55.js +121 -31
- package/dist/index55.js.map +1 -1
- package/dist/index56.js +107 -119
- package/dist/index56.js.map +1 -1
- package/dist/index57.js +161 -77
- package/dist/index57.js.map +1 -1
- package/dist/index58.js +31 -19
- package/dist/index58.js.map +1 -1
- package/dist/index59.js +117 -69
- package/dist/index59.js.map +1 -1
- package/dist/index6.js +61 -130
- package/dist/index6.js.map +1 -1
- package/dist/index60.js +82 -53
- package/dist/index60.js.map +1 -1
- package/dist/index61.js +19 -44
- package/dist/index61.js.map +1 -1
- package/dist/index62.js +70 -48
- package/dist/index62.js.map +1 -1
- package/dist/index63.js +55 -60
- package/dist/index63.js.map +1 -1
- package/dist/index64.js +39 -101
- package/dist/index64.js.map +1 -1
- package/dist/index65.js +52 -41
- package/dist/index65.js.map +1 -1
- package/dist/index66.js +58 -64
- package/dist/index66.js.map +1 -1
- package/dist/index67.js +105 -19
- package/dist/index67.js.map +1 -1
- package/dist/index68.js +41 -46
- package/dist/index68.js.map +1 -1
- package/dist/index69.js +63 -129
- package/dist/index69.js.map +1 -1
- package/dist/index7.js +130 -11
- package/dist/index7.js.map +1 -1
- package/dist/index70.js +19 -50
- package/dist/index70.js.map +1 -1
- package/dist/index71.js +46 -22
- package/dist/index71.js.map +1 -1
- package/dist/index72.js +134 -22
- package/dist/index72.js.map +1 -1
- package/dist/index73.js +51 -328
- package/dist/index73.js.map +1 -1
- package/dist/index74.js +19 -53
- package/dist/index74.js.map +1 -1
- package/dist/index75.js +31 -40
- package/dist/index75.js.map +1 -1
- package/dist/index76.js +22 -95
- package/dist/index76.js.map +1 -1
- package/dist/index77.js +311 -112
- package/dist/index77.js.map +1 -1
- package/dist/index78.js +52 -157
- package/dist/index78.js.map +1 -1
- package/dist/index79.js +40 -65
- package/dist/index79.js.map +1 -1
- package/dist/index8.js +11 -70
- package/dist/index8.js.map +1 -1
- package/dist/index80.js +23 -35
- package/dist/index80.js.map +1 -1
- package/dist/index81.js +88 -227
- package/dist/index81.js.map +1 -1
- package/dist/index82.js +130 -34
- package/dist/index82.js.map +1 -1
- package/dist/index83.js +153 -202
- package/dist/index83.js.map +1 -1
- package/dist/index84.js +61 -209
- package/dist/index84.js.map +1 -1
- package/dist/index85.js +34 -294
- package/dist/index85.js.map +1 -1
- package/dist/index86.js +228 -172
- package/dist/index86.js.map +1 -1
- package/dist/index87.js +32 -256
- package/dist/index87.js.map +1 -1
- package/dist/index88.js +208 -12
- package/dist/index88.js.map +1 -1
- package/dist/index89.js +209 -29
- package/dist/index89.js.map +1 -1
- package/dist/index9.js +69 -91
- package/dist/index9.js.map +1 -1
- package/dist/index90.js +294 -5
- package/dist/index90.js.map +1 -1
- package/dist/index91.js +176 -12
- package/dist/index91.js.map +1 -1
- package/dist/index92.js +256 -44
- package/dist/index92.js.map +1 -1
- package/dist/index93.js +13 -12
- package/dist/index93.js.map +1 -1
- package/dist/index94.js +32 -14
- package/dist/index94.js.map +1 -1
- package/dist/index95.js +5 -7
- package/dist/index95.js.map +1 -1
- package/dist/index96.js +13 -12
- package/dist/index96.js.map +1 -1
- package/dist/index97.js +42 -27
- package/dist/index97.js.map +1 -1
- package/dist/index98.js +11 -16
- package/dist/index98.js.map +1 -1
- package/dist/index99.js +12 -10790
- package/dist/index99.js.map +1 -1
- package/package.json +1 -1
package/dist/index35.js
CHANGED
|
@@ -1,100 +1,43 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
9
|
-
className: "mx-auto",
|
|
10
|
-
children: /* @__PURE__ */ e("g", { fill: "none", fillRule: "evenodd", children: [
|
|
11
|
-
/* @__PURE__ */ e("g", { transform: "translate(24 31.67)", children: [
|
|
12
|
-
/* @__PURE__ */ a(
|
|
13
|
-
"ellipse",
|
|
14
|
-
{
|
|
15
|
-
className: "fill-base-300",
|
|
16
|
-
cx: "67.797",
|
|
17
|
-
cy: "106.89",
|
|
18
|
-
rx: "67.797",
|
|
19
|
-
ry: "12.668"
|
|
20
|
-
}
|
|
21
|
-
),
|
|
22
|
-
/* @__PURE__ */ a(
|
|
23
|
-
"path",
|
|
24
|
-
{
|
|
25
|
-
className: "fill-base-200",
|
|
26
|
-
d: "M122.034 69.674L98.109 40.229c-1.148-1.386-2.826-2.225-4.593-2.225h-51.44c-1.766 0-3.444.839-4.592 2.225L13.56 69.674v15.383h108.475V69.674z"
|
|
27
|
-
}
|
|
28
|
-
),
|
|
29
|
-
/* @__PURE__ */ a(
|
|
30
|
-
"path",
|
|
31
|
-
{
|
|
32
|
-
className: "fill-base-100",
|
|
33
|
-
d: "M101.537 86.214L80.63 61.102c-1.001-1.207-2.507-1.867-4.048-1.867H31.724c-1.54 0-3.047.66-4.048 1.867L6.769 86.214v13.792h94.768V86.214z",
|
|
34
|
-
transform: "translate(13.56)"
|
|
35
|
-
}
|
|
36
|
-
),
|
|
37
|
-
/* @__PURE__ */ a(
|
|
38
|
-
"ellipse",
|
|
39
|
-
{
|
|
40
|
-
className: "fill-base-300",
|
|
41
|
-
cx: "67.797",
|
|
42
|
-
cy: "106.89",
|
|
43
|
-
rx: "67.797",
|
|
44
|
-
ry: "12.668"
|
|
45
|
-
}
|
|
46
|
-
),
|
|
47
|
-
/* @__PURE__ */ a(
|
|
48
|
-
"path",
|
|
49
|
-
{
|
|
50
|
-
className: "fill-base-200",
|
|
51
|
-
d: "M122.034 69.674L98.109 40.229c-1.148-1.386-2.826-2.225-4.593-2.225h-51.44c-1.766 0-3.444.839-4.592 2.225L13.56 69.674v15.383h108.475V69.674z"
|
|
52
|
-
}
|
|
53
|
-
),
|
|
54
|
-
/* @__PURE__ */ a(
|
|
55
|
-
"path",
|
|
56
|
-
{
|
|
57
|
-
className: "fill-base-content opacity-10",
|
|
58
|
-
d: "M33.83 0h67.933a4 4 0 0 1 4 4v93.344a4 4 0 0 1-4 4H33.83a4 4 0 0 1-4-4V4a4 4 0 0 1 4-4z"
|
|
59
|
-
}
|
|
60
|
-
),
|
|
61
|
-
/* @__PURE__ */ a(
|
|
62
|
-
"path",
|
|
63
|
-
{
|
|
64
|
-
className: "fill-base-100",
|
|
65
|
-
d: "M42.678 9.953h50.237a2 2 0 0 1 2 2V36.91a2 2 0 0 1-2 2H42.678a2 2 0 0 1-2-2V11.953a2 2 0 0 1 2-2zM42.94 49.767h49.713a2.262 2.262 0 1 1 0 4.524H42.94a2.262 2.262 0 0 1 0-4.524zM42.94 61.53h49.713a2.262 2.262 0 1 1 0 4.525H42.94a2.262 2.262 0 0 1 0-4.525zM121.813 105.032c-.775 3.071-3.497 5.36-6.735 5.36H20.515c-3.238 0-5.96-2.29-6.734-5.36a7.309 7.309 0 0 1-.222-1.79V69.675h26.318c2.907 0 5.25 2.448 5.25 5.42v.04c0 2.971 2.37 5.37 5.277 5.37h34.785c2.907 0 5.277-2.421 5.277-5.393V75.1c0-2.972 2.343-5.426 5.25-5.426h26.318v33.569c0 .617-.077 1.216-.221 1.789z"
|
|
66
|
-
}
|
|
67
|
-
)
|
|
68
|
-
] }),
|
|
69
|
-
/* @__PURE__ */ a(
|
|
70
|
-
"path",
|
|
71
|
-
{
|
|
72
|
-
className: "fill-base-content opacity-10",
|
|
73
|
-
d: "M149.121 33.292l-6.83 2.65a1 1 0 0 1-1.317-1.23l1.937-6.207c-2.589-2.944-4.109-6.534-4.109-10.408C138.802 8.102 148.92 0 161.402 0 173.881 0 184 8.102 184 18.097c0 9.995-10.118 18.097-22.599 18.097-4.528 0-8.744-1.066-12.28-2.902z"
|
|
74
|
-
}
|
|
75
|
-
),
|
|
76
|
-
/* @__PURE__ */ e("g", { className: "fill-base-100", transform: "translate(149.65 15.383)", children: [
|
|
77
|
-
/* @__PURE__ */ a("ellipse", { cx: "20.654", cy: "3.167", rx: "2.849", ry: "2.815" }),
|
|
78
|
-
/* @__PURE__ */ a("path", { d: "M5.698 5.63H0L2.898.704zM9.259.704h4.985V5.63H9.259z" })
|
|
79
|
-
] })
|
|
80
|
-
] })
|
|
81
|
-
}
|
|
82
|
-
), o = ({
|
|
83
|
-
children: l,
|
|
84
|
-
className: t = "",
|
|
85
|
-
description: s = "No Data",
|
|
86
|
-
image: c,
|
|
87
|
-
imageStyle: i,
|
|
88
|
-
...h
|
|
1
|
+
import { jsxs as p, jsx as m } from "react/jsx-runtime";
|
|
2
|
+
import b from "react";
|
|
3
|
+
const j = ({
|
|
4
|
+
position: r = "top-end",
|
|
5
|
+
children: s,
|
|
6
|
+
className: c = "",
|
|
7
|
+
...o
|
|
89
8
|
}) => {
|
|
90
|
-
const n =
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
9
|
+
const n = (d) => {
|
|
10
|
+
const [l, h] = d.split("-"), t = [];
|
|
11
|
+
switch (l) {
|
|
12
|
+
case "top":
|
|
13
|
+
t.push("indicator-top");
|
|
14
|
+
break;
|
|
15
|
+
case "middle":
|
|
16
|
+
t.push("indicator-middle");
|
|
17
|
+
break;
|
|
18
|
+
case "bottom":
|
|
19
|
+
t.push("indicator-bottom");
|
|
20
|
+
break;
|
|
21
|
+
}
|
|
22
|
+
switch (h) {
|
|
23
|
+
case "start":
|
|
24
|
+
t.push("indicator-start");
|
|
25
|
+
break;
|
|
26
|
+
case "center":
|
|
27
|
+
t.push("indicator-center");
|
|
28
|
+
break;
|
|
29
|
+
case "end":
|
|
30
|
+
t.push("indicator-end");
|
|
31
|
+
break;
|
|
32
|
+
}
|
|
33
|
+
return t.join(" ");
|
|
34
|
+
}, e = b.Children.toArray(s), a = e[0], i = e[1];
|
|
35
|
+
return /* @__PURE__ */ p("div", { className: `indicator inline-block ${c}`, ...o, children: [
|
|
36
|
+
i && /* @__PURE__ */ m("div", { className: `indicator-item ${n(r)}`, children: i }),
|
|
37
|
+
a
|
|
95
38
|
] });
|
|
96
39
|
};
|
|
97
40
|
export {
|
|
98
|
-
|
|
41
|
+
j as Indicator
|
|
99
42
|
};
|
|
100
43
|
//# sourceMappingURL=index35.js.map
|
package/dist/index35.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index35.js","sources":["../src/components/
|
|
1
|
+
{"version":3,"file":"index35.js","sources":["../src/components/Indicator.tsx"],"sourcesContent":["import React from 'react'\n\nexport type IndicatorPosition =\n | 'top-start'\n | 'top-center'\n | 'top-end'\n | 'middle-start'\n | 'middle-center'\n | 'middle-end'\n | 'bottom-start'\n | 'bottom-center'\n | 'bottom-end'\n\nexport interface IndicatorProps extends React.HTMLAttributes<HTMLDivElement> {\n position?: IndicatorPosition\n children: React.ReactNode\n}\n\nexport const Indicator: React.FC<IndicatorProps> = ({\n position = 'top-end',\n children,\n className = '',\n ...rest\n}) => {\n // Get position classes for indicator\n const getPositionClasses = (pos: IndicatorPosition) => {\n const [vertical, horizontal] = pos.split('-')\n const classes: string[] = []\n\n switch (vertical) {\n case 'top':\n classes.push('indicator-top')\n break\n case 'middle':\n classes.push('indicator-middle')\n break\n case 'bottom':\n classes.push('indicator-bottom')\n break\n }\n\n switch (horizontal) {\n case 'start':\n classes.push('indicator-start')\n break\n case 'center':\n classes.push('indicator-center')\n break\n case 'end':\n classes.push('indicator-end')\n break\n }\n\n return classes.join(' ')\n }\n\n const childrenArray = React.Children.toArray(children)\n const content = childrenArray[0]\n const indicatorElement = childrenArray[1]\n\n return (\n <div className={`indicator inline-block ${className}`} {...rest}>\n {indicatorElement && (\n <div className={`indicator-item ${getPositionClasses(position)}`}>\n {indicatorElement}\n </div>\n )}\n {content}\n </div>\n )\n}\n"],"names":["Indicator","position","children","className","rest","getPositionClasses","pos","vertical","horizontal","classes","childrenArray","React","content","indicatorElement","jsx"],"mappings":";;AAkBO,MAAMA,IAAsC,CAAC;AAAA,EAClD,UAAAC,IAAW;AAAA,EACX,UAAAC;AAAA,EACA,WAAAC,IAAY;AAAA,EACZ,GAAGC;AACL,MAAM;AAEJ,QAAMC,IAAqB,CAACC,MAA2B;AACrD,UAAM,CAACC,GAAUC,CAAU,IAAIF,EAAI,MAAM,GAAG,GACtCG,IAAoB,CAAA;AAE1B,YAAQF,GAAA;AAAA,MACN,KAAK;AACH,QAAAE,EAAQ,KAAK,eAAe;AAC5B;AAAA,MACF,KAAK;AACH,QAAAA,EAAQ,KAAK,kBAAkB;AAC/B;AAAA,MACF,KAAK;AACH,QAAAA,EAAQ,KAAK,kBAAkB;AAC/B;AAAA,IAAA;AAGJ,YAAQD,GAAA;AAAA,MACN,KAAK;AACH,QAAAC,EAAQ,KAAK,iBAAiB;AAC9B;AAAA,MACF,KAAK;AACH,QAAAA,EAAQ,KAAK,kBAAkB;AAC/B;AAAA,MACF,KAAK;AACH,QAAAA,EAAQ,KAAK,eAAe;AAC5B;AAAA,IAAA;AAGJ,WAAOA,EAAQ,KAAK,GAAG;AAAA,EACzB,GAEMC,IAAgBC,EAAM,SAAS,QAAQT,CAAQ,GAC/CU,IAAUF,EAAc,CAAC,GACzBG,IAAmBH,EAAc,CAAC;AAExC,2BACG,OAAA,EAAI,WAAW,0BAA0BP,CAAS,IAAK,GAAGC,GACxD,UAAA;AAAA,IAAAS,KACC,gBAAAC,EAAC,SAAI,WAAW,kBAAkBT,EAAmBJ,CAAQ,CAAC,IAC3D,UAAAY,EAAA,CACH;AAAA,IAEDD;AAAA,EAAA,GACH;AAEJ;"}
|
package/dist/index36.js
CHANGED
|
@@ -1,165 +1,194 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return i;
|
|
1
|
+
import { jsx as p } from "react/jsx-runtime";
|
|
2
|
+
import b, { useId as O, useState as y, useRef as x, useCallback as B, useEffect as k, createContext as R, useContext as F } from "react";
|
|
3
|
+
const A = R(void 0);
|
|
4
|
+
function v() {
|
|
5
|
+
const t = F(A);
|
|
6
|
+
if (!t)
|
|
7
|
+
throw new Error("Dropdown compound components must be used within Dropdown");
|
|
8
|
+
return t;
|
|
10
9
|
}
|
|
11
|
-
function
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
10
|
+
function M({
|
|
11
|
+
children: t,
|
|
12
|
+
hover: i = !1,
|
|
13
|
+
position: u = "bottom",
|
|
14
|
+
align: o = "start",
|
|
15
|
+
className: c = "",
|
|
16
|
+
...d
|
|
17
|
+
}) {
|
|
18
|
+
const n = O(), s = O(), [a, l] = y(!1), [r, I] = y(-1), [m, C] = y(0), e = x(/* @__PURE__ */ new Map()), f = x(null), w = B((D, h, j) => {
|
|
19
|
+
h ? e.current.set(D, { ref: h, disabled: j }) : e.current.delete(D);
|
|
20
|
+
}, []);
|
|
21
|
+
k(() => {
|
|
22
|
+
const D = (h) => {
|
|
23
|
+
f.current && !f.current.contains(h.target) && (l(!1), I(-1));
|
|
24
|
+
};
|
|
25
|
+
if (a)
|
|
26
|
+
return document.addEventListener("mousedown", D), () => document.removeEventListener("mousedown", D);
|
|
27
|
+
}, [a]);
|
|
28
|
+
const g = {
|
|
29
|
+
top: "dropdown-top",
|
|
30
|
+
bottom: "dropdown-bottom",
|
|
31
|
+
left: "dropdown-left",
|
|
32
|
+
right: "dropdown-right"
|
|
33
|
+
}, K = {
|
|
34
|
+
start: "",
|
|
35
|
+
center: "dropdown-center",
|
|
36
|
+
end: "dropdown-end"
|
|
37
|
+
}, N = [
|
|
38
|
+
"dropdown",
|
|
39
|
+
g[u],
|
|
40
|
+
K[o],
|
|
41
|
+
i && "dropdown-hover",
|
|
42
|
+
a && "dropdown-open",
|
|
43
|
+
c
|
|
44
|
+
].filter(Boolean).join(" ");
|
|
45
|
+
return /* @__PURE__ */ p(
|
|
46
|
+
A.Provider,
|
|
47
|
+
{
|
|
48
|
+
value: {
|
|
49
|
+
position: u,
|
|
50
|
+
align: o,
|
|
51
|
+
menuId: n,
|
|
52
|
+
triggerId: s,
|
|
53
|
+
isOpen: a,
|
|
54
|
+
setIsOpen: l,
|
|
55
|
+
focusedIndex: r,
|
|
56
|
+
setFocusedIndex: I,
|
|
57
|
+
registerItem: w,
|
|
58
|
+
itemCount: m,
|
|
59
|
+
setItemCount: C
|
|
60
|
+
},
|
|
61
|
+
children: /* @__PURE__ */ p("div", { ref: f, className: N, "data-state": a ? "open" : "closed", ...d, children: t })
|
|
62
|
+
}
|
|
63
|
+
);
|
|
18
64
|
}
|
|
19
|
-
function
|
|
20
|
-
|
|
65
|
+
function T({ children: t, className: i = "" }) {
|
|
66
|
+
const { menuId: u, triggerId: o, isOpen: c, setIsOpen: d, setFocusedIndex: n, itemCount: s } = v(), a = (r) => {
|
|
67
|
+
switch (r.key) {
|
|
68
|
+
case "Enter":
|
|
69
|
+
case " ":
|
|
70
|
+
case "ArrowDown":
|
|
71
|
+
r.preventDefault(), d(!0), n(0);
|
|
72
|
+
break;
|
|
73
|
+
case "ArrowUp":
|
|
74
|
+
r.preventDefault(), d(!0), n(s - 1);
|
|
75
|
+
break;
|
|
76
|
+
case "Escape":
|
|
77
|
+
r.preventDefault(), d(!1), n(-1);
|
|
78
|
+
break;
|
|
79
|
+
}
|
|
80
|
+
}, l = () => {
|
|
81
|
+
d(!c), c || n(0);
|
|
82
|
+
};
|
|
83
|
+
return /* @__PURE__ */ p(
|
|
84
|
+
"button",
|
|
85
|
+
{
|
|
86
|
+
id: o,
|
|
87
|
+
type: "button",
|
|
88
|
+
tabIndex: 0,
|
|
89
|
+
className: `btn ${i}`,
|
|
90
|
+
"aria-haspopup": "menu",
|
|
91
|
+
"aria-expanded": c,
|
|
92
|
+
"aria-controls": u,
|
|
93
|
+
onClick: l,
|
|
94
|
+
onKeyDown: a,
|
|
95
|
+
children: t
|
|
96
|
+
}
|
|
97
|
+
);
|
|
21
98
|
}
|
|
22
|
-
function
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
99
|
+
function V({ children: t, className: i = "" }) {
|
|
100
|
+
const { menuId: u, triggerId: o, isOpen: c, setIsOpen: d, focusedIndex: n, setFocusedIndex: s, setItemCount: a } = v(), l = x(null), r = b.Children.toArray(t).filter(
|
|
101
|
+
(e) => b.isValidElement(e) && e.type === E
|
|
102
|
+
);
|
|
103
|
+
k(() => {
|
|
104
|
+
a(r.length);
|
|
105
|
+
}, [r.length, a]), k(() => {
|
|
106
|
+
c && n >= 0 && l.current && l.current.querySelectorAll('[role="menuitem"]:not([aria-disabled="true"])')[n]?.focus();
|
|
107
|
+
}, [c, n]);
|
|
108
|
+
const I = (e) => {
|
|
109
|
+
const w = r.filter(
|
|
110
|
+
(g) => b.isValidElement(g) && !g.props.disabled
|
|
111
|
+
).length;
|
|
112
|
+
switch (e.key) {
|
|
113
|
+
case "ArrowDown":
|
|
114
|
+
e.preventDefault(), s((n + 1) % w);
|
|
115
|
+
break;
|
|
116
|
+
case "ArrowUp":
|
|
117
|
+
e.preventDefault(), s((n - 1 + w) % w);
|
|
118
|
+
break;
|
|
119
|
+
case "Home":
|
|
120
|
+
e.preventDefault(), s(0);
|
|
121
|
+
break;
|
|
122
|
+
case "End":
|
|
123
|
+
e.preventDefault(), s(w - 1);
|
|
124
|
+
break;
|
|
125
|
+
case "Escape":
|
|
126
|
+
e.preventDefault(), d(!1), s(-1), document.getElementById(o)?.focus();
|
|
127
|
+
break;
|
|
128
|
+
case "Tab":
|
|
129
|
+
d(!1), s(-1);
|
|
130
|
+
break;
|
|
131
|
+
}
|
|
132
|
+
}, m = [
|
|
133
|
+
"dropdown-content",
|
|
134
|
+
"menu",
|
|
135
|
+
"bg-base-100",
|
|
136
|
+
"rounded-box",
|
|
137
|
+
"z-[1]",
|
|
138
|
+
"shadow",
|
|
139
|
+
i
|
|
140
|
+
].filter(Boolean).join(" "), C = b.Children.map(t, (e, f) => b.isValidElement(e) && e.type === E ? b.cloneElement(e, { _index: f }) : e);
|
|
141
|
+
return /* @__PURE__ */ p(
|
|
142
|
+
"ul",
|
|
143
|
+
{
|
|
144
|
+
ref: l,
|
|
145
|
+
id: u,
|
|
146
|
+
role: "menu",
|
|
147
|
+
"aria-labelledby": o,
|
|
148
|
+
tabIndex: -1,
|
|
149
|
+
className: m,
|
|
150
|
+
onKeyDown: I,
|
|
151
|
+
children: C
|
|
152
|
+
}
|
|
153
|
+
);
|
|
27
154
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
xl: "input-xl"
|
|
50
|
-
}, F = {
|
|
51
|
-
neutral: "input-neutral",
|
|
52
|
-
primary: "input-primary",
|
|
53
|
-
secondary: "input-secondary",
|
|
54
|
-
accent: "input-accent",
|
|
55
|
-
info: "input-info",
|
|
56
|
-
success: "input-success",
|
|
57
|
-
warning: "input-warning",
|
|
58
|
-
error: "input-error"
|
|
59
|
-
}, S = [
|
|
60
|
-
"input",
|
|
61
|
-
!l && "border-0",
|
|
62
|
-
i && "input-ghost",
|
|
63
|
-
e && D[e],
|
|
64
|
-
r && F[r],
|
|
65
|
-
x
|
|
66
|
-
].filter(Boolean).join(" "), G = W(null), C = B || G, H = M(() => t ? j(g ?? N ?? "", t) : "", [t, g, N]), [b, v] = _(H), [I, E] = _(null);
|
|
67
|
-
P(() => {
|
|
68
|
-
t && g !== void 0 && v(j(g, t));
|
|
69
|
-
}, [t, g]), P(() => {
|
|
70
|
-
I !== null && C.current && (C.current.setSelectionRange(I, I), E(null));
|
|
71
|
-
}, [I, C]);
|
|
72
|
-
const J = M(
|
|
73
|
-
(s) => {
|
|
74
|
-
if (!t) {
|
|
75
|
-
d?.(s);
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
const f = s.target, y = f.value, h = j(y, t);
|
|
79
|
-
let p = "", a = 0;
|
|
80
|
-
for (let c = 0; c < t.length && a < h.length; c++) {
|
|
81
|
-
const o = t[c];
|
|
82
|
-
(o === "#" || o === "A" || o === "*") && (X(h[a], o) && (p += h[a]), a++);
|
|
83
|
-
}
|
|
84
|
-
v(p);
|
|
85
|
-
const V = T(p, t, R);
|
|
86
|
-
let u = q(t, 0), w = 0;
|
|
87
|
-
for (let c = 0; c < t.length; c++) {
|
|
88
|
-
const o = t[c];
|
|
89
|
-
(o === "#" || o === "A" || o === "*") && w < p.length && (w++, u = c + 1);
|
|
90
|
-
}
|
|
91
|
-
u = q(t, u), u > t.length && (u = t.length), E(u);
|
|
92
|
-
const Q = {
|
|
93
|
-
...s,
|
|
94
|
-
target: { ...f, value: V },
|
|
95
|
-
currentTarget: { ...f, value: V }
|
|
96
|
-
};
|
|
97
|
-
d?.(Q);
|
|
98
|
-
},
|
|
99
|
-
[t, R, d]
|
|
100
|
-
), L = M(
|
|
101
|
-
(s) => {
|
|
102
|
-
if (!t) {
|
|
103
|
-
A?.(s);
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
if (s.key === "Backspace") {
|
|
107
|
-
s.preventDefault();
|
|
108
|
-
const f = b.slice(0, -1);
|
|
109
|
-
v(f);
|
|
110
|
-
let y = 0, h = 0;
|
|
111
|
-
for (let u = 0; u < t.length; u++) {
|
|
112
|
-
const w = t[u];
|
|
113
|
-
if (w === "#" || w === "A" || w === "*")
|
|
114
|
-
if (h < f.length)
|
|
115
|
-
h++, y = u + 1;
|
|
116
|
-
else {
|
|
117
|
-
y = u;
|
|
118
|
-
break;
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
E(y);
|
|
122
|
-
const p = T(f, t, R), a = s.currentTarget, V = {
|
|
123
|
-
target: { ...a, value: p },
|
|
124
|
-
currentTarget: { ...a, value: p }
|
|
125
|
-
};
|
|
126
|
-
d?.(V);
|
|
127
|
-
}
|
|
128
|
-
A?.(s);
|
|
155
|
+
function E({
|
|
156
|
+
children: t,
|
|
157
|
+
onClick: i,
|
|
158
|
+
active: u = !1,
|
|
159
|
+
disabled: o = !1,
|
|
160
|
+
danger: c = !1,
|
|
161
|
+
className: d = ""
|
|
162
|
+
}) {
|
|
163
|
+
const { setIsOpen: n, setFocusedIndex: s, triggerId: a } = v(), l = [u && "active", o && "disabled", d].filter(Boolean).join(" "), r = () => {
|
|
164
|
+
o || (i?.(), n(!1), s(-1), document.getElementById(a)?.focus());
|
|
165
|
+
};
|
|
166
|
+
return /* @__PURE__ */ p("li", { className: l, role: "none", children: /* @__PURE__ */ p(
|
|
167
|
+
"a",
|
|
168
|
+
{
|
|
169
|
+
role: "menuitem",
|
|
170
|
+
tabIndex: o ? -1 : 0,
|
|
171
|
+
"aria-disabled": o || void 0,
|
|
172
|
+
className: c ? "text-error" : "",
|
|
173
|
+
onClick: r,
|
|
174
|
+
onKeyDown: (m) => {
|
|
175
|
+
(m.key === "Enter" || m.key === " ") && !o && (m.preventDefault(), r());
|
|
129
176
|
},
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
}
|
|
145
|
-
);
|
|
146
|
-
const O = T(b, t, R);
|
|
147
|
-
return /* @__PURE__ */ Z(
|
|
148
|
-
"input",
|
|
149
|
-
{
|
|
150
|
-
ref: C,
|
|
151
|
-
type: "text",
|
|
152
|
-
className: S,
|
|
153
|
-
value: O,
|
|
154
|
-
onChange: J,
|
|
155
|
-
onKeyDown: L,
|
|
156
|
-
...z
|
|
157
|
-
}
|
|
158
|
-
);
|
|
159
|
-
}
|
|
160
|
-
);
|
|
161
|
-
Y.displayName = "Input";
|
|
177
|
+
children: t
|
|
178
|
+
}
|
|
179
|
+
) });
|
|
180
|
+
}
|
|
181
|
+
function L({ className: t = "" }) {
|
|
182
|
+
const i = ["border-base-content/10", t].filter(Boolean).join(" ");
|
|
183
|
+
return /* @__PURE__ */ p("li", { role: "separator", className: "my-1", children: /* @__PURE__ */ p("hr", { className: i }) });
|
|
184
|
+
}
|
|
185
|
+
const q = Object.assign(M, {
|
|
186
|
+
Trigger: T,
|
|
187
|
+
Menu: V,
|
|
188
|
+
Item: E,
|
|
189
|
+
Divider: L
|
|
190
|
+
});
|
|
162
191
|
export {
|
|
163
|
-
|
|
192
|
+
q as Dropdown
|
|
164
193
|
};
|
|
165
194
|
//# sourceMappingURL=index36.js.map
|
package/dist/index36.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index36.js","sources":["../src/components/Input.tsx"],"sourcesContent":["import React, { forwardRef, useState, useCallback, useRef, useEffect } from 'react'\n\nexport interface InputProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n type?: 'text' | 'password' | 'email' | 'number' | 'date' | 'datetime-local' | 'week' | 'month' | 'tel' | 'url' | 'search' | 'time'\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n color?: 'neutral' | 'primary' | 'secondary' | 'accent' | 'info' | 'success' | 'warning' | 'error'\n ghost?: boolean\n bordered?: boolean\n className?: string\n /** Input mask pattern. Use # for digits, A for letters, * for alphanumeric */\n mask?: string\n /** Placeholder character shown in mask (default: _) */\n maskPlaceholder?: string\n}\n\n// Helper to apply mask to raw value\nfunction applyMask(raw: string, mask: string, placeholder: string): string {\n let result = ''\n let rawIndex = 0\n\n for (let i = 0; i < mask.length && rawIndex <= raw.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (rawIndex < raw.length) {\n result += raw[rawIndex]\n rawIndex++\n } else {\n result += placeholder\n }\n } else {\n result += maskChar\n }\n }\n\n return result\n}\n\n// Extract raw value from masked input\nfunction extractRaw(value: string, mask: string): string {\n let raw = ''\n for (let i = 0; i < value.length && i < mask.length; i++) {\n const maskChar = mask[i]\n if ((maskChar === '#' || maskChar === 'A' || maskChar === '*') && value[i] !== '_') {\n raw += value[i]\n }\n }\n return raw\n}\n\n// Check if character is valid for mask position\nfunction isValidChar(char: string, maskChar: string): boolean {\n if (maskChar === '#') return /\\d/.test(char)\n if (maskChar === 'A') return /[a-zA-Z]/.test(char)\n if (maskChar === '*') return /[a-zA-Z0-9]/.test(char)\n return false\n}\n\n// Find next input position in mask\nfunction findNextInputPosition(mask: string, fromIndex: number): number {\n for (let i = fromIndex; i < mask.length; i++) {\n if (mask[i] === '#' || mask[i] === 'A' || mask[i] === '*') {\n return i\n }\n }\n return mask.length\n}\n\nexport const Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n type = 'text',\n size,\n color,\n ghost = false,\n bordered = true,\n className = '',\n mask,\n maskPlaceholder = '_',\n value,\n defaultValue,\n onChange,\n onKeyDown,\n ...props\n },\n ref\n ) => {\n const sizeClasses = {\n xs: 'input-xs',\n sm: 'input-sm',\n md: 'input-md',\n lg: 'input-lg',\n xl: 'input-xl',\n }\n\n const colorClasses = {\n neutral: 'input-neutral',\n primary: 'input-primary',\n secondary: 'input-secondary',\n accent: 'input-accent',\n info: 'input-info',\n success: 'input-success',\n warning: 'input-warning',\n error: 'input-error',\n }\n\n const inputClasses = [\n 'input',\n !bordered && 'border-0',\n ghost && 'input-ghost',\n size && sizeClasses[size],\n color && colorClasses[color],\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n // Mask handling\n const innerRef = useRef<HTMLInputElement>(null)\n const inputRef = (ref as React.RefObject<HTMLInputElement>) || innerRef\n\n const getInitialRaw = useCallback(() => {\n if (!mask) return ''\n const initial = (value ?? defaultValue ?? '') as string\n return extractRaw(initial, mask)\n }, [mask, value, defaultValue])\n\n const [rawValue, setRawValue] = useState(getInitialRaw)\n const [cursorPos, setCursorPos] = useState<number | null>(null)\n\n // Sync with controlled value\n useEffect(() => {\n if (mask && value !== undefined) {\n setRawValue(extractRaw(value as string, mask))\n }\n }, [mask, value])\n\n // Set cursor position after render\n useEffect(() => {\n if (cursorPos !== null && inputRef.current) {\n inputRef.current.setSelectionRange(cursorPos, cursorPos)\n setCursorPos(null)\n }\n }, [cursorPos, inputRef])\n\n const handleMaskedChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!mask) {\n onChange?.(e)\n return\n }\n\n const input = e.target\n const inputValue = input.value\n\n // Extract what the user is trying to type\n const newRaw = extractRaw(inputValue, mask)\n\n // Filter to only valid characters\n let filteredRaw = ''\n let rawIdx = 0\n for (let i = 0; i < mask.length && rawIdx < newRaw.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (isValidChar(newRaw[rawIdx], maskChar)) {\n filteredRaw += newRaw[rawIdx]\n }\n rawIdx++\n }\n }\n\n setRawValue(filteredRaw)\n\n // Calculate new cursor position\n const maskedValue = applyMask(filteredRaw, mask, maskPlaceholder)\n let newCursor = findNextInputPosition(mask, 0)\n let charsPlaced = 0\n for (let i = 0; i < mask.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (charsPlaced < filteredRaw.length) {\n charsPlaced++\n newCursor = i + 1\n }\n }\n }\n // Skip to next input position if we're on a literal\n newCursor = findNextInputPosition(mask, newCursor)\n if (newCursor > mask.length) newCursor = mask.length\n\n setCursorPos(newCursor)\n\n // Create synthetic event with masked value\n const syntheticEvent = {\n ...e,\n target: { ...input, value: maskedValue },\n currentTarget: { ...input, value: maskedValue },\n } as React.ChangeEvent<HTMLInputElement>\n\n onChange?.(syntheticEvent)\n },\n [mask, maskPlaceholder, onChange]\n )\n\n const handleMaskedKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (!mask) {\n onKeyDown?.(e)\n return\n }\n\n if (e.key === 'Backspace') {\n e.preventDefault()\n const newRaw = rawValue.slice(0, -1)\n setRawValue(newRaw)\n\n // Calculate cursor position\n let newCursor = 0\n let charsPlaced = 0\n for (let i = 0; i < mask.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (charsPlaced < newRaw.length) {\n charsPlaced++\n newCursor = i + 1\n } else {\n newCursor = i\n break\n }\n }\n }\n setCursorPos(newCursor)\n\n const maskedValue = applyMask(newRaw, mask, maskPlaceholder)\n const input = e.currentTarget\n const syntheticEvent = {\n target: { ...input, value: maskedValue },\n currentTarget: { ...input, value: maskedValue },\n } as unknown as React.ChangeEvent<HTMLInputElement>\n\n onChange?.(syntheticEvent)\n }\n\n onKeyDown?.(e)\n },\n [mask, maskPlaceholder, rawValue, onChange, onKeyDown]\n )\n\n // If no mask, render simple input\n if (!mask) {\n return (\n <input\n ref={ref}\n type={type}\n className={inputClasses}\n value={value}\n defaultValue={defaultValue}\n onChange={onChange}\n onKeyDown={onKeyDown}\n {...props}\n />\n )\n }\n\n // Render masked input\n const maskedValue = applyMask(rawValue, mask, maskPlaceholder)\n\n return (\n <input\n ref={inputRef}\n type=\"text\"\n className={inputClasses}\n value={maskedValue}\n onChange={handleMaskedChange}\n onKeyDown={handleMaskedKeyDown}\n {...props}\n />\n )\n }\n)\n\nInput.displayName = 'Input'\n"],"names":["applyMask","raw","mask","placeholder","result","rawIndex","i","maskChar","extractRaw","value","isValidChar","char","findNextInputPosition","fromIndex","Input","forwardRef","type","size","color","ghost","bordered","className","maskPlaceholder","defaultValue","onChange","onKeyDown","props","ref","sizeClasses","colorClasses","inputClasses","innerRef","useRef","inputRef","getInitialRaw","useCallback","rawValue","setRawValue","useState","cursorPos","setCursorPos","useEffect","handleMaskedChange","e","input","inputValue","newRaw","filteredRaw","rawIdx","maskedValue","newCursor","charsPlaced","syntheticEvent","handleMaskedKeyDown","jsx"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index36.js","sources":["../src/components/Dropdown.tsx"],"sourcesContent":["import React, { createContext, useContext, useId, useRef, useState, useCallback, useEffect } from 'react'\n\ninterface DropdownContextValue {\n position?: 'top' | 'bottom' | 'left' | 'right'\n align?: 'start' | 'center' | 'end'\n menuId: string\n triggerId: string\n isOpen: boolean\n setIsOpen: (open: boolean) => void\n focusedIndex: number\n setFocusedIndex: (index: number) => void\n registerItem: (index: number, ref: HTMLElement | null, disabled: boolean) => void\n itemCount: number\n setItemCount: (count: number) => void\n}\n\nconst DropdownContext = createContext<DropdownContextValue | undefined>(undefined)\n\nfunction useDropdownContext() {\n const context = useContext(DropdownContext)\n if (!context) {\n throw new Error('Dropdown compound components must be used within Dropdown')\n }\n return context\n}\n\nexport interface DropdownProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n hover?: boolean\n position?: 'top' | 'bottom' | 'left' | 'right'\n align?: 'start' | 'center' | 'end'\n}\n\nexport interface DropdownTriggerProps {\n children: React.ReactNode\n className?: string\n}\n\nexport interface DropdownMenuProps {\n children: React.ReactNode\n className?: string\n}\n\nexport interface DropdownItemProps {\n children: React.ReactNode\n onClick?: () => void\n active?: boolean\n disabled?: boolean\n danger?: boolean\n className?: string\n _index?: number // Internal prop passed by DropdownMenu\n}\n\nexport interface DropdownDividerProps {\n className?: string\n}\n\nfunction DropdownRoot({\n children,\n hover = false,\n position = 'bottom',\n align = 'start',\n className = '',\n ...rest\n}: DropdownProps) {\n const menuId = useId()\n const triggerId = useId()\n const [isOpen, setIsOpen] = useState(false)\n const [focusedIndex, setFocusedIndex] = useState(-1)\n const [itemCount, setItemCount] = useState(0)\n const itemRefs = useRef<Map<number, { ref: HTMLElement | null; disabled: boolean }>>(new Map())\n const dropdownRef = useRef<HTMLDivElement>(null)\n\n const registerItem = useCallback((index: number, ref: HTMLElement | null, disabled: boolean) => {\n if (ref) {\n itemRefs.current.set(index, { ref, disabled })\n } else {\n itemRefs.current.delete(index)\n }\n }, [])\n\n // Close dropdown when clicking outside\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (dropdownRef.current && !dropdownRef.current.contains(event.target as Node)) {\n setIsOpen(false)\n setFocusedIndex(-1)\n }\n }\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside)\n return () => document.removeEventListener('mousedown', handleClickOutside)\n }\n }, [isOpen])\n\n const positionClasses: Record<string, string> = {\n top: 'dropdown-top',\n bottom: 'dropdown-bottom',\n left: 'dropdown-left',\n right: 'dropdown-right',\n }\n\n const alignClasses: Record<string, string> = {\n start: '',\n center: 'dropdown-center',\n end: 'dropdown-end',\n }\n\n const dropdownClasses = [\n 'dropdown',\n positionClasses[position],\n alignClasses[align],\n hover && 'dropdown-hover',\n isOpen && 'dropdown-open',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return (\n <DropdownContext.Provider\n value={{\n position,\n align,\n menuId,\n triggerId,\n isOpen,\n setIsOpen,\n focusedIndex,\n setFocusedIndex,\n registerItem,\n itemCount,\n setItemCount,\n }}\n >\n <div ref={dropdownRef} className={dropdownClasses} data-state={isOpen ? 'open' : 'closed'} {...rest}>{children}</div>\n </DropdownContext.Provider>\n )\n}\n\nfunction DropdownTrigger({ children, className = '' }: DropdownTriggerProps) {\n const { menuId, triggerId, isOpen, setIsOpen, setFocusedIndex, itemCount } = useDropdownContext()\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n switch (event.key) {\n case 'Enter':\n case ' ':\n case 'ArrowDown':\n event.preventDefault()\n setIsOpen(true)\n setFocusedIndex(0)\n break\n case 'ArrowUp':\n event.preventDefault()\n setIsOpen(true)\n setFocusedIndex(itemCount - 1)\n break\n case 'Escape':\n event.preventDefault()\n setIsOpen(false)\n setFocusedIndex(-1)\n break\n }\n }\n\n const handleClick = () => {\n setIsOpen(!isOpen)\n if (!isOpen) {\n setFocusedIndex(0)\n }\n }\n\n return (\n <button\n id={triggerId}\n type=\"button\"\n tabIndex={0}\n className={`btn ${className}`}\n aria-haspopup=\"menu\"\n aria-expanded={isOpen}\n aria-controls={menuId}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n >\n {children}\n </button>\n )\n}\n\nfunction DropdownMenu({ children, className = '' }: DropdownMenuProps) {\n const { menuId, triggerId, isOpen, setIsOpen, focusedIndex, setFocusedIndex, setItemCount } = useDropdownContext()\n const menuRef = useRef<HTMLUListElement>(null)\n\n // Count children and set item count\n const childArray = React.Children.toArray(children).filter(\n (child) => React.isValidElement(child) && (child.type === DropdownItem)\n )\n\n useEffect(() => {\n setItemCount(childArray.length)\n }, [childArray.length, setItemCount])\n\n // Focus management\n useEffect(() => {\n if (isOpen && focusedIndex >= 0 && menuRef.current) {\n const items = menuRef.current.querySelectorAll('[role=\"menuitem\"]:not([aria-disabled=\"true\"])')\n const item = items[focusedIndex] as HTMLElement\n item?.focus()\n }\n }, [isOpen, focusedIndex])\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n const enabledItems = childArray.filter(\n (child) => React.isValidElement(child) && !(child.props as DropdownItemProps).disabled\n )\n const enabledCount = enabledItems.length\n\n switch (event.key) {\n case 'ArrowDown':\n event.preventDefault()\n setFocusedIndex((focusedIndex + 1) % enabledCount)\n break\n case 'ArrowUp':\n event.preventDefault()\n setFocusedIndex((focusedIndex - 1 + enabledCount) % enabledCount)\n break\n case 'Home':\n event.preventDefault()\n setFocusedIndex(0)\n break\n case 'End':\n event.preventDefault()\n setFocusedIndex(enabledCount - 1)\n break\n case 'Escape':\n event.preventDefault()\n setIsOpen(false)\n setFocusedIndex(-1)\n // Return focus to trigger\n document.getElementById(triggerId)?.focus()\n break\n case 'Tab':\n setIsOpen(false)\n setFocusedIndex(-1)\n break\n }\n }\n\n const menuClasses = [\n 'dropdown-content',\n 'menu',\n 'bg-base-100',\n 'rounded-box',\n 'z-[1]',\n 'shadow',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n // Clone children to pass index\n const childrenWithIndex = React.Children.map(children, (child, index) => {\n if (React.isValidElement(child) && child.type === DropdownItem) {\n return React.cloneElement(child as React.ReactElement<any>, { _index: index })\n }\n return child\n })\n\n return (\n <ul\n ref={menuRef}\n id={menuId}\n role=\"menu\"\n aria-labelledby={triggerId}\n tabIndex={-1}\n className={menuClasses}\n onKeyDown={handleKeyDown}\n >\n {childrenWithIndex}\n </ul>\n )\n}\n\nfunction DropdownItem({\n children,\n onClick,\n active = false,\n disabled = false,\n danger = false,\n className = '',\n}: DropdownItemProps) {\n const { setIsOpen, setFocusedIndex, triggerId } = useDropdownContext()\n const itemClasses = [active && 'active', disabled && 'disabled', className].filter(Boolean).join(' ')\n\n const handleClick = () => {\n if (!disabled) {\n onClick?.()\n setIsOpen(false)\n setFocusedIndex(-1)\n document.getElementById(triggerId)?.focus()\n }\n }\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if ((event.key === 'Enter' || event.key === ' ') && !disabled) {\n event.preventDefault()\n handleClick()\n }\n }\n\n return (\n <li className={itemClasses} role=\"none\">\n <a\n role=\"menuitem\"\n tabIndex={disabled ? -1 : 0}\n aria-disabled={disabled || undefined}\n className={danger ? 'text-error' : ''}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n >\n {children}\n </a>\n </li>\n )\n}\n\nfunction DropdownDivider({ className = '' }: DropdownDividerProps) {\n const classes = ['border-base-content/10', className].filter(Boolean).join(' ')\n return (\n <li role=\"separator\" className=\"my-1\">\n <hr className={classes} />\n </li>\n )\n}\n\nexport const Dropdown = Object.assign(DropdownRoot, {\n Trigger: DropdownTrigger,\n Menu: DropdownMenu,\n Item: DropdownItem,\n Divider: DropdownDivider,\n})\n"],"names":["DropdownContext","createContext","useDropdownContext","context","useContext","DropdownRoot","children","hover","position","align","className","rest","menuId","useId","triggerId","isOpen","setIsOpen","useState","focusedIndex","setFocusedIndex","itemCount","setItemCount","itemRefs","useRef","dropdownRef","registerItem","useCallback","index","ref","disabled","useEffect","handleClickOutside","event","positionClasses","alignClasses","dropdownClasses","jsx","DropdownTrigger","handleKeyDown","handleClick","DropdownMenu","menuRef","childArray","React","child","DropdownItem","enabledCount","menuClasses","childrenWithIndex","onClick","active","danger","itemClasses","DropdownDivider","classes","Dropdown"],"mappings":";;AAgBA,MAAMA,IAAkBC,EAAgD,MAAS;AAEjF,SAASC,IAAqB;AAC5B,QAAMC,IAAUC,EAAWJ,CAAe;AAC1C,MAAI,CAACG;AACH,UAAM,IAAI,MAAM,2DAA2D;AAE7E,SAAOA;AACT;AAiCA,SAASE,EAAa;AAAA,EACpB,UAAAC;AAAA,EACA,OAAAC,IAAQ;AAAA,EACR,UAAAC,IAAW;AAAA,EACX,OAAAC,IAAQ;AAAA,EACR,WAAAC,IAAY;AAAA,EACZ,GAAGC;AACL,GAAkB;AAChB,QAAMC,IAASC,EAAA,GACTC,IAAYD,EAAA,GACZ,CAACE,GAAQC,CAAS,IAAIC,EAAS,EAAK,GACpC,CAACC,GAAcC,CAAe,IAAIF,EAAS,EAAE,GAC7C,CAACG,GAAWC,CAAY,IAAIJ,EAAS,CAAC,GACtCK,IAAWC,EAAoE,oBAAI,KAAK,GACxFC,IAAcD,EAAuB,IAAI,GAEzCE,IAAeC,EAAY,CAACC,GAAeC,GAAyBC,MAAsB;AAC9F,IAAID,IACFN,EAAS,QAAQ,IAAIK,GAAO,EAAE,KAAAC,GAAK,UAAAC,GAAU,IAE7CP,EAAS,QAAQ,OAAOK,CAAK;AAAA,EAEjC,GAAG,CAAA,CAAE;AAGL,EAAAG,EAAU,MAAM;AACd,UAAMC,IAAqB,CAACC,MAAsB;AAChD,MAAIR,EAAY,WAAW,CAACA,EAAY,QAAQ,SAASQ,EAAM,MAAc,MAC3EhB,EAAU,EAAK,GACfG,EAAgB,EAAE;AAAA,IAEtB;AAEA,QAAIJ;AACF,sBAAS,iBAAiB,aAAagB,CAAkB,GAClD,MAAM,SAAS,oBAAoB,aAAaA,CAAkB;AAAA,EAE7E,GAAG,CAAChB,CAAM,CAAC;AAEX,QAAMkB,IAA0C;AAAA,IAC9C,KAAK;AAAA,IACL,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,OAAO;AAAA,EAAA,GAGHC,IAAuC;AAAA,IAC3C,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,KAAK;AAAA,EAAA,GAGDC,IAAkB;AAAA,IACtB;AAAA,IACAF,EAAgBzB,CAAQ;AAAA,IACxB0B,EAAazB,CAAK;AAAA,IAClBF,KAAS;AAAA,IACTQ,KAAU;AAAA,IACVL;AAAA,EAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,SACE,gBAAA0B;AAAA,IAACpC,EAAgB;AAAA,IAAhB;AAAA,MACC,OAAO;AAAA,QACL,UAAAQ;AAAA,QACA,OAAAC;AAAA,QACA,QAAAG;AAAA,QACA,WAAAE;AAAA,QACA,QAAAC;AAAA,QACA,WAAAC;AAAA,QACA,cAAAE;AAAA,QACA,iBAAAC;AAAA,QACA,cAAAM;AAAA,QACA,WAAAL;AAAA,QACA,cAAAC;AAAA,MAAA;AAAA,MAGF,UAAA,gBAAAe,EAAC,OAAA,EAAI,KAAKZ,GAAa,WAAWW,GAAiB,cAAYpB,IAAS,SAAS,UAAW,GAAGJ,GAAO,UAAAL,EAAA,CAAS;AAAA,IAAA;AAAA,EAAA;AAGrH;AAEA,SAAS+B,EAAgB,EAAE,UAAA/B,GAAU,WAAAI,IAAY,MAA4B;AAC3E,QAAM,EAAE,QAAAE,GAAQ,WAAAE,GAAW,QAAAC,GAAQ,WAAAC,GAAW,iBAAAG,GAAiB,WAAAC,EAAA,IAAclB,EAAA,GAEvEoC,IAAgB,CAACN,MAA+B;AACpD,YAAQA,EAAM,KAAA;AAAA,MACZ,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,QAAAA,EAAM,eAAA,GACNhB,EAAU,EAAI,GACdG,EAAgB,CAAC;AACjB;AAAA,MACF,KAAK;AACH,QAAAa,EAAM,eAAA,GACNhB,EAAU,EAAI,GACdG,EAAgBC,IAAY,CAAC;AAC7B;AAAA,MACF,KAAK;AACH,QAAAY,EAAM,eAAA,GACNhB,EAAU,EAAK,GACfG,EAAgB,EAAE;AAClB;AAAA,IAAA;AAAA,EAEN,GAEMoB,IAAc,MAAM;AACxB,IAAAvB,EAAU,CAACD,CAAM,GACZA,KACHI,EAAgB,CAAC;AAAA,EAErB;AAEA,SACE,gBAAAiB;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAItB;AAAA,MACJ,MAAK;AAAA,MACL,UAAU;AAAA,MACV,WAAW,OAAOJ,CAAS;AAAA,MAC3B,iBAAc;AAAA,MACd,iBAAeK;AAAA,MACf,iBAAeH;AAAA,MACf,SAAS2B;AAAA,MACT,WAAWD;AAAA,MAEV,UAAAhC;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAASkC,EAAa,EAAE,UAAAlC,GAAU,WAAAI,IAAY,MAAyB;AACrE,QAAM,EAAE,QAAAE,GAAQ,WAAAE,GAAW,QAAAC,GAAQ,WAAAC,GAAW,cAAAE,GAAc,iBAAAC,GAAiB,cAAAE,EAAA,IAAiBnB,EAAA,GACxFuC,IAAUlB,EAAyB,IAAI,GAGvCmB,IAAaC,EAAM,SAAS,QAAQrC,CAAQ,EAAE;AAAA,IAClD,CAACsC,MAAUD,EAAM,eAAeC,CAAK,KAAMA,EAAM,SAASC;AAAA,EAAA;AAG5D,EAAAf,EAAU,MAAM;AACd,IAAAT,EAAaqB,EAAW,MAAM;AAAA,EAChC,GAAG,CAACA,EAAW,QAAQrB,CAAY,CAAC,GAGpCS,EAAU,MAAM;AACd,IAAIf,KAAUG,KAAgB,KAAKuB,EAAQ,WAC3BA,EAAQ,QAAQ,iBAAiB,+CAA+C,EAC3EvB,CAAY,GACzB,MAAA;AAAA,EAEV,GAAG,CAACH,GAAQG,CAAY,CAAC;AAEzB,QAAMoB,IAAgB,CAACN,MAA+B;AAIpD,UAAMc,IAHeJ,EAAW;AAAA,MAC9B,CAACE,MAAUD,EAAM,eAAeC,CAAK,KAAK,CAAEA,EAAM,MAA4B;AAAA,IAAA,EAE9C;AAElC,YAAQZ,EAAM,KAAA;AAAA,MACZ,KAAK;AACH,QAAAA,EAAM,eAAA,GACNb,GAAiBD,IAAe,KAAK4B,CAAY;AACjD;AAAA,MACF,KAAK;AACH,QAAAd,EAAM,eAAA,GACNb,GAAiBD,IAAe,IAAI4B,KAAgBA,CAAY;AAChE;AAAA,MACF,KAAK;AACH,QAAAd,EAAM,eAAA,GACNb,EAAgB,CAAC;AACjB;AAAA,MACF,KAAK;AACH,QAAAa,EAAM,eAAA,GACNb,EAAgB2B,IAAe,CAAC;AAChC;AAAA,MACF,KAAK;AACH,QAAAd,EAAM,eAAA,GACNhB,EAAU,EAAK,GACfG,EAAgB,EAAE,GAElB,SAAS,eAAeL,CAAS,GAAG,MAAA;AACpC;AAAA,MACF,KAAK;AACH,QAAAE,EAAU,EAAK,GACfG,EAAgB,EAAE;AAClB;AAAA,IAAA;AAAA,EAEN,GAEM4B,IAAc;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACArC;AAAA,EAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG,GAGLsC,IAAoBL,EAAM,SAAS,IAAIrC,GAAU,CAACsC,GAAOjB,MACzDgB,EAAM,eAAeC,CAAK,KAAKA,EAAM,SAASC,IACzCF,EAAM,aAAaC,GAAkC,EAAE,QAAQjB,GAAO,IAExEiB,CACR;AAED,SACE,gBAAAR;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAKK;AAAA,MACL,IAAI7B;AAAA,MACJ,MAAK;AAAA,MACL,mBAAiBE;AAAA,MACjB,UAAU;AAAA,MACV,WAAWiC;AAAA,MACX,WAAWT;AAAA,MAEV,UAAAU;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAASH,EAAa;AAAA,EACpB,UAAAvC;AAAA,EACA,SAAA2C;AAAA,EACA,QAAAC,IAAS;AAAA,EACT,UAAArB,IAAW;AAAA,EACX,QAAAsB,IAAS;AAAA,EACT,WAAAzC,IAAY;AACd,GAAsB;AACpB,QAAM,EAAE,WAAAM,GAAW,iBAAAG,GAAiB,WAAAL,EAAA,IAAcZ,EAAA,GAC5CkD,IAAc,CAACF,KAAU,UAAUrB,KAAY,YAAYnB,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,GAE9F6B,IAAc,MAAM;AACxB,IAAKV,MACHoB,IAAA,GACAjC,EAAU,EAAK,GACfG,EAAgB,EAAE,GAClB,SAAS,eAAeL,CAAS,GAAG,MAAA;AAAA,EAExC;AASA,SACE,gBAAAsB,EAAC,MAAA,EAAG,WAAWgB,GAAa,MAAK,QAC/B,UAAA,gBAAAhB;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,UAAUP,IAAW,KAAK;AAAA,MAC1B,iBAAeA,KAAY;AAAA,MAC3B,WAAWsB,IAAS,eAAe;AAAA,MACnC,SAASZ;AAAA,MACT,WAfgB,CAACP,MAA+B;AACpD,SAAKA,EAAM,QAAQ,WAAWA,EAAM,QAAQ,QAAQ,CAACH,MACnDG,EAAM,eAAA,GACNO,EAAA;AAAA,MAEJ;AAAA,MAYO,UAAAjC;AAAA,IAAA;AAAA,EAAA,GAEL;AAEJ;AAEA,SAAS+C,EAAgB,EAAE,WAAA3C,IAAY,MAA4B;AACjE,QAAM4C,IAAU,CAAC,0BAA0B5C,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAC9E,SACE,gBAAA0B,EAAC,MAAA,EAAG,MAAK,aAAY,WAAU,QAC7B,UAAA,gBAAAA,EAAC,MAAA,EAAG,WAAWkB,EAAA,CAAS,EAAA,CAC1B;AAEJ;AAEO,MAAMC,IAAW,OAAO,OAAOlD,GAAc;AAAA,EAClD,SAASgC;AAAA,EACT,MAAMG;AAAA,EACN,MAAMK;AAAA,EACN,SAASQ;AACX,CAAC;"}
|