@dimasbaguspm/versaur 0.0.0

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 (260) hide show
  1. package/README.md +81 -0
  2. package/dist/alert-DzSPXqwS.js +167 -0
  3. package/dist/app-bar-B4nQkgdL.js +92 -0
  4. package/dist/avatar-Bsn24V6g.js +91 -0
  5. package/dist/badge-DqLCHm9q.js +184 -0
  6. package/dist/bottom-bar-DOQ3gVwW.js +73 -0
  7. package/dist/breadcrumbs-PJV3izUu.js +59 -0
  8. package/dist/button-C8OibEPE.js +81 -0
  9. package/dist/button-float-B8tdLJkX.js +107 -0
  10. package/dist/button-icon-CWji4cBA.js +89 -0
  11. package/dist/calendar-CkLj89o2.js +112 -0
  12. package/dist/checkbox-input-CSboebwt.js +167 -0
  13. package/dist/chip-input-C1PJPDFq.js +189 -0
  14. package/dist/cn-Ca4KprQ1.js +2730 -0
  15. package/dist/components/alert/alert.atoms.d.ts +6 -0
  16. package/dist/components/alert/alert.d.ts +31 -0
  17. package/dist/components/alert/alert.stories.d.ts +42 -0
  18. package/dist/components/alert/helpers.d.ts +14 -0
  19. package/dist/components/alert/index.d.ts +2 -0
  20. package/dist/components/alert/types.d.ts +50 -0
  21. package/dist/components/alert.js +4 -0
  22. package/dist/components/app-bar/app-bar.atoms.d.ts +21 -0
  23. package/dist/components/app-bar/app-bar.d.ts +8 -0
  24. package/dist/components/app-bar/app-bar.stories.d.ts +19 -0
  25. package/dist/components/app-bar/helpers.d.ts +6 -0
  26. package/dist/components/app-bar/index.d.ts +2 -0
  27. package/dist/components/app-bar/types.d.ts +39 -0
  28. package/dist/components/app-bar.js +4 -0
  29. package/dist/components/avatar/avatar.atoms.d.ts +13 -0
  30. package/dist/components/avatar/avatar.d.ts +24 -0
  31. package/dist/components/avatar/avatar.stories.d.ts +42 -0
  32. package/dist/components/avatar/helpers.d.ts +14 -0
  33. package/dist/components/avatar/index.d.ts +2 -0
  34. package/dist/components/avatar/types.d.ts +46 -0
  35. package/dist/components/avatar.js +4 -0
  36. package/dist/components/badge/badge.d.ts +24 -0
  37. package/dist/components/badge/badge.stories.d.ts +46 -0
  38. package/dist/components/badge/helpers.d.ts +10 -0
  39. package/dist/components/badge/index.d.ts +2 -0
  40. package/dist/components/badge/types.d.ts +44 -0
  41. package/dist/components/badge.js +4 -0
  42. package/dist/components/bottom-bar/bottom-bar.atoms.d.ts +2 -0
  43. package/dist/components/bottom-bar/bottom-bar.d.ts +4 -0
  44. package/dist/components/bottom-bar/bottom-bar.stories.d.ts +6 -0
  45. package/dist/components/bottom-bar/helpers.d.ts +7 -0
  46. package/dist/components/bottom-bar/index.d.ts +2 -0
  47. package/dist/components/bottom-bar/types.d.ts +32 -0
  48. package/dist/components/bottom-bar.js +4 -0
  49. package/dist/components/breadcrumbs/breadcrumbs.atoms.d.ts +9 -0
  50. package/dist/components/breadcrumbs/breadcrumbs.d.ts +16 -0
  51. package/dist/components/breadcrumbs/breadcrumbs.stories.d.ts +7 -0
  52. package/dist/components/breadcrumbs/helpers.d.ts +7 -0
  53. package/dist/components/breadcrumbs/index.d.ts +2 -0
  54. package/dist/components/breadcrumbs/types.d.ts +21 -0
  55. package/dist/components/breadcrumbs.js +4 -0
  56. package/dist/components/button/button.d.ts +3 -0
  57. package/dist/components/button/button.stories.d.ts +50 -0
  58. package/dist/components/button/index.d.ts +2 -0
  59. package/dist/components/button/types.d.ts +30 -0
  60. package/dist/components/button-float/button-float.d.ts +8 -0
  61. package/dist/components/button-float/button-float.stories.d.ts +27 -0
  62. package/dist/components/button-float/helpers.d.ts +4 -0
  63. package/dist/components/button-float/index.d.ts +2 -0
  64. package/dist/components/button-float/types.d.ts +31 -0
  65. package/dist/components/button-float.js +4 -0
  66. package/dist/components/button-icon/button-icon.d.ts +3 -0
  67. package/dist/components/button-icon/button-icon.stories.d.ts +45 -0
  68. package/dist/components/button-icon/index.d.ts +2 -0
  69. package/dist/components/button-icon/types.d.ts +48 -0
  70. package/dist/components/button-icon.js +4 -0
  71. package/dist/components/button.js +4 -0
  72. package/dist/components/calendar/calendar.d.ts +8 -0
  73. package/dist/components/calendar/calendar.stories.d.ts +6 -0
  74. package/dist/components/calendar/index.d.ts +2 -0
  75. package/dist/components/calendar/types.d.ts +20 -0
  76. package/dist/components/calendar.js +4 -0
  77. package/dist/components/checkbox-input/checkbox-input.atoms.d.ts +9 -0
  78. package/dist/components/checkbox-input/checkbox-input.d.ts +5 -0
  79. package/dist/components/checkbox-input/checkbox-input.stories.d.ts +44 -0
  80. package/dist/components/checkbox-input/context.d.ts +10 -0
  81. package/dist/components/checkbox-input/helpers.d.ts +11 -0
  82. package/dist/components/checkbox-input/index.d.ts +2 -0
  83. package/dist/components/checkbox-input/types.d.ts +46 -0
  84. package/dist/components/checkbox-input.js +4 -0
  85. package/dist/components/chip-input/chip-input.atoms.d.ts +10 -0
  86. package/dist/components/chip-input/chip-input.d.ts +5 -0
  87. package/dist/components/chip-input/chip-input.stories.d.ts +12 -0
  88. package/dist/components/chip-input/context.d.ts +11 -0
  89. package/dist/components/chip-input/helpers.d.ts +4 -0
  90. package/dist/components/chip-input/index.d.ts +2 -0
  91. package/dist/components/chip-input/types.d.ts +51 -0
  92. package/dist/components/chip-input.js +4 -0
  93. package/dist/components/date-single-picker-input/date-single-picker-input.atoms.d.ts +13 -0
  94. package/dist/components/date-single-picker-input/date-single-picker-input.d.ts +10 -0
  95. package/dist/components/date-single-picker-input/date-single-picker-input.docked.d.ts +14 -0
  96. package/dist/components/date-single-picker-input/date-single-picker-input.docked.stories.d.ts +10 -0
  97. package/dist/components/date-single-picker-input/date-single-picker-input.modal.d.ts +15 -0
  98. package/dist/components/date-single-picker-input/date-single-picker-input.modal.stories.d.ts +10 -0
  99. package/dist/components/date-single-picker-input/helpers.d.ts +3 -0
  100. package/dist/components/date-single-picker-input/index.d.ts +2 -0
  101. package/dist/components/date-single-picker-input/types.d.ts +75 -0
  102. package/dist/components/date-single-picker-input/use-date-single-picker.d.ts +10 -0
  103. package/dist/components/date-single-picker-input.js +4 -0
  104. package/dist/components/drawer/context.d.ts +11 -0
  105. package/dist/components/drawer/drawer.atoms.d.ts +23 -0
  106. package/dist/components/drawer/drawer.d.ts +16 -0
  107. package/dist/components/drawer/drawer.stories.d.ts +41 -0
  108. package/dist/components/drawer/helpers.d.ts +39 -0
  109. package/dist/components/drawer/index.d.ts +10 -0
  110. package/dist/components/drawer/types.d.ts +93 -0
  111. package/dist/components/drawer.js +9 -0
  112. package/dist/components/icon/helpers.d.ts +4 -0
  113. package/dist/components/icon/icon.d.ts +8 -0
  114. package/dist/components/icon/icon.stories.d.ts +39 -0
  115. package/dist/components/icon/index.d.ts +2 -0
  116. package/dist/components/icon/types.d.ts +13 -0
  117. package/dist/components/icon.js +4 -0
  118. package/dist/components/index.d.ts +29 -0
  119. package/dist/components/loading-indicator/helpers.d.ts +9 -0
  120. package/dist/components/loading-indicator/index.d.ts +1 -0
  121. package/dist/components/loading-indicator/loading-indicator.atoms.d.ts +10 -0
  122. package/dist/components/loading-indicator/loading-indicator.d.ts +7 -0
  123. package/dist/components/loading-indicator/loading-indicator.stories.d.ts +16 -0
  124. package/dist/components/loading-indicator/types.d.ts +29 -0
  125. package/dist/components/loading-indicator.js +4 -0
  126. package/dist/components/menu/context.d.ts +13 -0
  127. package/dist/components/menu/helpers.d.ts +8 -0
  128. package/dist/components/menu/index.d.ts +2 -0
  129. package/dist/components/menu/menu.atoms.d.ts +14 -0
  130. package/dist/components/menu/menu.d.ts +7 -0
  131. package/dist/components/menu/menu.stories.d.ts +22 -0
  132. package/dist/components/menu/types.d.ts +36 -0
  133. package/dist/components/menu/use-menu.d.ts +3 -0
  134. package/dist/components/menu.js +4 -0
  135. package/dist/components/modal/helpers.d.ts +7 -0
  136. package/dist/components/modal/index.d.ts +2 -0
  137. package/dist/components/modal/modal.atoms.d.ts +8 -0
  138. package/dist/components/modal/modal.d.ts +7 -0
  139. package/dist/components/modal/modal.stories.d.ts +13 -0
  140. package/dist/components/modal/types.d.ts +48 -0
  141. package/dist/components/modal/use-escape-close.d.ts +6 -0
  142. package/dist/components/modal/use-focus-trap.d.ts +6 -0
  143. package/dist/components/modal.js +4 -0
  144. package/dist/components/radio-input/context.d.ts +11 -0
  145. package/dist/components/radio-input/helpers.d.ts +11 -0
  146. package/dist/components/radio-input/index.d.ts +2 -0
  147. package/dist/components/radio-input/radio-input.atoms.d.ts +9 -0
  148. package/dist/components/radio-input/radio-input.d.ts +5 -0
  149. package/dist/components/radio-input/radio-input.stories.d.ts +74 -0
  150. package/dist/components/radio-input/types.d.ts +54 -0
  151. package/dist/components/radio-input.js +4 -0
  152. package/dist/components/segment-multiple-input/context.d.ts +12 -0
  153. package/dist/components/segment-multiple-input/helpers.d.ts +15 -0
  154. package/dist/components/segment-multiple-input/index.d.ts +2 -0
  155. package/dist/components/segment-multiple-input/segment-multiple-input.atoms.d.ts +12 -0
  156. package/dist/components/segment-multiple-input/segment-multiple-input.d.ts +7 -0
  157. package/dist/components/segment-multiple-input/segment-multiple-input.stories.d.ts +66 -0
  158. package/dist/components/segment-multiple-input/types.d.ts +55 -0
  159. package/dist/components/segment-multiple-input.js +4 -0
  160. package/dist/components/segment-single-input/context.d.ts +12 -0
  161. package/dist/components/segment-single-input/helpers.d.ts +15 -0
  162. package/dist/components/segment-single-input/index.d.ts +2 -0
  163. package/dist/components/segment-single-input/segment-single-input.atoms.d.ts +11 -0
  164. package/dist/components/segment-single-input/segment-single-input.d.ts +7 -0
  165. package/dist/components/segment-single-input/segment-single-input.stories.d.ts +57 -0
  166. package/dist/components/segment-single-input/types.d.ts +55 -0
  167. package/dist/components/segment-single-input.js +4 -0
  168. package/dist/components/select-input/helpers.d.ts +3 -0
  169. package/dist/components/select-input/index.d.ts +2 -0
  170. package/dist/components/select-input/select-input.d.ts +9 -0
  171. package/dist/components/select-input/select-input.stories.d.ts +50 -0
  172. package/dist/components/select-input/types.d.ts +29 -0
  173. package/dist/components/select-input.js +4 -0
  174. package/dist/components/skeleton/helpers.d.ts +6 -0
  175. package/dist/components/skeleton/index.d.ts +2 -0
  176. package/dist/components/skeleton/skeleton.d.ts +6 -0
  177. package/dist/components/skeleton/skeleton.stories.d.ts +25 -0
  178. package/dist/components/skeleton/types.d.ts +17 -0
  179. package/dist/components/skeleton.js +4 -0
  180. package/dist/components/snackbar/helpers.d.ts +8 -0
  181. package/dist/components/snackbar/index.d.ts +2 -0
  182. package/dist/components/snackbar/snackbar.atoms.d.ts +10 -0
  183. package/dist/components/snackbar/snackbar.d.ts +6 -0
  184. package/dist/components/snackbar/snackbar.stories.d.ts +8 -0
  185. package/dist/components/snackbar/types.d.ts +40 -0
  186. package/dist/components/snackbar.js +4 -0
  187. package/dist/components/switch-input/helpers.d.ts +18 -0
  188. package/dist/components/switch-input/index.d.ts +3 -0
  189. package/dist/components/switch-input/switch-input.atoms.d.ts +28 -0
  190. package/dist/components/switch-input/switch-input.d.ts +6 -0
  191. package/dist/components/switch-input/switch-input.stories.d.ts +10 -0
  192. package/dist/components/switch-input/types.d.ts +49 -0
  193. package/dist/components/switch-input.js +7 -0
  194. package/dist/components/tabs/context.d.ts +3 -0
  195. package/dist/components/tabs/helpers.d.ts +8 -0
  196. package/dist/components/tabs/index.d.ts +2 -0
  197. package/dist/components/tabs/tabs.atoms.d.ts +10 -0
  198. package/dist/components/tabs/tabs.d.ts +5 -0
  199. package/dist/components/tabs/tabs.stories.d.ts +17 -0
  200. package/dist/components/tabs/types.d.ts +41 -0
  201. package/dist/components/tabs/use-tab-indicator.d.ts +13 -0
  202. package/dist/components/tabs.js +4 -0
  203. package/dist/components/text/helpers.d.ts +18 -0
  204. package/dist/components/text/index.d.ts +2 -0
  205. package/dist/components/text/text.d.ts +7 -0
  206. package/dist/components/text/text.stories.d.ts +14 -0
  207. package/dist/components/text/types.d.ts +30 -0
  208. package/dist/components/text-input/helpers.d.ts +3 -0
  209. package/dist/components/text-input/index.d.ts +2 -0
  210. package/dist/components/text-input/text-input.d.ts +9 -0
  211. package/dist/components/text-input/text-input.stories.d.ts +20 -0
  212. package/dist/components/text-input/types.d.ts +33 -0
  213. package/dist/components/text-input.js +4 -0
  214. package/dist/components/text.js +4 -0
  215. package/dist/components/textarea-input/helpers.d.ts +4 -0
  216. package/dist/components/textarea-input/index.d.ts +2 -0
  217. package/dist/components/textarea-input/textarea-input.d.ts +10 -0
  218. package/dist/components/textarea-input/textarea-input.stories.d.ts +50 -0
  219. package/dist/components/textarea-input/types.d.ts +40 -0
  220. package/dist/components/textarea-input.js +4 -0
  221. package/dist/components/tile/helpers.d.ts +8 -0
  222. package/dist/components/tile/index.d.ts +2 -0
  223. package/dist/components/tile/tile.d.ts +11 -0
  224. package/dist/components/tile/tile.stories.d.ts +35 -0
  225. package/dist/components/tile/types.d.ts +23 -0
  226. package/dist/components/tile.js +4 -0
  227. package/dist/components/top-bar/helpers.d.ts +26 -0
  228. package/dist/components/top-bar/index.d.ts +2 -0
  229. package/dist/components/top-bar/top-bar.atoms.d.ts +6 -0
  230. package/dist/components/top-bar/top-bar.d.ts +8 -0
  231. package/dist/components/top-bar/top-bar.stories.d.ts +15 -0
  232. package/dist/components/top-bar/types.d.ts +38 -0
  233. package/dist/components/top-bar.js +4 -0
  234. package/dist/date-single-picker-input--Ew0O9NQ.js +252 -0
  235. package/dist/drawer-DrnAR2a4.js +218 -0
  236. package/dist/helpers-CEDtBUGM.js +37 -0
  237. package/dist/hooks/index.d.ts +1 -0
  238. package/dist/hooks/index.js +1 -0
  239. package/dist/icon-D-lTZMHY.js +44 -0
  240. package/dist/index-DU1SCUkk.js +329 -0
  241. package/dist/index.d.ts +2 -0
  242. package/dist/index.js +68 -0
  243. package/dist/loading-indicator-BZMnT5PA.js +168 -0
  244. package/dist/menu-BZvilMF7.js +174 -0
  245. package/dist/modal-BGAtqMl9.js +149 -0
  246. package/dist/radio-input-BRGoevZY.js +173 -0
  247. package/dist/segment-multiple-input-VwHCqFd6.js +229 -0
  248. package/dist/segment-single-input-Cqoo7-C2.js +228 -0
  249. package/dist/select-input-DCb0usvK.js +108 -0
  250. package/dist/skeleton-D4X5USf_.js +59 -0
  251. package/dist/snackbar-CYias-fJ.js +79 -0
  252. package/dist/styles.css +115 -0
  253. package/dist/switch-input-C5s1lvYh.js +186 -0
  254. package/dist/tabs-C8aRKfxS.js +216 -0
  255. package/dist/text-B7e-au41.js +120 -0
  256. package/dist/text-input-BsWvUk_H.js +73 -0
  257. package/dist/textarea-input-DZExXEE8.js +102 -0
  258. package/dist/tile-Du7YciCG.js +51 -0
  259. package/dist/top-bar-ErHvwR4K.js +62 -0
  260. package/package.json +97 -0
