@tribepad/themis 1.0.0 → 1.0.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.
Files changed (326) hide show
  1. package/dist/elements/Accordion/index.js +325 -66
  2. package/dist/elements/Accordion/index.js.map +1 -1
  3. package/dist/elements/Accordion/index.mjs +317 -3
  4. package/dist/elements/Accordion/index.mjs.map +1 -1
  5. package/dist/elements/Avatar/index.js +461 -45
  6. package/dist/elements/Avatar/index.js.map +1 -1
  7. package/dist/elements/Avatar/index.mjs +456 -3
  8. package/dist/elements/Avatar/index.mjs.map +1 -1
  9. package/dist/elements/Badge/index.js +238 -36
  10. package/dist/elements/Badge/index.js.map +1 -1
  11. package/dist/elements/Badge/index.mjs +234 -4
  12. package/dist/elements/Badge/index.mjs.map +1 -1
  13. package/dist/elements/Breadcrumbs/index.js +808 -39
  14. package/dist/elements/Breadcrumbs/index.js.map +1 -1
  15. package/dist/elements/Breadcrumbs/index.mjs +810 -7
  16. package/dist/elements/Breadcrumbs/index.mjs.map +1 -1
  17. package/dist/elements/Button/index.js +282 -19
  18. package/dist/elements/Button/index.js.map +1 -1
  19. package/dist/elements/Button/index.mjs +283 -4
  20. package/dist/elements/Button/index.mjs.map +1 -1
  21. package/dist/elements/ButtonGroup/index.js +229 -56
  22. package/dist/elements/ButtonGroup/index.js.map +1 -1
  23. package/dist/elements/ButtonGroup/index.mjs +222 -3
  24. package/dist/elements/ButtonGroup/index.mjs.map +1 -1
  25. package/dist/elements/Card/Card.d.ts.map +1 -1
  26. package/dist/elements/Card/index.js +563 -67
  27. package/dist/elements/Card/index.js.map +1 -1
  28. package/dist/elements/Card/index.mjs +560 -6
  29. package/dist/elements/Card/index.mjs.map +1 -1
  30. package/dist/elements/Carousel/index.js +782 -14
  31. package/dist/elements/Carousel/index.js.map +1 -1
  32. package/dist/elements/Carousel/index.mjs +786 -8
  33. package/dist/elements/Carousel/index.mjs.map +1 -1
  34. package/dist/elements/Chart/index.js +1833 -36
  35. package/dist/elements/Chart/index.js.map +1 -1
  36. package/dist/elements/Chart/index.mjs +1832 -4
  37. package/dist/elements/Chart/index.mjs.map +1 -1
  38. package/dist/elements/Checkbox/index.js +310 -39
  39. package/dist/elements/Checkbox/index.js.map +1 -1
  40. package/dist/elements/Checkbox/index.mjs +306 -4
  41. package/dist/elements/Checkbox/index.mjs.map +1 -1
  42. package/dist/elements/CheckboxGroup/index.js +445 -59
  43. package/dist/elements/CheckboxGroup/index.js.map +1 -1
  44. package/dist/elements/CheckboxGroup/index.mjs +439 -4
  45. package/dist/elements/CheckboxGroup/index.mjs.map +1 -1
  46. package/dist/elements/DatePicker/index.js +871 -89
  47. package/dist/elements/DatePicker/index.js.map +1 -1
  48. package/dist/elements/DatePicker/index.mjs +853 -4
  49. package/dist/elements/DatePicker/index.mjs.map +1 -1
  50. package/dist/elements/Dropdown/index.js +189 -35
  51. package/dist/elements/Dropdown/index.js.map +1 -1
  52. package/dist/elements/Dropdown/index.mjs +184 -2
  53. package/dist/elements/Dropdown/index.mjs.map +1 -1
  54. package/dist/elements/FileField/index.js +1532 -129
  55. package/dist/elements/FileField/index.js.map +1 -1
  56. package/dist/elements/FileField/index.mjs +1507 -7
  57. package/dist/elements/FileField/index.mjs.map +1 -1
  58. package/dist/elements/FormLayout/index.js +166 -11
  59. package/dist/elements/FormLayout/index.js.map +1 -1
  60. package/dist/elements/FormLayout/index.mjs +167 -2
  61. package/dist/elements/FormLayout/index.mjs.map +1 -1
  62. package/dist/elements/Modal/index.js +228 -46
  63. package/dist/elements/Modal/index.js.map +1 -1
  64. package/dist/elements/Modal/index.mjs +220 -1
  65. package/dist/elements/Modal/index.mjs.map +1 -1
  66. package/dist/elements/NumberField/index.js +659 -48
  67. package/dist/elements/NumberField/index.js.map +1 -1
  68. package/dist/elements/NumberField/index.mjs +654 -6
  69. package/dist/elements/NumberField/index.mjs.map +1 -1
  70. package/dist/elements/OTPInput/index.js +729 -6
  71. package/dist/elements/OTPInput/index.js.map +1 -1
  72. package/dist/elements/OTPInput/index.mjs +732 -2
  73. package/dist/elements/OTPInput/index.mjs.map +1 -1
  74. package/dist/elements/Panel/index.js +326 -27
  75. package/dist/elements/Panel/index.js.map +1 -1
  76. package/dist/elements/Panel/index.mjs +323 -2
  77. package/dist/elements/Panel/index.mjs.map +1 -1
  78. package/dist/elements/Progress/index.js +181 -22
  79. package/dist/elements/Progress/index.js.map +1 -1
  80. package/dist/elements/Progress/index.mjs +181 -3
  81. package/dist/elements/Progress/index.mjs.map +1 -1
  82. package/dist/elements/RadioGroup/index.js +358 -34
  83. package/dist/elements/RadioGroup/index.js.map +1 -1
  84. package/dist/elements/RadioGroup/index.mjs +359 -4
  85. package/dist/elements/RadioGroup/index.mjs.map +1 -1
  86. package/dist/elements/Resizable/components/ResizableHandle.d.ts +0 -8
  87. package/dist/elements/Resizable/components/ResizableHandle.d.ts.map +1 -1
  88. package/dist/elements/Resizable/components/ResizablePanel.d.ts +0 -8
  89. package/dist/elements/Resizable/components/ResizablePanel.d.ts.map +1 -1
  90. package/dist/elements/Resizable/components/ResizablePanelGroup.d.ts +0 -8
  91. package/dist/elements/Resizable/components/ResizablePanelGroup.d.ts.map +1 -1
  92. package/dist/elements/Resizable/components/ResizablePopover.d.ts +0 -8
  93. package/dist/elements/Resizable/components/ResizablePopover.d.ts.map +1 -1
  94. package/dist/elements/Resizable/index.js +1568 -51
  95. package/dist/elements/Resizable/index.js.map +1 -1
  96. package/dist/elements/Resizable/index.mjs +1566 -6
  97. package/dist/elements/Resizable/index.mjs.map +1 -1
  98. package/dist/elements/Select/index.js +580 -22
  99. package/dist/elements/Select/index.js.map +1 -1
  100. package/dist/elements/Select/index.mjs +582 -2
  101. package/dist/elements/Select/index.mjs.map +1 -1
  102. package/dist/elements/Skeleton/index.js +77 -15
  103. package/dist/elements/Skeleton/index.js.map +1 -1
  104. package/dist/elements/Skeleton/index.mjs +78 -3
  105. package/dist/elements/Skeleton/index.mjs.map +1 -1
  106. package/dist/elements/Switch/index.js +153 -21
  107. package/dist/elements/Switch/index.js.map +1 -1
  108. package/dist/elements/Switch/index.mjs +149 -5
  109. package/dist/elements/Switch/index.mjs.map +1 -1
  110. package/dist/elements/Table/index.js +589 -68
  111. package/dist/elements/Table/index.js.map +1 -1
  112. package/dist/elements/Table/index.mjs +578 -5
  113. package/dist/elements/Table/index.mjs.map +1 -1
  114. package/dist/elements/Tabs/index.js +328 -63
  115. package/dist/elements/Tabs/index.js.map +1 -1
  116. package/dist/elements/Tabs/index.mjs +320 -3
  117. package/dist/elements/Tabs/index.mjs.map +1 -1
  118. package/dist/elements/TextField/index.js +695 -51
  119. package/dist/elements/TextField/index.js.map +1 -1
  120. package/dist/elements/TextField/index.mjs +684 -7
  121. package/dist/elements/TextField/index.mjs.map +1 -1
  122. package/dist/elements/TimeField/index.js +244 -33
  123. package/dist/elements/TimeField/index.js.map +1 -1
  124. package/dist/elements/TimeField/index.mjs +238 -2
  125. package/dist/elements/TimeField/index.mjs.map +1 -1
  126. package/dist/elements/Toast/index.js +727 -48
  127. package/dist/elements/Toast/index.js.map +1 -1
  128. package/dist/elements/Toast/index.mjs +724 -5
  129. package/dist/elements/Toast/index.mjs.map +1 -1
  130. package/dist/elements/Tooltip/index.js +315 -49
  131. package/dist/elements/Tooltip/index.js.map +1 -1
  132. package/dist/elements/Tooltip/index.mjs +310 -4
  133. package/dist/elements/Tooltip/index.mjs.map +1 -1
  134. package/dist/elements/index.js +12417 -799
  135. package/dist/elements/index.js.map +1 -1
  136. package/dist/elements/index.mjs +12233 -40
  137. package/dist/elements/index.mjs.map +1 -1
  138. package/dist/index.js +12452 -825
  139. package/dist/index.js.map +1 -1
  140. package/dist/index.mjs +12262 -42
  141. package/dist/index.mjs.map +1 -1
  142. package/dist/schemas/index.js +47 -21
  143. package/dist/schemas/index.js.map +1 -1
  144. package/dist/schemas/index.mjs +47 -2
  145. package/dist/schemas/index.mjs.map +1 -1
  146. package/dist/styles/index.js +161 -147
  147. package/dist/styles/index.js.map +1 -1
  148. package/dist/styles/index.mjs +128 -2
  149. package/dist/styles/index.mjs.map +1 -1
  150. package/dist/utils/index.js +7 -7
  151. package/dist/utils/index.js.map +1 -1
  152. package/dist/utils/index.mjs +9 -2
  153. package/dist/utils/index.mjs.map +1 -1
  154. package/package.json +1 -1
  155. package/dist/Carousel-NTZX5TOW.js +0 -16
  156. package/dist/Carousel-NTZX5TOW.js.map +0 -1
  157. package/dist/Carousel-YH3DOQJU.mjs +0 -7
  158. package/dist/Carousel-YH3DOQJU.mjs.map +0 -1
  159. package/dist/chunk-2HIUTHMU.mjs +0 -234
  160. package/dist/chunk-2HIUTHMU.mjs.map +0 -1
  161. package/dist/chunk-34GTFTDO.js +0 -431
  162. package/dist/chunk-34GTFTDO.js.map +0 -1
  163. package/dist/chunk-3H7ASYR7.js +0 -250
  164. package/dist/chunk-3H7ASYR7.js.map +0 -1
  165. package/dist/chunk-3IEN7JOP.js +0 -316
  166. package/dist/chunk-3IEN7JOP.js.map +0 -1
  167. package/dist/chunk-3JHN4GAL.js +0 -326
  168. package/dist/chunk-3JHN4GAL.js.map +0 -1
  169. package/dist/chunk-3MJPASQU.js +0 -232
  170. package/dist/chunk-3MJPASQU.js.map +0 -1
  171. package/dist/chunk-3XD2JUL3.js +0 -572
  172. package/dist/chunk-3XD2JUL3.js.map +0 -1
  173. package/dist/chunk-3YOY2VJ6.js +0 -189
  174. package/dist/chunk-3YOY2VJ6.js.map +0 -1
  175. package/dist/chunk-4DU5JSXB.js +0 -408
  176. package/dist/chunk-4DU5JSXB.js.map +0 -1
  177. package/dist/chunk-4E4E2GSS.js +0 -352
  178. package/dist/chunk-4E4E2GSS.js.map +0 -1
  179. package/dist/chunk-4NHAP4AN.mjs +0 -3
  180. package/dist/chunk-4NHAP4AN.mjs.map +0 -1
  181. package/dist/chunk-4S33J5NY.mjs +0 -415
  182. package/dist/chunk-4S33J5NY.mjs.map +0 -1
  183. package/dist/chunk-5SMGRT3G.mjs +0 -354
  184. package/dist/chunk-5SMGRT3G.mjs.map +0 -1
  185. package/dist/chunk-5SVLJN2C.mjs +0 -22
  186. package/dist/chunk-5SVLJN2C.mjs.map +0 -1
  187. package/dist/chunk-66WTU4EB.mjs +0 -299
  188. package/dist/chunk-66WTU4EB.mjs.map +0 -1
  189. package/dist/chunk-6S25NMOT.mjs +0 -335
  190. package/dist/chunk-6S25NMOT.mjs.map +0 -1
  191. package/dist/chunk-6SP7UB3D.js +0 -4
  192. package/dist/chunk-6SP7UB3D.js.map +0 -1
  193. package/dist/chunk-6TYWWQHM.mjs +0 -565
  194. package/dist/chunk-6TYWWQHM.mjs.map +0 -1
  195. package/dist/chunk-A3YUJA6W.mjs +0 -384
  196. package/dist/chunk-A3YUJA6W.mjs.map +0 -1
  197. package/dist/chunk-A6KEDVUR.js +0 -61
  198. package/dist/chunk-A6KEDVUR.js.map +0 -1
  199. package/dist/chunk-A77RUEWL.js +0 -730
  200. package/dist/chunk-A77RUEWL.js.map +0 -1
  201. package/dist/chunk-AA4IKMPE.mjs +0 -3
  202. package/dist/chunk-AA4IKMPE.mjs.map +0 -1
  203. package/dist/chunk-AKIA6GW6.mjs +0 -163
  204. package/dist/chunk-AKIA6GW6.mjs.map +0 -1
  205. package/dist/chunk-AL6P275L.mjs +0 -435
  206. package/dist/chunk-AL6P275L.mjs.map +0 -1
  207. package/dist/chunk-AZ3RJYTB.js +0 -37
  208. package/dist/chunk-AZ3RJYTB.js.map +0 -1
  209. package/dist/chunk-B5Q4UPL6.js +0 -32
  210. package/dist/chunk-B5Q4UPL6.js.map +0 -1
  211. package/dist/chunk-B6DHPMDP.mjs +0 -335
  212. package/dist/chunk-B6DHPMDP.mjs.map +0 -1
  213. package/dist/chunk-BDXKKMBZ.mjs +0 -184
  214. package/dist/chunk-BDXKKMBZ.mjs.map +0 -1
  215. package/dist/chunk-BL6E2DLZ.mjs +0 -52
  216. package/dist/chunk-BL6E2DLZ.mjs.map +0 -1
  217. package/dist/chunk-CGFDS4XS.mjs +0 -121
  218. package/dist/chunk-CGFDS4XS.mjs.map +0 -1
  219. package/dist/chunk-CJIW5TKI.js +0 -139
  220. package/dist/chunk-CJIW5TKI.js.map +0 -1
  221. package/dist/chunk-CKNISJOQ.js +0 -314
  222. package/dist/chunk-CKNISJOQ.js.map +0 -1
  223. package/dist/chunk-D6CBOECS.mjs +0 -1757
  224. package/dist/chunk-D6CBOECS.mjs.map +0 -1
  225. package/dist/chunk-DDWEVC2S.js +0 -166
  226. package/dist/chunk-DDWEVC2S.js.map +0 -1
  227. package/dist/chunk-DZ556D2F.mjs +0 -176
  228. package/dist/chunk-DZ556D2F.mjs.map +0 -1
  229. package/dist/chunk-E2KQFV3O.mjs +0 -10
  230. package/dist/chunk-E2KQFV3O.mjs.map +0 -1
  231. package/dist/chunk-EMMLADSC.js +0 -126
  232. package/dist/chunk-EMMLADSC.js.map +0 -1
  233. package/dist/chunk-EP4WOI5D.mjs +0 -926
  234. package/dist/chunk-EP4WOI5D.mjs.map +0 -1
  235. package/dist/chunk-FJRXLJC2.mjs +0 -160
  236. package/dist/chunk-FJRXLJC2.mjs.map +0 -1
  237. package/dist/chunk-FKQI434R.js +0 -345
  238. package/dist/chunk-FKQI434R.js.map +0 -1
  239. package/dist/chunk-FPKEAJRZ.mjs +0 -100
  240. package/dist/chunk-FPKEAJRZ.mjs.map +0 -1
  241. package/dist/chunk-FWQYB22U.js +0 -183
  242. package/dist/chunk-FWQYB22U.js.map +0 -1
  243. package/dist/chunk-GD5GHTMA.js +0 -189
  244. package/dist/chunk-GD5GHTMA.js.map +0 -1
  245. package/dist/chunk-GE5XTSDZ.js +0 -447
  246. package/dist/chunk-GE5XTSDZ.js.map +0 -1
  247. package/dist/chunk-GVE47ZAX.mjs +0 -32
  248. package/dist/chunk-GVE47ZAX.mjs.map +0 -1
  249. package/dist/chunk-HK46BT5U.mjs +0 -18
  250. package/dist/chunk-HK46BT5U.mjs.map +0 -1
  251. package/dist/chunk-HQVRMR6N.js +0 -365
  252. package/dist/chunk-HQVRMR6N.js.map +0 -1
  253. package/dist/chunk-HSGBJPJO.mjs +0 -398
  254. package/dist/chunk-HSGBJPJO.mjs.map +0 -1
  255. package/dist/chunk-I3AUTOMZ.mjs +0 -125
  256. package/dist/chunk-I3AUTOMZ.mjs.map +0 -1
  257. package/dist/chunk-IEI5LD5C.mjs +0 -1161
  258. package/dist/chunk-IEI5LD5C.mjs.map +0 -1
  259. package/dist/chunk-IIPTC2X7.mjs +0 -118
  260. package/dist/chunk-IIPTC2X7.mjs.map +0 -1
  261. package/dist/chunk-J7TLHF2Q.js +0 -4
  262. package/dist/chunk-J7TLHF2Q.js.map +0 -1
  263. package/dist/chunk-JJOWXFXQ.mjs +0 -765
  264. package/dist/chunk-JJOWXFXQ.mjs.map +0 -1
  265. package/dist/chunk-JPTSS2OA.mjs +0 -3
  266. package/dist/chunk-JPTSS2OA.mjs.map +0 -1
  267. package/dist/chunk-KFXXRLTP.js +0 -396
  268. package/dist/chunk-KFXXRLTP.js.map +0 -1
  269. package/dist/chunk-KPRRBSG6.mjs +0 -272
  270. package/dist/chunk-KPRRBSG6.mjs.map +0 -1
  271. package/dist/chunk-NFSBGRDB.mjs +0 -57
  272. package/dist/chunk-NFSBGRDB.mjs.map +0 -1
  273. package/dist/chunk-NGJVCFTM.js +0 -219
  274. package/dist/chunk-NGJVCFTM.js.map +0 -1
  275. package/dist/chunk-NSQ6MZJ6.mjs +0 -728
  276. package/dist/chunk-NSQ6MZJ6.mjs.map +0 -1
  277. package/dist/chunk-NYQYHT76.mjs +0 -296
  278. package/dist/chunk-NYQYHT76.mjs.map +0 -1
  279. package/dist/chunk-OLJJGI5B.js +0 -1193
  280. package/dist/chunk-OLJJGI5B.js.map +0 -1
  281. package/dist/chunk-Q3572X2J.js +0 -292
  282. package/dist/chunk-Q3572X2J.js.map +0 -1
  283. package/dist/chunk-QH7N7D4I.mjs +0 -210
  284. package/dist/chunk-QH7N7D4I.mjs.map +0 -1
  285. package/dist/chunk-R7XUIV25.js +0 -466
  286. package/dist/chunk-R7XUIV25.js.map +0 -1
  287. package/dist/chunk-RFFO4KPM.js +0 -135
  288. package/dist/chunk-RFFO4KPM.js.map +0 -1
  289. package/dist/chunk-RFX7QKA7.mjs +0 -180
  290. package/dist/chunk-RFX7QKA7.mjs.map +0 -1
  291. package/dist/chunk-SN5LFAP3.js +0 -940
  292. package/dist/chunk-SN5LFAP3.js.map +0 -1
  293. package/dist/chunk-T4COXKQ3.js +0 -24
  294. package/dist/chunk-T4COXKQ3.js.map +0 -1
  295. package/dist/chunk-TS54QM27.js +0 -125
  296. package/dist/chunk-TS54QM27.js.map +0 -1
  297. package/dist/chunk-UE2S4PCX.mjs +0 -220
  298. package/dist/chunk-UE2S4PCX.mjs.map +0 -1
  299. package/dist/chunk-UTW3QX2A.mjs +0 -282
  300. package/dist/chunk-UTW3QX2A.mjs.map +0 -1
  301. package/dist/chunk-V74LGMAE.js +0 -1767
  302. package/dist/chunk-V74LGMAE.js.map +0 -1
  303. package/dist/chunk-VIREG536.js +0 -12
  304. package/dist/chunk-VIREG536.js.map +0 -1
  305. package/dist/chunk-VY7M7346.js +0 -4
  306. package/dist/chunk-VY7M7346.js.map +0 -1
  307. package/dist/chunk-W3TJOO7H.mjs +0 -319
  308. package/dist/chunk-W3TJOO7H.mjs.map +0 -1
  309. package/dist/chunk-WIUOB36M.js +0 -54
  310. package/dist/chunk-WIUOB36M.js.map +0 -1
  311. package/dist/chunk-WJGLM4CY.js +0 -291
  312. package/dist/chunk-WJGLM4CY.js.map +0 -1
  313. package/dist/chunk-WNURH5OO.mjs +0 -453
  314. package/dist/chunk-WNURH5OO.mjs.map +0 -1
  315. package/dist/chunk-X25TNRSD.mjs +0 -364
  316. package/dist/chunk-X25TNRSD.mjs.map +0 -1
  317. package/dist/chunk-Y3GT7ETK.js +0 -108
  318. package/dist/chunk-Y3GT7ETK.js.map +0 -1
  319. package/dist/chunk-Z4FRNOF6.mjs +0 -115
  320. package/dist/chunk-Z4FRNOF6.mjs.map +0 -1
  321. package/dist/chunk-ZMYLD3BN.js +0 -166
  322. package/dist/chunk-ZMYLD3BN.js.map +0 -1
  323. package/dist/chunk-ZP2KV6EX.js +0 -815
  324. package/dist/chunk-ZP2KV6EX.js.map +0 -1
  325. package/dist/chunk-ZVKXFELU.js +0 -366
  326. package/dist/chunk-ZVKXFELU.js.map +0 -1
