@psnext/design-system 1.1.0 → 1.2.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 (787) hide show
  1. package/README.md +137 -30
  2. package/dist/Header.cjs +890 -0
  3. package/dist/Header.cjs.map +1 -0
  4. package/dist/Header.js +798 -0
  5. package/dist/Header.js.map +1 -0
  6. package/dist/Icon.cjs +1969 -0
  7. package/dist/Icon.cjs.map +1 -0
  8. package/dist/Icon.js +1956 -0
  9. package/dist/Icon.js.map +1 -0
  10. package/dist/{ThemeProvider.cjs → Logo.cjs} +2 -1075
  11. package/dist/Logo.cjs.map +1 -0
  12. package/dist/{ThemeProvider.js → Logo.js} +4 -704
  13. package/dist/Logo.js.map +1 -0
  14. package/dist/Sidebar.cjs +562 -0
  15. package/dist/Sidebar.cjs.map +1 -0
  16. package/dist/Sidebar.js +416 -0
  17. package/dist/Sidebar.js.map +1 -0
  18. package/dist/{utils.cjs → chunk.cjs} +0 -39
  19. package/dist/cn.cjs +15 -0
  20. package/dist/cn.cjs.map +1 -0
  21. package/dist/cn.js +10 -0
  22. package/dist/cn.js.map +1 -0
  23. package/dist/index.cjs +413 -346
  24. package/dist/index.d.cts +12 -1996
  25. package/dist/index.d.cts.map +1 -1
  26. package/dist/index.d.ts +12 -1996
  27. package/dist/index.d.ts.map +1 -1
  28. package/dist/index.js +71 -5
  29. package/dist/index10.d.cts +38 -0
  30. package/dist/index10.d.cts.map +1 -0
  31. package/dist/index10.d.ts +38 -0
  32. package/dist/index10.d.ts.map +1 -0
  33. package/dist/index11.d.cts +30 -0
  34. package/dist/index11.d.cts.map +1 -0
  35. package/dist/index11.d.ts +30 -0
  36. package/dist/index11.d.ts.map +1 -0
  37. package/dist/index12.d.cts +75 -0
  38. package/dist/index12.d.cts.map +1 -0
  39. package/dist/index12.d.ts +75 -0
  40. package/dist/index12.d.ts.map +1 -0
  41. package/dist/index13.d.cts +57 -0
  42. package/dist/index13.d.cts.map +1 -0
  43. package/dist/index13.d.ts +57 -0
  44. package/dist/index13.d.ts.map +1 -0
  45. package/dist/index14.d.cts +98 -0
  46. package/dist/index14.d.cts.map +1 -0
  47. package/dist/index14.d.ts +98 -0
  48. package/dist/index14.d.ts.map +1 -0
  49. package/dist/index15.d.cts +29 -0
  50. package/dist/index15.d.cts.map +1 -0
  51. package/dist/index15.d.ts +29 -0
  52. package/dist/index15.d.ts.map +1 -0
  53. package/dist/index16.d.cts +38 -0
  54. package/dist/index16.d.cts.map +1 -0
  55. package/dist/index16.d.ts +38 -0
  56. package/dist/index16.d.ts.map +1 -0
  57. package/dist/index17.d.cts +19 -0
  58. package/dist/index17.d.cts.map +1 -0
  59. package/dist/index17.d.ts +19 -0
  60. package/dist/index17.d.ts.map +1 -0
  61. package/dist/index18.d.cts +73 -0
  62. package/dist/index18.d.cts.map +1 -0
  63. package/dist/index18.d.ts +73 -0
  64. package/dist/index18.d.ts.map +1 -0
  65. package/dist/index19.d.cts +66 -0
  66. package/dist/index19.d.cts.map +1 -0
  67. package/dist/index19.d.ts +66 -0
  68. package/dist/index19.d.ts.map +1 -0
  69. package/dist/index2.d.cts +44 -4
  70. package/dist/index2.d.cts.map +1 -0
  71. package/dist/index2.d.ts +44 -4
  72. package/dist/index2.d.ts.map +1 -0
  73. package/dist/index20.d.cts +96 -0
  74. package/dist/index20.d.cts.map +1 -0
  75. package/dist/index20.d.ts +96 -0
  76. package/dist/index20.d.ts.map +1 -0
  77. package/dist/index21.d.cts +34 -0
  78. package/dist/index21.d.cts.map +1 -0
  79. package/dist/index21.d.ts +34 -0
  80. package/dist/index21.d.ts.map +1 -0
  81. package/dist/index22.d.cts +62 -0
  82. package/dist/index22.d.cts.map +1 -0
  83. package/dist/index22.d.ts +62 -0
  84. package/dist/index22.d.ts.map +1 -0
  85. package/dist/index23.d.cts +99 -0
  86. package/dist/index23.d.cts.map +1 -0
  87. package/dist/index23.d.ts +99 -0
  88. package/dist/index23.d.ts.map +1 -0
  89. package/dist/index24.d.cts +49 -0
  90. package/dist/index24.d.cts.map +1 -0
  91. package/dist/index24.d.ts +49 -0
  92. package/dist/index24.d.ts.map +1 -0
  93. package/dist/index25.d.cts +17 -0
  94. package/dist/index25.d.cts.map +1 -0
  95. package/dist/index25.d.ts +17 -0
  96. package/dist/index25.d.ts.map +1 -0
  97. package/dist/index26.d.cts +80 -0
  98. package/dist/index26.d.cts.map +1 -0
  99. package/dist/index26.d.ts +80 -0
  100. package/dist/index26.d.ts.map +1 -0
  101. package/dist/index27.d.cts +71 -0
  102. package/dist/index27.d.cts.map +1 -0
  103. package/dist/index27.d.ts +71 -0
  104. package/dist/index27.d.ts.map +1 -0
  105. package/dist/index28.d.cts +37 -0
  106. package/dist/index28.d.cts.map +1 -0
  107. package/dist/index28.d.ts +37 -0
  108. package/dist/index28.d.ts.map +1 -0
  109. package/dist/index29.d.cts +25 -0
  110. package/dist/index29.d.cts.map +1 -0
  111. package/dist/index29.d.ts +25 -0
  112. package/dist/index29.d.ts.map +1 -0
  113. package/dist/index3.d.cts +62 -0
  114. package/dist/index3.d.cts.map +1 -0
  115. package/dist/index3.d.ts +62 -0
  116. package/dist/index3.d.ts.map +1 -0
  117. package/dist/index30.d.cts +59 -0
  118. package/dist/index30.d.cts.map +1 -0
  119. package/dist/index30.d.ts +59 -0
  120. package/dist/index30.d.ts.map +1 -0
  121. package/dist/index31.d.cts +40 -0
  122. package/dist/index31.d.cts.map +1 -0
  123. package/dist/index31.d.ts +40 -0
  124. package/dist/index31.d.ts.map +1 -0
  125. package/dist/index32.d.cts +23 -0
  126. package/dist/index32.d.cts.map +1 -0
  127. package/dist/index32.d.ts +23 -0
  128. package/dist/index32.d.ts.map +1 -0
  129. package/dist/index33.d.cts +55 -0
  130. package/dist/index33.d.cts.map +1 -0
  131. package/dist/index33.d.ts +55 -0
  132. package/dist/index33.d.ts.map +1 -0
  133. package/dist/index34.d.cts +43 -0
  134. package/dist/index34.d.cts.map +1 -0
  135. package/dist/index34.d.ts +43 -0
  136. package/dist/index34.d.ts.map +1 -0
  137. package/dist/index35.d.cts +77 -0
  138. package/dist/index35.d.cts.map +1 -0
  139. package/dist/index35.d.ts +77 -0
  140. package/dist/index35.d.ts.map +1 -0
  141. package/dist/index36.d.cts +19 -0
  142. package/dist/index36.d.cts.map +1 -0
  143. package/dist/index36.d.ts +19 -0
  144. package/dist/index36.d.ts.map +1 -0
  145. package/dist/index37.d.cts +29 -0
  146. package/dist/index37.d.cts.map +1 -0
  147. package/dist/index37.d.ts +29 -0
  148. package/dist/index37.d.ts.map +1 -0
  149. package/dist/index38.d.cts +20 -0
  150. package/dist/index38.d.cts.map +1 -0
  151. package/dist/index38.d.ts +20 -0
  152. package/dist/index38.d.ts.map +1 -0
  153. package/dist/index39.d.cts +105 -0
  154. package/dist/index39.d.cts.map +1 -0
  155. package/dist/index39.d.ts +105 -0
  156. package/dist/index39.d.ts.map +1 -0
  157. package/dist/index4.d.cts +11 -0
  158. package/dist/index4.d.cts.map +1 -0
  159. package/dist/index4.d.ts +11 -0
  160. package/dist/index4.d.ts.map +1 -0
  161. package/dist/index40.d.cts +22 -0
  162. package/dist/index40.d.cts.map +1 -0
  163. package/dist/index40.d.ts +22 -0
  164. package/dist/index40.d.ts.map +1 -0
  165. package/dist/index41.d.cts +56 -0
  166. package/dist/index41.d.cts.map +1 -0
  167. package/dist/index41.d.ts +56 -0
  168. package/dist/index41.d.ts.map +1 -0
  169. package/dist/index42.d.cts +45 -0
  170. package/dist/index42.d.cts.map +1 -0
  171. package/dist/index42.d.ts +45 -0
  172. package/dist/index42.d.ts.map +1 -0
  173. package/dist/index43.d.cts +96 -0
  174. package/dist/index43.d.cts.map +1 -0
  175. package/dist/index43.d.ts +96 -0
  176. package/dist/index43.d.ts.map +1 -0
  177. package/dist/index44.d.cts +48 -0
  178. package/dist/index44.d.cts.map +1 -0
  179. package/dist/index44.d.ts +48 -0
  180. package/dist/index44.d.ts.map +1 -0
  181. package/dist/index45.d.cts +28 -0
  182. package/dist/index45.d.cts.map +1 -0
  183. package/dist/index45.d.ts +28 -0
  184. package/dist/index45.d.ts.map +1 -0
  185. package/dist/index46.d.cts +41 -0
  186. package/dist/index46.d.cts.map +1 -0
  187. package/dist/index46.d.ts +41 -0
  188. package/dist/index46.d.ts.map +1 -0
  189. package/dist/index47.d.cts +25 -0
  190. package/dist/index47.d.cts.map +1 -0
  191. package/dist/index47.d.ts +25 -0
  192. package/dist/index47.d.ts.map +1 -0
  193. package/dist/index48.d.cts +21 -0
  194. package/dist/index48.d.cts.map +1 -0
  195. package/dist/index48.d.ts +21 -0
  196. package/dist/index48.d.ts.map +1 -0
  197. package/dist/index49.d.cts +69 -0
  198. package/dist/index49.d.cts.map +1 -0
  199. package/dist/index49.d.ts +69 -0
  200. package/dist/index49.d.ts.map +1 -0
  201. package/dist/index5.d.cts +45 -0
  202. package/dist/index5.d.cts.map +1 -0
  203. package/dist/index5.d.ts +45 -0
  204. package/dist/index5.d.ts.map +1 -0
  205. package/dist/index50.d.cts +63 -0
  206. package/dist/index50.d.cts.map +1 -0
  207. package/dist/index50.d.ts +63 -0
  208. package/dist/index50.d.ts.map +1 -0
  209. package/dist/index51.d.cts +31 -0
  210. package/dist/index51.d.cts.map +1 -0
  211. package/dist/index51.d.ts +31 -0
  212. package/dist/index51.d.ts.map +1 -0
  213. package/dist/index52.d.cts +209 -0
  214. package/dist/index52.d.cts.map +1 -0
  215. package/dist/index52.d.ts +209 -0
  216. package/dist/index52.d.ts.map +1 -0
  217. package/dist/index53.d.cts +26 -0
  218. package/dist/index53.d.cts.map +1 -0
  219. package/dist/index53.d.ts +26 -0
  220. package/dist/index53.d.ts.map +1 -0
  221. package/dist/index54.d.cts +28 -0
  222. package/dist/index54.d.cts.map +1 -0
  223. package/dist/index54.d.ts +28 -0
  224. package/dist/index54.d.ts.map +1 -0
  225. package/dist/index55.d.cts +25 -0
  226. package/dist/index55.d.cts.map +1 -0
  227. package/dist/index55.d.ts +25 -0
  228. package/dist/index55.d.ts.map +1 -0
  229. package/dist/index56.d.cts +12 -0
  230. package/dist/index56.d.cts.map +1 -0
  231. package/dist/index56.d.ts +12 -0
  232. package/dist/index56.d.ts.map +1 -0
  233. package/dist/index57.d.cts +50 -0
  234. package/dist/index57.d.cts.map +1 -0
  235. package/dist/index57.d.ts +50 -0
  236. package/dist/index57.d.ts.map +1 -0
  237. package/dist/index58.d.cts +51 -0
  238. package/dist/index58.d.cts.map +1 -0
  239. package/dist/index58.d.ts +51 -0
  240. package/dist/index58.d.ts.map +1 -0
  241. package/dist/index59.d.cts +58 -0
  242. package/dist/index59.d.cts.map +1 -0
  243. package/dist/index59.d.ts +58 -0
  244. package/dist/index59.d.ts.map +1 -0
  245. package/dist/index6.d.cts +26 -0
  246. package/dist/index6.d.cts.map +1 -0
  247. package/dist/index6.d.ts +26 -0
  248. package/dist/index6.d.ts.map +1 -0
  249. package/dist/index60.d.cts +45 -0
  250. package/dist/index60.d.cts.map +1 -0
  251. package/dist/index60.d.ts +45 -0
  252. package/dist/index60.d.ts.map +1 -0
  253. package/dist/index61.d.cts +21 -0
  254. package/dist/index61.d.cts.map +1 -0
  255. package/dist/index61.d.ts +21 -0
  256. package/dist/index61.d.ts.map +1 -0
  257. package/dist/index62.d.cts +45 -0
  258. package/dist/index62.d.cts.map +1 -0
  259. package/dist/index62.d.ts +45 -0
  260. package/dist/index62.d.ts.map +1 -0
  261. package/dist/index63.d.cts +23 -0
  262. package/dist/index63.d.cts.map +1 -0
  263. package/dist/index63.d.ts +23 -0
  264. package/dist/index63.d.ts.map +1 -0
  265. package/dist/index64.d.cts +48 -0
  266. package/dist/index64.d.cts.map +1 -0
  267. package/dist/index64.d.ts +48 -0
  268. package/dist/index64.d.ts.map +1 -0
  269. package/dist/index65.d.cts +25 -0
  270. package/dist/index65.d.cts.map +1 -0
  271. package/dist/index65.d.ts +25 -0
  272. package/dist/index65.d.ts.map +1 -0
  273. package/dist/index66.d.cts +19 -0
  274. package/dist/index66.d.cts.map +1 -0
  275. package/dist/index66.d.ts +19 -0
  276. package/dist/index66.d.ts.map +1 -0
  277. package/dist/index67.d.cts +37 -0
  278. package/dist/index67.d.cts.map +1 -0
  279. package/dist/index67.d.ts +37 -0
  280. package/dist/index67.d.ts.map +1 -0
  281. package/dist/index68.d.cts +36 -0
  282. package/dist/index68.d.cts.map +1 -0
  283. package/dist/index68.d.ts +36 -0
  284. package/dist/index68.d.ts.map +1 -0
  285. package/dist/index69.d.cts +69 -0
  286. package/dist/index69.d.ts +69 -0
  287. package/dist/index7.d.cts +46 -0
  288. package/dist/index7.d.cts.map +1 -0
  289. package/dist/index7.d.ts +46 -0
  290. package/dist/index7.d.ts.map +1 -0
  291. package/dist/index70.d.cts +242 -0
  292. package/dist/index70.d.cts.map +1 -0
  293. package/dist/index70.d.ts +242 -0
  294. package/dist/index70.d.ts.map +1 -0
  295. package/dist/index8.d.cts +26 -0
  296. package/dist/index8.d.cts.map +1 -0
  297. package/dist/index8.d.ts +26 -0
  298. package/dist/index8.d.ts.map +1 -0
  299. package/dist/index9.d.cts +20 -0
  300. package/dist/index9.d.cts.map +1 -0
  301. package/dist/index9.d.ts +20 -0
  302. package/dist/index9.d.ts.map +1 -0
  303. package/dist/layouts/Container/index.cjs +39 -0
  304. package/dist/layouts/Container/index.cjs.map +1 -0
  305. package/dist/layouts/Container/index.d.cts +2 -0
  306. package/dist/layouts/Container/index.d.ts +2 -0
  307. package/dist/layouts/Container/index.js +38 -0
  308. package/dist/layouts/Container/index.js.map +1 -0
  309. package/dist/layouts/PageBackground/index.cjs +22 -0
  310. package/dist/layouts/PageBackground/index.cjs.map +1 -0
  311. package/dist/layouts/PageBackground/index.d.cts +2 -0
  312. package/dist/layouts/PageBackground/index.d.ts +2 -0
  313. package/dist/layouts/PageBackground/index.js +21 -0
  314. package/dist/layouts/PageBackground/index.js.map +1 -0
  315. package/dist/{Stack.cjs → layouts/Stack/index.cjs} +7 -15
  316. package/dist/layouts/Stack/index.cjs.map +1 -0
  317. package/dist/layouts/Stack/index.d.cts +2 -0
  318. package/dist/layouts/Stack/index.d.ts +2 -0
  319. package/dist/{Stack.js → layouts/Stack/index.js} +4 -3
  320. package/dist/layouts/Stack/index.js.map +1 -0
  321. package/dist/layouts/TwoColumn/index.cjs +51 -0
  322. package/dist/layouts/TwoColumn/index.cjs.map +1 -0
  323. package/dist/layouts/TwoColumn/index.d.cts +2 -0
  324. package/dist/layouts/TwoColumn/index.d.ts +2 -0
  325. package/dist/layouts/TwoColumn/index.js +48 -0
  326. package/dist/layouts/TwoColumn/index.js.map +1 -0
  327. package/dist/layouts/index.cjs +13 -100
  328. package/dist/layouts/index.d.cts +5 -76
  329. package/dist/layouts/index.d.ts +5 -76
  330. package/dist/layouts/index.js +4 -91
  331. package/dist/patterns/DataTable/index.cjs +114 -0
  332. package/dist/patterns/DataTable/index.cjs.map +1 -0
  333. package/dist/patterns/DataTable/index.d.cts +43 -0
  334. package/dist/patterns/DataTable/index.d.cts.map +1 -0
  335. package/dist/patterns/DataTable/index.d.ts +43 -0
  336. package/dist/patterns/DataTable/index.d.ts.map +1 -0
  337. package/dist/patterns/DataTable/index.js +110 -0
  338. package/dist/patterns/DataTable/index.js.map +1 -0
  339. package/dist/patterns/Footer/index.cjs +76 -0
  340. package/dist/patterns/Footer/index.cjs.map +1 -0
  341. package/dist/patterns/Footer/index.d.cts +54 -0
  342. package/dist/patterns/Footer/index.d.cts.map +1 -0
  343. package/dist/patterns/Footer/index.d.ts +54 -0
  344. package/dist/patterns/Footer/index.d.ts.map +1 -0
  345. package/dist/patterns/Footer/index.js +70 -0
  346. package/dist/patterns/Footer/index.js.map +1 -0
  347. package/dist/patterns/Header/index.cjs +17 -0
  348. package/dist/patterns/Header/index.d.cts +2 -0
  349. package/dist/patterns/Header/index.d.ts +2 -0
  350. package/dist/patterns/Header/index.js +2 -0
  351. package/dist/patterns/MediaObject/index.cjs +108 -0
  352. package/dist/patterns/MediaObject/index.cjs.map +1 -0
  353. package/dist/patterns/MediaObject/index.d.cts +71 -0
  354. package/dist/patterns/MediaObject/index.d.cts.map +1 -0
  355. package/dist/patterns/MediaObject/index.d.ts +71 -0
  356. package/dist/patterns/MediaObject/index.d.ts.map +1 -0
  357. package/dist/patterns/MediaObject/index.js +99 -0
  358. package/dist/patterns/MediaObject/index.js.map +1 -0
  359. package/dist/patterns/SectionCard/index.cjs +35 -0
  360. package/dist/patterns/SectionCard/index.cjs.map +1 -0
  361. package/dist/patterns/SectionCard/index.d.cts +21 -0
  362. package/dist/patterns/SectionCard/index.d.cts.map +1 -0
  363. package/dist/patterns/SectionCard/index.d.ts +21 -0
  364. package/dist/patterns/SectionCard/index.d.ts.map +1 -0
  365. package/dist/patterns/SectionCard/index.js +34 -0
  366. package/dist/patterns/SectionCard/index.js.map +1 -0
  367. package/dist/patterns/SectionHeading/index.cjs +44 -0
  368. package/dist/patterns/SectionHeading/index.cjs.map +1 -0
  369. package/dist/patterns/SectionHeading/index.d.cts +37 -0
  370. package/dist/patterns/SectionHeading/index.d.cts.map +1 -0
  371. package/dist/patterns/SectionHeading/index.d.ts +37 -0
  372. package/dist/patterns/SectionHeading/index.d.ts.map +1 -0
  373. package/dist/patterns/SectionHeading/index.js +43 -0
  374. package/dist/patterns/SectionHeading/index.js.map +1 -0
  375. package/dist/patterns/index.cjs +40 -1124
  376. package/dist/patterns/index.d.cts +7 -410
  377. package/dist/patterns/index.d.ts +7 -410
  378. package/dist/patterns/index.js +6 -1088
  379. package/dist/primitives/Accordion/index.cjs +54 -0
  380. package/dist/primitives/Accordion/index.cjs.map +1 -0
  381. package/dist/primitives/Accordion/index.d.cts +2 -0
  382. package/dist/primitives/Accordion/index.d.ts +2 -0
  383. package/dist/primitives/Accordion/index.js +50 -0
  384. package/dist/primitives/Accordion/index.js.map +1 -0
  385. package/dist/primitives/Alert/index.cjs +61 -0
  386. package/dist/primitives/Alert/index.cjs.map +1 -0
  387. package/dist/primitives/Alert/index.d.cts +2 -0
  388. package/dist/primitives/Alert/index.d.ts +2 -0
  389. package/dist/primitives/Alert/index.js +57 -0
  390. package/dist/primitives/Alert/index.js.map +1 -0
  391. package/dist/primitives/AlertDialog/index.cjs +102 -0
  392. package/dist/primitives/AlertDialog/index.cjs.map +1 -0
  393. package/dist/primitives/AlertDialog/index.d.cts +2 -0
  394. package/dist/primitives/AlertDialog/index.d.ts +2 -0
  395. package/dist/primitives/AlertDialog/index.js +90 -0
  396. package/dist/primitives/AlertDialog/index.js.map +1 -0
  397. package/dist/primitives/AspectRatio/index.cjs +15 -0
  398. package/dist/primitives/AspectRatio/index.cjs.map +1 -0
  399. package/dist/primitives/AspectRatio/index.d.cts +2 -0
  400. package/dist/primitives/AspectRatio/index.d.ts +2 -0
  401. package/dist/primitives/AspectRatio/index.js +14 -0
  402. package/dist/primitives/AspectRatio/index.js.map +1 -0
  403. package/dist/primitives/Avatar/index.cjs +64 -0
  404. package/dist/primitives/Avatar/index.cjs.map +1 -0
  405. package/dist/primitives/Avatar/index.d.cts +2 -0
  406. package/dist/primitives/Avatar/index.d.ts +2 -0
  407. package/dist/primitives/Avatar/index.js +58 -0
  408. package/dist/primitives/Avatar/index.js.map +1 -0
  409. package/dist/primitives/Badge/index.cjs +44 -0
  410. package/dist/primitives/Badge/index.cjs.map +1 -0
  411. package/dist/primitives/Badge/index.d.cts +2 -0
  412. package/dist/primitives/Badge/index.d.ts +2 -0
  413. package/dist/primitives/Badge/index.js +43 -0
  414. package/dist/primitives/Badge/index.js.map +1 -0
  415. package/dist/primitives/Breadcrumb/index.cjs +82 -0
  416. package/dist/primitives/Breadcrumb/index.cjs.map +1 -0
  417. package/dist/primitives/Breadcrumb/index.d.cts +2 -0
  418. package/dist/primitives/Breadcrumb/index.d.ts +2 -0
  419. package/dist/primitives/Breadcrumb/index.js +75 -0
  420. package/dist/primitives/Breadcrumb/index.js.map +1 -0
  421. package/dist/primitives/Button/index.cjs +61 -0
  422. package/dist/primitives/Button/index.cjs.map +1 -0
  423. package/dist/primitives/Button/index.d.cts +2 -0
  424. package/dist/primitives/Button/index.d.ts +2 -0
  425. package/dist/primitives/Button/index.js +60 -0
  426. package/dist/primitives/Button/index.js.map +1 -0
  427. package/dist/primitives/ButtonGroup/index.cjs +46 -0
  428. package/dist/primitives/ButtonGroup/index.cjs.map +1 -0
  429. package/dist/primitives/ButtonGroup/index.d.cts +2 -0
  430. package/dist/primitives/ButtonGroup/index.d.ts +2 -0
  431. package/dist/primitives/ButtonGroup/index.js +43 -0
  432. package/dist/primitives/ButtonGroup/index.js.map +1 -0
  433. package/dist/primitives/Calendar/index.cjs +112 -0
  434. package/dist/primitives/Calendar/index.cjs.map +1 -0
  435. package/dist/primitives/Calendar/index.d.cts +2 -0
  436. package/dist/primitives/Calendar/index.d.ts +2 -0
  437. package/dist/primitives/Calendar/index.js +108 -0
  438. package/dist/primitives/Calendar/index.js.map +1 -0
  439. package/dist/primitives/Card/index.cjs +128 -0
  440. package/dist/primitives/Card/index.cjs.map +1 -0
  441. package/dist/primitives/Card/index.d.cts +2 -0
  442. package/dist/primitives/Card/index.d.ts +2 -0
  443. package/dist/primitives/Card/index.js +121 -0
  444. package/dist/primitives/Card/index.js.map +1 -0
  445. package/dist/primitives/Carousel/index.cjs +146 -0
  446. package/dist/primitives/Carousel/index.cjs.map +1 -0
  447. package/dist/primitives/Carousel/index.d.cts +2 -0
  448. package/dist/primitives/Carousel/index.d.ts +2 -0
  449. package/dist/primitives/Carousel/index.js +138 -0
  450. package/dist/primitives/Carousel/index.js.map +1 -0
  451. package/dist/primitives/Chart/index.cjs +162 -0
  452. package/dist/primitives/Chart/index.cjs.map +1 -0
  453. package/dist/primitives/Chart/index.d.cts +2 -0
  454. package/dist/primitives/Chart/index.d.ts +2 -0
  455. package/dist/primitives/Chart/index.js +153 -0
  456. package/dist/primitives/Chart/index.js.map +1 -0
  457. package/dist/primitives/Checkbox/index.cjs +53 -0
  458. package/dist/primitives/Checkbox/index.cjs.map +1 -0
  459. package/dist/primitives/Checkbox/index.d.cts +2 -0
  460. package/dist/primitives/Checkbox/index.d.ts +2 -0
  461. package/dist/primitives/Checkbox/index.js +51 -0
  462. package/dist/primitives/Checkbox/index.js.map +1 -0
  463. package/dist/primitives/CheckboxTree/index.cjs +106 -0
  464. package/dist/primitives/CheckboxTree/index.cjs.map +1 -0
  465. package/dist/primitives/CheckboxTree/index.d.cts +2 -0
  466. package/dist/primitives/CheckboxTree/index.d.ts +2 -0
  467. package/dist/primitives/CheckboxTree/index.js +103 -0
  468. package/dist/primitives/CheckboxTree/index.js.map +1 -0
  469. package/dist/primitives/Collapsible/index.cjs +31 -0
  470. package/dist/primitives/Collapsible/index.cjs.map +1 -0
  471. package/dist/primitives/Collapsible/index.d.cts +2 -0
  472. package/dist/primitives/Collapsible/index.d.ts +2 -0
  473. package/dist/primitives/Collapsible/index.js +28 -0
  474. package/dist/primitives/Collapsible/index.js.map +1 -0
  475. package/dist/primitives/Command/index.cjs +104 -0
  476. package/dist/primitives/Command/index.cjs.map +1 -0
  477. package/dist/primitives/Command/index.d.cts +2 -0
  478. package/dist/primitives/Command/index.d.ts +2 -0
  479. package/dist/primitives/Command/index.js +95 -0
  480. package/dist/primitives/Command/index.js.map +1 -0
  481. package/dist/primitives/ContextMenu/index.cjs +152 -0
  482. package/dist/primitives/ContextMenu/index.cjs.map +1 -0
  483. package/dist/primitives/ContextMenu/index.d.cts +2 -0
  484. package/dist/primitives/ContextMenu/index.d.ts +2 -0
  485. package/dist/primitives/ContextMenu/index.js +137 -0
  486. package/dist/primitives/ContextMenu/index.js.map +1 -0
  487. package/dist/primitives/Credits/index.cjs +39 -0
  488. package/dist/primitives/Credits/index.cjs.map +1 -0
  489. package/dist/primitives/Credits/index.d.cts +2 -0
  490. package/dist/primitives/Credits/index.d.ts +2 -0
  491. package/dist/primitives/Credits/index.js +38 -0
  492. package/dist/primitives/Credits/index.js.map +1 -0
  493. package/dist/primitives/Dialog/index.cjs +121 -0
  494. package/dist/primitives/Dialog/index.cjs.map +1 -0
  495. package/dist/primitives/Dialog/index.d.cts +2 -0
  496. package/dist/primitives/Dialog/index.d.ts +2 -0
  497. package/dist/primitives/Dialog/index.js +111 -0
  498. package/dist/primitives/Dialog/index.js.map +1 -0
  499. package/dist/primitives/Drawer/index.cjs +98 -0
  500. package/dist/primitives/Drawer/index.cjs.map +1 -0
  501. package/dist/primitives/Drawer/index.d.cts +2 -0
  502. package/dist/primitives/Drawer/index.d.ts +2 -0
  503. package/dist/primitives/Drawer/index.js +88 -0
  504. package/dist/primitives/Drawer/index.js.map +1 -0
  505. package/dist/primitives/DropdownMenu/index.cjs +153 -0
  506. package/dist/primitives/DropdownMenu/index.cjs.map +1 -0
  507. package/dist/primitives/DropdownMenu/index.d.cts +2 -0
  508. package/dist/primitives/DropdownMenu/index.d.ts +2 -0
  509. package/dist/primitives/DropdownMenu/index.js +138 -0
  510. package/dist/primitives/DropdownMenu/index.js.map +1 -0
  511. package/dist/primitives/Empty/index.cjs +84 -0
  512. package/dist/primitives/Empty/index.cjs.map +1 -0
  513. package/dist/primitives/Empty/index.d.cts +2 -0
  514. package/dist/primitives/Empty/index.d.ts +2 -0
  515. package/dist/primitives/Empty/index.js +77 -0
  516. package/dist/primitives/Empty/index.js.map +1 -0
  517. package/dist/primitives/Field/index.cjs +139 -0
  518. package/dist/primitives/Field/index.cjs.map +1 -0
  519. package/dist/primitives/Field/index.d.cts +2 -0
  520. package/dist/primitives/Field/index.d.ts +2 -0
  521. package/dist/primitives/Field/index.js +129 -0
  522. package/dist/primitives/Field/index.js.map +1 -0
  523. package/dist/primitives/Form/index.cjs +104 -0
  524. package/dist/primitives/Form/index.cjs.map +1 -0
  525. package/dist/primitives/Form/index.d.cts +2 -0
  526. package/dist/primitives/Form/index.d.ts +2 -0
  527. package/dist/primitives/Form/index.js +94 -0
  528. package/dist/primitives/Form/index.js.map +1 -0
  529. package/dist/primitives/Heading/index.cjs +53 -0
  530. package/dist/primitives/Heading/index.cjs.map +1 -0
  531. package/dist/primitives/Heading/index.d.cts +2 -0
  532. package/dist/primitives/Heading/index.d.ts +2 -0
  533. package/dist/primitives/Heading/index.js +52 -0
  534. package/dist/primitives/Heading/index.js.map +1 -0
  535. package/dist/primitives/HoverCard/index.cjs +38 -0
  536. package/dist/primitives/HoverCard/index.cjs.map +1 -0
  537. package/dist/primitives/HoverCard/index.d.cts +2 -0
  538. package/dist/primitives/HoverCard/index.d.ts +2 -0
  539. package/dist/primitives/HoverCard/index.js +35 -0
  540. package/dist/primitives/HoverCard/index.js.map +1 -0
  541. package/dist/primitives/Icon/index.cjs +4 -0
  542. package/dist/primitives/Icon/index.d.cts +2 -0
  543. package/dist/primitives/Icon/index.d.ts +2 -0
  544. package/dist/primitives/Icon/index.js +2 -0
  545. package/dist/primitives/InfoBanner/index.cjs +79 -0
  546. package/dist/primitives/InfoBanner/index.cjs.map +1 -0
  547. package/dist/primitives/InfoBanner/index.d.cts +2 -0
  548. package/dist/primitives/InfoBanner/index.d.ts +2 -0
  549. package/dist/primitives/InfoBanner/index.js +78 -0
  550. package/dist/primitives/InfoBanner/index.js.map +1 -0
  551. package/dist/primitives/Input/index.cjs +39 -0
  552. package/dist/primitives/Input/index.cjs.map +1 -0
  553. package/dist/primitives/Input/index.d.cts +2 -0
  554. package/dist/primitives/Input/index.d.ts +2 -0
  555. package/dist/primitives/Input/index.js +38 -0
  556. package/dist/primitives/Input/index.js.map +1 -0
  557. package/dist/primitives/InputGroup/index.cjs +91 -0
  558. package/dist/primitives/InputGroup/index.cjs.map +1 -0
  559. package/dist/primitives/InputGroup/index.d.cts +2 -0
  560. package/dist/primitives/InputGroup/index.d.ts +2 -0
  561. package/dist/primitives/InputGroup/index.js +85 -0
  562. package/dist/primitives/InputGroup/index.js.map +1 -0
  563. package/dist/primitives/InputOtp/index.cjs +80 -0
  564. package/dist/primitives/InputOtp/index.cjs.map +1 -0
  565. package/dist/primitives/InputOtp/index.d.cts +2 -0
  566. package/dist/primitives/InputOtp/index.d.ts +2 -0
  567. package/dist/primitives/InputOtp/index.js +74 -0
  568. package/dist/primitives/InputOtp/index.js.map +1 -0
  569. package/dist/primitives/Item/index.cjs +137 -0
  570. package/dist/primitives/Item/index.cjs.map +1 -0
  571. package/dist/primitives/Item/index.d.cts +2 -0
  572. package/dist/primitives/Item/index.d.ts +2 -0
  573. package/dist/primitives/Item/index.js +127 -0
  574. package/dist/primitives/Item/index.js.map +1 -0
  575. package/dist/primitives/Kbd/index.cjs +25 -0
  576. package/dist/primitives/Kbd/index.cjs.map +1 -0
  577. package/dist/primitives/Kbd/index.d.cts +2 -0
  578. package/dist/primitives/Kbd/index.d.ts +2 -0
  579. package/dist/primitives/Kbd/index.js +23 -0
  580. package/dist/primitives/Kbd/index.js.map +1 -0
  581. package/dist/primitives/Label/index.cjs +18 -0
  582. package/dist/primitives/Label/index.cjs.map +1 -0
  583. package/dist/primitives/Label/index.d.cts +2 -0
  584. package/dist/primitives/Label/index.d.ts +2 -0
  585. package/dist/primitives/Label/index.js +17 -0
  586. package/dist/primitives/Label/index.js.map +1 -0
  587. package/dist/primitives/Link/index.cjs +38 -0
  588. package/dist/primitives/Link/index.cjs.map +1 -0
  589. package/dist/primitives/Link/index.d.cts +2 -0
  590. package/dist/primitives/Link/index.d.ts +2 -0
  591. package/dist/primitives/Link/index.js +37 -0
  592. package/dist/primitives/Link/index.js.map +1 -0
  593. package/dist/primitives/Logo/index.cjs +3 -0
  594. package/dist/primitives/Logo/index.d.cts +2 -0
  595. package/dist/primitives/Logo/index.d.ts +2 -0
  596. package/dist/primitives/Logo/index.js +2 -0
  597. package/dist/primitives/Menubar/index.cjs +165 -0
  598. package/dist/primitives/Menubar/index.cjs.map +1 -0
  599. package/dist/primitives/Menubar/index.d.cts +2 -0
  600. package/dist/primitives/Menubar/index.d.ts +2 -0
  601. package/dist/primitives/Menubar/index.js +149 -0
  602. package/dist/primitives/Menubar/index.js.map +1 -0
  603. package/dist/primitives/NativeSelect/index.cjs +40 -0
  604. package/dist/primitives/NativeSelect/index.cjs.map +1 -0
  605. package/dist/primitives/NativeSelect/index.d.cts +2 -0
  606. package/dist/primitives/NativeSelect/index.d.ts +2 -0
  607. package/dist/primitives/NativeSelect/index.js +39 -0
  608. package/dist/primitives/NativeSelect/index.js.map +1 -0
  609. package/dist/primitives/NavRail/index.cjs +195 -0
  610. package/dist/primitives/NavRail/index.cjs.map +1 -0
  611. package/dist/primitives/NavRail/index.d.cts +2 -0
  612. package/dist/primitives/NavRail/index.d.ts +2 -0
  613. package/dist/primitives/NavRail/index.js +185 -0
  614. package/dist/primitives/NavRail/index.js.map +1 -0
  615. package/dist/primitives/NavigationMenu/index.cjs +98 -0
  616. package/dist/primitives/NavigationMenu/index.cjs.map +1 -0
  617. package/dist/primitives/NavigationMenu/index.d.cts +2 -0
  618. package/dist/primitives/NavigationMenu/index.d.ts +2 -0
  619. package/dist/primitives/NavigationMenu/index.js +89 -0
  620. package/dist/primitives/NavigationMenu/index.js.map +1 -0
  621. package/dist/primitives/Pagination/index.cjs +93 -0
  622. package/dist/primitives/Pagination/index.cjs.map +1 -0
  623. package/dist/primitives/Pagination/index.d.cts +2 -0
  624. package/dist/primitives/Pagination/index.d.ts +2 -0
  625. package/dist/primitives/Pagination/index.js +86 -0
  626. package/dist/primitives/Pagination/index.js.map +1 -0
  627. package/dist/primitives/Popover/index.cjs +70 -0
  628. package/dist/primitives/Popover/index.cjs.map +1 -0
  629. package/dist/primitives/Popover/index.d.cts +2 -0
  630. package/dist/primitives/Popover/index.d.ts +2 -0
  631. package/dist/primitives/Popover/index.js +63 -0
  632. package/dist/primitives/Popover/index.js.map +1 -0
  633. package/dist/primitives/Progress/index.cjs +44 -0
  634. package/dist/primitives/Progress/index.cjs.map +1 -0
  635. package/dist/primitives/Progress/index.d.cts +2 -0
  636. package/dist/primitives/Progress/index.d.ts +2 -0
  637. package/dist/primitives/Progress/index.js +43 -0
  638. package/dist/primitives/Progress/index.js.map +1 -0
  639. package/dist/primitives/RadioGroup/index.cjs +65 -0
  640. package/dist/primitives/RadioGroup/index.cjs.map +1 -0
  641. package/dist/primitives/RadioGroup/index.d.cts +2 -0
  642. package/dist/primitives/RadioGroup/index.d.ts +2 -0
  643. package/dist/primitives/RadioGroup/index.js +62 -0
  644. package/dist/primitives/RadioGroup/index.js.map +1 -0
  645. package/dist/primitives/Resizable/index.cjs +41 -0
  646. package/dist/primitives/Resizable/index.cjs.map +1 -0
  647. package/dist/primitives/Resizable/index.d.cts +2 -0
  648. package/dist/primitives/Resizable/index.d.ts +2 -0
  649. package/dist/primitives/Resizable/index.js +36 -0
  650. package/dist/primitives/Resizable/index.js.map +1 -0
  651. package/dist/primitives/ScrollArea/index.cjs +40 -0
  652. package/dist/primitives/ScrollArea/index.cjs.map +1 -0
  653. package/dist/primitives/ScrollArea/index.d.cts +2 -0
  654. package/dist/primitives/ScrollArea/index.d.ts +2 -0
  655. package/dist/primitives/ScrollArea/index.js +38 -0
  656. package/dist/primitives/ScrollArea/index.js.map +1 -0
  657. package/dist/primitives/Select/index.cjs +126 -0
  658. package/dist/primitives/Select/index.cjs.map +1 -0
  659. package/dist/primitives/Select/index.d.cts +2 -0
  660. package/dist/primitives/Select/index.d.ts +2 -0
  661. package/dist/primitives/Select/index.js +116 -0
  662. package/dist/primitives/Select/index.js.map +1 -0
  663. package/dist/primitives/Separator/index.cjs +25 -0
  664. package/dist/primitives/Separator/index.cjs.map +1 -0
  665. package/dist/primitives/Separator/index.d.cts +2 -0
  666. package/dist/primitives/Separator/index.d.ts +2 -0
  667. package/dist/primitives/Separator/index.js +24 -0
  668. package/dist/primitives/Separator/index.js.map +1 -0
  669. package/dist/primitives/Sheet/index.cjs +107 -0
  670. package/dist/primitives/Sheet/index.cjs.map +1 -0
  671. package/dist/primitives/Sheet/index.d.cts +2 -0
  672. package/dist/primitives/Sheet/index.d.ts +2 -0
  673. package/dist/primitives/Sheet/index.js +99 -0
  674. package/dist/primitives/Sheet/index.js.map +1 -0
  675. package/dist/primitives/Sidebar/index.cjs +26 -0
  676. package/dist/primitives/Sidebar/index.d.cts +2 -0
  677. package/dist/primitives/Sidebar/index.d.ts +2 -0
  678. package/dist/primitives/Sidebar/index.js +2 -0
  679. package/dist/primitives/Skeleton/index.cjs +43 -0
  680. package/dist/primitives/Skeleton/index.cjs.map +1 -0
  681. package/dist/primitives/Skeleton/index.d.cts +2 -0
  682. package/dist/primitives/Skeleton/index.d.ts +2 -0
  683. package/dist/primitives/Skeleton/index.js +39 -0
  684. package/dist/primitives/Skeleton/index.js.map +1 -0
  685. package/dist/primitives/Slider/index.cjs +46 -0
  686. package/dist/primitives/Slider/index.cjs.map +1 -0
  687. package/dist/primitives/Slider/index.d.cts +2 -0
  688. package/dist/primitives/Slider/index.d.ts +2 -0
  689. package/dist/primitives/Slider/index.js +43 -0
  690. package/dist/primitives/Slider/index.js.map +1 -0
  691. package/dist/primitives/Sonner/index.cjs +42 -0
  692. package/dist/primitives/Sonner/index.cjs.map +1 -0
  693. package/dist/primitives/Sonner/index.d.cts +2 -0
  694. package/dist/primitives/Sonner/index.d.ts +2 -0
  695. package/dist/primitives/Sonner/index.js +41 -0
  696. package/dist/primitives/Sonner/index.js.map +1 -0
  697. package/dist/primitives/Spinner/index.cjs +19 -0
  698. package/dist/primitives/Spinner/index.cjs.map +1 -0
  699. package/dist/primitives/Spinner/index.d.cts +2 -0
  700. package/dist/primitives/Spinner/index.d.ts +2 -0
  701. package/dist/primitives/Spinner/index.js +18 -0
  702. package/dist/primitives/Spinner/index.js.map +1 -0
  703. package/dist/primitives/Switch/index.cjs +71 -0
  704. package/dist/primitives/Switch/index.cjs.map +1 -0
  705. package/dist/primitives/Switch/index.d.cts +2 -0
  706. package/dist/primitives/Switch/index.d.ts +2 -0
  707. package/dist/primitives/Switch/index.js +68 -0
  708. package/dist/primitives/Switch/index.js.map +1 -0
  709. package/dist/primitives/Table/index.cjs +84 -0
  710. package/dist/primitives/Table/index.cjs.map +1 -0
  711. package/dist/primitives/Table/index.d.cts +2 -0
  712. package/dist/primitives/Table/index.d.ts +2 -0
  713. package/dist/primitives/Table/index.js +76 -0
  714. package/dist/primitives/Table/index.js.map +1 -0
  715. package/dist/primitives/Tabs/index.cjs +267 -0
  716. package/dist/primitives/Tabs/index.cjs.map +1 -0
  717. package/dist/primitives/Tabs/index.d.cts +2 -0
  718. package/dist/primitives/Tabs/index.d.ts +2 -0
  719. package/dist/primitives/Tabs/index.js +258 -0
  720. package/dist/primitives/Tabs/index.js.map +1 -0
  721. package/dist/primitives/Text/index.cjs +64 -0
  722. package/dist/primitives/Text/index.cjs.map +1 -0
  723. package/dist/primitives/Text/index.d.cts +2 -0
  724. package/dist/primitives/Text/index.d.ts +2 -0
  725. package/dist/primitives/Text/index.js +63 -0
  726. package/dist/primitives/Text/index.js.map +1 -0
  727. package/dist/primitives/Textarea/index.cjs +24 -0
  728. package/dist/primitives/Textarea/index.cjs.map +1 -0
  729. package/dist/primitives/Textarea/index.d.cts +2 -0
  730. package/dist/primitives/Textarea/index.d.ts +2 -0
  731. package/dist/primitives/Textarea/index.js +23 -0
  732. package/dist/primitives/Textarea/index.js.map +1 -0
  733. package/dist/primitives/ThemeProvider/index.cjs +93 -0
  734. package/dist/primitives/ThemeProvider/index.cjs.map +1 -0
  735. package/dist/primitives/ThemeProvider/index.d.cts +2 -0
  736. package/dist/primitives/ThemeProvider/index.d.ts +2 -0
  737. package/dist/primitives/ThemeProvider/index.js +88 -0
  738. package/dist/primitives/ThemeProvider/index.js.map +1 -0
  739. package/dist/primitives/Toggle/index.cjs +59 -0
  740. package/dist/primitives/Toggle/index.cjs.map +1 -0
  741. package/dist/primitives/Toggle/index.d.cts +2 -0
  742. package/dist/primitives/Toggle/index.d.ts +2 -0
  743. package/dist/primitives/Toggle/index.js +58 -0
  744. package/dist/primitives/Toggle/index.js.map +1 -0
  745. package/dist/primitives/ToggleGroup/index.cjs +65 -0
  746. package/dist/primitives/ToggleGroup/index.cjs.map +1 -0
  747. package/dist/primitives/ToggleGroup/index.d.cts +2 -0
  748. package/dist/primitives/ToggleGroup/index.d.ts +2 -0
  749. package/dist/primitives/ToggleGroup/index.js +61 -0
  750. package/dist/primitives/ToggleGroup/index.js.map +1 -0
  751. package/dist/primitives/Tooltip/index.cjs +47 -0
  752. package/dist/primitives/Tooltip/index.cjs.map +1 -0
  753. package/dist/primitives/Tooltip/index.d.cts +2 -0
  754. package/dist/primitives/Tooltip/index.d.ts +2 -0
  755. package/dist/primitives/Tooltip/index.js +43 -0
  756. package/dist/primitives/Tooltip/index.js.map +1 -0
  757. package/dist/primitives/index.cjs +398 -335
  758. package/dist/primitives/index.d.cts +65 -3
  759. package/dist/primitives/index.d.ts +65 -3
  760. package/dist/primitives/index.js +65 -3
  761. package/dist/styles/base.css +70 -0
  762. package/dist/styles/semantic.css +62 -2
  763. package/dist/styles/theme.css +12 -0
  764. package/package.json +21 -2
  765. package/dist/Stack.cjs.map +0 -1
  766. package/dist/Stack.js.map +0 -1
  767. package/dist/ThemeProvider.cjs.map +0 -1
  768. package/dist/ThemeProvider.d.cts +0 -85
  769. package/dist/ThemeProvider.d.cts.map +0 -1
  770. package/dist/ThemeProvider.d.ts +0 -85
  771. package/dist/ThemeProvider.d.ts.map +0 -1
  772. package/dist/ThemeProvider.js.map +0 -1
  773. package/dist/layouts/index.cjs.map +0 -1
  774. package/dist/layouts/index.d.cts.map +0 -1
  775. package/dist/layouts/index.d.ts.map +0 -1
  776. package/dist/layouts/index.js.map +0 -1
  777. package/dist/patterns/index.cjs.map +0 -1
  778. package/dist/patterns/index.d.cts.map +0 -1
  779. package/dist/patterns/index.d.ts.map +0 -1
  780. package/dist/patterns/index.js.map +0 -1
  781. package/dist/primitives.cjs +0 -6979
  782. package/dist/primitives.cjs.map +0 -1
  783. package/dist/primitives.js +0 -5357
  784. package/dist/primitives.js.map +0 -1
  785. package/dist/utils.cjs.map +0 -1
  786. package/dist/utils.js +0 -27
  787. package/dist/utils.js.map +0 -1
