asterui 0.12.48 → 0.12.50

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.
Files changed (201) hide show
  1. package/dist/components/Alert.js +18 -18
  2. package/dist/components/Alert.js.map +1 -1
  3. package/dist/components/Anchor.js +53 -53
  4. package/dist/components/Anchor.js.map +1 -1
  5. package/dist/components/Autocomplete.js +115 -114
  6. package/dist/components/Autocomplete.js.map +1 -1
  7. package/dist/components/Avatar.js +33 -32
  8. package/dist/components/Avatar.js.map +1 -1
  9. package/dist/components/Badge.js +99 -99
  10. package/dist/components/Badge.js.map +1 -1
  11. package/dist/components/Breadcrumb.js +12 -11
  12. package/dist/components/Breadcrumb.js.map +1 -1
  13. package/dist/components/Browser.js +10 -10
  14. package/dist/components/Browser.js.map +1 -1
  15. package/dist/components/Button.js +80 -79
  16. package/dist/components/Button.js.map +1 -1
  17. package/dist/components/Card.d.ts +2 -0
  18. package/dist/components/Card.js +111 -110
  19. package/dist/components/Card.js.map +1 -1
  20. package/dist/components/Carousel.js +59 -59
  21. package/dist/components/Carousel.js.map +1 -1
  22. package/dist/components/Cascader.js +175 -174
  23. package/dist/components/Cascader.js.map +1 -1
  24. package/dist/components/Chat.js +27 -27
  25. package/dist/components/Chat.js.map +1 -1
  26. package/dist/components/Checkbox.js +98 -97
  27. package/dist/components/Checkbox.js.map +1 -1
  28. package/dist/components/Code.js +11 -11
  29. package/dist/components/Code.js.map +1 -1
  30. package/dist/components/Collapse.js +46 -46
  31. package/dist/components/Collapse.js.map +1 -1
  32. package/dist/components/ColorPicker.d.ts +1 -1
  33. package/dist/components/ColorPicker.js +93 -91
  34. package/dist/components/ColorPicker.js.map +1 -1
  35. package/dist/components/Command.d.ts +65 -0
  36. package/dist/components/Command.js +422 -0
  37. package/dist/components/Command.js.map +1 -0
  38. package/dist/components/ConfigProvider.d.ts +1 -1
  39. package/dist/components/ConfigProvider.js +9 -9
  40. package/dist/components/ConfigProvider.js.map +1 -1
  41. package/dist/components/ContextMenu.js +33 -33
  42. package/dist/components/ContextMenu.js.map +1 -1
  43. package/dist/components/CopyButton.js +74 -73
  44. package/dist/components/CopyButton.js.map +1 -1
  45. package/dist/components/Countdown.js +60 -59
  46. package/dist/components/Countdown.js.map +1 -1
  47. package/dist/components/DatePicker.d.ts +1 -1
  48. package/dist/components/DatePicker.js +54 -53
  49. package/dist/components/DatePicker.js.map +1 -1
  50. package/dist/components/Diff.js +10 -10
  51. package/dist/components/Diff.js.map +1 -1
  52. package/dist/components/Divider.js +21 -20
  53. package/dist/components/Divider.js.map +1 -1
  54. package/dist/components/Dock.js +28 -27
  55. package/dist/components/Dock.js.map +1 -1
  56. package/dist/components/Drawer.js +43 -43
  57. package/dist/components/Drawer.js.map +1 -1
  58. package/dist/components/Dropdown.js +127 -127
  59. package/dist/components/Dropdown.js.map +1 -1
  60. package/dist/components/Empty.js +16 -15
  61. package/dist/components/Empty.js.map +1 -1
  62. package/dist/components/Fieldset.js +11 -10
  63. package/dist/components/Fieldset.js.map +1 -1
  64. package/dist/components/FileInput.js +30 -29
  65. package/dist/components/FileInput.js.map +1 -1
  66. package/dist/components/Filter.d.ts +1 -1
  67. package/dist/components/Filter.js +32 -30
  68. package/dist/components/Filter.js.map +1 -1
  69. package/dist/components/FloatButton.js +83 -83
  70. package/dist/components/FloatButton.js.map +1 -1
  71. package/dist/components/Footer.js +14 -13
  72. package/dist/components/Footer.js.map +1 -1
  73. package/dist/components/Form.js +133 -132
  74. package/dist/components/Form.js.map +1 -1
  75. package/dist/components/Hero.js +12 -11
  76. package/dist/components/Hero.js.map +1 -1
  77. package/dist/components/HoverGallery.js +7 -7
  78. package/dist/components/HoverGallery.js.map +1 -1
  79. package/dist/components/Image.js +40 -40
  80. package/dist/components/Image.js.map +1 -1
  81. package/dist/components/Input.js +171 -169
  82. package/dist/components/Input.js.map +1 -1
  83. package/dist/components/InputNumber.js +84 -83
  84. package/dist/components/InputNumber.js.map +1 -1
  85. package/dist/components/Join.js +11 -10
  86. package/dist/components/Join.js.map +1 -1
  87. package/dist/components/Kbd.js +15 -15
  88. package/dist/components/Kbd.js.map +1 -1
  89. package/dist/components/Layout.js +66 -66
  90. package/dist/components/Layout.js.map +1 -1
  91. package/dist/components/List.d.ts +1 -1
  92. package/dist/components/List.js +75 -72
  93. package/dist/components/List.js.map +1 -1
  94. package/dist/components/Loading.d.ts +1 -1
  95. package/dist/components/Loading.js +31 -29
  96. package/dist/components/Loading.js.map +1 -1
  97. package/dist/components/Mask.js +31 -31
  98. package/dist/components/Mask.js.map +1 -1
  99. package/dist/components/Mention.js +61 -61
  100. package/dist/components/Mention.js.map +1 -1
  101. package/dist/components/Menu.js +84 -84
  102. package/dist/components/Menu.js.map +1 -1
  103. package/dist/components/Message.js +30 -29
  104. package/dist/components/Message.js.map +1 -1
  105. package/dist/components/Modal.js +117 -116
  106. package/dist/components/Modal.js.map +1 -1
  107. package/dist/components/MonthCalendar.d.ts +31 -0
  108. package/dist/components/MonthCalendar.js +205 -0
  109. package/dist/components/MonthCalendar.js.map +1 -0
  110. package/dist/components/Navbar.js +25 -25
  111. package/dist/components/Navbar.js.map +1 -1
  112. package/dist/components/Notification.js +56 -55
  113. package/dist/components/Notification.js.map +1 -1
  114. package/dist/components/OTPInput.js +69 -68
  115. package/dist/components/OTPInput.js.map +1 -1
  116. package/dist/components/Pagination.d.ts +1 -1
  117. package/dist/components/Pagination.js +60 -58
  118. package/dist/components/Pagination.js.map +1 -1
  119. package/dist/components/Phone.js +10 -10
  120. package/dist/components/Phone.js.map +1 -1
  121. package/dist/components/Popconfirm.js +60 -60
  122. package/dist/components/Popconfirm.js.map +1 -1
  123. package/dist/components/Progress.js +17 -17
  124. package/dist/components/Progress.js.map +1 -1
  125. package/dist/components/QRCode.js +23 -23
  126. package/dist/components/QRCode.js.map +1 -1
  127. package/dist/components/RadialProgress.js +17 -17
  128. package/dist/components/RadialProgress.js.map +1 -1
  129. package/dist/components/Radio.js +41 -40
  130. package/dist/components/Radio.js.map +1 -1
  131. package/dist/components/Range.d.ts +1 -1
  132. package/dist/components/Range.js +39 -37
  133. package/dist/components/Range.js.map +1 -1
  134. package/dist/components/Rating.js +79 -78
  135. package/dist/components/Rating.js.map +1 -1
  136. package/dist/components/ResponsiveDrawer.js +27 -27
  137. package/dist/components/ResponsiveDrawer.js.map +1 -1
  138. package/dist/components/RichTextEditor.d.ts +32 -0
  139. package/dist/components/RichTextEditor.js +335 -0
  140. package/dist/components/RichTextEditor.js.map +1 -0
  141. package/dist/components/Segmented.d.ts +1 -1
  142. package/dist/components/Segmented.js +48 -46
  143. package/dist/components/Segmented.js.map +1 -1
  144. package/dist/components/Select.js +55 -54
  145. package/dist/components/Select.js.map +1 -1
  146. package/dist/components/Skeleton.js +9 -9
  147. package/dist/components/Skeleton.js.map +1 -1
  148. package/dist/components/Splitter.js +93 -93
  149. package/dist/components/Splitter.js.map +1 -1
  150. package/dist/components/Stat.js +17 -16
  151. package/dist/components/Stat.js.map +1 -1
  152. package/dist/components/Status.js +29 -29
  153. package/dist/components/Status.js.map +1 -1
  154. package/dist/components/Steps.js +61 -61
  155. package/dist/components/Steps.js.map +1 -1
  156. package/dist/components/Table.js +256 -256
  157. package/dist/components/Table.js.map +1 -1
  158. package/dist/components/Tabs.js +65 -65
  159. package/dist/components/Tabs.js.map +1 -1
  160. package/dist/components/Tag.js +147 -147
  161. package/dist/components/Tag.js.map +1 -1
  162. package/dist/components/TextRotate.js +6 -6
  163. package/dist/components/TextRotate.js.map +1 -1
  164. package/dist/components/Textarea.js +35 -34
  165. package/dist/components/Textarea.js.map +1 -1
  166. package/dist/components/ThemeController.d.ts +1 -1
  167. package/dist/components/ThemeController.js +71 -68
  168. package/dist/components/ThemeController.js.map +1 -1
  169. package/dist/components/TimePicker.d.ts +1 -1
  170. package/dist/components/TimePicker.js +133 -129
  171. package/dist/components/TimePicker.js.map +1 -1
  172. package/dist/components/Timeline.js +79 -79
  173. package/dist/components/Timeline.js.map +1 -1
  174. package/dist/components/Toggle.js +33 -32
  175. package/dist/components/Toggle.js.map +1 -1
  176. package/dist/components/Tooltip.js +25 -25
  177. package/dist/components/Tooltip.js.map +1 -1
  178. package/dist/components/Tour.js +126 -126
  179. package/dist/components/Tour.js.map +1 -1
  180. package/dist/components/Transfer.js +93 -92
  181. package/dist/components/Transfer.js.map +1 -1
  182. package/dist/components/Tree.js +200 -200
  183. package/dist/components/Tree.js.map +1 -1
  184. package/dist/components/TreeSelect.js +255 -254
  185. package/dist/components/TreeSelect.js.map +1 -1
  186. package/dist/components/Typography.js +71 -70
  187. package/dist/components/Typography.js.map +1 -1
  188. package/dist/components/Upload.js +81 -81
  189. package/dist/components/Upload.js.map +1 -1
  190. package/dist/components/WeekCalendar.d.ts +35 -0
  191. package/dist/components/WeekCalendar.js +204 -0
  192. package/dist/components/WeekCalendar.js.map +1 -0
  193. package/dist/components/Window.js +7 -7
  194. package/dist/components/Window.js.map +1 -1
  195. package/dist/editor.d.ts +1 -0
  196. package/dist/editor.js +5 -0
  197. package/dist/editor.js.map +1 -0
  198. package/dist/index.d.ts +6 -0
  199. package/dist/index.js +221 -215
  200. package/dist/index.js.map +1 -1
  201. package/package.json +30 -1
