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/index78.js
CHANGED
|
@@ -1,164 +1,59 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
import { useState as
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
}, [t]), j(() => {
|
|
35
|
-
function e(s) {
|
|
36
|
-
A.current && !A.current.contains(s.target) && C(!1);
|
|
37
|
-
}
|
|
38
|
-
if (u)
|
|
39
|
-
return document.addEventListener("mousedown", e), () => document.removeEventListener("mousedown", e);
|
|
40
|
-
}, [u]);
|
|
41
|
-
const m = (e, s, w) => {
|
|
42
|
-
const g = /* @__PURE__ */ new Date(), b = new Date(
|
|
43
|
-
g.getFullYear(),
|
|
44
|
-
g.getMonth(),
|
|
45
|
-
g.getDate(),
|
|
46
|
-
e,
|
|
47
|
-
s,
|
|
48
|
-
w
|
|
49
|
-
);
|
|
50
|
-
O(b), p?.(b);
|
|
51
|
-
}, I = (e) => {
|
|
52
|
-
let s = e;
|
|
53
|
-
n === "12" && (s = P === "PM" ? e % 12 + 12 : e % 12), M(s), m(s, S, y);
|
|
54
|
-
}, L = (e) => {
|
|
55
|
-
v(e), m(l, e, y);
|
|
56
|
-
}, R = (e) => {
|
|
57
|
-
H(e), m(l, S, e);
|
|
58
|
-
}, D = (e) => {
|
|
59
|
-
k(e);
|
|
60
|
-
const s = e === "PM" ? l % 12 + 12 : l % 12;
|
|
61
|
-
M(s), m(s, S, y);
|
|
62
|
-
}, T = (e, s, w, g, b = 0) => {
|
|
63
|
-
const F = Array.from({ length: s - b + 1 }, (f, K) => b + K);
|
|
64
|
-
return /* @__PURE__ */ c("div", { className: "flex flex-col", children: [
|
|
65
|
-
/* @__PURE__ */ r("div", { className: "text-xs font-semibold text-center text-base-content/60 py-2", children: e }),
|
|
66
|
-
/* @__PURE__ */ r("div", { className: "flex-1 overflow-y-auto max-h-48", children: F.map((f) => /* @__PURE__ */ r(
|
|
1
|
+
import { jsxs as C, jsx as s, Fragment as g } from "react/jsx-runtime";
|
|
2
|
+
import c, { useState as j } from "react";
|
|
3
|
+
function T({
|
|
4
|
+
children: a,
|
|
5
|
+
activeKey: e,
|
|
6
|
+
defaultActiveKey: p,
|
|
7
|
+
onChange: m,
|
|
8
|
+
variant: i,
|
|
9
|
+
size: n,
|
|
10
|
+
className: v = "",
|
|
11
|
+
...f
|
|
12
|
+
}) {
|
|
13
|
+
const o = c.Children.toArray(a).filter(
|
|
14
|
+
(t) => c.isValidElement(t) && t.type === d
|
|
15
|
+
), [x, u] = j(
|
|
16
|
+
p || o[0]?.props.tabKey || ""
|
|
17
|
+
), b = e !== void 0 ? e : x, y = (t) => {
|
|
18
|
+
e === void 0 && u(t), m?.(t);
|
|
19
|
+
}, h = {
|
|
20
|
+
box: "tabs-box",
|
|
21
|
+
border: "tabs-border",
|
|
22
|
+
lift: "tabs-lift"
|
|
23
|
+
}, K = {
|
|
24
|
+
xs: "tabs-xs",
|
|
25
|
+
sm: "tabs-sm",
|
|
26
|
+
md: "tabs-md",
|
|
27
|
+
lg: "tabs-lg",
|
|
28
|
+
xl: "tabs-xl"
|
|
29
|
+
}, A = ["tabs", i && h[i], n && K[n], v].filter(Boolean).join(" "), l = o.find((t) => t.props.tabKey === b);
|
|
30
|
+
return /* @__PURE__ */ C("div", { ...f, children: [
|
|
31
|
+
/* @__PURE__ */ s("div", { role: "tablist", className: A, children: o.map((t) => {
|
|
32
|
+
const r = b === t.props.tabKey;
|
|
33
|
+
return /* @__PURE__ */ s(
|
|
67
34
|
"button",
|
|
68
35
|
{
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
children:
|
|
36
|
+
role: "tab",
|
|
37
|
+
className: `tab ${r ? "tab-active" : ""} ${t.props.disabled ? "tab-disabled" : ""}`,
|
|
38
|
+
onClick: () => !t.props.disabled && y(t.props.tabKey),
|
|
39
|
+
disabled: t.props.disabled,
|
|
40
|
+
"data-state": r ? "active" : "inactive",
|
|
41
|
+
"aria-selected": r,
|
|
42
|
+
children: t.props.tab
|
|
76
43
|
},
|
|
77
|
-
|
|
78
|
-
)
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
return /* @__PURE__ */ c("div", { ref: A, className: `relative ${h}`, "data-state": u ? "open" : "closed", ...E, children: [
|
|
82
|
-
/* @__PURE__ */ r(
|
|
83
|
-
_,
|
|
84
|
-
{
|
|
85
|
-
value: q(o, n, $),
|
|
86
|
-
placeholder: i,
|
|
87
|
-
disabled: d,
|
|
88
|
-
size: x,
|
|
89
|
-
readOnly: !0,
|
|
90
|
-
onClick: () => !d && C(!u),
|
|
91
|
-
className: "cursor-pointer"
|
|
92
|
-
}
|
|
93
|
-
),
|
|
94
|
-
u && /* @__PURE__ */ c("div", { className: "absolute top-full left-0 mt-2 bg-base-100 border border-base-300 rounded-lg shadow-lg z-50", children: [
|
|
95
|
-
/* @__PURE__ */ c("div", { className: "flex divide-x divide-base-300", children: [
|
|
96
|
-
T(
|
|
97
|
-
"Hour",
|
|
98
|
-
n === "12" ? 12 : 23,
|
|
99
|
-
z,
|
|
100
|
-
I,
|
|
101
|
-
n === "12" ? 1 : 0
|
|
102
|
-
),
|
|
103
|
-
T("Min", 59, S, L),
|
|
104
|
-
$ && T("Sec", 59, y, R),
|
|
105
|
-
n === "12" && /* @__PURE__ */ c("div", { className: "flex flex-col", children: [
|
|
106
|
-
/* @__PURE__ */ r("div", { className: "text-xs font-semibold text-center text-base-content/60 py-2", children: "Period" }),
|
|
107
|
-
/* @__PURE__ */ c("div", { className: "flex-1 flex flex-col p-2 gap-2", children: [
|
|
108
|
-
/* @__PURE__ */ r(
|
|
109
|
-
"button",
|
|
110
|
-
{
|
|
111
|
-
type: "button",
|
|
112
|
-
onClick: () => D("AM"),
|
|
113
|
-
className: `
|
|
114
|
-
btn btn-sm
|
|
115
|
-
${P === "AM" ? "btn-primary" : "btn-ghost"}
|
|
116
|
-
`,
|
|
117
|
-
children: "AM"
|
|
118
|
-
}
|
|
119
|
-
),
|
|
120
|
-
/* @__PURE__ */ r(
|
|
121
|
-
"button",
|
|
122
|
-
{
|
|
123
|
-
type: "button",
|
|
124
|
-
onClick: () => D("PM"),
|
|
125
|
-
className: `
|
|
126
|
-
btn btn-sm
|
|
127
|
-
${P === "PM" ? "btn-primary" : "btn-ghost"}
|
|
128
|
-
`,
|
|
129
|
-
children: "PM"
|
|
130
|
-
}
|
|
131
|
-
)
|
|
132
|
-
] })
|
|
133
|
-
] })
|
|
134
|
-
] }),
|
|
135
|
-
/* @__PURE__ */ c("div", { className: "flex justify-end gap-2 p-3 border-t border-base-300", children: [
|
|
136
|
-
/* @__PURE__ */ r(
|
|
137
|
-
"button",
|
|
138
|
-
{
|
|
139
|
-
type: "button",
|
|
140
|
-
onClick: () => {
|
|
141
|
-
const e = /* @__PURE__ */ new Date();
|
|
142
|
-
M(e.getHours()), v(e.getMinutes()), H(e.getSeconds()), k(e.getHours() >= 12 ? "PM" : "AM"), m(e.getHours(), e.getMinutes(), e.getSeconds());
|
|
143
|
-
},
|
|
144
|
-
className: "btn btn-ghost btn-sm",
|
|
145
|
-
children: "Now"
|
|
146
|
-
}
|
|
147
|
-
),
|
|
148
|
-
/* @__PURE__ */ r(
|
|
149
|
-
"button",
|
|
150
|
-
{
|
|
151
|
-
type: "button",
|
|
152
|
-
onClick: () => C(!1),
|
|
153
|
-
className: "btn btn-primary btn-sm",
|
|
154
|
-
children: "OK"
|
|
155
|
-
}
|
|
156
|
-
)
|
|
157
|
-
] })
|
|
158
|
-
] })
|
|
44
|
+
t.props.tabKey
|
|
45
|
+
);
|
|
46
|
+
}) }),
|
|
47
|
+
l && /* @__PURE__ */ s("div", { className: "mt-4", children: l.props.children })
|
|
159
48
|
] });
|
|
160
|
-
}
|
|
49
|
+
}
|
|
50
|
+
function d({ children: a }) {
|
|
51
|
+
return /* @__PURE__ */ s(g, { children: a });
|
|
52
|
+
}
|
|
53
|
+
const R = Object.assign(T, {
|
|
54
|
+
Panel: d
|
|
55
|
+
});
|
|
161
56
|
export {
|
|
162
|
-
|
|
57
|
+
R as Tabs
|
|
163
58
|
};
|
|
164
59
|
//# sourceMappingURL=index78.js.map
|
package/dist/index78.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index78.js","sources":["../src/components/TimePicker.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react'\nimport { Input } from './Input'\n\nexport interface TimePickerProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'defaultValue'> {\n value?: Date | null\n defaultValue?: Date | null\n onChange?: (date: Date | null) => void\n format?: '12' | '24'\n placeholder?: string\n disabled?: boolean\n size?: 'xs' | 'sm' | 'md' | 'lg'\n showSeconds?: boolean\n}\n\nfunction formatTime(date: Date | null, format: '12' | '24' = '24', showSeconds: boolean = false): string {\n if (!date) return ''\n\n let hours = date.getHours()\n const minutes = String(date.getMinutes()).padStart(2, '0')\n const seconds = String(date.getSeconds()).padStart(2, '0')\n\n if (format === '12') {\n const period = hours >= 12 ? 'PM' : 'AM'\n hours = hours % 12 || 12\n const timeStr = showSeconds\n ? `${hours}:${minutes}:${seconds} ${period}`\n : `${hours}:${minutes} ${period}`\n return timeStr\n }\n\n const hoursStr = String(hours).padStart(2, '0')\n return showSeconds ? `${hoursStr}:${minutes}:${seconds}` : `${hoursStr}:${minutes}`\n}\n\nexport const TimePicker: React.FC<TimePickerProps> = ({\n value,\n defaultValue,\n onChange,\n format = '24',\n placeholder = 'Select time',\n disabled = false,\n className = '',\n size = 'md',\n showSeconds = false,\n ...rest\n}) => {\n const [selectedTime, setSelectedTime] = useState<Date | null>(\n value || defaultValue || null\n )\n const [isOpen, setIsOpen] = useState(false)\n const [hours, setHours] = useState(selectedTime ? selectedTime.getHours() : 0)\n const [minutes, setMinutes] = useState(selectedTime ? selectedTime.getMinutes() : 0)\n const [seconds, setSeconds] = useState(selectedTime ? selectedTime.getSeconds() : 0)\n const [period, setPeriod] = useState<'AM' | 'PM'>(\n selectedTime && selectedTime.getHours() >= 12 ? 'PM' : 'AM'\n )\n\n const containerRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (value !== undefined) {\n setSelectedTime(value)\n if (value) {\n setHours(value.getHours())\n setMinutes(value.getMinutes())\n setSeconds(value.getSeconds())\n setPeriod(value.getHours() >= 12 ? 'PM' : 'AM')\n }\n }\n }, [value])\n\n useEffect(() => {\n function handleClickOutside(event: MouseEvent) {\n if (containerRef.current && !containerRef.current.contains(event.target as Node)) {\n setIsOpen(false)\n }\n }\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside)\n return () => document.removeEventListener('mousedown', handleClickOutside)\n }\n }, [isOpen])\n\n const handleTimeChange = (newHours: number, newMinutes: number, newSeconds: number) => {\n const now = new Date()\n const newTime = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate(),\n newHours,\n newMinutes,\n newSeconds\n )\n setSelectedTime(newTime)\n onChange?.(newTime)\n }\n\n const handleHourChange = (newHour: number) => {\n let actualHour = newHour\n if (format === '12') {\n actualHour = period === 'PM' ? (newHour % 12) + 12 : newHour % 12\n }\n setHours(actualHour)\n handleTimeChange(actualHour, minutes, seconds)\n }\n\n const handleMinuteChange = (newMinute: number) => {\n setMinutes(newMinute)\n handleTimeChange(hours, newMinute, seconds)\n }\n\n const handleSecondChange = (newSecond: number) => {\n setSeconds(newSecond)\n handleTimeChange(hours, minutes, newSecond)\n }\n\n const handlePeriodChange = (newPeriod: 'AM' | 'PM') => {\n setPeriod(newPeriod)\n const newHours = newPeriod === 'PM'\n ? (hours % 12) + 12\n : hours % 12\n setHours(newHours)\n handleTimeChange(newHours, minutes, seconds)\n }\n\n const renderTimeColumn = (\n label: string,\n maxValue: number,\n currentValue: number,\n onChange: (value: number) => void,\n start: number = 0\n ) => {\n const items = Array.from({ length: maxValue - start + 1 }, (_, i) => start + i)\n\n return (\n <div className=\"flex flex-col\">\n <div className=\"text-xs font-semibold text-center text-base-content/60 py-2\">\n {label}\n </div>\n <div className=\"flex-1 overflow-y-auto max-h-48\">\n {items.map((item) => (\n <button\n key={item}\n type=\"button\"\n onClick={() => onChange(item)}\n className={`\n w-full px-4 py-2 text-center hover:bg-base-200 transition-colors\n ${currentValue === item ? 'bg-primary text-primary-content' : ''}\n `}\n >\n {String(item).padStart(2, '0')}\n </button>\n ))}\n </div>\n </div>\n )\n }\n\n const displayHours = format === '12' ? (hours % 12 || 12) : hours\n\n return (\n <div ref={containerRef} className={`relative ${className}`} data-state={isOpen ? 'open' : 'closed'} {...rest}>\n <Input\n value={formatTime(selectedTime, format, showSeconds)}\n placeholder={placeholder}\n disabled={disabled}\n size={size}\n readOnly\n onClick={() => !disabled && setIsOpen(!isOpen)}\n className=\"cursor-pointer\"\n />\n\n {isOpen && (\n <div className=\"absolute top-full left-0 mt-2 bg-base-100 border border-base-300 rounded-lg shadow-lg z-50\">\n <div className=\"flex divide-x divide-base-300\">\n {renderTimeColumn(\n 'Hour',\n format === '12' ? 12 : 23,\n displayHours,\n handleHourChange,\n format === '12' ? 1 : 0\n )}\n\n {renderTimeColumn('Min', 59, minutes, handleMinuteChange)}\n\n {showSeconds && renderTimeColumn('Sec', 59, seconds, handleSecondChange)}\n\n {format === '12' && (\n <div className=\"flex flex-col\">\n <div className=\"text-xs font-semibold text-center text-base-content/60 py-2\">\n Period\n </div>\n <div className=\"flex-1 flex flex-col p-2 gap-2\">\n <button\n type=\"button\"\n onClick={() => handlePeriodChange('AM')}\n className={`\n btn btn-sm\n ${period === 'AM' ? 'btn-primary' : 'btn-ghost'}\n `}\n >\n AM\n </button>\n <button\n type=\"button\"\n onClick={() => handlePeriodChange('PM')}\n className={`\n btn btn-sm\n ${period === 'PM' ? 'btn-primary' : 'btn-ghost'}\n `}\n >\n PM\n </button>\n </div>\n </div>\n )}\n </div>\n\n {/* Action buttons */}\n <div className=\"flex justify-end gap-2 p-3 border-t border-base-300\">\n <button\n type=\"button\"\n onClick={() => {\n const now = new Date()\n setHours(now.getHours())\n setMinutes(now.getMinutes())\n setSeconds(now.getSeconds())\n setPeriod(now.getHours() >= 12 ? 'PM' : 'AM')\n handleTimeChange(now.getHours(), now.getMinutes(), now.getSeconds())\n }}\n className=\"btn btn-ghost btn-sm\"\n >\n Now\n </button>\n <button\n type=\"button\"\n onClick={() => setIsOpen(false)}\n className=\"btn btn-primary btn-sm\"\n >\n OK\n </button>\n </div>\n </div>\n )}\n </div>\n )\n}\n"],"names":["formatTime","date","format","showSeconds","hours","minutes","seconds","period","hoursStr","TimePicker","value","defaultValue","onChange","placeholder","disabled","className","size","rest","selectedTime","setSelectedTime","useState","isOpen","setIsOpen","setHours","setMinutes","setSeconds","setPeriod","containerRef","useRef","useEffect","handleClickOutside","event","handleTimeChange","newHours","newMinutes","newSeconds","now","newTime","handleHourChange","newHour","actualHour","handleMinuteChange","newMinute","handleSecondChange","newSecond","handlePeriodChange","newPeriod","renderTimeColumn","label","maxValue","currentValue","start","items","_","i","jsxs","jsx","item","displayHours","Input"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index78.js","sources":["../src/components/Tabs.tsx"],"sourcesContent":["import React, { useState } from 'react'\n\nexport interface TabsProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n children: React.ReactNode\n activeKey?: string\n defaultActiveKey?: string\n onChange?: (key: string) => void\n variant?: 'box' | 'border' | 'lift'\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n}\n\nexport interface TabPanelProps {\n tab: React.ReactNode\n tabKey: string\n disabled?: boolean\n children?: React.ReactNode\n}\n\nfunction TabsRoot({\n children,\n activeKey,\n defaultActiveKey,\n onChange,\n variant,\n size,\n className = '',\n ...rest\n}: TabsProps) {\n // Get all panel children\n const panels = React.Children.toArray(children).filter(\n (child): child is React.ReactElement<TabPanelProps> =>\n React.isValidElement(child) && child.type === TabPanel\n )\n\n const [internalActiveKey, setInternalActiveKey] = useState(\n defaultActiveKey || panels[0]?.props.tabKey || ''\n )\n const currentActiveKey = activeKey !== undefined ? activeKey : internalActiveKey\n\n const handleTabClick = (key: string) => {\n if (activeKey === undefined) {\n setInternalActiveKey(key)\n }\n onChange?.(key)\n }\n\n const variantClasses = {\n box: 'tabs-box',\n border: 'tabs-border',\n lift: 'tabs-lift',\n }\n\n const sizeClasses = {\n xs: 'tabs-xs',\n sm: 'tabs-sm',\n md: 'tabs-md',\n lg: 'tabs-lg',\n xl: 'tabs-xl',\n }\n\n const classes = ['tabs', variant && variantClasses[variant], size && sizeClasses[size], className]\n .filter(Boolean)\n .join(' ')\n\n const activePanel = panels.find((panel) => panel.props.tabKey === currentActiveKey)\n\n return (\n <div {...rest}>\n <div role=\"tablist\" className={classes}>\n {panels.map((panel) => {\n const isActive = currentActiveKey === panel.props.tabKey\n return (\n <button\n key={panel.props.tabKey}\n role=\"tab\"\n className={`tab ${isActive ? 'tab-active' : ''} ${\n panel.props.disabled ? 'tab-disabled' : ''\n }`}\n onClick={() => !panel.props.disabled && handleTabClick(panel.props.tabKey)}\n disabled={panel.props.disabled}\n data-state={isActive ? 'active' : 'inactive'}\n aria-selected={isActive}\n >\n {panel.props.tab}\n </button>\n )\n })}\n </div>\n {activePanel && <div className=\"mt-4\">{activePanel.props.children}</div>}\n </div>\n )\n}\n\nfunction TabPanel({ children }: TabPanelProps) {\n // This component is only used for type checking and is not rendered directly\n // The actual rendering is done in TabsRoot\n return <>{children}</>\n}\n\nexport const Tabs = Object.assign(TabsRoot, {\n Panel: TabPanel,\n})\n"],"names":["TabsRoot","children","activeKey","defaultActiveKey","onChange","variant","size","className","rest","panels","React","child","TabPanel","internalActiveKey","setInternalActiveKey","useState","currentActiveKey","handleTabClick","key","variantClasses","sizeClasses","classes","activePanel","panel","jsxs","jsx","isActive","Tabs"],"mappings":";;AAkBA,SAASA,EAAS;AAAA,EAChB,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,UAAAC;AAAA,EACA,SAAAC;AAAA,EACA,MAAAC;AAAA,EACA,WAAAC,IAAY;AAAA,EACZ,GAAGC;AACL,GAAc;AAEZ,QAAMC,IAASC,EAAM,SAAS,QAAQT,CAAQ,EAAE;AAAA,IAC9C,CAACU,MACCD,EAAM,eAAeC,CAAK,KAAKA,EAAM,SAASC;AAAA,EAAA,GAG5C,CAACC,GAAmBC,CAAoB,IAAIC;AAAA,IAChDZ,KAAoBM,EAAO,CAAC,GAAG,MAAM,UAAU;AAAA,EAAA,GAE3CO,IAAmBd,MAAc,SAAYA,IAAYW,GAEzDI,IAAiB,CAACC,MAAgB;AACtC,IAAIhB,MAAc,UAChBY,EAAqBI,CAAG,GAE1Bd,IAAWc,CAAG;AAAA,EAChB,GAEMC,IAAiB;AAAA,IACrB,KAAK;AAAA,IACL,QAAQ;AAAA,IACR,MAAM;AAAA,EAAA,GAGFC,IAAc;AAAA,IAClB,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,EAAA,GAGAC,IAAU,CAAC,QAAQhB,KAAWc,EAAed,CAAO,GAAGC,KAAQc,EAAYd,CAAI,GAAGC,CAAS,EAC9F,OAAO,OAAO,EACd,KAAK,GAAG,GAELe,IAAcb,EAAO,KAAK,CAACc,MAAUA,EAAM,MAAM,WAAWP,CAAgB;AAElF,SACE,gBAAAQ,EAAC,OAAA,EAAK,GAAGhB,GACP,UAAA;AAAA,IAAA,gBAAAiB,EAAC,OAAA,EAAI,MAAK,WAAU,WAAWJ,GAC5B,UAAAZ,EAAO,IAAI,CAACc,MAAU;AACrB,YAAMG,IAAWV,MAAqBO,EAAM,MAAM;AAClD,aACE,gBAAAE;AAAA,QAAC;AAAA,QAAA;AAAA,UAEC,MAAK;AAAA,UACL,WAAW,OAAOC,IAAW,eAAe,EAAE,IAC5CH,EAAM,MAAM,WAAW,iBAAiB,EAC1C;AAAA,UACA,SAAS,MAAM,CAACA,EAAM,MAAM,YAAYN,EAAeM,EAAM,MAAM,MAAM;AAAA,UACzE,UAAUA,EAAM,MAAM;AAAA,UACtB,cAAYG,IAAW,WAAW;AAAA,UAClC,iBAAeA;AAAA,UAEd,YAAM,MAAM;AAAA,QAAA;AAAA,QAVRH,EAAM,MAAM;AAAA,MAAA;AAAA,IAavB,CAAC,EAAA,CACH;AAAA,IACCD,KAAe,gBAAAG,EAAC,OAAA,EAAI,WAAU,QAAQ,UAAAH,EAAY,MAAM,SAAA,CAAS;AAAA,EAAA,GACpE;AAEJ;AAEA,SAASV,EAAS,EAAE,UAAAX,KAA2B;AAG7C,gCAAU,UAAAA,GAAS;AACrB;AAEO,MAAM0B,IAAO,OAAO,OAAO3B,GAAU;AAAA,EAC1C,OAAOY;AACT,CAAC;"}
|
package/dist/index79.js
CHANGED
|
@@ -1,68 +1,43 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
}) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
l
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
/* @__PURE__ */ e("hr", {}),
|
|
41
|
-
i && /* @__PURE__ */ e("div", { className: "timeline-middle", children: i }),
|
|
42
|
-
l && /* @__PURE__ */ e("div", { className: c, children: l }),
|
|
43
|
-
t !== void 0 && /* @__PURE__ */ e("hr", {})
|
|
44
|
-
] }) : f ? /* @__PURE__ */ d("li", { className: r, ...s, children: [
|
|
45
|
-
/* @__PURE__ */ e("hr", {}),
|
|
46
|
-
n && /* @__PURE__ */ e("div", { className: m, children: n }),
|
|
47
|
-
i && /* @__PURE__ */ e("div", { className: "timeline-middle", children: i }),
|
|
48
|
-
l && /* @__PURE__ */ e("div", { className: c, children: l }),
|
|
49
|
-
/* @__PURE__ */ e("hr", {})
|
|
50
|
-
] }) : u ? /* @__PURE__ */ d("li", { className: r, ...s, children: [
|
|
51
|
-
n && /* @__PURE__ */ e("div", { className: m, children: n }),
|
|
52
|
-
i && /* @__PURE__ */ e("div", { className: "timeline-middle", children: i }),
|
|
53
|
-
l && /* @__PURE__ */ e("div", { className: c, children: l }),
|
|
54
|
-
/* @__PURE__ */ e("hr", {})
|
|
55
|
-
] }) : /* @__PURE__ */ d("li", { className: r, ...s, children: [
|
|
56
|
-
/* @__PURE__ */ e("hr", {}),
|
|
57
|
-
i && /* @__PURE__ */ e("div", { className: "timeline-middle", children: i }),
|
|
58
|
-
n && /* @__PURE__ */ e("div", { className: m, children: n }),
|
|
59
|
-
l && /* @__PURE__ */ e("div", { className: c, children: l })
|
|
60
|
-
] });
|
|
61
|
-
}
|
|
62
|
-
const b = Object.assign(N, {
|
|
63
|
-
Item: p
|
|
64
|
-
});
|
|
1
|
+
import { jsx as m } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as i } from "react";
|
|
3
|
+
const f = i(
|
|
4
|
+
({
|
|
5
|
+
size: e,
|
|
6
|
+
color: a,
|
|
7
|
+
ghost: t = !1,
|
|
8
|
+
bordered: r = !0,
|
|
9
|
+
className: s = "",
|
|
10
|
+
...x
|
|
11
|
+
}, o) => {
|
|
12
|
+
const n = {
|
|
13
|
+
xs: "textarea-xs",
|
|
14
|
+
sm: "textarea-sm",
|
|
15
|
+
md: "textarea-md",
|
|
16
|
+
lg: "textarea-lg",
|
|
17
|
+
xl: "textarea-xl"
|
|
18
|
+
}, l = {
|
|
19
|
+
neutral: "textarea-neutral",
|
|
20
|
+
primary: "textarea-primary",
|
|
21
|
+
secondary: "textarea-secondary",
|
|
22
|
+
accent: "textarea-accent",
|
|
23
|
+
info: "textarea-info",
|
|
24
|
+
success: "textarea-success",
|
|
25
|
+
warning: "textarea-warning",
|
|
26
|
+
error: "textarea-error"
|
|
27
|
+
}, c = [
|
|
28
|
+
"textarea",
|
|
29
|
+
"w-full",
|
|
30
|
+
r && "textarea-bordered",
|
|
31
|
+
t && "textarea-ghost",
|
|
32
|
+
e && n[e],
|
|
33
|
+
a && l[a],
|
|
34
|
+
s
|
|
35
|
+
].filter(Boolean).join(" ");
|
|
36
|
+
return /* @__PURE__ */ m("textarea", { ref: o, className: c, ...x });
|
|
37
|
+
}
|
|
38
|
+
);
|
|
39
|
+
f.displayName = "Textarea";
|
|
65
40
|
export {
|
|
66
|
-
|
|
41
|
+
f as Textarea
|
|
67
42
|
};
|
|
68
43
|
//# sourceMappingURL=index79.js.map
|
package/dist/index79.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index79.js","sources":["../src/components/
|
|
1
|
+
{"version":3,"file":"index79.js","sources":["../src/components/Textarea.tsx"],"sourcesContent":["import React, { forwardRef } from 'react'\n\nexport interface TextareaProps extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'size'> {\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}\n\nexport const Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>(\n (\n {\n size,\n color,\n ghost = false,\n bordered = true,\n className = '',\n ...props\n },\n ref\n ) => {\n const sizeClasses = {\n xs: 'textarea-xs',\n sm: 'textarea-sm',\n md: 'textarea-md',\n lg: 'textarea-lg',\n xl: 'textarea-xl',\n }\n\n const colorClasses = {\n neutral: 'textarea-neutral',\n primary: 'textarea-primary',\n secondary: 'textarea-secondary',\n accent: 'textarea-accent',\n info: 'textarea-info',\n success: 'textarea-success',\n warning: 'textarea-warning',\n error: 'textarea-error',\n }\n\n const textareaClasses = [\n 'textarea',\n 'w-full',\n bordered && 'textarea-bordered',\n ghost && 'textarea-ghost',\n size && sizeClasses[size],\n color && colorClasses[color],\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return <textarea ref={ref} className={textareaClasses} {...props} />\n }\n)\n\nTextarea.displayName = 'Textarea'\n"],"names":["Textarea","forwardRef","size","color","ghost","bordered","className","props","ref","sizeClasses","colorClasses","textareaClasses"],"mappings":";;AAUO,MAAMA,IAAWC;AAAA,EACtB,CACE;AAAA,IACE,MAAAC;AAAA,IACA,OAAAC;AAAA,IACA,OAAAC,IAAQ;AAAA,IACR,UAAAC,IAAW;AAAA,IACX,WAAAC,IAAY;AAAA,IACZ,GAAGC;AAAA,EAAA,GAELC,MACG;AACH,UAAMC,IAAc;AAAA,MAClB,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IAAA,GAGAC,IAAe;AAAA,MACnB,SAAS;AAAA,MACT,SAAS;AAAA,MACT,WAAW;AAAA,MACX,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,MACT,OAAO;AAAA,IAAA,GAGHC,IAAkB;AAAA,MACtB;AAAA,MACA;AAAA,MACAN,KAAY;AAAA,MACZD,KAAS;AAAA,MACTF,KAAQO,EAAYP,CAAI;AAAA,MACxBC,KAASO,EAAaP,CAAK;AAAA,MAC3BG;AAAA,IAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,6BAAQ,YAAA,EAAS,KAAAE,GAAU,WAAWG,GAAkB,GAAGJ,GAAO;AAAA,EACpE;AACF;AAEAP,EAAS,cAAc;"}
|
package/dist/index8.js
CHANGED
|
@@ -1,73 +1,14 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
|
|
3
|
-
children:
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
shape: a,
|
|
12
|
-
noAnimation: m = !1,
|
|
13
|
-
className: h = "",
|
|
14
|
-
...n
|
|
15
|
-
}) => {
|
|
16
|
-
const y = {
|
|
17
|
-
primary: "btn-primary",
|
|
18
|
-
secondary: "btn-secondary",
|
|
19
|
-
accent: "btn-accent",
|
|
20
|
-
info: "btn-info",
|
|
21
|
-
success: "btn-success",
|
|
22
|
-
warning: "btn-warning",
|
|
23
|
-
error: "btn-error",
|
|
24
|
-
neutral: "btn-neutral",
|
|
25
|
-
ghost: "btn-ghost",
|
|
26
|
-
link: "btn-link"
|
|
27
|
-
}, g = {
|
|
28
|
-
xs: "btn-xs",
|
|
29
|
-
sm: "btn-sm",
|
|
30
|
-
md: "",
|
|
31
|
-
lg: "btn-lg",
|
|
32
|
-
xl: "btn-xl"
|
|
33
|
-
}, x = {
|
|
34
|
-
square: "btn-square",
|
|
35
|
-
circle: "btn-circle",
|
|
36
|
-
wide: "btn-wide",
|
|
37
|
-
block: "btn-block"
|
|
38
|
-
}, r = [
|
|
39
|
-
"btn",
|
|
40
|
-
e && y[e],
|
|
41
|
-
g[b],
|
|
42
|
-
i && "btn-outline",
|
|
43
|
-
d && "btn-dash",
|
|
44
|
-
u && "btn-soft",
|
|
45
|
-
f && "btn-active",
|
|
46
|
-
a && x[a],
|
|
47
|
-
m && "no-animation",
|
|
48
|
-
h
|
|
49
|
-
].filter(Boolean).join(" "), o = /* @__PURE__ */ j(v, { children: [
|
|
50
|
-
t && /* @__PURE__ */ s("span", { className: "loading loading-spinner", "aria-hidden": "true" }),
|
|
51
|
-
l
|
|
52
|
-
] });
|
|
53
|
-
if ("href" in n && n.href !== void 0) {
|
|
54
|
-
const { href: k, ...w } = n;
|
|
55
|
-
return /* @__PURE__ */ s("a", { href: k, className: r, ...w, children: o });
|
|
56
|
-
}
|
|
57
|
-
const { htmlType: p, ...c } = n;
|
|
58
|
-
return /* @__PURE__ */ s(
|
|
59
|
-
"button",
|
|
60
|
-
{
|
|
61
|
-
type: p ?? "button",
|
|
62
|
-
className: r,
|
|
63
|
-
"aria-busy": t ? "true" : void 0,
|
|
64
|
-
disabled: t || c.disabled,
|
|
65
|
-
...c,
|
|
66
|
-
children: o
|
|
67
|
-
}
|
|
68
|
-
);
|
|
69
|
-
};
|
|
1
|
+
import { jsx as r } from "react/jsx-runtime";
|
|
2
|
+
function c({ children: t, className: e = "", ...u }) {
|
|
3
|
+
return /* @__PURE__ */ r("div", { className: `breadcrumbs text-sm ${e}`, ...u, children: /* @__PURE__ */ r("ul", { children: t }) });
|
|
4
|
+
}
|
|
5
|
+
function i({ children: t, href: e, onClick: u, className: m = "", ...n }) {
|
|
6
|
+
return e || u ? /* @__PURE__ */ r("li", { className: m, ...n, children: /* @__PURE__ */ r("a", { href: e, onClick: u, children: t }) }) : /* @__PURE__ */ r("li", { className: m, ...n, children: t });
|
|
7
|
+
}
|
|
8
|
+
const a = Object.assign(c, {
|
|
9
|
+
Item: i
|
|
10
|
+
});
|
|
70
11
|
export {
|
|
71
|
-
|
|
12
|
+
a as Breadcrumb
|
|
72
13
|
};
|
|
73
14
|
//# sourceMappingURL=index8.js.map
|
package/dist/index8.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index8.js","sources":["../src/components/
|
|
1
|
+
{"version":3,"file":"index8.js","sources":["../src/components/Breadcrumb.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface BreadcrumbProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n}\n\nexport interface BreadcrumbItemProps extends Omit<React.LiHTMLAttributes<HTMLLIElement>, 'onClick'> {\n children: React.ReactNode\n href?: string\n onClick?: () => void\n}\n\nfunction BreadcrumbRoot({ children, className = '', ...rest }: BreadcrumbProps) {\n return (\n <div className={`breadcrumbs text-sm ${className}`} {...rest}>\n <ul>{children}</ul>\n </div>\n )\n}\n\nfunction BreadcrumbItem({ children, href, onClick, className = '', ...rest }: BreadcrumbItemProps) {\n if (href || onClick) {\n return (\n <li className={className} {...rest}>\n <a href={href} onClick={onClick}>\n {children}\n </a>\n </li>\n )\n }\n\n return <li className={className} {...rest}>{children}</li>\n}\n\nexport const Breadcrumb = Object.assign(BreadcrumbRoot, {\n Item: BreadcrumbItem,\n})\n"],"names":["BreadcrumbRoot","children","className","rest","jsx","BreadcrumbItem","href","onClick","Breadcrumb"],"mappings":";AAYA,SAASA,EAAe,EAAE,UAAAC,GAAU,WAAAC,IAAY,IAAI,GAAGC,KAAyB;AAC9E,SACE,gBAAAC,EAAC,OAAA,EAAI,WAAW,uBAAuBF,CAAS,IAAK,GAAGC,GACtD,UAAA,gBAAAC,EAAC,MAAA,EAAI,UAAAH,EAAA,CAAS,GAChB;AAEJ;AAEA,SAASI,EAAe,EAAE,UAAAJ,GAAU,MAAAK,GAAM,SAAAC,GAAS,WAAAL,IAAY,IAAI,GAAGC,KAA6B;AACjG,SAAIG,KAAQC,IAER,gBAAAH,EAAC,MAAA,EAAG,WAAAF,GAAuB,GAAGC,GAC5B,4BAAC,KAAA,EAAE,MAAAG,GAAY,SAAAC,GACZ,UAAAN,EAAA,CACH,EAAA,CACF,IAIG,gBAAAG,EAAC,MAAA,EAAG,WAAAF,GAAuB,GAAGC,GAAO,UAAAF,GAAS;AACvD;AAEO,MAAMO,IAAa,OAAO,OAAOR,GAAgB;AAAA,EACtD,MAAMK;AACR,CAAC;"}
|
package/dist/index80.js
CHANGED
|
@@ -1,38 +1,26 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
info: "toggle-info",
|
|
24
|
-
error: "toggle-error"
|
|
25
|
-
}, r = [
|
|
26
|
-
"toggle",
|
|
27
|
-
e && s[e],
|
|
28
|
-
g && a[g],
|
|
29
|
-
t
|
|
30
|
-
].filter(Boolean).join(" "), c = o.checked ? "checked" : "unchecked";
|
|
31
|
-
return /* @__PURE__ */ n("input", { ref: l, type: "checkbox", className: r, "data-state": c, ...o });
|
|
32
|
-
}
|
|
33
|
-
);
|
|
34
|
-
m.displayName = "Toggle";
|
|
1
|
+
import { jsx as t } from "react/jsx-runtime";
|
|
2
|
+
const c = {
|
|
3
|
+
6e3: "duration-6000",
|
|
4
|
+
9e3: "duration-9000",
|
|
5
|
+
12e3: "duration-12000",
|
|
6
|
+
15e3: "duration-15000",
|
|
7
|
+
18e3: "duration-18000"
|
|
8
|
+
}, l = ({
|
|
9
|
+
items: s,
|
|
10
|
+
duration: e,
|
|
11
|
+
centered: a = !1,
|
|
12
|
+
className: n = ""
|
|
13
|
+
}) => {
|
|
14
|
+
const r = e ? c[e] : "";
|
|
15
|
+
return /* @__PURE__ */ t(
|
|
16
|
+
"span",
|
|
17
|
+
{
|
|
18
|
+
className: `text-rotate ${r} ${a ? "justify-items-center" : ""} ${n}`.trim(),
|
|
19
|
+
children: /* @__PURE__ */ t("span", { children: s.slice(0, 6).map((i, o) => /* @__PURE__ */ t("span", { children: i }, o)) })
|
|
20
|
+
}
|
|
21
|
+
);
|
|
22
|
+
};
|
|
35
23
|
export {
|
|
36
|
-
|
|
24
|
+
l as TextRotate
|
|
37
25
|
};
|
|
38
26
|
//# sourceMappingURL=index80.js.map
|
package/dist/index80.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index80.js","sources":["../src/components/
|
|
1
|
+
{"version":3,"file":"index80.js","sources":["../src/components/TextRotate.tsx"],"sourcesContent":["import React from 'react'\n\nexport type TextRotateDuration = 6000 | 9000 | 12000 | 15000 | 18000\n\nconst durationClasses: Record<TextRotateDuration, string> = {\n 6000: 'duration-6000',\n 9000: 'duration-9000',\n 12000: 'duration-12000',\n 15000: 'duration-15000',\n 18000: 'duration-18000',\n}\n\nexport interface TextRotateProps {\n /** Text items to rotate through (max 6) */\n items: React.ReactNode[]\n /** Animation duration in ms (default 10000) */\n duration?: TextRotateDuration\n /** Center text horizontally */\n centered?: boolean\n /** Additional CSS classes */\n className?: string\n}\n\nexport const TextRotate: React.FC<TextRotateProps> = ({\n items,\n duration,\n centered = false,\n className = '',\n}) => {\n const durationClass = duration ? durationClasses[duration] : ''\n\n return (\n <span\n className={`text-rotate ${durationClass} ${centered ? 'justify-items-center' : ''} ${className}`.trim()}\n >\n <span>\n {items.slice(0, 6).map((item, index) => (\n <span key={index}>{item}</span>\n ))}\n </span>\n </span>\n )\n}\n"],"names":["durationClasses","TextRotate","items","duration","centered","className","durationClass","jsx","item","index"],"mappings":";AAIA,MAAMA,IAAsD;AAAA,EAC1D,KAAM;AAAA,EACN,KAAM;AAAA,EACN,MAAO;AAAA,EACP,MAAO;AAAA,EACP,MAAO;AACT,GAaaC,IAAwC,CAAC;AAAA,EACpD,OAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,WAAAC,IAAY;AACd,MAAM;AACJ,QAAMC,IAAgBH,IAAWH,EAAgBG,CAAQ,IAAI;AAE7D,SACE,gBAAAI;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,eAAeD,CAAa,IAAIF,IAAW,yBAAyB,EAAE,IAAIC,CAAS,GAAG,KAAA;AAAA,MAEjG,4BAAC,QAAA,EACE,UAAAH,EAAM,MAAM,GAAG,CAAC,EAAE,IAAI,CAACM,GAAMC,MAC5B,gBAAAF,EAAC,QAAA,EAAkB,UAAAC,EAAA,GAARC,CAAa,CACzB,EAAA,CACH;AAAA,IAAA;AAAA,EAAA;AAGN;"}
|