@@ -0,0 +1,195 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ const require_chunk = require("../../chunk.cjs");
3
+ const require_cn = require("../../cn.cjs");
4
+ const require_primitives_Popover_index = require("../Popover/index.cjs");
5
+ const require_primitives_Tooltip_index = require("../Tooltip/index.cjs");
6
+ let react = require("react");
7
+ react = require_chunk.__toESM(react);
8
+ let lucide_react = require("lucide-react");
9
+ let radix_ui = require("radix-ui");
10
+ let react_jsx_runtime = require("react/jsx-runtime");
11
+ //#region src/primitives/NavRail/NavRail.tsx
12
+ const NavRailContext = react.createContext("icon");
13
+ const RAIL_BY_MODE = {
14
+ icon: "w-14 items-center",
15
+ text: "w-56 items-stretch",
16
+ expanded: "w-56 items-stretch",
17
+ "expand-on-hover": "w-14 items-stretch transition-[width] duration-200 ease-out hover:w-56"
18
+ };
19
+ const ITEM_BASE = "relative flex h-10 cursor-pointer items-center text-foreground outline-none transition-colors hover:bg-foreground/10 focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)] [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-5";
20
+ const ITEM_BY_MODE = {
21
+ icon: "w-10 justify-center rounded-full",
22
+ text: "w-full justify-start gap-3 rounded-lg px-2.5",
23
+ expanded: "w-full justify-start gap-3 rounded-lg px-2.5",
24
+ "expand-on-hover": "w-full justify-start gap-3 rounded-lg px-2.5"
25
+ };
26
+ const ICON_BY_MODE = {
27
+ icon: "flex shrink-0 items-center justify-center",
28
+ text: "hidden",
29
+ expanded: "flex shrink-0 items-center justify-center",
30
+ "expand-on-hover": "flex shrink-0 items-center justify-center"
31
+ };
32
+ const LABEL_ROW = "min-w-0 flex-1 truncate text-left text-sm font-medium";
33
+ const LABEL_BY_MODE = {
34
+ icon: "sr-only",
35
+ text: LABEL_ROW,
36
+ expanded: LABEL_ROW,
37
+ "expand-on-hover": require_cn.cn(LABEL_ROW, "opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100")
38
+ };
39
+ const CHEVRON_BY_MODE = {
40
+ icon: "absolute top-1/2 right-[-4px] size-3 -translate-y-1/2 text-muted-foreground",
41
+ text: "ml-auto size-4 shrink-0 text-muted-foreground",
42
+ expanded: "ml-auto size-4 shrink-0 text-muted-foreground",
43
+ "expand-on-hover": "ml-auto size-4 shrink-0 text-muted-foreground opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100"
44
+ };
45
+ /** The vertical navigation rail container; sets the display `mode` for all items via context. */
46
+ function NavRail({ mode = "icon", className, ...props }) {
47
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(NavRailContext.Provider, {
48
+ value: mode,
49
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("nav", {
50
+ "data-slot": "nav-rail",
51
+ "data-mode": mode,
52
+ className: require_cn.cn("group/nav-rail flex flex-col gap-1 overflow-hidden rounded-2xl bg-[var(--glass-strong)] p-2 backdrop-blur-[var(--glass-blur)]", RAIL_BY_MODE[mode], className),
53
+ ...props
54
+ })
55
+ });
56
+ }
57
+ /** A thin divider between groups of rail items. */
58
+ function NavRailSeparator({ className, ...props }) {
59
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
60
+ "data-slot": "nav-rail-separator",
61
+ role: "separator",
62
+ className: require_cn.cn("my-1 h-px w-6 shrink-0 self-center bg-border", className),
63
+ ...props
64
+ });
65
+ }
66
+ /** A single navigation entry; an icon (as children) plus a `label`, with a tooltip in icon mode. */
67
+ function NavRailItem({ label, active, asChild = false, tooltipSide = "right", className, children, ...props }) {
68
+ const mode = react.useContext(NavRailContext);
69
+ const shared = {
70
+ "data-slot": "nav-rail-item",
71
+ "data-active": active || void 0,
72
+ "aria-label": label,
73
+ "aria-current": active ? "page" : void 0,
74
+ className: require_cn.cn(ITEM_BASE, ITEM_BY_MODE[mode], className),
75
+ ...props
76
+ };
77
+ const labelEl = /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
78
+ "data-slot": "nav-rail-item-label",
79
+ className: LABEL_BY_MODE[mode],
80
+ children: label
81
+ });
82
+ const el = asChild ? /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(radix_ui.Slot.Root, {
83
+ ...shared,
84
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.Slot.Slottable, { children }), labelEl]
85
+ }) : /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("button", {
86
+ type: "button",
87
+ ...shared,
88
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
89
+ "data-slot": "nav-rail-item-icon",
90
+ className: ICON_BY_MODE[mode],
91
+ children
92
+ }), labelEl]
93
+ });
94
+ if (mode !== "icon") return el;
95
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(require_primitives_Tooltip_index.Tooltip, { children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_primitives_Tooltip_index.TooltipTrigger, {
96
+ asChild: true,
97
+ children: el
98
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_primitives_Tooltip_index.TooltipContent, {
99
+ side: tooltipSide,
100
+ children: label
101
+ })] });
102
+ }
103
+ /** The footer slot of the rail showing the signed-in user (avatar + name + email). */
104
+ function NavRailUser({ avatar, name, email, className, ...props }) {
105
+ const mode = react.useContext(NavRailContext);
106
+ const detailsHidden = mode === "icon";
107
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
108
+ "data-slot": "nav-rail-user",
109
+ className: require_cn.cn("mt-auto flex h-12 w-full items-center rounded-lg", className),
110
+ ...props,
111
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
112
+ "data-slot": "nav-rail-user-avatar",
113
+ className: "flex w-10 shrink-0 items-center justify-center",
114
+ children: avatar
115
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
116
+ "data-slot": "nav-rail-user-details",
117
+ className: require_cn.cn("flex min-w-0 flex-1 flex-col justify-center text-left leading-tight", detailsHidden && "sr-only", mode === "expand-on-hover" && "opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100"),
118
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
119
+ className: "truncate text-sm font-medium",
120
+ children: name
121
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
122
+ className: "truncate text-xs text-muted-foreground",
123
+ children: email
124
+ })]
125
+ })]
126
+ });
127
+ }
128
+ /** Root for a rail item that opens a flyout submenu (wraps Popover). */
129
+ function NavRailMenu(props) {
130
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_primitives_Popover_index.Popover, { ...props });
131
+ }
132
+ /** The rail item that opens its flyout submenu; renders a chevron affordance. */
133
+ function NavRailMenuTrigger({ label, active, className, children, ...props }) {
134
+ const mode = react.useContext(NavRailContext);
135
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_primitives_Popover_index.PopoverTrigger, {
136
+ asChild: true,
137
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("button", {
138
+ type: "button",
139
+ "data-slot": "nav-rail-menu-trigger",
140
+ "data-active": active || void 0,
141
+ "aria-label": label,
142
+ className: require_cn.cn(ITEM_BASE, ITEM_BY_MODE[mode], className),
143
+ ...props,
144
+ children: [
145
+ /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
146
+ "data-slot": "nav-rail-item-icon",
147
+ className: ICON_BY_MODE[mode],
148
+ children
149
+ }),
150
+ /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
151
+ "data-slot": "nav-rail-item-label",
152
+ className: LABEL_BY_MODE[mode],
153
+ children: label
154
+ }),
155
+ /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.ChevronRightIcon, {
156
+ "aria-hidden": true,
157
+ className: CHEVRON_BY_MODE[mode]
158
+ })
159
+ ]
160
+ })
161
+ });
162
+ }
163
+ /** The glass flyout panel that holds the submenu items (portalled Popover content). */
164
+ function NavRailMenuContent({ className, side = "right", align = "start", sideOffset = 8, ...props }) {
165
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_primitives_Popover_index.PopoverContent, {
166
+ "data-slot": "nav-rail-menu-content",
167
+ side,
168
+ align,
169
+ sideOffset,
170
+ className: require_cn.cn("flex w-[180px] flex-col gap-0.5 rounded-2xl border border-border bg-[var(--glass-subtle)] p-1.5 text-foreground shadow-sm backdrop-blur-[var(--glass-blur)]", className),
171
+ ...props
172
+ });
173
+ }
174
+ /** A single entry inside a NavRail flyout submenu. */
175
+ function NavRailMenuItem({ className, active, asChild = false, ...props }) {
176
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(asChild ? radix_ui.Slot.Root : "button", {
177
+ "data-slot": "nav-rail-menu-item",
178
+ "data-active": active || void 0,
179
+ "aria-current": active ? "page" : void 0,
180
+ className: require_cn.cn("flex w-full cursor-pointer items-center gap-2.5 rounded-lg px-3 py-2 text-left text-sm text-foreground outline-none transition-colors", "hover:bg-foreground/10 focus-visible:bg-foreground/10", "data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)]", "[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4", className),
181
+ ...asChild ? {} : { type: "button" },
182
+ ...props
183
+ });
184
+ }
185
+ //#endregion
186
+ exports.NavRail = NavRail;
187
+ exports.NavRailItem = NavRailItem;
188
+ exports.NavRailMenu = NavRailMenu;
189
+ exports.NavRailMenuContent = NavRailMenuContent;
190
+ exports.NavRailMenuItem = NavRailMenuItem;
191
+ exports.NavRailMenuTrigger = NavRailMenuTrigger;
192
+ exports.NavRailSeparator = NavRailSeparator;
193
+ exports.NavRailUser = NavRailUser;
194
+
195
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","names":["React","cn","Slot","Tooltip","TooltipTrigger","TooltipContent","Popover","PopoverTrigger","ChevronRightIcon","PopoverContent"],"sources":["../../../src/primitives/NavRail/NavRail.tsx"],"sourcesContent":["import { ChevronRightIcon } from \"lucide-react\";\nimport { Slot } from \"radix-ui\";\nimport * as React from \"react\";\n\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/primitives/Popover\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"@/primitives/Tooltip\";\nimport { cn } from \"@/utils\";\n\n// NavRail — a vertical navigation rail (the app's side nav). Four display modes:\n// icon-only (tooltips), text-only, expanded (icon + text), and expand-on-hover\n// (icon-only that widens to reveal labels on hover). Items can open a flyout\n// submenu (NavRailMenu) and the rail can show a user footer (NavRailUser).\n//\n// All items share a constant height (h-10) with the icon pinned to the left, so\n// expanding the rail just REVEALS the labels to the right — the icon never moves\n// and the row height never changes.\n//\n// LAYOUT NOTE: `expand-on-hover` changes the rail's width. To make the content\n// give up space as the rail expands (rather than overlap it), put the rail in a\n// flex row as a `shrink-0` child (it keeps its own w-14/w-56 width) next to a\n// `flex-1 min-w-0` content column — the column shrinks as the rail widens.\n\ntype NavRailMode = \"icon\" | \"text\" | \"expanded\" | \"expand-on-hover\";\n\nconst NavRailContext = React.createContext<NavRailMode>(\"icon\");\n\nconst RAIL_BY_MODE: Record<NavRailMode, string> = {\n icon: \"w-14 items-center\",\n text: \"w-56 items-stretch\",\n expanded: \"w-56 items-stretch\",\n \"expand-on-hover\": \"w-14 items-stretch transition-[width] duration-200 ease-out hover:w-56\",\n};\n\nconst ITEM_BASE =\n \"relative flex h-10 cursor-pointer items-center text-foreground outline-none transition-colors hover:bg-foreground/10 focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)] [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-5\";\n\nconst ITEM_BY_MODE: Record<NavRailMode, string> = {\n icon: \"w-10 justify-center rounded-full\",\n text: \"w-full justify-start gap-3 rounded-lg px-2.5\",\n expanded: \"w-full justify-start gap-3 rounded-lg px-2.5\",\n \"expand-on-hover\": \"w-full justify-start gap-3 rounded-lg px-2.5\",\n};\n\nconst ICON_BY_MODE: Record<NavRailMode, string> = {\n icon: \"flex shrink-0 items-center justify-center\",\n text: \"hidden\", // text-only mode hides the icon\n expanded: \"flex shrink-0 items-center justify-center\",\n \"expand-on-hover\": \"flex shrink-0 items-center justify-center\",\n};\n\nconst LABEL_ROW = \"min-w-0 flex-1 truncate text-left text-sm font-medium\";\nconst LABEL_BY_MODE: Record<NavRailMode, string> = {\n icon: \"sr-only\",\n text: LABEL_ROW,\n expanded: LABEL_ROW,\n // Always laid out (so the icon never reflows); revealed via opacity on hover.\n \"expand-on-hover\": cn(\n LABEL_ROW,\n \"opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100\",\n ),\n};\n\nconst CHEVRON_BY_MODE: Record<NavRailMode, string> = {\n // Vertically centered, overhanging the right edge (clear of the centered icon).\n icon: \"absolute top-1/2 right-[-4px] size-3 -translate-y-1/2 text-muted-foreground\",\n text: \"ml-auto size-4 shrink-0 text-muted-foreground\",\n expanded: \"ml-auto size-4 shrink-0 text-muted-foreground\",\n \"expand-on-hover\":\n \"ml-auto size-4 shrink-0 text-muted-foreground opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100\",\n};\n\n/** The vertical navigation rail container; sets the display `mode` for all items via context. */\nfunction NavRail({\n mode = \"icon\",\n className,\n ...props\n}: React.ComponentProps<\"nav\"> & {\n /** Display mode for the rail and its items: icon-only (tooltips), text-only, expanded (icon + text), or expand-on-hover. */\n mode?: NavRailMode;\n}) {\n return (\n <NavRailContext.Provider value={mode}>\n <nav\n data-slot=\"nav-rail\"\n data-mode={mode}\n className={cn(\n \"group/nav-rail flex flex-col gap-1 overflow-hidden rounded-2xl bg-[var(--glass-strong)] p-2 backdrop-blur-[var(--glass-blur)]\",\n RAIL_BY_MODE[mode],\n className,\n )}\n {...props}\n />\n </NavRailContext.Provider>\n );\n}\n\n/** A thin divider between groups of rail items. */\nfunction NavRailSeparator({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"nav-rail-separator\"\n role=\"separator\"\n className={cn(\"my-1 h-px w-6 shrink-0 self-center bg-border\", className)}\n {...props}\n />\n );\n}\n\ntype NavRailItemProps = Omit<React.ComponentProps<\"button\">, \"aria-label\"> & {\n /** Tooltip text (icon mode) + accessible name + inline label (text/expanded). */\n label: string;\n /** Marks the item as the current page (active styling + `aria-current=\"page\"`). */\n active?: boolean;\n /** Render the child element instead of a <button> (e.g. a router link). */\n asChild?: boolean;\n /** Which side the tooltip opens on in icon mode. */\n tooltipSide?: \"top\" | \"right\" | \"bottom\" | \"left\";\n};\n\n/** A single navigation entry; an icon (as children) plus a `label`, with a tooltip in icon mode. */\nfunction NavRailItem({\n label,\n active,\n asChild = false,\n tooltipSide = \"right\",\n className,\n children,\n ...props\n}: NavRailItemProps) {\n const mode = React.useContext(NavRailContext);\n const shared = {\n \"data-slot\": \"nav-rail-item\",\n \"data-active\": active || undefined,\n \"aria-label\": label,\n \"aria-current\": active ? (\"page\" as const) : undefined,\n className: cn(ITEM_BASE, ITEM_BY_MODE[mode], className),\n ...props,\n };\n const labelEl = (\n <span data-slot=\"nav-rail-item-label\" className={LABEL_BY_MODE[mode]}>\n {label}\n </span>\n );\n\n const el = asChild ? (\n <Slot.Root {...shared}>\n <Slot.Slottable>{children}</Slot.Slottable>\n {labelEl}\n </Slot.Root>\n ) : (\n <button type=\"button\" {...shared}>\n <span data-slot=\"nav-rail-item-icon\" className={ICON_BY_MODE[mode]}>\n {children}\n </span>\n {labelEl}\n </button>\n );\n\n if (mode !== \"icon\") return el;\n return (\n <Tooltip>\n <TooltipTrigger asChild>{el}</TooltipTrigger>\n <TooltipContent side={tooltipSide}>{label}</TooltipContent>\n </Tooltip>\n );\n}\n\n// ── User footer ─────────────────────────────────────────────────────────────\n\ntype NavRailUserProps = React.ComponentProps<\"div\"> & {\n /** The avatar element (e.g. an <Avatar />). */\n avatar: React.ReactNode;\n /** The user's display name (hidden in icon mode). */\n name: React.ReactNode;\n /** The user's secondary line, e.g. email (hidden in icon mode). */\n email: React.ReactNode;\n};\n\n/** The footer slot of the rail showing the signed-in user (avatar + name + email). */\nfunction NavRailUser({ avatar, name, email, className, ...props }: NavRailUserProps) {\n const mode = React.useContext(NavRailContext);\n const detailsHidden = mode === \"icon\";\n return (\n <div\n data-slot=\"nav-rail-user\"\n className={cn(\"mt-auto flex h-12 w-full items-center rounded-lg\", className)}\n {...props}\n >\n {/* Fixed w-10 slot centers any avatar on the same axis as the icon column,\n so it never shifts between modes regardless of avatar size. */}\n <span\n data-slot=\"nav-rail-user-avatar\"\n className=\"flex w-10 shrink-0 items-center justify-center\"\n >\n {avatar}\n </span>\n <div\n data-slot=\"nav-rail-user-details\"\n className={cn(\n \"flex min-w-0 flex-1 flex-col justify-center text-left leading-tight\",\n detailsHidden && \"sr-only\",\n mode === \"expand-on-hover\" &&\n \"opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100\",\n )}\n >\n <span className=\"truncate text-sm font-medium\">{name}</span>\n <span className=\"truncate text-xs text-muted-foreground\">{email}</span>\n </div>\n </div>\n );\n}\n\n// ── Flyout submenu ──────────────────────────────────────────────────────────\n\n/** Root for a rail item that opens a flyout submenu (wraps Popover). */\nfunction NavRailMenu(props: React.ComponentProps<typeof Popover>) {\n return <Popover {...props} />;\n}\n\ntype NavRailMenuTriggerProps = Omit<React.ComponentProps<\"button\">, \"aria-label\"> & {\n /** Tooltip/accessible name + inline label for the trigger item. */\n label: string;\n /** Marks the trigger as active (current section) styling. */\n active?: boolean;\n};\n\n/** The rail item that opens its flyout submenu; renders a chevron affordance. */\nfunction NavRailMenuTrigger({\n label,\n active,\n className,\n children,\n ...props\n}: NavRailMenuTriggerProps) {\n const mode = React.useContext(NavRailContext);\n return (\n <PopoverTrigger asChild>\n <button\n type=\"button\"\n data-slot=\"nav-rail-menu-trigger\"\n data-active={active || undefined}\n aria-label={label}\n className={cn(ITEM_BASE, ITEM_BY_MODE[mode], className)}\n {...props}\n >\n <span data-slot=\"nav-rail-item-icon\" className={ICON_BY_MODE[mode]}>\n {children}\n </span>\n <span data-slot=\"nav-rail-item-label\" className={LABEL_BY_MODE[mode]}>\n {label}\n </span>\n <ChevronRightIcon aria-hidden className={CHEVRON_BY_MODE[mode]} />\n </button>\n </PopoverTrigger>\n );\n}\n\n/** The glass flyout panel that holds the submenu items (portalled Popover content). */\nfunction NavRailMenuContent({\n className,\n side = \"right\",\n align = \"start\",\n sideOffset = 8,\n ...props\n}: React.ComponentProps<typeof PopoverContent>) {\n return (\n <PopoverContent\n data-slot=\"nav-rail-menu-content\"\n side={side}\n align={align}\n sideOffset={sideOffset}\n // Glass flyout (matches the prototype sub-nav): translucent + blurred,\n // 16px radius, hairline border, soft shadow. Tokens, not prototype code.\n className={cn(\n \"flex w-[180px] flex-col gap-0.5 rounded-2xl border border-border bg-[var(--glass-subtle)] p-1.5 text-foreground shadow-sm backdrop-blur-[var(--glass-blur)]\",\n className,\n )}\n {...props}\n />\n );\n}\n\ntype NavRailMenuItemProps = React.ComponentProps<\"button\"> & {\n /** Marks the entry as the current page (active styling + `aria-current=\"page\"`). */\n active?: boolean;\n /** Render the child element instead of a <button> (e.g. a router link). */\n asChild?: boolean;\n};\n\n/** A single entry inside a NavRail flyout submenu. */\nfunction NavRailMenuItem({ className, active, asChild = false, ...props }: NavRailMenuItemProps) {\n const Comp = asChild ? Slot.Root : \"button\";\n return (\n <Comp\n data-slot=\"nav-rail-menu-item\"\n data-active={active || undefined}\n aria-current={active ? \"page\" : undefined}\n className={cn(\n \"flex w-full cursor-pointer items-center gap-2.5 rounded-lg px-3 py-2 text-left text-sm text-foreground outline-none transition-colors\",\n \"hover:bg-foreground/10 focus-visible:bg-foreground/10\",\n \"data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)]\",\n \"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className,\n )}\n {...(asChild ? {} : { type: \"button\" as const })}\n {...props}\n />\n );\n}\n\nexport {\n NavRail,\n NavRailItem,\n NavRailUser,\n NavRailSeparator,\n NavRailMenu,\n NavRailMenuTrigger,\n NavRailMenuContent,\n NavRailMenuItem,\n type NavRailMode,\n type NavRailItemProps,\n type NavRailUserProps,\n type NavRailMenuTriggerProps,\n type NavRailMenuItemProps,\n};\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { a as NavRailMenuContent, c as NavRailMenuTrigger, d as NavRailSeparator, f as NavRailUser, i as NavRailMenu, l as NavRailMenuTriggerProps, n as NavRailItem, o as NavRailMenuItem, p as NavRailUserProps, r as NavRailItemProps, s as NavRailMenuItemProps, t as NavRail, u as NavRailMode } from "../../index43.cjs";
2
+ export { NavRail, NavRailItem, NavRailItemProps, NavRailMenu, NavRailMenuContent, NavRailMenuItem, NavRailMenuItemProps, NavRailMenuTrigger, NavRailMenuTriggerProps, NavRailMode, NavRailSeparator, NavRailUser, NavRailUserProps };
@@ -0,0 +1,2 @@
1
+ import { a as NavRailMenuContent, c as NavRailMenuTrigger, d as NavRailSeparator, f as NavRailUser, i as NavRailMenu, l as NavRailMenuTriggerProps, n as NavRailItem, o as NavRailMenuItem, p as NavRailUserProps, r as NavRailItemProps, s as NavRailMenuItemProps, t as NavRail, u as NavRailMode } from "../../index43.js";
2
+ export { NavRail, NavRailItem, NavRailItemProps, NavRailMenu, NavRailMenuContent, NavRailMenuItem, NavRailMenuItemProps, NavRailMenuTrigger, NavRailMenuTriggerProps, NavRailMode, NavRailSeparator, NavRailUser, NavRailUserProps };
@@ -0,0 +1,185 @@
1
+ import { t as cn } from "../../cn.js";
2
+ import { Popover as Popover$1, PopoverContent, PopoverTrigger } from "../Popover/index.js";
3
+ import { Tooltip as Tooltip$1, TooltipContent, TooltipTrigger } from "../Tooltip/index.js";
4
+ import * as React from "react";
5
+ import { ChevronRightIcon } from "lucide-react";
6
+ import { Slot } from "radix-ui";
7
+ import { jsx, jsxs } from "react/jsx-runtime";
8
+ //#region src/primitives/NavRail/NavRail.tsx
9
+ const NavRailContext = React.createContext("icon");
10
+ const RAIL_BY_MODE = {
11
+ icon: "w-14 items-center",
12
+ text: "w-56 items-stretch",
13
+ expanded: "w-56 items-stretch",
14
+ "expand-on-hover": "w-14 items-stretch transition-[width] duration-200 ease-out hover:w-56"
15
+ };
16
+ const ITEM_BASE = "relative flex h-10 cursor-pointer items-center text-foreground outline-none transition-colors hover:bg-foreground/10 focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)] [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-5";
17
+ const ITEM_BY_MODE = {
18
+ icon: "w-10 justify-center rounded-full",
19
+ text: "w-full justify-start gap-3 rounded-lg px-2.5",
20
+ expanded: "w-full justify-start gap-3 rounded-lg px-2.5",
21
+ "expand-on-hover": "w-full justify-start gap-3 rounded-lg px-2.5"
22
+ };
23
+ const ICON_BY_MODE = {
24
+ icon: "flex shrink-0 items-center justify-center",
25
+ text: "hidden",
26
+ expanded: "flex shrink-0 items-center justify-center",
27
+ "expand-on-hover": "flex shrink-0 items-center justify-center"
28
+ };
29
+ const LABEL_ROW = "min-w-0 flex-1 truncate text-left text-sm font-medium";
30
+ const LABEL_BY_MODE = {
31
+ icon: "sr-only",
32
+ text: LABEL_ROW,
33
+ expanded: LABEL_ROW,
34
+ "expand-on-hover": cn(LABEL_ROW, "opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100")
35
+ };
36
+ const CHEVRON_BY_MODE = {
37
+ icon: "absolute top-1/2 right-[-4px] size-3 -translate-y-1/2 text-muted-foreground",
38
+ text: "ml-auto size-4 shrink-0 text-muted-foreground",
39
+ expanded: "ml-auto size-4 shrink-0 text-muted-foreground",
40
+ "expand-on-hover": "ml-auto size-4 shrink-0 text-muted-foreground opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100"
41
+ };
42
+ /** The vertical navigation rail container; sets the display `mode` for all items via context. */
43
+ function NavRail({ mode = "icon", className, ...props }) {
44
+ return /* @__PURE__ */ jsx(NavRailContext.Provider, {
45
+ value: mode,
46
+ children: /* @__PURE__ */ jsx("nav", {
47
+ "data-slot": "nav-rail",
48
+ "data-mode": mode,
49
+ className: cn("group/nav-rail flex flex-col gap-1 overflow-hidden rounded-2xl bg-[var(--glass-strong)] p-2 backdrop-blur-[var(--glass-blur)]", RAIL_BY_MODE[mode], className),
50
+ ...props
51
+ })
52
+ });
53
+ }
54
+ /** A thin divider between groups of rail items. */
55
+ function NavRailSeparator({ className, ...props }) {
56
+ return /* @__PURE__ */ jsx("div", {
57
+ "data-slot": "nav-rail-separator",
58
+ role: "separator",
59
+ className: cn("my-1 h-px w-6 shrink-0 self-center bg-border", className),
60
+ ...props
61
+ });
62
+ }
63
+ /** A single navigation entry; an icon (as children) plus a `label`, with a tooltip in icon mode. */
64
+ function NavRailItem({ label, active, asChild = false, tooltipSide = "right", className, children, ...props }) {
65
+ const mode = React.useContext(NavRailContext);
66
+ const shared = {
67
+ "data-slot": "nav-rail-item",
68
+ "data-active": active || void 0,
69
+ "aria-label": label,
70
+ "aria-current": active ? "page" : void 0,
71
+ className: cn(ITEM_BASE, ITEM_BY_MODE[mode], className),
72
+ ...props
73
+ };
74
+ const labelEl = /* @__PURE__ */ jsx("span", {
75
+ "data-slot": "nav-rail-item-label",
76
+ className: LABEL_BY_MODE[mode],
77
+ children: label
78
+ });
79
+ const el = asChild ? /* @__PURE__ */ jsxs(Slot.Root, {
80
+ ...shared,
81
+ children: [/* @__PURE__ */ jsx(Slot.Slottable, { children }), labelEl]
82
+ }) : /* @__PURE__ */ jsxs("button", {
83
+ type: "button",
84
+ ...shared,
85
+ children: [/* @__PURE__ */ jsx("span", {
86
+ "data-slot": "nav-rail-item-icon",
87
+ className: ICON_BY_MODE[mode],
88
+ children
89
+ }), labelEl]
90
+ });
91
+ if (mode !== "icon") return el;
92
+ return /* @__PURE__ */ jsxs(Tooltip$1, { children: [/* @__PURE__ */ jsx(TooltipTrigger, {
93
+ asChild: true,
94
+ children: el
95
+ }), /* @__PURE__ */ jsx(TooltipContent, {
96
+ side: tooltipSide,
97
+ children: label
98
+ })] });
99
+ }
100
+ /** The footer slot of the rail showing the signed-in user (avatar + name + email). */
101
+ function NavRailUser({ avatar, name, email, className, ...props }) {
102
+ const mode = React.useContext(NavRailContext);
103
+ const detailsHidden = mode === "icon";
104
+ return /* @__PURE__ */ jsxs("div", {
105
+ "data-slot": "nav-rail-user",
106
+ className: cn("mt-auto flex h-12 w-full items-center rounded-lg", className),
107
+ ...props,
108
+ children: [/* @__PURE__ */ jsx("span", {
109
+ "data-slot": "nav-rail-user-avatar",
110
+ className: "flex w-10 shrink-0 items-center justify-center",
111
+ children: avatar
112
+ }), /* @__PURE__ */ jsxs("div", {
113
+ "data-slot": "nav-rail-user-details",
114
+ className: cn("flex min-w-0 flex-1 flex-col justify-center text-left leading-tight", detailsHidden && "sr-only", mode === "expand-on-hover" && "opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100"),
115
+ children: [/* @__PURE__ */ jsx("span", {
116
+ className: "truncate text-sm font-medium",
117
+ children: name
118
+ }), /* @__PURE__ */ jsx("span", {
119
+ className: "truncate text-xs text-muted-foreground",
120
+ children: email
121
+ })]
122
+ })]
123
+ });
124
+ }
125
+ /** Root for a rail item that opens a flyout submenu (wraps Popover). */
126
+ function NavRailMenu(props) {
127
+ return /* @__PURE__ */ jsx(Popover$1, { ...props });
128
+ }
129
+ /** The rail item that opens its flyout submenu; renders a chevron affordance. */
130
+ function NavRailMenuTrigger({ label, active, className, children, ...props }) {
131
+ const mode = React.useContext(NavRailContext);
132
+ return /* @__PURE__ */ jsx(PopoverTrigger, {
133
+ asChild: true,
134
+ children: /* @__PURE__ */ jsxs("button", {
135
+ type: "button",
136
+ "data-slot": "nav-rail-menu-trigger",
137
+ "data-active": active || void 0,
138
+ "aria-label": label,
139
+ className: cn(ITEM_BASE, ITEM_BY_MODE[mode], className),
140
+ ...props,
141
+ children: [
142
+ /* @__PURE__ */ jsx("span", {
143
+ "data-slot": "nav-rail-item-icon",
144
+ className: ICON_BY_MODE[mode],
145
+ children
146
+ }),
147
+ /* @__PURE__ */ jsx("span", {
148
+ "data-slot": "nav-rail-item-label",
149
+ className: LABEL_BY_MODE[mode],
150
+ children: label
151
+ }),
152
+ /* @__PURE__ */ jsx(ChevronRightIcon, {
153
+ "aria-hidden": true,
154
+ className: CHEVRON_BY_MODE[mode]
155
+ })
156
+ ]
157
+ })
158
+ });
159
+ }
160
+ /** The glass flyout panel that holds the submenu items (portalled Popover content). */
161
+ function NavRailMenuContent({ className, side = "right", align = "start", sideOffset = 8, ...props }) {
162
+ return /* @__PURE__ */ jsx(PopoverContent, {
163
+ "data-slot": "nav-rail-menu-content",
164
+ side,
165
+ align,
166
+ sideOffset,
167
+ className: cn("flex w-[180px] flex-col gap-0.5 rounded-2xl border border-border bg-[var(--glass-subtle)] p-1.5 text-foreground shadow-sm backdrop-blur-[var(--glass-blur)]", className),
168
+ ...props
169
+ });
170
+ }
171
+ /** A single entry inside a NavRail flyout submenu. */
172
+ function NavRailMenuItem({ className, active, asChild = false, ...props }) {
173
+ return /* @__PURE__ */ jsx(asChild ? Slot.Root : "button", {
174
+ "data-slot": "nav-rail-menu-item",
175
+ "data-active": active || void 0,
176
+ "aria-current": active ? "page" : void 0,
177
+ className: cn("flex w-full cursor-pointer items-center gap-2.5 rounded-lg px-3 py-2 text-left text-sm text-foreground outline-none transition-colors", "hover:bg-foreground/10 focus-visible:bg-foreground/10", "data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)]", "[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4", className),
178
+ ...asChild ? {} : { type: "button" },
179
+ ...props
180
+ });
181
+ }
182
+ //#endregion
183
+ export { NavRail, NavRailItem, NavRailMenu, NavRailMenuContent, NavRailMenuItem, NavRailMenuTrigger, NavRailSeparator, NavRailUser };
184
+
185
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["Tooltip","Popover"],"sources":["../../../src/primitives/NavRail/NavRail.tsx"],"sourcesContent":["import { ChevronRightIcon } from \"lucide-react\";\nimport { Slot } from \"radix-ui\";\nimport * as React from \"react\";\n\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/primitives/Popover\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"@/primitives/Tooltip\";\nimport { cn } from \"@/utils\";\n\n// NavRail — a vertical navigation rail (the app's side nav). Four display modes:\n// icon-only (tooltips), text-only, expanded (icon + text), and expand-on-hover\n// (icon-only that widens to reveal labels on hover). Items can open a flyout\n// submenu (NavRailMenu) and the rail can show a user footer (NavRailUser).\n//\n// All items share a constant height (h-10) with the icon pinned to the left, so\n// expanding the rail just REVEALS the labels to the right — the icon never moves\n// and the row height never changes.\n//\n// LAYOUT NOTE: `expand-on-hover` changes the rail's width. To make the content\n// give up space as the rail expands (rather than overlap it), put the rail in a\n// flex row as a `shrink-0` child (it keeps its own w-14/w-56 width) next to a\n// `flex-1 min-w-0` content column — the column shrinks as the rail widens.\n\ntype NavRailMode = \"icon\" | \"text\" | \"expanded\" | \"expand-on-hover\";\n\nconst NavRailContext = React.createContext<NavRailMode>(\"icon\");\n\nconst RAIL_BY_MODE: Record<NavRailMode, string> = {\n icon: \"w-14 items-center\",\n text: \"w-56 items-stretch\",\n expanded: \"w-56 items-stretch\",\n \"expand-on-hover\": \"w-14 items-stretch transition-[width] duration-200 ease-out hover:w-56\",\n};\n\nconst ITEM_BASE =\n \"relative flex h-10 cursor-pointer items-center text-foreground outline-none transition-colors hover:bg-foreground/10 focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)] [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-5\";\n\nconst ITEM_BY_MODE: Record<NavRailMode, string> = {\n icon: \"w-10 justify-center rounded-full\",\n text: \"w-full justify-start gap-3 rounded-lg px-2.5\",\n expanded: \"w-full justify-start gap-3 rounded-lg px-2.5\",\n \"expand-on-hover\": \"w-full justify-start gap-3 rounded-lg px-2.5\",\n};\n\nconst ICON_BY_MODE: Record<NavRailMode, string> = {\n icon: \"flex shrink-0 items-center justify-center\",\n text: \"hidden\", // text-only mode hides the icon\n expanded: \"flex shrink-0 items-center justify-center\",\n \"expand-on-hover\": \"flex shrink-0 items-center justify-center\",\n};\n\nconst LABEL_ROW = \"min-w-0 flex-1 truncate text-left text-sm font-medium\";\nconst LABEL_BY_MODE: Record<NavRailMode, string> = {\n icon: \"sr-only\",\n text: LABEL_ROW,\n expanded: LABEL_ROW,\n // Always laid out (so the icon never reflows); revealed via opacity on hover.\n \"expand-on-hover\": cn(\n LABEL_ROW,\n \"opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100\",\n ),\n};\n\nconst CHEVRON_BY_MODE: Record<NavRailMode, string> = {\n // Vertically centered, overhanging the right edge (clear of the centered icon).\n icon: \"absolute top-1/2 right-[-4px] size-3 -translate-y-1/2 text-muted-foreground\",\n text: \"ml-auto size-4 shrink-0 text-muted-foreground\",\n expanded: \"ml-auto size-4 shrink-0 text-muted-foreground\",\n \"expand-on-hover\":\n \"ml-auto size-4 shrink-0 text-muted-foreground opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100\",\n};\n\n/** The vertical navigation rail container; sets the display `mode` for all items via context. */\nfunction NavRail({\n mode = \"icon\",\n className,\n ...props\n}: React.ComponentProps<\"nav\"> & {\n /** Display mode for the rail and its items: icon-only (tooltips), text-only, expanded (icon + text), or expand-on-hover. */\n mode?: NavRailMode;\n}) {\n return (\n <NavRailContext.Provider value={mode}>\n <nav\n data-slot=\"nav-rail\"\n data-mode={mode}\n className={cn(\n \"group/nav-rail flex flex-col gap-1 overflow-hidden rounded-2xl bg-[var(--glass-strong)] p-2 backdrop-blur-[var(--glass-blur)]\",\n RAIL_BY_MODE[mode],\n className,\n )}\n {...props}\n />\n </NavRailContext.Provider>\n );\n}\n\n/** A thin divider between groups of rail items. */\nfunction NavRailSeparator({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"nav-rail-separator\"\n role=\"separator\"\n className={cn(\"my-1 h-px w-6 shrink-0 self-center bg-border\", className)}\n {...props}\n />\n );\n}\n\ntype NavRailItemProps = Omit<React.ComponentProps<\"button\">, \"aria-label\"> & {\n /** Tooltip text (icon mode) + accessible name + inline label (text/expanded). */\n label: string;\n /** Marks the item as the current page (active styling + `aria-current=\"page\"`). */\n active?: boolean;\n /** Render the child element instead of a <button> (e.g. a router link). */\n asChild?: boolean;\n /** Which side the tooltip opens on in icon mode. */\n tooltipSide?: \"top\" | \"right\" | \"bottom\" | \"left\";\n};\n\n/** A single navigation entry; an icon (as children) plus a `label`, with a tooltip in icon mode. */\nfunction NavRailItem({\n label,\n active,\n asChild = false,\n tooltipSide = \"right\",\n className,\n children,\n ...props\n}: NavRailItemProps) {\n const mode = React.useContext(NavRailContext);\n const shared = {\n \"data-slot\": \"nav-rail-item\",\n \"data-active\": active || undefined,\n \"aria-label\": label,\n \"aria-current\": active ? (\"page\" as const) : undefined,\n className: cn(ITEM_BASE, ITEM_BY_MODE[mode], className),\n ...props,\n };\n const labelEl = (\n <span data-slot=\"nav-rail-item-label\" className={LABEL_BY_MODE[mode]}>\n {label}\n </span>\n );\n\n const el = asChild ? (\n <Slot.Root {...shared}>\n <Slot.Slottable>{children}</Slot.Slottable>\n {labelEl}\n </Slot.Root>\n ) : (\n <button type=\"button\" {...shared}>\n <span data-slot=\"nav-rail-item-icon\" className={ICON_BY_MODE[mode]}>\n {children}\n </span>\n {labelEl}\n </button>\n );\n\n if (mode !== \"icon\") return el;\n return (\n <Tooltip>\n <TooltipTrigger asChild>{el}</TooltipTrigger>\n <TooltipContent side={tooltipSide}>{label}</TooltipContent>\n </Tooltip>\n );\n}\n\n// ── User footer ─────────────────────────────────────────────────────────────\n\ntype NavRailUserProps = React.ComponentProps<\"div\"> & {\n /** The avatar element (e.g. an <Avatar />). */\n avatar: React.ReactNode;\n /** The user's display name (hidden in icon mode). */\n name: React.ReactNode;\n /** The user's secondary line, e.g. email (hidden in icon mode). */\n email: React.ReactNode;\n};\n\n/** The footer slot of the rail showing the signed-in user (avatar + name + email). */\nfunction NavRailUser({ avatar, name, email, className, ...props }: NavRailUserProps) {\n const mode = React.useContext(NavRailContext);\n const detailsHidden = mode === \"icon\";\n return (\n <div\n data-slot=\"nav-rail-user\"\n className={cn(\"mt-auto flex h-12 w-full items-center rounded-lg\", className)}\n {...props}\n >\n {/* Fixed w-10 slot centers any avatar on the same axis as the icon column,\n so it never shifts between modes regardless of avatar size. */}\n <span\n data-slot=\"nav-rail-user-avatar\"\n className=\"flex w-10 shrink-0 items-center justify-center\"\n >\n {avatar}\n </span>\n <div\n data-slot=\"nav-rail-user-details\"\n className={cn(\n \"flex min-w-0 flex-1 flex-col justify-center text-left leading-tight\",\n detailsHidden && \"sr-only\",\n mode === \"expand-on-hover\" &&\n \"opacity-0 transition-opacity duration-200 group-hover/nav-rail:opacity-100\",\n )}\n >\n <span className=\"truncate text-sm font-medium\">{name}</span>\n <span className=\"truncate text-xs text-muted-foreground\">{email}</span>\n </div>\n </div>\n );\n}\n\n// ── Flyout submenu ──────────────────────────────────────────────────────────\n\n/** Root for a rail item that opens a flyout submenu (wraps Popover). */\nfunction NavRailMenu(props: React.ComponentProps<typeof Popover>) {\n return <Popover {...props} />;\n}\n\ntype NavRailMenuTriggerProps = Omit<React.ComponentProps<\"button\">, \"aria-label\"> & {\n /** Tooltip/accessible name + inline label for the trigger item. */\n label: string;\n /** Marks the trigger as active (current section) styling. */\n active?: boolean;\n};\n\n/** The rail item that opens its flyout submenu; renders a chevron affordance. */\nfunction NavRailMenuTrigger({\n label,\n active,\n className,\n children,\n ...props\n}: NavRailMenuTriggerProps) {\n const mode = React.useContext(NavRailContext);\n return (\n <PopoverTrigger asChild>\n <button\n type=\"button\"\n data-slot=\"nav-rail-menu-trigger\"\n data-active={active || undefined}\n aria-label={label}\n className={cn(ITEM_BASE, ITEM_BY_MODE[mode], className)}\n {...props}\n >\n <span data-slot=\"nav-rail-item-icon\" className={ICON_BY_MODE[mode]}>\n {children}\n </span>\n <span data-slot=\"nav-rail-item-label\" className={LABEL_BY_MODE[mode]}>\n {label}\n </span>\n <ChevronRightIcon aria-hidden className={CHEVRON_BY_MODE[mode]} />\n </button>\n </PopoverTrigger>\n );\n}\n\n/** The glass flyout panel that holds the submenu items (portalled Popover content). */\nfunction NavRailMenuContent({\n className,\n side = \"right\",\n align = \"start\",\n sideOffset = 8,\n ...props\n}: React.ComponentProps<typeof PopoverContent>) {\n return (\n <PopoverContent\n data-slot=\"nav-rail-menu-content\"\n side={side}\n align={align}\n sideOffset={sideOffset}\n // Glass flyout (matches the prototype sub-nav): translucent + blurred,\n // 16px radius, hairline border, soft shadow. Tokens, not prototype code.\n className={cn(\n \"flex w-[180px] flex-col gap-0.5 rounded-2xl border border-border bg-[var(--glass-subtle)] p-1.5 text-foreground shadow-sm backdrop-blur-[var(--glass-blur)]\",\n className,\n )}\n {...props}\n />\n );\n}\n\ntype NavRailMenuItemProps = React.ComponentProps<\"button\"> & {\n /** Marks the entry as the current page (active styling + `aria-current=\"page\"`). */\n active?: boolean;\n /** Render the child element instead of a <button> (e.g. a router link). */\n asChild?: boolean;\n};\n\n/** A single entry inside a NavRail flyout submenu. */\nfunction NavRailMenuItem({ className, active, asChild = false, ...props }: NavRailMenuItemProps) {\n const Comp = asChild ? Slot.Root : \"button\";\n return (\n <Comp\n data-slot=\"nav-rail-menu-item\"\n data-active={active || undefined}\n aria-current={active ? \"page\" : undefined}\n className={cn(\n \"flex w-full cursor-pointer items-center gap-2.5 rounded-lg px-3 py-2 text-left text-sm text-foreground outline-none transition-colors\",\n \"hover:bg-foreground/10 focus-visible:bg-foreground/10\",\n \"data-[active=true]:bg-[var(--white)] data-[active=true]:font-medium data-[active=true]:text-[var(--brand-colors-brand-500)] data-[active=true]:hover:bg-[var(--white)]\",\n \"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className,\n )}\n {...(asChild ? {} : { type: \"button\" as const })}\n {...props}\n />\n );\n}\n\nexport {\n NavRail,\n NavRailItem,\n NavRailUser,\n NavRailSeparator,\n NavRailMenu,\n NavRailMenuTrigger,\n NavRailMenuContent,\n NavRailMenuItem,\n type NavRailMode,\n type NavRailItemProps,\n type NavRailUserProps,\n type NavRailMenuTriggerProps,\n type NavRailMenuItemProps,\n};\n"],"mappings":"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"}
@@ -0,0 +1,98 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ const require_cn = require("../../cn.cjs");
3
+ let lucide_react = require("lucide-react");
4
+ let radix_ui = require("radix-ui");
5
+ let react_jsx_runtime = require("react/jsx-runtime");
6
+ let class_variance_authority = require("class-variance-authority");
7
+ //#region src/primitives/NavigationMenu/NavigationMenu.tsx
8
+ /** Root of a horizontal navigation bar; renders a `<nav>` and optionally an animated viewport. */
9
+ function NavigationMenu({ className, children, viewport = true, ...props }) {
10
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(radix_ui.NavigationMenu.Root, {
11
+ "data-slot": "navigation-menu",
12
+ "data-viewport": viewport,
13
+ className: require_cn.cn("group/navigation-menu relative flex max-w-max flex-1 items-center justify-center", className),
14
+ ...props,
15
+ children: [children, viewport && /* @__PURE__ */ (0, react_jsx_runtime.jsx)(NavigationMenuViewport, {})]
16
+ });
17
+ }
18
+ /** Horizontal list wrapper for the top-level navigation items. */
19
+ function NavigationMenuList({ className, ...props }) {
20
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.NavigationMenu.List, {
21
+ "data-slot": "navigation-menu-list",
22
+ className: require_cn.cn("group flex flex-1 list-none items-center justify-center gap-1", className),
23
+ ...props
24
+ });
25
+ }
26
+ /** A single top-level entry; holds either a link or a trigger plus its content. */
27
+ function NavigationMenuItem({ className, ...props }) {
28
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.NavigationMenu.Item, {
29
+ "data-slot": "navigation-menu-item",
30
+ className: require_cn.cn("relative", className),
31
+ ...props
32
+ });
33
+ }
34
+ const navigationMenuTriggerStyle = (0, class_variance_authority.cva)("group inline-flex h-9 w-max items-center justify-center rounded-md bg-background px-4 py-2 text-sm font-medium transition-[color,box-shadow] outline-none hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=open]:bg-accent/50 data-[state=open]:text-accent-foreground data-[state=open]:hover:bg-accent data-[state=open]:focus:bg-accent");
35
+ /** Button that toggles an item's content panel; renders a rotating chevron. */
36
+ function NavigationMenuTrigger({ className, children, ...props }) {
37
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(radix_ui.NavigationMenu.Trigger, {
38
+ "data-slot": "navigation-menu-trigger",
39
+ className: require_cn.cn(navigationMenuTriggerStyle(), "group", className),
40
+ ...props,
41
+ children: [
42
+ children,
43
+ " ",
44
+ /* @__PURE__ */ (0, react_jsx_runtime.jsx)(lucide_react.ChevronDownIcon, {
45
+ className: "relative top-[1px] ml-1 size-3 transition duration-300 group-data-[state=open]:rotate-180",
46
+ "aria-hidden": "true"
47
+ })
48
+ ]
49
+ });
50
+ }
51
+ /** The panel revealed when an item's trigger is open; holds links or rich content. */
52
+ function NavigationMenuContent({ className, ...props }) {
53
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.NavigationMenu.Content, {
54
+ "data-slot": "navigation-menu-content",
55
+ className: require_cn.cn("top-0 left-0 w-full p-2 pr-2.5 data-[motion=from-end]:slide-in-from-right-52 data-[motion=from-start]:slide-in-from-left-52 data-[motion=to-end]:slide-out-to-right-52 data-[motion=to-start]:slide-out-to-left-52 data-[motion^=from-]:animate-in data-[motion^=from-]:fade-in data-[motion^=to-]:animate-out data-[motion^=to-]:fade-out md:absolute md:w-auto", "group-data-[viewport=false]/navigation-menu:top-full group-data-[viewport=false]/navigation-menu:mt-1.5 group-data-[viewport=false]/navigation-menu:overflow-hidden group-data-[viewport=false]/navigation-menu:rounded-md group-data-[viewport=false]/navigation-menu:border group-data-[viewport=false]/navigation-menu:bg-popover group-data-[viewport=false]/navigation-menu:text-popover-foreground group-data-[viewport=false]/navigation-menu:shadow group-data-[viewport=false]/navigation-menu:duration-200 **:data-[slot=navigation-menu-link]:focus:ring-0 **:data-[slot=navigation-menu-link]:focus:outline-none group-data-[viewport=false]/navigation-menu:data-[state=closed]:animate-out group-data-[viewport=false]/navigation-menu:data-[state=closed]:fade-out-0 group-data-[viewport=false]/navigation-menu:data-[state=closed]:zoom-out-95 group-data-[viewport=false]/navigation-menu:data-[state=open]:animate-in group-data-[viewport=false]/navigation-menu:data-[state=open]:fade-in-0 group-data-[viewport=false]/navigation-menu:data-[state=open]:zoom-in-95", className),
56
+ ...props
57
+ });
58
+ }
59
+ /** Shared animated container that the active item's content is portaled into when `viewport` is enabled. */
60
+ function NavigationMenuViewport({ className, ...props }) {
61
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
62
+ className: require_cn.cn("absolute top-full left-0 isolate z-50 flex justify-center"),
63
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.NavigationMenu.Viewport, {
64
+ "data-slot": "navigation-menu-viewport",
65
+ className: require_cn.cn("origin-top-center relative mt-1.5 h-[var(--radix-navigation-menu-viewport-height)] w-full overflow-hidden rounded-md border bg-popover text-popover-foreground shadow data-[state=closed]:animate-out data-[state=closed]:zoom-out-95 data-[state=open]:animate-in data-[state=open]:zoom-in-90 md:w-[var(--radix-navigation-menu-viewport-width)]", className),
66
+ ...props
67
+ })
68
+ });
69
+ }
70
+ /** A navigable link styled for use as a top-level item or inside content; set `active` to mark the current page. */
71
+ function NavigationMenuLink({ className, ...props }) {
72
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.NavigationMenu.Link, {
73
+ "data-slot": "navigation-menu-link",
74
+ className: require_cn.cn("flex flex-col gap-1 rounded-sm p-2 text-sm transition-all outline-none hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 data-[active=true]:bg-accent/50 data-[active=true]:text-accent-foreground data-[active=true]:hover:bg-accent data-[active=true]:focus:bg-accent [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground", className),
75
+ ...props
76
+ });
77
+ }
78
+ /** Optional arrow that points from the active trigger to its content panel. */
79
+ function NavigationMenuIndicator({ className, ...props }) {
80
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(radix_ui.NavigationMenu.Indicator, {
81
+ "data-slot": "navigation-menu-indicator",
82
+ className: require_cn.cn("top-full z-[1] flex h-1.5 items-end justify-center overflow-hidden data-[state=hidden]:animate-out data-[state=hidden]:fade-out data-[state=visible]:animate-in data-[state=visible]:fade-in", className),
83
+ ...props,
84
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", { className: "relative top-[60%] h-2 w-2 rotate-45 rounded-tl-sm bg-border shadow-md" })
85
+ });
86
+ }
87
+ //#endregion
88
+ exports.NavigationMenu = NavigationMenu;
89
+ exports.NavigationMenuContent = NavigationMenuContent;
90
+ exports.NavigationMenuIndicator = NavigationMenuIndicator;
91
+ exports.NavigationMenuItem = NavigationMenuItem;
92
+ exports.NavigationMenuLink = NavigationMenuLink;
93
+ exports.NavigationMenuList = NavigationMenuList;
94
+ exports.NavigationMenuTrigger = NavigationMenuTrigger;
95
+ exports.NavigationMenuViewport = NavigationMenuViewport;
96
+ exports.navigationMenuTriggerStyle = navigationMenuTriggerStyle;
97
+
98
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","names":["NavigationMenuPrimitive","cn","ChevronDownIcon"],"sources":["../../../src/primitives/NavigationMenu/NavigationMenu.tsx"],"sourcesContent":["import { cva } from \"class-variance-authority\";\nimport { ChevronDownIcon } from \"lucide-react\";\nimport { NavigationMenu as NavigationMenuPrimitive } from \"radix-ui\";\nimport type * as React from \"react\";\n\nimport { cn } from \"@/utils\";\n\n/** Root of a horizontal navigation bar; renders a `<nav>` and optionally an animated viewport. */\nfunction NavigationMenu({\n className,\n children,\n viewport = true,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Root> & {\n /** When true (default), renders a shared animated viewport that hosts the active item's content. Set false to render content inline beneath each item. */\n viewport?: boolean;\n}) {\n return (\n <NavigationMenuPrimitive.Root\n data-slot=\"navigation-menu\"\n data-viewport={viewport}\n className={cn(\n \"group/navigation-menu relative flex max-w-max flex-1 items-center justify-center\",\n className,\n )}\n {...props}\n >\n {children}\n {viewport && <NavigationMenuViewport />}\n </NavigationMenuPrimitive.Root>\n );\n}\n\n/** Horizontal list wrapper for the top-level navigation items. */\nfunction NavigationMenuList({\n className,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.List>) {\n return (\n <NavigationMenuPrimitive.List\n data-slot=\"navigation-menu-list\"\n className={cn(\"group flex flex-1 list-none items-center justify-center gap-1\", className)}\n {...props}\n />\n );\n}\n\n/** A single top-level entry; holds either a link or a trigger plus its content. */\nfunction NavigationMenuItem({\n className,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Item>) {\n return (\n <NavigationMenuPrimitive.Item\n data-slot=\"navigation-menu-item\"\n className={cn(\"relative\", className)}\n {...props}\n />\n );\n}\n\nconst navigationMenuTriggerStyle = cva(\n \"group inline-flex h-9 w-max items-center justify-center rounded-md bg-background px-4 py-2 text-sm font-medium transition-[color,box-shadow] outline-none hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=open]:bg-accent/50 data-[state=open]:text-accent-foreground data-[state=open]:hover:bg-accent data-[state=open]:focus:bg-accent\",\n);\n\n/** Button that toggles an item's content panel; renders a rotating chevron. */\nfunction NavigationMenuTrigger({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Trigger>) {\n return (\n <NavigationMenuPrimitive.Trigger\n data-slot=\"navigation-menu-trigger\"\n className={cn(navigationMenuTriggerStyle(), \"group\", className)}\n {...props}\n >\n {children}{\" \"}\n <ChevronDownIcon\n className=\"relative top-[1px] ml-1 size-3 transition duration-300 group-data-[state=open]:rotate-180\"\n aria-hidden=\"true\"\n />\n </NavigationMenuPrimitive.Trigger>\n );\n}\n\n/** The panel revealed when an item's trigger is open; holds links or rich content. */\nfunction NavigationMenuContent({\n className,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Content>) {\n return (\n <NavigationMenuPrimitive.Content\n data-slot=\"navigation-menu-content\"\n className={cn(\n \"top-0 left-0 w-full p-2 pr-2.5 data-[motion=from-end]:slide-in-from-right-52 data-[motion=from-start]:slide-in-from-left-52 data-[motion=to-end]:slide-out-to-right-52 data-[motion=to-start]:slide-out-to-left-52 data-[motion^=from-]:animate-in data-[motion^=from-]:fade-in data-[motion^=to-]:animate-out data-[motion^=to-]:fade-out md:absolute md:w-auto\",\n \"group-data-[viewport=false]/navigation-menu:top-full group-data-[viewport=false]/navigation-menu:mt-1.5 group-data-[viewport=false]/navigation-menu:overflow-hidden group-data-[viewport=false]/navigation-menu:rounded-md group-data-[viewport=false]/navigation-menu:border group-data-[viewport=false]/navigation-menu:bg-popover group-data-[viewport=false]/navigation-menu:text-popover-foreground group-data-[viewport=false]/navigation-menu:shadow group-data-[viewport=false]/navigation-menu:duration-200 **:data-[slot=navigation-menu-link]:focus:ring-0 **:data-[slot=navigation-menu-link]:focus:outline-none group-data-[viewport=false]/navigation-menu:data-[state=closed]:animate-out group-data-[viewport=false]/navigation-menu:data-[state=closed]:fade-out-0 group-data-[viewport=false]/navigation-menu:data-[state=closed]:zoom-out-95 group-data-[viewport=false]/navigation-menu:data-[state=open]:animate-in group-data-[viewport=false]/navigation-menu:data-[state=open]:fade-in-0 group-data-[viewport=false]/navigation-menu:data-[state=open]:zoom-in-95\",\n className,\n )}\n {...props}\n />\n );\n}\n\n/** Shared animated container that the active item's content is portaled into when `viewport` is enabled. */\nfunction NavigationMenuViewport({\n className,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Viewport>) {\n return (\n <div className={cn(\"absolute top-full left-0 isolate z-50 flex justify-center\")}>\n <NavigationMenuPrimitive.Viewport\n data-slot=\"navigation-menu-viewport\"\n className={cn(\n \"origin-top-center relative mt-1.5 h-[var(--radix-navigation-menu-viewport-height)] w-full overflow-hidden rounded-md border bg-popover text-popover-foreground shadow data-[state=closed]:animate-out data-[state=closed]:zoom-out-95 data-[state=open]:animate-in data-[state=open]:zoom-in-90 md:w-[var(--radix-navigation-menu-viewport-width)]\",\n className,\n )}\n {...props}\n />\n </div>\n );\n}\n\n/** A navigable link styled for use as a top-level item or inside content; set `active` to mark the current page. */\nfunction NavigationMenuLink({\n className,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Link>) {\n return (\n <NavigationMenuPrimitive.Link\n data-slot=\"navigation-menu-link\"\n className={cn(\n \"flex flex-col gap-1 rounded-sm p-2 text-sm transition-all outline-none hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 data-[active=true]:bg-accent/50 data-[active=true]:text-accent-foreground data-[active=true]:hover:bg-accent data-[active=true]:focus:bg-accent [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground\",\n className,\n )}\n {...props}\n />\n );\n}\n\n/** Optional arrow that points from the active trigger to its content panel. */\nfunction NavigationMenuIndicator({\n className,\n ...props\n}: React.ComponentProps<typeof NavigationMenuPrimitive.Indicator>) {\n return (\n <NavigationMenuPrimitive.Indicator\n data-slot=\"navigation-menu-indicator\"\n className={cn(\n \"top-full z-[1] flex h-1.5 items-end justify-center overflow-hidden data-[state=hidden]:animate-out data-[state=hidden]:fade-out data-[state=visible]:animate-in data-[state=visible]:fade-in\",\n className,\n )}\n {...props}\n >\n <div className=\"relative top-[60%] h-2 w-2 rotate-45 rounded-tl-sm bg-border shadow-md\" />\n </NavigationMenuPrimitive.Indicator>\n );\n}\n\nexport {\n NavigationMenu,\n NavigationMenuList,\n NavigationMenuItem,\n NavigationMenuContent,\n NavigationMenuTrigger,\n NavigationMenuLink,\n NavigationMenuIndicator,\n NavigationMenuViewport,\n navigationMenuTriggerStyle,\n};\n"],"mappings":";;;;;;;;AAQA,SAAS,eAAe,EACtB,WACA,UACA,WAAW,MACX,GAAG,SAIF;CACD,OACE,iBAAA,GAAA,kBAAA,MAACA,SAAAA,eAAwB,MAAzB;EACE,aAAU;EACV,iBAAe;EACf,WAAWC,WAAAA,GACT,oFACA,SACF;EACA,GAAI;YAPN,CASG,UACA,YAAY,iBAAA,GAAA,kBAAA,KAAC,wBAAD,CAAyB,CAAA,CACV;;AAElC;;AAGA,SAAS,mBAAmB,EAC1B,WACA,GAAG,SACyD;CAC5D,OACE,iBAAA,GAAA,kBAAA,KAACD,SAAAA,eAAwB,MAAzB;EACE,aAAU;EACV,WAAWC,WAAAA,GAAG,iEAAiE,SAAS;EACxF,GAAI;CACL,CAAA;AAEL;;AAGA,SAAS,mBAAmB,EAC1B,WACA,GAAG,SACyD;CAC5D,OACE,iBAAA,GAAA,kBAAA,KAACD,SAAAA,eAAwB,MAAzB;EACE,aAAU;EACV,WAAWC,WAAAA,GAAG,YAAY,SAAS;EACnC,GAAI;CACL,CAAA;AAEL;AAEA,MAAM,8BAAA,GAAA,yBAAA,KACJ,8fACF;;AAGA,SAAS,sBAAsB,EAC7B,WACA,UACA,GAAG,SAC4D;CAC/D,OACE,iBAAA,GAAA,kBAAA,MAACD,SAAAA,eAAwB,SAAzB;EACE,aAAU;EACV,WAAWC,WAAAA,GAAG,2BAA2B,GAAG,SAAS,SAAS;EAC9D,GAAI;YAHN;GAKG;GAAU;GACX,iBAAA,GAAA,kBAAA,KAACC,aAAAA,iBAAD;IACE,WAAU;IACV,eAAY;GACb,CAAA;EAC8B;;AAErC;;AAGA,SAAS,sBAAsB,EAC7B,WACA,GAAG,SAC4D;CAC/D,OACE,iBAAA,GAAA,kBAAA,KAACF,SAAAA,eAAwB,SAAzB;EACE,aAAU;EACV,WAAWC,WAAAA,GACT,oWACA,6hCACA,SACF;EACA,GAAI;CACL,CAAA;AAEL;;AAGA,SAAS,uBAAuB,EAC9B,WACA,GAAG,SAC6D;CAChE,OACE,iBAAA,GAAA,kBAAA,KAAC,OAAD;EAAK,WAAWA,WAAAA,GAAG,2DAA2D;YAC5E,iBAAA,GAAA,kBAAA,KAACD,SAAAA,eAAwB,UAAzB;GACE,aAAU;GACV,WAAWC,WAAAA,GACT,sVACA,SACF;GACA,GAAI;EACL,CAAA;CACE,CAAA;AAET;;AAGA,SAAS,mBAAmB,EAC1B,WACA,GAAG,SACyD;CAC5D,OACE,iBAAA,GAAA,kBAAA,KAACD,SAAAA,eAAwB,MAAzB;EACE,aAAU;EACV,WAAWC,WAAAA,GACT,ydACA,SACF;EACA,GAAI;CACL,CAAA;AAEL;;AAGA,SAAS,wBAAwB,EAC/B,WACA,GAAG,SAC8D;CACjE,OACE,iBAAA,GAAA,kBAAA,KAACD,SAAAA,eAAwB,WAAzB;EACE,aAAU;EACV,WAAWC,WAAAA,GACT,gMACA,SACF;EACA,GAAI;YAEJ,iBAAA,GAAA,kBAAA,KAAC,OAAD,EAAK,WAAU,yEAA0E,CAAA;CACxD,CAAA;AAEvC"}
@@ -0,0 +1,2 @@
1
+ import { a as NavigationMenuLink, c as NavigationMenuViewport, i as NavigationMenuItem, l as navigationMenuTriggerStyle, n as NavigationMenuContent, o as NavigationMenuList, r as NavigationMenuIndicator, s as NavigationMenuTrigger, t as NavigationMenu } from "../../index41.cjs";
2
+ export { NavigationMenu, NavigationMenuContent, NavigationMenuIndicator, NavigationMenuItem, NavigationMenuLink, NavigationMenuList, NavigationMenuTrigger, NavigationMenuViewport, navigationMenuTriggerStyle };
@@ -0,0 +1,2 @@
1
+ import { a as NavigationMenuLink, c as NavigationMenuViewport, i as NavigationMenuItem, l as navigationMenuTriggerStyle, n as NavigationMenuContent, o as NavigationMenuList, r as NavigationMenuIndicator, s as NavigationMenuTrigger, t as NavigationMenu } from "../../index41.js";
2
+ export { NavigationMenu, NavigationMenuContent, NavigationMenuIndicator, NavigationMenuItem, NavigationMenuLink, NavigationMenuList, NavigationMenuTrigger, NavigationMenuViewport, navigationMenuTriggerStyle };