@@ -1,27 +1,27 @@
1
- import { jsx as n, jsxs as j, Fragment as $ } from "react/jsx-runtime";
2
- import { forwardRef as I, useState as M } from "react";
3
- const p = {
4
- primary: "badge-primary",
5
- secondary: "badge-secondary",
6
- accent: "badge-accent",
7
- neutral: "badge-neutral",
8
- info: "badge-info",
9
- success: "badge-success",
10
- warning: "badge-warning",
11
- error: "badge-error",
12
- ghost: "badge-ghost"
13
- }, L = {
14
- xs: "badge-xs text-xs",
15
- sm: "badge-sm text-sm",
16
- md: "badge-md",
17
- lg: "badge-lg text-lg",
18
- xl: "badge-xl text-xl"
19
- }, z = {
1
+ import { jsx as s, jsxs as X, Fragment as q } from "react/jsx-runtime";
2
+ import { forwardRef as G, useState as H } from "react";
3
+ const P = "badge", y = "badge-primary", B = "badge-secondary", C = "badge-accent", x = "badge-neutral", k = "badge-info", w = "badge-success", N = "badge-warning", T = "badge-error", D = "badge-ghost", J = "badge-xs", Q = "badge-sm", U = "badge-md", Y = "badge-lg", Z = "badge-xl", e = "badge-outline", _ = "badge-soft", ee = "badge-dash", te = "btn", oe = "btn-ghost", ae = "btn-xs", p = {
4
+ primary: y,
5
+ secondary: B,
6
+ accent: C,
7
+ neutral: x,
8
+ info: k,
9
+ success: w,
10
+ warning: N,
11
+ error: T,
12
+ ghost: D
13
+ }, W = {
14
+ xs: `${J} text-xs`,
15
+ sm: `${Q} text-sm`,
16
+ md: U,
17
+ lg: `${Y} text-lg`,
18
+ xl: `${Z} text-xl`
19
+ }, ne = {
20
20
  filled: "",
21
- outlined: "badge-outline",
22
- soft: "badge-soft",
23
- dash: "badge-dash"
24
- }, H = () => /* @__PURE__ */ n(
21
+ outlined: e,
22
+ soft: _,
23
+ dash: ee
24
+ }, ue = () => /* @__PURE__ */ s(
25
25
  "div",
26
26
  {
27
27
  id: "tag-live-region",
@@ -31,58 +31,58 @@ const p = {
31
31
  className: "sr-only",
32
32
  style: { position: "absolute", width: 1, height: 1, padding: 0, margin: -1, overflow: "hidden", clip: "rect(0, 0, 0, 0)", whiteSpace: "nowrap", border: 0 }
33
33
  }
34
- ), F = (t) => {
35
- const s = document.getElementById("tag-live-region");
36
- s && (s.textContent = `${t} removed`, setTimeout(() => {
37
- s.textContent = "";
34
+ ), se = (a) => {
35
+ const r = document.getElementById("tag-live-region");
36
+ r && (r.textContent = `${a} removed`, setTimeout(() => {
37
+ r.textContent = "";
38
38
  }, 1e3));
39
- }, P = I(
39
+ }, re = G(
40
40
  ({
41
- closable: t = !1,
42
- closeIcon: s,
43
- onClose: c,
44
- color: a,
45
- icon: i,
46
- size: o = "md",
47
- variant: h = "filled",
48
- visible: u,
49
- disabled: e = !1,
50
- href: l,
51
- target: v,
52
- children: d,
53
- className: b = "",
54
- "data-testid": f,
41
+ closable: a = !1,
42
+ closeIcon: r,
43
+ onClose: u,
44
+ color: o,
45
+ icon: d,
46
+ size: n = "md",
47
+ variant: f = "filled",
48
+ visible: h,
49
+ disabled: t = !1,
50
+ href: c,
51
+ target: b,
52
+ children: l,
53
+ className: v = "",
54
+ "data-testid": m,
55
55
  "aria-label": g,
56
- ...y
57
- }, C) => {
58
- const [B, R] = M(!0), x = u !== void 0, E = x ? u : B, m = f ?? "tag", k = g ?? (typeof d == "string" ? d : "tag"), w = (r) => {
59
- r.stopPropagation(), r.preventDefault(), !e && (x || R(!1), F(k), c?.());
60
- }, K = (r) => {
61
- (r.key === "Enter" || r.key === " ") && (r.preventDefault(), w(r));
56
+ ...S
57
+ }, I) => {
58
+ const [z, A] = H(!0), L = h !== void 0, F = L ? h : z, $ = m ?? "tag", j = g ?? (typeof l == "string" ? l : "tag"), E = (i) => {
59
+ i.stopPropagation(), i.preventDefault(), !t && (L || A(!1), se(j), u?.());
60
+ }, O = (i) => {
61
+ (i.key === "Enter" || i.key === " ") && (i.preventDefault(), E(i));
62
62
  };
63
- if (!E) return null;
64
- const S = a && p[a] ? p[a] : "", N = a && !p[a] ? { backgroundColor: a, borderColor: a } : void 0, T = [
65
- "badge gap-1 inline-flex items-center",
66
- S,
67
- L[o],
68
- z[h],
69
- e && "opacity-50 cursor-not-allowed",
70
- l && !e && "cursor-pointer hover:opacity-80",
71
- b
72
- ].filter(Boolean).join(" "), D = /* @__PURE__ */ j($, { children: [
73
- i && /* @__PURE__ */ n("span", { className: "inline-flex", children: i }),
74
- d,
75
- t && /* @__PURE__ */ n(
63
+ if (!F) return null;
64
+ const V = o && p[o] ? p[o] : "", R = o && !p[o] ? { backgroundColor: o, borderColor: o } : void 0, K = [
65
+ `${P} gap-1 inline-flex items-center`,
66
+ V,
67
+ W[n],
68
+ ne[f],
69
+ t && "opacity-50 cursor-not-allowed",
70
+ c && !t && "cursor-pointer hover:opacity-80",
71
+ v
72
+ ].filter(Boolean).join(" "), M = /* @__PURE__ */ X(q, { children: [
73
+ d && /* @__PURE__ */ s("span", { className: "inline-flex", children: d }),
74
+ l,
75
+ a && /* @__PURE__ */ s(
76
76
  "button",
77
77
  {
78
78
  type: "button",
79
- onClick: w,
80
- onKeyDown: K,
81
- disabled: e,
82
- className: "btn btn-ghost btn-xs p-0 min-h-0 h-auto hover:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-1 rounded",
83
- "aria-label": `Remove ${k}`,
84
- "data-testid": `${m}-close`,
85
- children: s || /* @__PURE__ */ n(
79
+ onClick: E,
80
+ onKeyDown: O,
81
+ disabled: t,
82
+ className: `${te} ${oe} ${ae} p-0 min-h-0 h-auto hover:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-1 rounded`,
83
+ "aria-label": `Remove ${j}`,
84
+ "data-testid": `${$}-close`,
85
+ children: r || /* @__PURE__ */ s(
86
86
  "svg",
87
87
  {
88
88
  className: "w-3 h-3",
@@ -90,7 +90,7 @@ const p = {
90
90
  stroke: "currentColor",
91
91
  viewBox: "0 0 24 24",
92
92
  "aria-hidden": "true",
93
- children: /* @__PURE__ */ n(
93
+ children: /* @__PURE__ */ s(
94
94
  "path",
95
95
  {
96
96
  strokeLinecap: "round",
@@ -104,107 +104,107 @@ const p = {
104
104
  }
105
105
  )
106
106
  ] });
107
- return l && !e ? /* @__PURE__ */ n(
107
+ return c && !t ? /* @__PURE__ */ s(
108
108
  "a",
109
109
  {
110
- ref: C,
111
- href: l,
112
- target: v,
113
- className: T,
114
- style: N,
115
- "data-testid": m,
116
- "data-disabled": e || void 0,
117
- ...y,
118
- children: D
110
+ ref: I,
111
+ href: c,
112
+ target: b,
113
+ className: K,
114
+ style: R,
115
+ "data-testid": $,
116
+ "data-disabled": t || void 0,
117
+ ...S,
118
+ children: M
119
119
  }
120
- ) : /* @__PURE__ */ n(
120
+ ) : /* @__PURE__ */ s(
121
121
  "span",
122
122
  {
123
- ref: C,
124
- className: T,
125
- style: N,
126
- "data-testid": m,
127
- "data-disabled": e || void 0,
128
- "aria-disabled": e || void 0,
129
- ...y,
130
- children: D
123
+ ref: I,
124
+ className: K,
125
+ style: R,
126
+ "data-testid": $,
127
+ "data-disabled": t || void 0,
128
+ "aria-disabled": t || void 0,
129
+ ...S,
130
+ children: M
131
131
  }
132
132
  );
133
133
  }
134
134
  );
135
- P.displayName = "Tag";
136
- const V = {
137
- primary: "badge-primary",
138
- secondary: "badge-secondary",
139
- accent: "badge-accent",
140
- neutral: "badge-neutral",
141
- info: "badge-info",
142
- success: "badge-success",
143
- warning: "badge-warning",
144
- error: "badge-error",
145
- ghost: "badge-ghost"
146
- }, W = {
147
- primary: "badge-outline hover:badge-primary hover:badge-outline",
148
- secondary: "badge-outline hover:badge-secondary hover:badge-outline",
149
- accent: "badge-outline hover:badge-accent hover:badge-outline",
150
- neutral: "badge-outline hover:badge-neutral hover:badge-outline",
151
- info: "badge-outline hover:badge-info hover:badge-outline",
152
- success: "badge-outline hover:badge-success hover:badge-outline",
153
- warning: "badge-outline hover:badge-warning hover:badge-outline",
154
- error: "badge-outline hover:badge-error hover:badge-outline",
155
- ghost: "badge-outline hover:badge-ghost hover:badge-outline"
156
- }, q = I(
135
+ re.displayName = "Tag";
136
+ const ie = {
137
+ primary: y,
138
+ secondary: B,
139
+ accent: C,
140
+ neutral: x,
141
+ info: k,
142
+ success: w,
143
+ warning: N,
144
+ error: T,
145
+ ghost: D
146
+ }, de = {
147
+ primary: `${e} hover:${y} hover:${e}`,
148
+ secondary: `${e} hover:${B} hover:${e}`,
149
+ accent: `${e} hover:${C} hover:${e}`,
150
+ neutral: `${e} hover:${x} hover:${e}`,
151
+ info: `${e} hover:${k} hover:${e}`,
152
+ success: `${e} hover:${w} hover:${e}`,
153
+ warning: `${e} hover:${N} hover:${e}`,
154
+ error: `${e} hover:${T} hover:${e}`,
155
+ ghost: `${e} hover:${D} hover:${e}`
156
+ }, ce = G(
157
157
  ({
158
- checked: t = !1,
159
- onChange: s,
160
- icon: c,
161
- size: a = "md",
162
- color: i = "primary",
163
- disabled: o = !1,
164
- children: h,
165
- className: u = "",
166
- "data-testid": e,
167
- ...l
168
- }, v) => {
169
- const d = e ?? "checkable-tag", b = () => {
170
- o || s?.(!t);
171
- }, f = [
172
- "badge gap-1 cursor-pointer transition-colors",
158
+ checked: a = !1,
159
+ onChange: r,
160
+ icon: u,
161
+ size: o = "md",
162
+ color: d = "primary",
163
+ disabled: n = !1,
164
+ children: f,
165
+ className: h = "",
166
+ "data-testid": t,
167
+ ...c
168
+ }, b) => {
169
+ const l = t ?? "checkable-tag", v = () => {
170
+ n || r?.(!a);
171
+ }, m = [
172
+ `${P} gap-1 cursor-pointer transition-colors`,
173
173
  "focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-2",
174
- L[a],
175
- t ? V[i] : W[i],
176
- o && "opacity-50 cursor-not-allowed",
177
- u
174
+ W[o],
175
+ a ? ie[d] : de[d],
176
+ n && "opacity-50 cursor-not-allowed",
177
+ h
178
178
  ].filter(Boolean).join(" ");
179
- return /* @__PURE__ */ j(
179
+ return /* @__PURE__ */ X(
180
180
  "span",
181
181
  {
182
- ref: v,
183
- className: f,
184
- onClick: b,
182
+ ref: b,
183
+ className: m,
184
+ onClick: v,
185
185
  role: "checkbox",
186
- "aria-checked": t,
187
- "aria-disabled": o || void 0,
188
- tabIndex: o ? -1 : 0,
186
+ "aria-checked": a,
187
+ "aria-disabled": n || void 0,
188
+ tabIndex: n ? -1 : 0,
189
189
  onKeyDown: (g) => {
190
- o || (g.key === "Enter" || g.key === " ") && (g.preventDefault(), b());
190
+ n || (g.key === "Enter" || g.key === " ") && (g.preventDefault(), v());
191
191
  },
192
- "data-testid": d,
193
- "data-state": t ? "checked" : "unchecked",
194
- "data-disabled": o || void 0,
195
- ...l,
192
+ "data-testid": l,
193
+ "data-state": a ? "checked" : "unchecked",
194
+ "data-disabled": n || void 0,
195
+ ...c,
196
196
  children: [
197
- c && /* @__PURE__ */ n("span", { className: "inline-flex", children: c }),
198
- h
197
+ u && /* @__PURE__ */ s("span", { className: "inline-flex", children: u }),
198
+ f
199
199
  ]
200
200
  }
201
201
  );
202
202
  }
203
203
  );
204
- q.displayName = "CheckableTag";
204
+ ce.displayName = "CheckableTag";
205
205
  export {
206
- q as CheckableTag,
207
- P as Tag,
208
- H as TagLiveRegion
206
+ ce as CheckableTag,
207
+ re as Tag,
208
+ ue as TagLiveRegion
209
209
  };
210
210
  //# sourceMappingURL=Tag.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Tag.js","sources":["../../src/components/Tag.tsx"],"sourcesContent":["import React, { useState, forwardRef } from 'react'\n\nexport type TagSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl'\nexport type TagColor =\n | 'primary'\n | 'secondary'\n | 'accent'\n | 'neutral'\n | 'info'\n | 'success'\n | 'warning'\n | 'error'\n | 'ghost'\n\nexport type TagVariant = 'filled' | 'outlined' | 'soft' | 'dash'\n\nexport interface TagProps extends Omit<React.HTMLAttributes<HTMLElement>, 'color'> {\n closable?: boolean\n closeIcon?: React.ReactNode\n onClose?: () => void\n color?: TagColor | string\n icon?: React.ReactNode\n size?: TagSize\n variant?: TagVariant\n visible?: boolean\n disabled?: boolean\n href?: string\n target?: string\n children?: React.ReactNode\n 'data-testid'?: string\n 'aria-label'?: string\n}\n\nexport interface CheckableTagProps extends Omit<React.HTMLAttributes<HTMLSpanElement>, 'onChange' | 'color'> {\n checked?: boolean\n onChange?: (checked: boolean) => void\n icon?: React.ReactNode\n size?: TagSize\n color?: TagColor\n disabled?: boolean\n children?: React.ReactNode\n 'data-testid'?: string\n}\n\nconst colorClasses: Record<string, string> = {\n primary: 'badge-primary',\n secondary: 'badge-secondary',\n accent: 'badge-accent',\n neutral: 'badge-neutral',\n info: 'badge-info',\n success: 'badge-success',\n warning: 'badge-warning',\n error: 'badge-error',\n ghost: 'badge-ghost',\n}\n\nconst sizeClasses: Record<TagSize, string> = {\n xs: 'badge-xs text-xs',\n sm: 'badge-sm text-sm',\n md: 'badge-md',\n lg: 'badge-lg text-lg',\n xl: 'badge-xl text-xl',\n}\n\nconst variantClasses: Record<TagVariant, string> = {\n filled: '',\n outlined: 'badge-outline',\n soft: 'badge-soft',\n dash: 'badge-dash',\n}\n\nconst TagLiveRegion: React.FC = () => (\n <div\n id=\"tag-live-region\"\n role=\"status\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n className=\"sr-only\"\n style={{ position: 'absolute', width: 1, height: 1, padding: 0, margin: -1, overflow: 'hidden', clip: 'rect(0, 0, 0, 0)', whiteSpace: 'nowrap', border: 0 }}\n />\n)\n\nconst announceTagRemoval = (label: string) => {\n const region = document.getElementById('tag-live-region')\n if (region) {\n region.textContent = `${label} removed`\n setTimeout(() => {\n region.textContent = ''\n }, 1000)\n }\n}\n\nexport const Tag = forwardRef<HTMLElement, TagProps>(\n (\n {\n closable = false,\n closeIcon,\n onClose,\n color,\n icon,\n size = 'md',\n variant = 'filled',\n visible: controlledVisible,\n disabled = false,\n href,\n target,\n children,\n className = '',\n 'data-testid': testId,\n 'aria-label': ariaLabel,\n ...rest\n },\n ref\n ) => {\n const [internalVisible, setInternalVisible] = useState(true)\n const isControlled = controlledVisible !== undefined\n const visible = isControlled ? controlledVisible : internalVisible\n const baseTestId = testId ?? 'tag'\n const tagLabel = ariaLabel ?? (typeof children === 'string' ? children : 'tag')\n\n const handleClose = (e: React.MouseEvent) => {\n e.stopPropagation()\n e.preventDefault()\n if (disabled) return\n if (!isControlled) {\n setInternalVisible(false)\n }\n announceTagRemoval(tagLabel)\n onClose?.()\n }\n\n const handleCloseKeyDown = (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n handleClose(e as unknown as React.MouseEvent)\n }\n }\n\n if (!visible) return null\n\n const colorClass = color && colorClasses[color] ? colorClasses[color] : ''\n const customColorStyle =\n color && !colorClasses[color] ? { backgroundColor: color, borderColor: color } : undefined\n\n const tagClasses = [\n 'badge gap-1 inline-flex items-center',\n colorClass,\n sizeClasses[size],\n variantClasses[variant],\n disabled && 'opacity-50 cursor-not-allowed',\n href && !disabled && 'cursor-pointer hover:opacity-80',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n const content = (\n <>\n {icon && <span className=\"inline-flex\">{icon}</span>}\n {children}\n {closable && (\n <button\n type=\"button\"\n onClick={handleClose}\n onKeyDown={handleCloseKeyDown}\n disabled={disabled}\n className=\"btn btn-ghost btn-xs p-0 min-h-0 h-auto hover:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-1 rounded\"\n aria-label={`Remove ${tagLabel}`}\n data-testid={`${baseTestId}-close`}\n >\n {closeIcon || (\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n aria-hidden=\"true\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n )}\n </button>\n )}\n </>\n )\n\n if (href && !disabled) {\n return (\n <a\n ref={ref as React.Ref<HTMLAnchorElement>}\n href={href}\n target={target}\n className={tagClasses}\n style={customColorStyle}\n data-testid={baseTestId}\n data-disabled={disabled || undefined}\n {...rest}\n >\n {content}\n </a>\n )\n }\n\n return (\n <span\n ref={ref as React.Ref<HTMLSpanElement>}\n className={tagClasses}\n style={customColorStyle}\n data-testid={baseTestId}\n data-disabled={disabled || undefined}\n aria-disabled={disabled || undefined}\n {...rest}\n >\n {content}\n </span>\n )\n }\n)\n\nTag.displayName = 'Tag'\n\nconst checkedColorClasses: Record<TagColor, string> = {\n primary: 'badge-primary',\n secondary: 'badge-secondary',\n accent: 'badge-accent',\n neutral: 'badge-neutral',\n info: 'badge-info',\n success: 'badge-success',\n warning: 'badge-warning',\n error: 'badge-error',\n ghost: 'badge-ghost',\n}\n\nconst uncheckedColorClasses: Record<TagColor, string> = {\n primary: 'badge-outline hover:badge-primary hover:badge-outline',\n secondary: 'badge-outline hover:badge-secondary hover:badge-outline',\n accent: 'badge-outline hover:badge-accent hover:badge-outline',\n neutral: 'badge-outline hover:badge-neutral hover:badge-outline',\n info: 'badge-outline hover:badge-info hover:badge-outline',\n success: 'badge-outline hover:badge-success hover:badge-outline',\n warning: 'badge-outline hover:badge-warning hover:badge-outline',\n error: 'badge-outline hover:badge-error hover:badge-outline',\n ghost: 'badge-outline hover:badge-ghost hover:badge-outline',\n}\n\nexport const CheckableTag = forwardRef<HTMLSpanElement, CheckableTagProps>(\n (\n {\n checked = false,\n onChange,\n icon,\n size = 'md',\n color = 'primary',\n disabled = false,\n children,\n className = '',\n 'data-testid': testId,\n ...rest\n },\n ref\n ) => {\n const baseTestId = testId ?? 'checkable-tag'\n\n const handleClick = () => {\n if (disabled) return\n onChange?.(!checked)\n }\n\n const tagClasses = [\n 'badge gap-1 cursor-pointer transition-colors',\n 'focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-2',\n sizeClasses[size],\n checked ? checkedColorClasses[color] : uncheckedColorClasses[color],\n disabled && 'opacity-50 cursor-not-allowed',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return (\n <span\n ref={ref}\n className={tagClasses}\n onClick={handleClick}\n role=\"checkbox\"\n aria-checked={checked}\n aria-disabled={disabled || undefined}\n tabIndex={disabled ? -1 : 0}\n onKeyDown={(e) => {\n if (disabled) return\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n handleClick()\n }\n }}\n data-testid={baseTestId}\n data-state={checked ? 'checked' : 'unchecked'}\n data-disabled={disabled || undefined}\n {...rest}\n >\n {icon && <span className=\"inline-flex\">{icon}</span>}\n {children}\n </span>\n )\n }\n)\n\nCheckableTag.displayName = 'CheckableTag'\n\nexport { TagLiveRegion }\n"],"names":["colorClasses","sizeClasses","variantClasses","TagLiveRegion","jsx","announceTagRemoval","label","region","Tag","forwardRef","closable","closeIcon","onClose","color","icon","size","variant","controlledVisible","disabled","href","target","children","className","testId","ariaLabel","rest","ref","internalVisible","setInternalVisible","useState","isControlled","visible","baseTestId","tagLabel","handleClose","e","handleCloseKeyDown","colorClass","customColorStyle","tagClasses","content","jsxs","Fragment","checkedColorClasses","uncheckedColorClasses","CheckableTag","checked","onChange","handleClick"],"mappings":"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"}
1
+ {"version":3,"file":"Tag.js","sources":["../../src/components/Tag.tsx"],"sourcesContent":["import React, { useState, forwardRef } from 'react'\n\n// DaisyUI classes\nconst dBadge = 'badge'\nconst dBadgePrimary = 'badge-primary'\nconst dBadgeSecondary = 'badge-secondary'\nconst dBadgeAccent = 'badge-accent'\nconst dBadgeNeutral = 'badge-neutral'\nconst dBadgeInfo = 'badge-info'\nconst dBadgeSuccess = 'badge-success'\nconst dBadgeWarning = 'badge-warning'\nconst dBadgeError = 'badge-error'\nconst dBadgeGhost = 'badge-ghost'\nconst dBadgeXs = 'badge-xs'\nconst dBadgeSm = 'badge-sm'\nconst dBadgeMd = 'badge-md'\nconst dBadgeLg = 'badge-lg'\nconst dBadgeXl = 'badge-xl'\nconst dBadgeOutline = 'badge-outline'\nconst dBadgeSoft = 'badge-soft'\nconst dBadgeDash = 'badge-dash'\nconst dBtn = 'btn'\nconst dBtnGhost = 'btn-ghost'\nconst dBtnXs = 'btn-xs'\n\nexport type TagSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl'\nexport type TagColor =\n | 'primary'\n | 'secondary'\n | 'accent'\n | 'neutral'\n | 'info'\n | 'success'\n | 'warning'\n | 'error'\n | 'ghost'\n\nexport type TagVariant = 'filled' | 'outlined' | 'soft' | 'dash'\n\nexport interface TagProps extends Omit<React.HTMLAttributes<HTMLElement>, 'color'> {\n closable?: boolean\n closeIcon?: React.ReactNode\n onClose?: () => void\n color?: TagColor | string\n icon?: React.ReactNode\n size?: TagSize\n variant?: TagVariant\n visible?: boolean\n disabled?: boolean\n href?: string\n target?: string\n children?: React.ReactNode\n 'data-testid'?: string\n 'aria-label'?: string\n}\n\nexport interface CheckableTagProps extends Omit<React.HTMLAttributes<HTMLSpanElement>, 'onChange' | 'color'> {\n checked?: boolean\n onChange?: (checked: boolean) => void\n icon?: React.ReactNode\n size?: TagSize\n color?: TagColor\n disabled?: boolean\n children?: React.ReactNode\n 'data-testid'?: string\n}\n\nconst colorClasses: Record<string, string> = {\n primary: dBadgePrimary,\n secondary: dBadgeSecondary,\n accent: dBadgeAccent,\n neutral: dBadgeNeutral,\n info: dBadgeInfo,\n success: dBadgeSuccess,\n warning: dBadgeWarning,\n error: dBadgeError,\n ghost: dBadgeGhost,\n}\n\nconst sizeClasses: Record<TagSize, string> = {\n xs: `${dBadgeXs} text-xs`,\n sm: `${dBadgeSm} text-sm`,\n md: dBadgeMd,\n lg: `${dBadgeLg} text-lg`,\n xl: `${dBadgeXl} text-xl`,\n}\n\nconst variantClasses: Record<TagVariant, string> = {\n filled: '',\n outlined: dBadgeOutline,\n soft: dBadgeSoft,\n dash: dBadgeDash,\n}\n\nconst TagLiveRegion: React.FC = () => (\n <div\n id=\"tag-live-region\"\n role=\"status\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n className=\"sr-only\"\n style={{ position: 'absolute', width: 1, height: 1, padding: 0, margin: -1, overflow: 'hidden', clip: 'rect(0, 0, 0, 0)', whiteSpace: 'nowrap', border: 0 }}\n />\n)\n\nconst announceTagRemoval = (label: string) => {\n const region = document.getElementById('tag-live-region')\n if (region) {\n region.textContent = `${label} removed`\n setTimeout(() => {\n region.textContent = ''\n }, 1000)\n }\n}\n\nexport const Tag = forwardRef<HTMLElement, TagProps>(\n (\n {\n closable = false,\n closeIcon,\n onClose,\n color,\n icon,\n size = 'md',\n variant = 'filled',\n visible: controlledVisible,\n disabled = false,\n href,\n target,\n children,\n className = '',\n 'data-testid': testId,\n 'aria-label': ariaLabel,\n ...rest\n },\n ref\n ) => {\n const [internalVisible, setInternalVisible] = useState(true)\n const isControlled = controlledVisible !== undefined\n const visible = isControlled ? controlledVisible : internalVisible\n const baseTestId = testId ?? 'tag'\n const tagLabel = ariaLabel ?? (typeof children === 'string' ? children : 'tag')\n\n const handleClose = (e: React.MouseEvent) => {\n e.stopPropagation()\n e.preventDefault()\n if (disabled) return\n if (!isControlled) {\n setInternalVisible(false)\n }\n announceTagRemoval(tagLabel)\n onClose?.()\n }\n\n const handleCloseKeyDown = (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n handleClose(e as unknown as React.MouseEvent)\n }\n }\n\n if (!visible) return null\n\n const colorClass = color && colorClasses[color] ? colorClasses[color] : ''\n const customColorStyle =\n color && !colorClasses[color] ? { backgroundColor: color, borderColor: color } : undefined\n\n const tagClasses = [\n `${dBadge} gap-1 inline-flex items-center`,\n colorClass,\n sizeClasses[size],\n variantClasses[variant],\n disabled && 'opacity-50 cursor-not-allowed',\n href && !disabled && 'cursor-pointer hover:opacity-80',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n const content = (\n <>\n {icon && <span className=\"inline-flex\">{icon}</span>}\n {children}\n {closable && (\n <button\n type=\"button\"\n onClick={handleClose}\n onKeyDown={handleCloseKeyDown}\n disabled={disabled}\n className={`${dBtn} ${dBtnGhost} ${dBtnXs} p-0 min-h-0 h-auto hover:bg-transparent focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-1 rounded`}\n aria-label={`Remove ${tagLabel}`}\n data-testid={`${baseTestId}-close`}\n >\n {closeIcon || (\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n aria-hidden=\"true\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n )}\n </button>\n )}\n </>\n )\n\n if (href && !disabled) {\n return (\n <a\n ref={ref as React.Ref<HTMLAnchorElement>}\n href={href}\n target={target}\n className={tagClasses}\n style={customColorStyle}\n data-testid={baseTestId}\n data-disabled={disabled || undefined}\n {...rest}\n >\n {content}\n </a>\n )\n }\n\n return (\n <span\n ref={ref as React.Ref<HTMLSpanElement>}\n className={tagClasses}\n style={customColorStyle}\n data-testid={baseTestId}\n data-disabled={disabled || undefined}\n aria-disabled={disabled || undefined}\n {...rest}\n >\n {content}\n </span>\n )\n }\n)\n\nTag.displayName = 'Tag'\n\nconst checkedColorClasses: Record<TagColor, string> = {\n primary: dBadgePrimary,\n secondary: dBadgeSecondary,\n accent: dBadgeAccent,\n neutral: dBadgeNeutral,\n info: dBadgeInfo,\n success: dBadgeSuccess,\n warning: dBadgeWarning,\n error: dBadgeError,\n ghost: dBadgeGhost,\n}\n\nconst uncheckedColorClasses: Record<TagColor, string> = {\n primary: `${dBadgeOutline} hover:${dBadgePrimary} hover:${dBadgeOutline}`,\n secondary: `${dBadgeOutline} hover:${dBadgeSecondary} hover:${dBadgeOutline}`,\n accent: `${dBadgeOutline} hover:${dBadgeAccent} hover:${dBadgeOutline}`,\n neutral: `${dBadgeOutline} hover:${dBadgeNeutral} hover:${dBadgeOutline}`,\n info: `${dBadgeOutline} hover:${dBadgeInfo} hover:${dBadgeOutline}`,\n success: `${dBadgeOutline} hover:${dBadgeSuccess} hover:${dBadgeOutline}`,\n warning: `${dBadgeOutline} hover:${dBadgeWarning} hover:${dBadgeOutline}`,\n error: `${dBadgeOutline} hover:${dBadgeError} hover:${dBadgeOutline}`,\n ghost: `${dBadgeOutline} hover:${dBadgeGhost} hover:${dBadgeOutline}`,\n}\n\nexport const CheckableTag = forwardRef<HTMLSpanElement, CheckableTagProps>(\n (\n {\n checked = false,\n onChange,\n icon,\n size = 'md',\n color = 'primary',\n disabled = false,\n children,\n className = '',\n 'data-testid': testId,\n ...rest\n },\n ref\n ) => {\n const baseTestId = testId ?? 'checkable-tag'\n\n const handleClick = () => {\n if (disabled) return\n onChange?.(!checked)\n }\n\n const tagClasses = [\n `${dBadge} gap-1 cursor-pointer transition-colors`,\n 'focus:outline-none focus-visible:ring-2 focus-visible:ring-current focus-visible:ring-offset-2',\n sizeClasses[size],\n checked ? checkedColorClasses[color] : uncheckedColorClasses[color],\n disabled && 'opacity-50 cursor-not-allowed',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return (\n <span\n ref={ref}\n className={tagClasses}\n onClick={handleClick}\n role=\"checkbox\"\n aria-checked={checked}\n aria-disabled={disabled || undefined}\n tabIndex={disabled ? -1 : 0}\n onKeyDown={(e) => {\n if (disabled) return\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n handleClick()\n }\n }}\n data-testid={baseTestId}\n data-state={checked ? 'checked' : 'unchecked'}\n data-disabled={disabled || undefined}\n {...rest}\n >\n {icon && <span className=\"inline-flex\">{icon}</span>}\n {children}\n </span>\n )\n }\n)\n\nCheckableTag.displayName = 'CheckableTag'\n\nexport { TagLiveRegion }\n"],"names":["dBadge","dBadgePrimary","dBadgeSecondary","dBadgeAccent","dBadgeNeutral","dBadgeInfo","dBadgeSuccess","dBadgeWarning","dBadgeError","dBadgeGhost","dBadgeXs","dBadgeSm","dBadgeMd","dBadgeLg","dBadgeXl","dBadgeOutline","dBadgeSoft","dBadgeDash","dBtn","dBtnGhost","dBtnXs","colorClasses","sizeClasses","variantClasses","TagLiveRegion","jsx","announceTagRemoval","label","region","Tag","forwardRef","closable","closeIcon","onClose","color","icon","size","variant","controlledVisible","disabled","href","target","children","className","testId","ariaLabel","rest","ref","internalVisible","setInternalVisible","useState","isControlled","visible","baseTestId","tagLabel","handleClose","e","handleCloseKeyDown","colorClass","customColorStyle","tagClasses","content","jsxs","Fragment","checkedColorClasses","uncheckedColorClasses","CheckableTag","checked","onChange","handleClick"],"mappings":";;AAGA,MAAMA,IAAS,SACTC,IAAgB,iBAChBC,IAAkB,mBAClBC,IAAe,gBACfC,IAAgB,iBAChBC,IAAa,cACbC,IAAgB,iBAChBC,IAAgB,iBAChBC,IAAc,eACdC,IAAc,eACdC,IAAW,YACXC,IAAW,YACXC,IAAW,YACXC,IAAW,YACXC,IAAW,YACXC,IAAgB,iBAChBC,IAAa,cACbC,KAAa,cACbC,KAAO,OACPC,KAAY,aACZC,KAAS,UA4CTC,IAAuC;AAAA,EAC3C,SAASpB;AAAA,EACT,WAAWC;AAAA,EACX,QAAQC;AAAA,EACR,SAASC;AAAA,EACT,MAAMC;AAAA,EACN,SAASC;AAAA,EACT,SAASC;AAAA,EACT,OAAOC;AAAA,EACP,OAAOC;AACT,GAEMa,IAAuC;AAAA,EAC3C,IAAI,GAAGZ,CAAQ;AAAA,EACf,IAAI,GAAGC,CAAQ;AAAA,EACf,IAAIC;AAAA,EACJ,IAAI,GAAGC,CAAQ;AAAA,EACf,IAAI,GAAGC,CAAQ;AACjB,GAEMS,KAA6C;AAAA,EACjD,QAAQ;AAAA,EACR,UAAUR;AAAA,EACV,MAAMC;AAAA,EACN,MAAMC;AACR,GAEMO,KAA0B,MAC9B,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,IAAG;AAAA,IACH,MAAK;AAAA,IACL,aAAU;AAAA,IACV,eAAY;AAAA,IACZ,WAAU;AAAA,IACV,OAAO,EAAE,UAAU,YAAY,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,IAAI,UAAU,UAAU,MAAM,oBAAoB,YAAY,UAAU,QAAQ,EAAA;AAAA,EAAE;AAC5J,GAGIC,KAAqB,CAACC,MAAkB;AAC5C,QAAMC,IAAS,SAAS,eAAe,iBAAiB;AACxD,EAAIA,MACFA,EAAO,cAAc,GAAGD,CAAK,YAC7B,WAAW,MAAM;AACf,IAAAC,EAAO,cAAc;AAAA,EACvB,GAAG,GAAI;AAEX,GAEaC,KAAMC;AAAA,EACjB,CACE;AAAA,IACE,UAAAC,IAAW;AAAA,IACX,WAAAC;AAAA,IACA,SAAAC;AAAA,IACA,OAAAC;AAAA,IACA,MAAAC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,SAAAC,IAAU;AAAA,IACV,SAASC;AAAA,IACT,UAAAC,IAAW;AAAA,IACX,MAAAC;AAAA,IACA,QAAAC;AAAA,IACA,UAAAC;AAAA,IACA,WAAAC,IAAY;AAAA,IACZ,eAAeC;AAAA,IACf,cAAcC;AAAA,IACd,GAAGC;AAAA,EAAA,GAELC,MACG;AACH,UAAM,CAACC,GAAiBC,CAAkB,IAAIC,EAAS,EAAI,GACrDC,IAAeb,MAAsB,QACrCc,IAAUD,IAAeb,IAAoBU,GAC7CK,IAAaT,KAAU,OACvBU,IAAWT,MAAc,OAAOH,KAAa,WAAWA,IAAW,QAEnEa,IAAc,CAACC,MAAwB;AAG3C,MAFAA,EAAE,gBAAA,GACFA,EAAE,eAAA,GACE,CAAAjB,MACCY,KACHF,EAAmB,EAAK,GAE1BvB,GAAmB4B,CAAQ,GAC3BrB,IAAA;AAAA,IACF,GAEMwB,IAAqB,CAACD,MAA2B;AACrD,OAAIA,EAAE,QAAQ,WAAWA,EAAE,QAAQ,SACjCA,EAAE,eAAA,GACFD,EAAYC,CAAgC;AAAA,IAEhD;AAEA,QAAI,CAACJ,EAAS,QAAO;AAErB,UAAMM,IAAaxB,KAASb,EAAaa,CAAK,IAAIb,EAAaa,CAAK,IAAI,IAClEyB,IACJzB,KAAS,CAACb,EAAaa,CAAK,IAAI,EAAE,iBAAiBA,GAAO,aAAaA,EAAA,IAAU,QAE7E0B,IAAa;AAAA,MACjB,GAAG5D,CAAM;AAAA,MACT0D;AAAA,MACApC,EAAYc,CAAI;AAAA,MAChBb,GAAec,CAAO;AAAA,MACtBE,KAAY;AAAA,MACZC,KAAQ,CAACD,KAAY;AAAA,MACrBI;AAAA,IAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG,GAELkB,IACJ,gBAAAC,EAAAC,GAAA,EACG,UAAA;AAAA,MAAA5B,KAAQ,gBAAAV,EAAC,QAAA,EAAK,WAAU,eAAe,UAAAU,GAAK;AAAA,MAC5CO;AAAA,MACAX,KACC,gBAAAN;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,SAAS8B;AAAA,UACT,WAAWE;AAAA,UACX,UAAAlB;AAAA,UACA,WAAW,GAAGrB,EAAI,IAAIC,EAAS,IAAIC,EAAM;AAAA,UACzC,cAAY,UAAUkC,CAAQ;AAAA,UAC9B,eAAa,GAAGD,CAAU;AAAA,UAEzB,UAAArB,KACC,gBAAAP;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAU;AAAA,cACV,MAAK;AAAA,cACL,QAAO;AAAA,cACP,SAAQ;AAAA,cACR,eAAY;AAAA,cAEZ,UAAA,gBAAAA;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,eAAc;AAAA,kBACd,gBAAe;AAAA,kBACf,aAAa;AAAA,kBACb,GAAE;AAAA,gBAAA;AAAA,cAAA;AAAA,YACJ;AAAA,UAAA;AAAA,QACF;AAAA,MAAA;AAAA,IAEJ,GAEJ;AAGF,WAAIe,KAAQ,CAACD,IAET,gBAAAd;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAAsB;AAAA,QACA,MAAAP;AAAA,QACA,QAAAC;AAAA,QACA,WAAWmB;AAAA,QACX,OAAOD;AAAA,QACP,eAAaN;AAAA,QACb,iBAAed,KAAY;AAAA,QAC1B,GAAGO;AAAA,QAEH,UAAAe;AAAA,MAAA;AAAA,IAAA,IAML,gBAAApC;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAAsB;AAAA,QACA,WAAWa;AAAA,QACX,OAAOD;AAAA,QACP,eAAaN;AAAA,QACb,iBAAed,KAAY;AAAA,QAC3B,iBAAeA,KAAY;AAAA,QAC1B,GAAGO;AAAA,QAEH,UAAAe;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AAEAhC,GAAI,cAAc;AAElB,MAAMmC,KAAgD;AAAA,EACpD,SAAS/D;AAAA,EACT,WAAWC;AAAA,EACX,QAAQC;AAAA,EACR,SAASC;AAAA,EACT,MAAMC;AAAA,EACN,SAASC;AAAA,EACT,SAASC;AAAA,EACT,OAAOC;AAAA,EACP,OAAOC;AACT,GAEMwD,KAAkD;AAAA,EACtD,SAAS,GAAGlD,CAAa,UAAUd,CAAa,UAAUc,CAAa;AAAA,EACvE,WAAW,GAAGA,CAAa,UAAUb,CAAe,UAAUa,CAAa;AAAA,EAC3E,QAAQ,GAAGA,CAAa,UAAUZ,CAAY,UAAUY,CAAa;AAAA,EACrE,SAAS,GAAGA,CAAa,UAAUX,CAAa,UAAUW,CAAa;AAAA,EACvE,MAAM,GAAGA,CAAa,UAAUV,CAAU,UAAUU,CAAa;AAAA,EACjE,SAAS,GAAGA,CAAa,UAAUT,CAAa,UAAUS,CAAa;AAAA,EACvE,SAAS,GAAGA,CAAa,UAAUR,CAAa,UAAUQ,CAAa;AAAA,EACvE,OAAO,GAAGA,CAAa,UAAUP,CAAW,UAAUO,CAAa;AAAA,EACnE,OAAO,GAAGA,CAAa,UAAUN,CAAW,UAAUM,CAAa;AACrE,GAEamD,KAAepC;AAAA,EAC1B,CACE;AAAA,IACE,SAAAqC,IAAU;AAAA,IACV,UAAAC;AAAA,IACA,MAAAjC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,OAAAF,IAAQ;AAAA,IACR,UAAAK,IAAW;AAAA,IACX,UAAAG;AAAA,IACA,WAAAC,IAAY;AAAA,IACZ,eAAeC;AAAA,IACf,GAAGE;AAAA,EAAA,GAELC,MACG;AACH,UAAMM,IAAaT,KAAU,iBAEvByB,IAAc,MAAM;AACxB,MAAI9B,KACJ6B,IAAW,CAACD,CAAO;AAAA,IACrB,GAEMP,IAAa;AAAA,MACjB,GAAG5D,CAAM;AAAA,MACT;AAAA,MACAsB,EAAYc,CAAI;AAAA,MAChB+B,IAAUH,GAAoB9B,CAAK,IAAI+B,GAAsB/B,CAAK;AAAA,MAClEK,KAAY;AAAA,MACZI;AAAA,IAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,WACE,gBAAAmB;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAAf;AAAA,QACA,WAAWa;AAAA,QACX,SAASS;AAAA,QACT,MAAK;AAAA,QACL,gBAAcF;AAAA,QACd,iBAAe5B,KAAY;AAAA,QAC3B,UAAUA,IAAW,KAAK;AAAA,QAC1B,WAAW,CAACiB,MAAM;AAChB,UAAIjB,MACAiB,EAAE,QAAQ,WAAWA,EAAE,QAAQ,SACjCA,EAAE,eAAA,GACFa,EAAA;AAAA,QAEJ;AAAA,QACA,eAAahB;AAAA,QACb,cAAYc,IAAU,YAAY;AAAA,QAClC,iBAAe5B,KAAY;AAAA,QAC1B,GAAGO;AAAA,QAEH,UAAA;AAAA,UAAAX,KAAQ,gBAAAV,EAAC,QAAA,EAAK,WAAU,eAAe,UAAAU,GAAK;AAAA,UAC5CO;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AAEAwB,GAAa,cAAc;"}
@@ -1,26 +1,26 @@
1
1
  import { jsx as t } from "react/jsx-runtime";
2
- const c = {
2
+ const c = "text-rotate", d = {
3
3
  6e3: "duration-6000",
4
4
  9e3: "duration-9000",
5
5
  12e3: "duration-12000",
6
6
  15e3: "duration-15000",
7
7
  18e3: "duration-18000"
8
- }, l = ({
8
+ }, u = ({
9
9
  items: s,
10
10
  duration: e,
11
11
  centered: a = !1,
12
12
  className: n = ""
13
13
  }) => {
14
- const r = e ? c[e] : "";
14
+ const r = e ? d[e] : "";
15
15
  return /* @__PURE__ */ t(
16
16
  "span",
17
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)) })
18
+ className: `${c} ${r} ${a ? "justify-items-center" : ""} ${n}`.trim(),
19
+ children: /* @__PURE__ */ t("span", { children: s.slice(0, 6).map((o, i) => /* @__PURE__ */ t("span", { children: o }, i)) })
20
20
  }
21
21
  );
22
22
  };
23
23
  export {
24
- l as TextRotate
24
+ u as TextRotate
25
25
  };
26
26
  //# sourceMappingURL=TextRotate.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextRotate.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;"}
1
+ {"version":3,"file":"TextRotate.js","sources":["../../src/components/TextRotate.tsx"],"sourcesContent":["import React from 'react'\n\n// DaisyUI classes\nconst dTextRotate = 'text-rotate'\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={`${dTextRotate} ${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":["dTextRotate","durationClasses","TextRotate","items","duration","centered","className","durationClass","jsx","item","index"],"mappings":";AAGA,MAAMA,IAAc,eAIdC,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,GAAGR,CAAW,IAAIO,CAAa,IAAIF,IAAW,yBAAyB,EAAE,IAAIC,CAAS,GAAG,KAAA;AAAA,MAEpG,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;"}
@@ -1,43 +1,44 @@
1
1
  import { jsx as m } from "react/jsx-runtime";
2
- import { forwardRef as i } from "react";
3
- const f = i(
2
+ import { forwardRef as T } from "react";
3
+ import { useConfig as f } from "./ConfigProvider.js";
4
+ const u = "textarea", g = "textarea-bordered", p = "textarea-ghost", y = "textarea-xs", S = "textarea-sm", w = "textarea-md", C = "textarea-lg", z = "textarea-xl", N = "textarea-neutral", h = "textarea-primary", j = "textarea-secondary", B = "textarea-accent", X = "textarea-info", b = "textarea-success", v = "textarea-warning", A = "textarea-error", E = T(
4
5
  ({
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",
6
+ size: t,
7
+ color: e,
8
+ ghost: r = !1,
9
+ bordered: s = !0,
10
+ className: o = "",
11
+ ...n
12
+ }, x) => {
13
+ const { componentSize: c } = f(), a = t ?? c ?? "md", d = {
14
+ xs: y,
15
+ sm: S,
16
+ md: w,
17
+ lg: C,
18
+ xl: z
19
+ }, i = {
20
+ neutral: N,
21
+ primary: h,
22
+ secondary: j,
23
+ accent: B,
24
+ info: X,
25
+ success: b,
26
+ warning: v,
27
+ error: A
28
+ }, l = [
29
+ u,
29
30
  "w-full",
30
- r && "textarea-bordered",
31
- t && "textarea-ghost",
32
- e && n[e],
33
- a && l[a],
34
- s
31
+ s && g,
32
+ r && p,
33
+ a && d[a],
34
+ e && i[e],
35
+ o
35
36
  ].filter(Boolean).join(" ");
36
- return /* @__PURE__ */ m("textarea", { ref: o, className: c, ...x });
37
+ return /* @__PURE__ */ m("textarea", { ref: x, className: l, ...n });
37
38
  }
38
39
  );
39
- f.displayName = "Textarea";
40
+ E.displayName = "Textarea";
40
41
  export {
41
- f as Textarea
42
+ E as Textarea
42
43
  };
43
44
  //# sourceMappingURL=Textarea.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Textarea.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;"}
1
+ {"version":3,"file":"Textarea.js","sources":["../../src/components/Textarea.tsx"],"sourcesContent":["import React, { forwardRef } from 'react'\nimport { useConfig } from './ConfigProvider'\n\n// DaisyUI classes\nconst dTextarea = 'textarea'\nconst dTextareaBordered = 'textarea-bordered'\nconst dTextareaGhost = 'textarea-ghost'\nconst dTextareaXs = 'textarea-xs'\nconst dTextareaSm = 'textarea-sm'\nconst dTextareaMd = 'textarea-md'\nconst dTextareaLg = 'textarea-lg'\nconst dTextareaXl = 'textarea-xl'\nconst dTextareaNeutral = 'textarea-neutral'\nconst dTextareaPrimary = 'textarea-primary'\nconst dTextareaSecondary = 'textarea-secondary'\nconst dTextareaAccent = 'textarea-accent'\nconst dTextareaInfo = 'textarea-info'\nconst dTextareaSuccess = 'textarea-success'\nconst dTextareaWarning = 'textarea-warning'\nconst dTextareaError = 'textarea-error'\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 { componentSize } = useConfig()\n const effectiveSize = size ?? componentSize ?? 'md'\n\n const sizeClasses = {\n xs: dTextareaXs,\n sm: dTextareaSm,\n md: dTextareaMd,\n lg: dTextareaLg,\n xl: dTextareaXl,\n }\n\n const colorClasses = {\n neutral: dTextareaNeutral,\n primary: dTextareaPrimary,\n secondary: dTextareaSecondary,\n accent: dTextareaAccent,\n info: dTextareaInfo,\n success: dTextareaSuccess,\n warning: dTextareaWarning,\n error: dTextareaError,\n }\n\n const textareaClasses = [\n dTextarea,\n 'w-full',\n bordered && dTextareaBordered,\n ghost && dTextareaGhost,\n effectiveSize && sizeClasses[effectiveSize],\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":["dTextarea","dTextareaBordered","dTextareaGhost","dTextareaXs","dTextareaSm","dTextareaMd","dTextareaLg","dTextareaXl","dTextareaNeutral","dTextareaPrimary","dTextareaSecondary","dTextareaAccent","dTextareaInfo","dTextareaSuccess","dTextareaWarning","dTextareaError","Textarea","forwardRef","size","color","ghost","bordered","className","props","ref","componentSize","useConfig","effectiveSize","sizeClasses","colorClasses","textareaClasses"],"mappings":";;;AAIA,MAAMA,IAAY,YACZC,IAAoB,qBACpBC,IAAiB,kBACjBC,IAAc,eACdC,IAAc,eACdC,IAAc,eACdC,IAAc,eACdC,IAAc,eACdC,IAAmB,oBACnBC,IAAmB,oBACnBC,IAAqB,sBACrBC,IAAkB,mBAClBC,IAAgB,iBAChBC,IAAmB,oBACnBC,IAAmB,oBACnBC,IAAiB,kBAUVC,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,UAAM,EAAE,eAAAC,EAAA,IAAkBC,EAAA,GACpBC,IAAgBT,KAAQO,KAAiB,MAEzCG,IAAc;AAAA,MAClB,IAAIzB;AAAA,MACJ,IAAIC;AAAA,MACJ,IAAIC;AAAA,MACJ,IAAIC;AAAA,MACJ,IAAIC;AAAA,IAAA,GAGAsB,IAAe;AAAA,MACnB,SAASrB;AAAA,MACT,SAASC;AAAA,MACT,WAAWC;AAAA,MACX,QAAQC;AAAA,MACR,MAAMC;AAAA,MACN,SAASC;AAAA,MACT,SAASC;AAAA,MACT,OAAOC;AAAA,IAAA,GAGHe,IAAkB;AAAA,MACtB9B;AAAA,MACA;AAAA,MACAqB,KAAYpB;AAAA,MACZmB,KAASlB;AAAA,MACTyB,KAAiBC,EAAYD,CAAa;AAAA,MAC1CR,KAASU,EAAaV,CAAK;AAAA,MAC3BG;AAAA,IAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,6BAAQ,YAAA,EAAS,KAAAE,GAAU,WAAWM,GAAkB,GAAGP,GAAO;AAAA,EACpE;AACF;AAEAP,EAAS,cAAc;"}
@@ -14,7 +14,7 @@ export interface ThemeControllerToggleProps {
14
14
  lightTheme?: string;
15
15
  darkTheme?: string;
16
16
  onChange?: (theme: string) => void;
17
- size?: 'xs' | 'sm' | 'md' | 'lg';
17
+ size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl';
18
18
  className?: string;
19
19
  }
20
20
  declare function ThemeControllerSwap({ lightTheme, darkTheme, onChange, className, }: ThemeControllerSwapProps): import("react/jsx-runtime").JSX.Element;