@@ -1,4 +1,584 @@
1
- export { MultiSelect, Select, SelectHeaderPropsSchema, SelectItemPropsSchema, SelectPropsSchema, SelectSectionPropsSchema } from '../../chunk-6TYWWQHM.mjs';
2
- import '../../chunk-5SVLJN2C.mjs';
1
+ "use client";
2
+ import { forwardRef, useId, Children, useMemo, isValidElement } from 'react';
3
+ import { Select as Select$1, Label, Text, Button, SelectValue, FieldError, Popover, ListBox, ListBoxItem, Header, ListBoxSection } from 'react-aria-components';
4
+ import { cva } from 'class-variance-authority';
5
+ import { Loader2, ChevronDown, AlertCircle, CheckSquare, Check } from 'lucide-react';
6
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
7
+ import { z } from 'zod';
8
+
9
+ // src/elements/Select/Select.tsx
10
+ var selectTriggerVariants = cva(
11
+ [
12
+ // Base styles
13
+ "flex",
14
+ "w-full",
15
+ "items-center",
16
+ "justify-between",
17
+ "rounded-md",
18
+ "border",
19
+ "bg-[var(--content-background)]",
20
+ "text-[var(--content-foreground)]",
21
+ "transition-colors",
22
+ "duration-200",
23
+ "outline-none",
24
+ // Focus ring (WCAG 2.2 AAA - 7:1 contrast)
25
+ "focus-visible:ring-2",
26
+ "focus-visible:ring-[var(--ring)]",
27
+ "focus-visible:ring-offset-2",
28
+ // Hover state
29
+ "hover:bg-[var(--accent)]/10",
30
+ // Disabled state
31
+ "disabled:cursor-not-allowed",
32
+ "disabled:opacity-50",
33
+ // Loading state
34
+ "data-[loading=true]:cursor-wait",
35
+ // Truncate text
36
+ "truncate"
37
+ ],
38
+ {
39
+ variants: {
40
+ size: {
41
+ // All sizes use 44px minimum touch target for WCAG 2.2 AAA compliance
42
+ // Visual height varies but touch area remains accessible
43
+ sm: "h-9 px-3 text-sm min-h-[44px]",
44
+ default: "h-11 px-4 text-base min-h-[44px]",
45
+ lg: "h-14 px-5 text-lg min-h-[44px]"
46
+ },
47
+ isInvalid: {
48
+ true: "border-[var(--destructive)]",
49
+ false: "border-[var(--input)] hover:border-[var(--input)]/80"
50
+ }
51
+ },
52
+ defaultVariants: {
53
+ size: "default",
54
+ isInvalid: false
55
+ }
56
+ }
57
+ );
58
+ var selectItemVariants = cva(
59
+ [
60
+ // Base styles
61
+ "relative",
62
+ "flex",
63
+ "w-full",
64
+ "cursor-pointer",
65
+ "select-none",
66
+ "items-center",
67
+ "rounded-sm",
68
+ "outline-none",
69
+ "transition-colors",
70
+ // Padding for checkmark icon (left side)
71
+ "pl-8",
72
+ "pr-2",
73
+ // Hover state
74
+ "hover:bg-[var(--accent)]",
75
+ "hover:text-[var(--accent-foreground)]",
76
+ // Focus state
77
+ "focus:bg-[var(--accent)]",
78
+ "focus:text-[var(--accent-foreground)]",
79
+ // Selected state
80
+ "data-[selected=true]:bg-[var(--accent)]",
81
+ "data-[selected=true]:text-[var(--accent-foreground)]",
82
+ // Disabled state
83
+ "data-[disabled=true]:pointer-events-none",
84
+ "data-[disabled=true]:opacity-50",
85
+ "data-[disabled=true]:text-[var(--menu-muted)]"
86
+ ],
87
+ {
88
+ variants: {
89
+ size: {
90
+ // All sizes use 44px minimum touch target for WCAG 2.2 AAA compliance
91
+ sm: "h-9 py-1.5 text-sm min-h-[44px]",
92
+ default: "h-11 py-2 text-base min-h-[44px]",
93
+ lg: "h-14 py-3 text-lg min-h-[44px]"
94
+ }
95
+ },
96
+ defaultVariants: {
97
+ size: "default"
98
+ }
99
+ }
100
+ );
101
+ var selectPopoverVariants = cva(
102
+ [
103
+ // Base styles - use menu tokens to match Dropdown styling
104
+ "z-50",
105
+ "w-[--trigger-width]",
106
+ "rounded-md",
107
+ "border",
108
+ "border-[var(--menu-border)]",
109
+ "bg-[var(--menu-background)]",
110
+ "text-[var(--menu-foreground)]",
111
+ "shadow-md",
112
+ "outline-none",
113
+ "overflow-auto",
114
+ // Animations
115
+ "data-[entering]:animate-in",
116
+ "data-[entering]:fade-in-0",
117
+ "data-[entering]:zoom-in-95",
118
+ "data-[exiting]:animate-out",
119
+ "data-[exiting]:fade-out-0",
120
+ "data-[exiting]:zoom-out-95"
121
+ ],
122
+ {
123
+ variants: {
124
+ size: {
125
+ sm: "max-h-[200px] p-1",
126
+ default: "max-h-[300px] p-1",
127
+ lg: "max-h-[400px] p-1"
128
+ }
129
+ },
130
+ defaultVariants: {
131
+ size: "default"
132
+ }
133
+ }
134
+ );
135
+ var selectSectionVariants = cva(
136
+ [
137
+ "px-2",
138
+ "py-1.5",
139
+ "text-xs",
140
+ "font-semibold",
141
+ "text-[var(--menu-muted)]",
142
+ "uppercase",
143
+ "tracking-wider"
144
+ ],
145
+ {
146
+ variants: {
147
+ size: {
148
+ sm: "px-2 py-1 text-[10px]",
149
+ default: "px-2 py-1.5 text-xs",
150
+ lg: "px-3 py-2 text-sm"
151
+ }
152
+ },
153
+ defaultVariants: {
154
+ size: "default"
155
+ }
156
+ }
157
+ );
158
+ var selectErrorVariants = cva(
159
+ [
160
+ "flex",
161
+ "items-center",
162
+ "gap-1.5",
163
+ "text-sm",
164
+ "font-medium",
165
+ "text-[var(--destructive)]",
166
+ "mt-1.5"
167
+ ],
168
+ {
169
+ variants: {
170
+ size: {
171
+ sm: "text-xs mt-1",
172
+ default: "text-sm mt-1.5",
173
+ lg: "text-base mt-2"
174
+ }
175
+ },
176
+ defaultVariants: {
177
+ size: "default"
178
+ }
179
+ }
180
+ );
181
+ var SelectRoot = forwardRef(
182
+ ({
183
+ // Display props
184
+ label,
185
+ placeholder,
186
+ description,
187
+ // Selection props
188
+ value,
189
+ defaultValue,
190
+ // State props
191
+ isOpen,
192
+ isDisabled = false,
193
+ isRequired = false,
194
+ disabledKeys,
195
+ // Validation props
196
+ validate,
197
+ validationBehavior = "aria",
198
+ errorMessage,
199
+ // Loading state
200
+ isLoading = false,
201
+ emptyStateMessage,
202
+ // Form integration
203
+ name,
204
+ // Size variant
205
+ size = "default",
206
+ // Event handlers
207
+ onChange,
208
+ onOpenChange,
209
+ // Standard props
210
+ className,
211
+ children,
212
+ ...props
213
+ }, ref) => {
214
+ const labelId = useId();
215
+ const descriptionId = useId();
216
+ const errorId = useId();
217
+ const childCount = Children.count(children);
218
+ if (childCount > 1e3) {
219
+ console.warn(
220
+ "Select has >1000 items. Consider using Autocomplete component for better performance."
221
+ );
222
+ }
223
+ const isInvalid = Boolean(errorMessage);
224
+ return /* @__PURE__ */ jsxs(
225
+ Select$1,
226
+ {
227
+ value,
228
+ defaultValue,
229
+ onChange: (key) => {
230
+ if (onChange) {
231
+ onChange(key);
232
+ }
233
+ },
234
+ placeholder,
235
+ disabledKeys,
236
+ isOpen,
237
+ onOpenChange,
238
+ isDisabled: isDisabled || isLoading,
239
+ isRequired,
240
+ name,
241
+ validate,
242
+ validationBehavior,
243
+ isInvalid,
244
+ className,
245
+ ...props,
246
+ children: [
247
+ /* @__PURE__ */ jsxs(Label, { id: labelId, className: "text-sm font-medium text-[var(--content-foreground)]", children: [
248
+ label,
249
+ isRequired && /* @__PURE__ */ jsx("span", { className: "text-[var(--destructive)] ml-1", children: "*" })
250
+ ] }),
251
+ description && /* @__PURE__ */ jsx(Text, { id: descriptionId, slot: "description", className: "text-sm text-[var(--menu-muted)] mt-1", children: description }),
252
+ /* @__PURE__ */ jsxs(
253
+ Button,
254
+ {
255
+ ref,
256
+ className: selectTriggerVariants({ size, isInvalid }),
257
+ "aria-labelledby": labelId,
258
+ "aria-describedby": description ? descriptionId : errorMessage ? errorId : void 0,
259
+ "data-loading": isLoading,
260
+ ...isRequired && { "aria-required": "true" },
261
+ ...isLoading && { "aria-busy": "true" },
262
+ ...(isDisabled || isLoading) && { "aria-disabled": "true" },
263
+ children: [
264
+ /* @__PURE__ */ jsx(SelectValue, { className: "flex-1 text-left truncate" }),
265
+ isLoading ? /* @__PURE__ */ jsx(Loader2, { className: "h-4 w-4 animate-spin text-[var(--menu-muted)]", "aria-hidden": "true" }) : /* @__PURE__ */ jsx(ChevronDown, { className: "h-4 w-4 text-[var(--menu-muted)]", "aria-hidden": "true" })
266
+ ]
267
+ }
268
+ ),
269
+ /* @__PURE__ */ jsx(FieldError, { id: errorId, className: selectErrorVariants({ size }), children: ({ validationErrors }) => {
270
+ const displayError = errorMessage || validationErrors.join(" ");
271
+ return displayError ? /* @__PURE__ */ jsxs(Fragment, { children: [
272
+ /* @__PURE__ */ jsx(AlertCircle, { className: "h-4 w-4", "aria-hidden": "true" }),
273
+ displayError
274
+ ] }) : null;
275
+ } }),
276
+ /* @__PURE__ */ jsx(Popover, { className: selectPopoverVariants({ size }), children: /* @__PURE__ */ jsxs(ListBox, { className: "outline-none", children: [
277
+ isLoading && childCount > 0 && /* @__PURE__ */ jsx(Fragment, { children: Array.from({ length: 3 }).map((_, i) => /* @__PURE__ */ jsx(
278
+ "div",
279
+ {
280
+ className: "h-11 px-4 py-2",
281
+ children: /* @__PURE__ */ jsx("div", { className: "h-4 bg-[var(--accent-background)] rounded animate-pulse" })
282
+ },
283
+ `skeleton-${i}`
284
+ )) }),
285
+ !isLoading && /* @__PURE__ */ jsxs(Fragment, { children: [
286
+ children,
287
+ childCount === 0 && /* @__PURE__ */ jsx(
288
+ ListBoxItem,
289
+ {
290
+ id: "__empty__",
291
+ textValue: "empty",
292
+ isDisabled: true,
293
+ className: "py-6 text-center text-sm text-[var(--menu-muted)] cursor-default pointer-events-none",
294
+ children: /* @__PURE__ */ jsx("span", { role: "status", children: emptyStateMessage || "No options available" })
295
+ }
296
+ )
297
+ ] })
298
+ ] }) })
299
+ ]
300
+ }
301
+ );
302
+ }
303
+ );
304
+ SelectRoot.displayName = "Select";
305
+ var MultiSelectRoot = forwardRef(
306
+ ({
307
+ // Display props
308
+ label,
309
+ placeholder,
310
+ description,
311
+ // Selection props
312
+ value,
313
+ defaultValue,
314
+ selectionMode: _selectionMode = "multiple",
315
+ // State props
316
+ isOpen,
317
+ isDisabled = false,
318
+ isRequired = false,
319
+ disabledKeys,
320
+ // Validation props
321
+ validate,
322
+ validationBehavior = "aria",
323
+ errorMessage,
324
+ // Loading state
325
+ isLoading = false,
326
+ emptyStateMessage,
327
+ // Form integration
328
+ name,
329
+ // Size variant
330
+ size = "default",
331
+ // Event handlers
332
+ onChange,
333
+ onOpenChange,
334
+ // Standard props
335
+ className,
336
+ children,
337
+ ...props
338
+ }, ref) => {
339
+ const labelId = useId();
340
+ const descriptionId = useId();
341
+ const errorId = useId();
342
+ const childCount = Children.count(children);
343
+ if (childCount > 1e3) {
344
+ console.warn(
345
+ "Select has >1000 items. Consider using Autocomplete component for better performance."
346
+ );
347
+ }
348
+ const isInvalid = Boolean(errorMessage);
349
+ const valueToLabelMap = useMemo(() => {
350
+ const map = /* @__PURE__ */ new Map();
351
+ const processChildren = (nodes) => {
352
+ Children.forEach(nodes, (child) => {
353
+ if (isValidElement(child)) {
354
+ const element = child;
355
+ if (element.type === SelectItem || element.props?.value) {
356
+ const itemValue = element.props.value;
357
+ const itemChildren = element.props.children;
358
+ if (itemValue && typeof itemChildren === "string") {
359
+ map.set(itemValue, itemChildren);
360
+ }
361
+ }
362
+ if (element.props?.children) {
363
+ processChildren(element.props.children);
364
+ }
365
+ }
366
+ });
367
+ };
368
+ processChildren(children);
369
+ return map;
370
+ }, [children]);
371
+ const displayValue = useMemo(() => {
372
+ if (!value || !Array.isArray(value) || value.length === 0) {
373
+ return placeholder || "";
374
+ }
375
+ if (value.length <= 2) {
376
+ const labels = value.map((v) => valueToLabelMap.get(v) || v);
377
+ return labels.join(", ");
378
+ }
379
+ return `${value.length} items selected`;
380
+ }, [value, valueToLabelMap, placeholder]);
381
+ return /* @__PURE__ */ jsxs(
382
+ Select$1,
383
+ {
384
+ value,
385
+ defaultValue,
386
+ onChange: (keys) => {
387
+ if (onChange) {
388
+ onChange(keys);
389
+ }
390
+ },
391
+ selectionMode: "multiple",
392
+ disabledKeys,
393
+ isOpen,
394
+ onOpenChange,
395
+ isDisabled: isDisabled || isLoading,
396
+ isRequired,
397
+ name,
398
+ validate,
399
+ validationBehavior,
400
+ isInvalid,
401
+ className,
402
+ ...props,
403
+ children: [
404
+ /* @__PURE__ */ jsxs(Label, { id: labelId, className: "text-sm font-medium text-[var(--content-foreground)]", children: [
405
+ label,
406
+ isRequired && /* @__PURE__ */ jsx("span", { className: "text-[var(--destructive)] ml-1", children: "*" })
407
+ ] }),
408
+ description && /* @__PURE__ */ jsx(Text, { id: descriptionId, slot: "description", className: "text-sm text-[var(--menu-muted)] mt-1", children: description }),
409
+ /* @__PURE__ */ jsxs(
410
+ Button,
411
+ {
412
+ ref,
413
+ className: selectTriggerVariants({ size, isInvalid }),
414
+ "aria-labelledby": labelId,
415
+ "aria-describedby": description ? descriptionId : errorMessage ? errorId : void 0,
416
+ "data-loading": isLoading,
417
+ ...isRequired && { "aria-required": "true" },
418
+ ...isLoading && { "aria-busy": "true" },
419
+ ...(isDisabled || isLoading) && { "aria-disabled": "true" },
420
+ children: [
421
+ /* @__PURE__ */ jsx("span", { className: "flex-1 text-left truncate", children: displayValue }),
422
+ isLoading ? /* @__PURE__ */ jsx(Loader2, { className: "h-4 w-4 animate-spin text-[var(--menu-muted)]", "aria-hidden": "true" }) : /* @__PURE__ */ jsx(ChevronDown, { className: "h-4 w-4 text-[var(--menu-muted)]", "aria-hidden": "true" })
423
+ ]
424
+ }
425
+ ),
426
+ /* @__PURE__ */ jsx(FieldError, { id: errorId, className: selectErrorVariants({ size }), children: ({ validationErrors }) => {
427
+ const displayError = errorMessage || validationErrors.join(" ");
428
+ return displayError ? /* @__PURE__ */ jsxs(Fragment, { children: [
429
+ /* @__PURE__ */ jsx(AlertCircle, { className: "h-4 w-4", "aria-hidden": "true" }),
430
+ displayError
431
+ ] }) : null;
432
+ } }),
433
+ /* @__PURE__ */ jsx(Popover, { className: selectPopoverVariants({ size }), children: /* @__PURE__ */ jsxs(ListBox, { className: "outline-none", children: [
434
+ isLoading && childCount > 0 && /* @__PURE__ */ jsx(Fragment, { children: Array.from({ length: 3 }).map((_, i) => /* @__PURE__ */ jsx("div", { className: "h-11 px-4 py-2", children: /* @__PURE__ */ jsx("div", { className: "h-4 bg-[var(--accent-background)] rounded animate-pulse" }) }, `skeleton-${i}`)) }),
435
+ !isLoading && /* @__PURE__ */ jsxs(Fragment, { children: [
436
+ children,
437
+ childCount === 0 && /* @__PURE__ */ jsx(
438
+ ListBoxItem,
439
+ {
440
+ id: "__empty__",
441
+ textValue: "empty",
442
+ isDisabled: true,
443
+ className: "py-6 text-center text-sm text-[var(--menu-muted)] cursor-default pointer-events-none",
444
+ children: /* @__PURE__ */ jsx("span", { role: "status", children: emptyStateMessage || "No options available" })
445
+ }
446
+ )
447
+ ] })
448
+ ] }) })
449
+ ]
450
+ }
451
+ );
452
+ }
453
+ );
454
+ MultiSelectRoot.displayName = "MultiSelect";
455
+ function SelectItem({ children, textValue, value, isDisabled = false, className, ...props }) {
456
+ if (!textValue && typeof children !== "string") {
457
+ const message = "Select.Item with custom children requires textValue prop for accessibility";
458
+ if (process.env.NODE_ENV === "development") {
459
+ throw new Error(message);
460
+ } else {
461
+ console.warn(message);
462
+ }
463
+ }
464
+ return /* @__PURE__ */ jsx(
465
+ ListBoxItem,
466
+ {
467
+ id: value,
468
+ textValue: textValue || (typeof children === "string" ? children : void 0),
469
+ className: `${selectItemVariants({ size: "default" })} ${className || ""}`,
470
+ isDisabled,
471
+ ...props,
472
+ children: ({ isSelected, selectionMode, isDisabled: itemDisabled }) => /* @__PURE__ */ jsxs(Fragment, { children: [
473
+ selectionMode === "multiple" ? /* @__PURE__ */ jsx(
474
+ CheckSquare,
475
+ {
476
+ className: `absolute left-2 h-4 w-4 ${isSelected ? "visible" : "invisible"}`,
477
+ "aria-hidden": "true"
478
+ }
479
+ ) : isSelected && /* @__PURE__ */ jsx(Check, { className: "absolute left-2 h-4 w-4", "aria-hidden": "true" }),
480
+ /* @__PURE__ */ jsx("span", { className: itemDisabled ? "text-[var(--menu-muted)]" : "", children })
481
+ ] })
482
+ }
483
+ );
484
+ }
485
+ SelectItem.displayName = "SelectItem";
486
+ function SelectSection({ children, className, ...props }) {
487
+ return /* @__PURE__ */ jsx(ListBoxSection, { className: `border-t border-[var(--border)] first:border-t-0 ${className || ""}`, ...props, children });
488
+ }
489
+ SelectSection.displayName = "SelectSection";
490
+ function SelectHeader({ children, className, ...props }) {
491
+ return /* @__PURE__ */ jsx(Header, { className: `${selectSectionVariants({ size: "default" })} ${className || ""}`, ...props, children });
492
+ }
493
+ SelectHeader.displayName = "SelectHeader";
494
+ var Select = Object.assign(SelectRoot, {
495
+ Item: SelectItem,
496
+ Section: SelectSection,
497
+ Header: SelectHeader
498
+ });
499
+ var MultiSelect = Object.assign(MultiSelectRoot, {
500
+ Item: SelectItem,
501
+ Section: SelectSection,
502
+ Header: SelectHeader
503
+ });
504
+ var BaseComponentPropsSchema = z.object({
505
+ // Styling
506
+ className: z.string().optional(),
507
+ // React
508
+ children: z.any().optional(),
509
+ // ReactNode not directly supported by Zod
510
+ id: z.string().optional(),
511
+ // Accessibility (WCAG 2.2 AA requirements)
512
+ "aria-label": z.string().optional(),
513
+ "aria-labelledby": z.string().optional(),
514
+ "aria-describedby": z.string().optional(),
515
+ "aria-live": z.enum(["off", "polite", "assertive"]).optional(),
516
+ "aria-hidden": z.boolean().optional(),
517
+ // Testing & Development
518
+ "data-testid": z.string().optional()
519
+ });
520
+
521
+ // src/elements/Select/Select.types.ts
522
+ var SelectSizeSchema = z.enum(["sm", "default", "lg"]);
523
+ var SelectionModeSchema = z.enum(["single", "multiple"]);
524
+ var ValidationBehaviorSchema = z.enum(["native", "aria"]);
525
+ var SelectPropsSchema = BaseComponentPropsSchema.extend({
526
+ // Display props (US-1)
527
+ label: z.string(),
528
+ // Required for accessibility
529
+ placeholder: z.string().optional(),
530
+ description: z.string().optional(),
531
+ // Selection props (US-1, US-6)
532
+ value: z.union([z.string(), z.array(z.string())]).optional(),
533
+ defaultValue: z.union([z.string(), z.array(z.string())]).optional(),
534
+ selectionMode: SelectionModeSchema.optional().default("single"),
535
+ // State props (US-1, US-5)
536
+ isOpen: z.boolean().optional(),
537
+ isDisabled: z.boolean().optional().default(false),
538
+ isRequired: z.boolean().optional().default(false),
539
+ disabledKeys: z.array(z.string()).optional(),
540
+ // Validation props (US-4)
541
+ validate: z.custom().optional(),
542
+ validationBehavior: ValidationBehaviorSchema.optional().default("aria"),
543
+ errorMessage: z.string().optional(),
544
+ // Loading state (US-7)
545
+ isLoading: z.boolean().optional().default(false),
546
+ emptyStateMessage: z.string().optional(),
547
+ // Form integration (US-10)
548
+ name: z.string().optional(),
549
+ // Size variant (US-9)
550
+ size: SelectSizeSchema.optional().default("default"),
551
+ // Event handlers (US-1)
552
+ onChange: z.custom().optional(),
553
+ onOpenChange: z.custom().optional(),
554
+ // Children (Select.Item, Select.Section components)
555
+ children: z.custom()
556
+ });
557
+ var SelectItemPropsSchema = BaseComponentPropsSchema.extend({
558
+ // Item value (required)
559
+ value: z.string(),
560
+ // Text value for typeahead and accessibility (required for custom children)
561
+ textValue: z.string().optional(),
562
+ // Disabled state
563
+ isDisabled: z.boolean().optional().default(false),
564
+ // Item content
565
+ children: z.custom(),
566
+ // Optional className for custom styling
567
+ className: z.string().optional()
568
+ });
569
+ var SelectSectionPropsSchema = BaseComponentPropsSchema.extend({
570
+ // Section content (typically Select.Header + Select.Item components)
571
+ children: z.custom(),
572
+ // Optional className for custom styling
573
+ className: z.string().optional()
574
+ });
575
+ var SelectHeaderPropsSchema = BaseComponentPropsSchema.extend({
576
+ // Header text
577
+ children: z.custom(),
578
+ // Optional className for header styling
579
+ className: z.string().optional()
580
+ });
581
+
582
+ export { MultiSelect, Select, SelectHeaderPropsSchema, SelectItemPropsSchema, SelectPropsSchema, SelectSectionPropsSchema };
3
583
  //# sourceMappingURL=index.mjs.map
4
584
  //# sourceMappingURL=index.mjs.map