@@ -0,0 +1,174 @@
1
+ import { c as b, j as l } from "./index-DU1SCUkk.js";
2
+ import { createContext as h, useContext as w, forwardRef as f, useId as M, useEffect as m, useRef as g } from "react";
3
+ import { c as y } from "./cn-Ca4KprQ1.js";
4
+ const x = h(null), p = () => {
5
+ const n = w(x);
6
+ if (!n)
7
+ throw new Error("useMenuContext must be used within a Menu component");
8
+ return n;
9
+ }, E = b(
10
+ // Modern, clean, accessible base style
11
+ "z-50 min-w-40 bg-neutral-50 text-black rounded-lg shadow-md border border-transparent",
12
+ {
13
+ variants: {
14
+ variant: {
15
+ default: "",
16
+ outline: "border bg-transparent"
17
+ },
18
+ size: {
19
+ sm: "py-2",
20
+ md: "py-2.5"
21
+ }
22
+ },
23
+ defaultVariants: {
24
+ variant: "default",
25
+ size: "md"
26
+ }
27
+ }
28
+ ), z = b(
29
+ "w-full text-left px-4 rounded-md cursor-pointer transition-colors duration-150 font-medium select-none focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-coral/70 hover:bg-slate-100 active:bg-slate-200 disabled:opacity-50 disabled:cursor-not-allowed",
30
+ {
31
+ variants: {
32
+ variant: {
33
+ default: "",
34
+ outline: "border border-color-neutral"
35
+ },
36
+ size: {
37
+ sm: "text-sm py-2",
38
+ md: "text-base py-2.5"
39
+ }
40
+ },
41
+ defaultVariants: {
42
+ variant: "default",
43
+ size: "md"
44
+ }
45
+ }
46
+ ), I = f(
47
+ ({ children: n, ...e }, t) => {
48
+ const { open: u, triggerRef: r } = p();
49
+ return /* @__PURE__ */ l.jsx(
50
+ "button",
51
+ {
52
+ ref: (o) => {
53
+ r.current = o, typeof t == "function" ? t(o) : t && (t.current = o);
54
+ },
55
+ "aria-haspopup": "menu",
56
+ "aria-expanded": u,
57
+ "aria-controls": "menu-content",
58
+ type: "button",
59
+ ...e,
60
+ children: n
61
+ }
62
+ );
63
+ }
64
+ ), j = f(
65
+ ({ children: n, className: e, ...t }, u) => {
66
+ const { open: r, contentRef: o, triggerRef: i, size: s } = p(), d = M();
67
+ let c = 0, v = 0;
68
+ if (i.current) {
69
+ const a = i.current.getBoundingClientRect();
70
+ c = a.bottom + window.scrollY + 4, v = a.left + window.scrollX;
71
+ }
72
+ return /* @__PURE__ */ l.jsx(
73
+ "div",
74
+ {
75
+ ref: (a) => {
76
+ o.current = a, typeof u == "function" ? u(a) : u && (u.current = a);
77
+ },
78
+ id: `menu-content-${d}`,
79
+ role: "menu",
80
+ tabIndex: -1,
81
+ "aria-hidden": !r,
82
+ className: y(
83
+ E({
84
+ size: s
85
+ }),
86
+ "absolute z-50 transition-opacity duration-150 ease-out",
87
+ r ? "opacity-100" : "opacity-0",
88
+ e
89
+ ),
90
+ style: {
91
+ minWidth: i.current?.offsetWidth,
92
+ top: c,
93
+ left: v
94
+ },
95
+ ...t,
96
+ children: r && n
97
+ }
98
+ );
99
+ }
100
+ ), k = f(
101
+ ({ children: n, disabled: e, className: t, ...u }, r) => {
102
+ const { size: o } = p();
103
+ return /* @__PURE__ */ l.jsx(
104
+ "button",
105
+ {
106
+ ref: r,
107
+ role: "menuitem",
108
+ tabIndex: 0,
109
+ disabled: e,
110
+ "aria-disabled": e,
111
+ className: y(
112
+ z({
113
+ size: o
114
+ }),
115
+ t
116
+ ),
117
+ ...u,
118
+ children: n
119
+ }
120
+ );
121
+ }
122
+ );
123
+ function C(n, e, t, u) {
124
+ m(() => {
125
+ if (!n) return;
126
+ function r(o) {
127
+ !e.current?.contains(o.target) && !t.current?.contains(o.target) && u();
128
+ }
129
+ return document.addEventListener("mousedown", r), () => document.removeEventListener("mousedown", r);
130
+ }, [n, u, e, t]);
131
+ }
132
+ function D(n, e) {
133
+ m(() => {
134
+ if (n && e.current) {
135
+ const t = e.current.querySelectorAll('[role="menuitem"]');
136
+ t.length && t[0].focus();
137
+ }
138
+ }, [n, e]);
139
+ }
140
+ function A(n, e, t, u) {
141
+ m(() => {
142
+ if (!n || !e.current) return;
143
+ const r = e.current;
144
+ function o(i) {
145
+ const s = Array.from(
146
+ r.querySelectorAll('[role="menuitem"]')
147
+ ), d = document.activeElement, c = s.indexOf(d);
148
+ i.key === "ArrowDown" ? (i.preventDefault(), s.length && s[(c + 1) % s.length].focus()) : i.key === "ArrowUp" ? (i.preventDefault(), s.length && s[(c - 1 + s.length) % s.length].focus()) : i.key === "Home" ? (i.preventDefault(), s.length && s[0].focus()) : i.key === "End" ? (i.preventDefault(), s.length && s[s.length - 1].focus()) : i.key === "Escape" && (i.preventDefault(), u(), t.current?.focus());
149
+ }
150
+ return r.addEventListener("keydown", o), () => r.removeEventListener("keydown", o);
151
+ }, [n, u, e, t]);
152
+ }
153
+ const L = ({
154
+ children: n,
155
+ isOpen: e,
156
+ onOutsideClick: t,
157
+ size: u = "md"
158
+ }) => {
159
+ const r = g(null), o = g(null);
160
+ return C(e, o, r, t), D(e, o), A(e, o, r, t), /* @__PURE__ */ l.jsx(
161
+ x.Provider,
162
+ {
163
+ value: { open: e, triggerRef: r, contentRef: o, size: u },
164
+ children: n
165
+ }
166
+ );
167
+ }, q = Object.assign(L, {
168
+ Trigger: I,
169
+ Content: j,
170
+ Item: k
171
+ });
172
+ export {
173
+ q as M
174
+ };
@@ -0,0 +1,149 @@
1
+ import { j as o, c as y } from "./index-DU1SCUkk.js";
2
+ import { forwardRef as s, useEffect as d, useRef as x, useState as p } from "react";
3
+ import { c as u } from "./cn-Ca4KprQ1.js";
4
+ const E = s(
5
+ ({ className: e, ...t }, a) => /* @__PURE__ */ o.jsx(
6
+ "div",
7
+ {
8
+ ref: a,
9
+ className: u("px-6 pt-6 pb-2 text-lg font-semibold", e),
10
+ ...t
11
+ }
12
+ )
13
+ ), k = s(
14
+ ({ className: e, ...t }, a) => /* @__PURE__ */ o.jsx(
15
+ "div",
16
+ {
17
+ ref: a,
18
+ className: u("px-6 py-4 flex justify-end gap-2", e),
19
+ ...t
20
+ }
21
+ )
22
+ ), M = s(
23
+ ({ className: e, ...t }, a) => /* @__PURE__ */ o.jsx("div", { ref: a, className: u("px-6 py-2", e), ...t })
24
+ ), R = s(
25
+ ({ onOverlayClick: e, ...t }, a) => /* @__PURE__ */ o.jsx(
26
+ "div",
27
+ {
28
+ ref: a,
29
+ role: "presentation",
30
+ tabIndex: -1,
31
+ "aria-modal": "true",
32
+ onClick: e,
33
+ ...t
34
+ }
35
+ )
36
+ ), N = y(
37
+ "fixed inset-0 z-51 transition-opacity duration-300 bg-black/30 backdrop-blur-md flex items-center justify-center transition-opacity duration-200 ease-in-out",
38
+ {
39
+ variants: {
40
+ placement: {
41
+ top: "items-start",
42
+ center: "items-center"
43
+ }
44
+ },
45
+ defaultVariants: {
46
+ placement: "center"
47
+ }
48
+ }
49
+ ), V = y(
50
+ [
51
+ "bg-white rounded-lg shadow-xl relative",
52
+ "flex flex-col",
53
+ "outline-none",
54
+ "mx-4",
55
+ "transition-all duration-200 ease-in-out "
56
+ ],
57
+ {
58
+ variants: {
59
+ size: {
60
+ sm: "w-[20rem] max-w-sm",
61
+ // 20rem, 320px
62
+ md: "w-[28rem] max-w-md",
63
+ // 28rem, 448px
64
+ lg: "w-[36rem] max-w-lg"
65
+ // 36rem, 576px
66
+ },
67
+ placement: {
68
+ top: "mt-4",
69
+ center: ""
70
+ }
71
+ },
72
+ defaultVariants: {
73
+ size: "md",
74
+ placement: "center"
75
+ }
76
+ }
77
+ );
78
+ function A(e, t) {
79
+ d(() => {
80
+ if (t && e.current) {
81
+ const a = e.current.querySelectorAll(
82
+ 'button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])'
83
+ );
84
+ a.length && a[0].focus();
85
+ }
86
+ }, [t, e]);
87
+ }
88
+ function F(e, t) {
89
+ d(() => {
90
+ if (!e) return;
91
+ const a = (n) => {
92
+ n.key === "Escape" && t();
93
+ };
94
+ return document.addEventListener("keydown", a), () => document.removeEventListener("keydown", a);
95
+ }, [e, t]);
96
+ }
97
+ const I = 200, T = ({
98
+ isOpen: e,
99
+ onOpenChange: t,
100
+ size: a = "md",
101
+ placement: n = "center",
102
+ children: v,
103
+ disableOverlayClose: b,
104
+ disableEscClose: w,
105
+ ...j
106
+ }) => {
107
+ const r = x(null), i = x(null), [g, m] = p(e), [f, c] = p(!1);
108
+ return d(() => {
109
+ if (e)
110
+ m(!0), c(!1), r.current = document.activeElement;
111
+ else if (g) {
112
+ c(!0);
113
+ const l = setTimeout(() => {
114
+ m(!1), c(!1), r.current && r.current.focus();
115
+ }, I);
116
+ return () => clearTimeout(l);
117
+ }
118
+ }, [e]), F(e && !w, () => {
119
+ t && t(!1);
120
+ }), A(i, e), /* @__PURE__ */ o.jsx(
121
+ R,
122
+ {
123
+ ref: i,
124
+ className: `${N({ placement: n })} transition-opacity duration-200 ease-in-out ` + (e && !f ? "opacity-100" : "opacity-0 pointer-events-none"),
125
+ onOverlayClick: (l) => {
126
+ l.target === i.current && !b && t && t(!1);
127
+ },
128
+ placement: n,
129
+ children: /* @__PURE__ */ o.jsx(
130
+ "div",
131
+ {
132
+ className: `${V({ size: a, placement: n })} transition-all duration-200 ease-in-out ` + (e && !f ? "opacity-100 scale-100" : "opacity-0 scale-95 pointer-events-none"),
133
+ role: "dialog",
134
+ ...j,
135
+ tabIndex: 0,
136
+ "aria-hidden": !e,
137
+ children: v
138
+ }
139
+ )
140
+ }
141
+ );
142
+ }, B = Object.assign(T, {
143
+ Header: E,
144
+ Body: M,
145
+ Footer: k
146
+ });
147
+ export {
148
+ B as M
149
+ };
@@ -0,0 +1,173 @@
1
+ import { c as m, j as r } from "./index-DU1SCUkk.js";
2
+ import f, { createContext as k, useContext as w } from "react";
3
+ import { c as h } from "./cn-Ca4KprQ1.js";
4
+ const y = m("space-y-2", {
5
+ variants: {
6
+ direction: {
7
+ vertical: "space-y-2 space-x-0",
8
+ horizontal: "flex flex-wrap gap-4 space-y-0"
9
+ }
10
+ },
11
+ defaultVariants: {
12
+ direction: "vertical"
13
+ }
14
+ }), v = m(
15
+ "relative h-4 w-4 rounded-full border cursor-pointer transition-all duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:opacity-50 disabled:cursor-not-allowed appearance-none bg-white",
16
+ {
17
+ variants: {
18
+ variant: {
19
+ // Core variants using Versaur color system
20
+ primary: "border-coral/40 checked:bg-coral checked:border-coral focus:ring-coral/20",
21
+ secondary: "border-sage/40 checked:bg-sage checked:border-sage focus:ring-sage/20",
22
+ tertiary: "border-mist/40 checked:bg-mist checked:border-mist focus:ring-mist/20",
23
+ ghost: "border-slate/40 checked:bg-slate checked:border-slate focus:ring-slate/20",
24
+ neutral: "border-gray-300 checked:bg-gray-500 checked:border-gray-500 focus:ring-gray-400/20",
25
+ // Outline variants
26
+ "primary-outline": "border-coral checked:bg-white checked:border-coral focus:ring-coral/20",
27
+ "secondary-outline": "border-sage checked:bg-white checked:border-sage focus:ring-sage/20",
28
+ "tertiary-outline": "border-mist checked:bg-white checked:border-mist focus:ring-mist/20",
29
+ "ghost-outline": "border-slate checked:bg-white checked:border-slate focus:ring-slate/20",
30
+ "neutral-outline": "border-gray-400 checked:bg-white checked:border-gray-400 focus:ring-gray-500/20",
31
+ // Semantic variants
32
+ success: "border-success/40 checked:bg-success checked:border-success focus:ring-success/20",
33
+ "success-outline": "border-success checked:bg-white checked:border-success focus:ring-success/20",
34
+ info: "border-info/40 checked:bg-info checked:border-info focus:ring-info/20",
35
+ "info-outline": "border-info checked:bg-white checked:border-info focus:ring-info/20",
36
+ warning: "border-warning/40 checked:bg-warning checked:border-warning focus:ring-warning/20",
37
+ "warning-outline": "border-warning checked:bg-white checked:border-warning focus:ring-warning/20",
38
+ danger: "border-danger/40 checked:bg-danger checked:border-danger focus:ring-danger/20",
39
+ "danger-outline": "border-danger checked:bg-white checked:border-danger focus:ring-danger/20"
40
+ },
41
+ size: {
42
+ sm: "h-3 w-3",
43
+ md: "h-4 w-4",
44
+ lg: "h-5 w-5"
45
+ }
46
+ },
47
+ defaultVariants: {
48
+ variant: "primary",
49
+ size: "md"
50
+ }
51
+ }
52
+ ), j = m(
53
+ "text-foreground cursor-pointer select-none",
54
+ {
55
+ variants: {
56
+ size: {
57
+ sm: "text-xs",
58
+ md: "text-sm",
59
+ lg: "text-base"
60
+ },
61
+ disabled: {
62
+ true: "opacity-50 cursor-not-allowed",
63
+ false: ""
64
+ }
65
+ },
66
+ defaultVariants: {
67
+ size: "md",
68
+ disabled: !1
69
+ }
70
+ }
71
+ ), x = k(
72
+ null
73
+ ), z = () => {
74
+ const o = w(x);
75
+ if (!o)
76
+ throw new Error(
77
+ "useRadioInputContext must be used within RadioInputContext"
78
+ );
79
+ return o;
80
+ }, R = f.forwardRef(
81
+ ({ children: o, description: c, className: a, disabled: i, id: n, value: l, ...b }, g) => {
82
+ const e = z(), u = f.useId(), d = n || u, t = i || e.disabled, s = e.error ? "danger" : e.variant || "primary";
83
+ return /* @__PURE__ */ r.jsxs("div", { className: "flex items-center gap-2", children: [
84
+ /* @__PURE__ */ r.jsx("div", { className: "relative flex items-center", children: /* @__PURE__ */ r.jsx(
85
+ "input",
86
+ {
87
+ ref: g,
88
+ type: "radio",
89
+ id: d,
90
+ name: e.name,
91
+ value: l,
92
+ disabled: t,
93
+ className: h(
94
+ v({
95
+ variant: s,
96
+ size: e.size
97
+ }),
98
+ // Custom radio dot styling using ::before - centered positioning with size variants
99
+ 'before:content-[""] before:absolute before:left-1/2 before:top-1/2 before:-translate-x-1/2 before:-translate-y-1/2 before:rounded-full before:bg-white before:opacity-0 before:transition-opacity before:duration-200',
100
+ // Size-specific radio dot dimensions
101
+ e.size === "sm" && "before:w-[6px] before:h-[6px]",
102
+ e.size === "md" && "before:w-[8px] before:h-[8px]",
103
+ e.size === "lg" && "before:w-[10px] before:h-[10px]",
104
+ "checked:before:opacity-100",
105
+ // Outline variants use colored radio dot
106
+ s?.includes("outline") && "checked:before:bg-current",
107
+ a
108
+ ),
109
+ ...b
110
+ }
111
+ ) }),
112
+ /* @__PURE__ */ r.jsxs("div", { className: "flex-1", children: [
113
+ /* @__PURE__ */ r.jsx(
114
+ "label",
115
+ {
116
+ htmlFor: d,
117
+ className: j({
118
+ size: e.size,
119
+ disabled: t
120
+ }),
121
+ children: o
122
+ }
123
+ ),
124
+ c && /* @__PURE__ */ r.jsx(
125
+ "div",
126
+ {
127
+ className: h(
128
+ "text-gray-600 mt-1",
129
+ e.size === "sm" && "text-xs",
130
+ e.size === "md" && "text-xs",
131
+ e.size === "lg" && "text-sm",
132
+ t && "opacity-50"
133
+ ),
134
+ children: c
135
+ }
136
+ )
137
+ ] })
138
+ ] });
139
+ }
140
+ ), N = f.forwardRef(
141
+ ({
142
+ variant: o = "primary",
143
+ size: c = "md",
144
+ label: a,
145
+ helperText: i,
146
+ error: n,
147
+ direction: l = "vertical",
148
+ className: b,
149
+ disabled: g,
150
+ name: e,
151
+ children: u,
152
+ ...d
153
+ }, t) => {
154
+ const s = !!n, p = {
155
+ variant: o,
156
+ size: c,
157
+ disabled: g,
158
+ error: s,
159
+ name: e
160
+ };
161
+ return /* @__PURE__ */ r.jsx(x.Provider, { value: p, children: /* @__PURE__ */ r.jsxs("div", { ref: t, className: h("w-full", b), ...d, children: [
162
+ a && /* @__PURE__ */ r.jsx("div", { className: "block text-sm font-medium text-foreground mb-3", children: a }),
163
+ /* @__PURE__ */ r.jsx("div", { className: y({ direction: l }), children: u }),
164
+ s && /* @__PURE__ */ r.jsx("div", { className: "mt-2 text-sm text-danger", role: "alert", children: n }),
165
+ !s && i && /* @__PURE__ */ r.jsx("div", { className: "mt-2 text-sm text-gray-600", children: i })
166
+ ] }) });
167
+ }
168
+ ), O = Object.assign(N, {
169
+ Option: R
170
+ });
171
+ export {
172
+ O as R
173
+ };