@contractspec/lib.ui-kit-web 1.57.0 → 1.58.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 (545) hide show
  1. package/dist/browser/index.js +13 -0
  2. package/dist/browser/ui/accordion.js +73 -0
  3. package/dist/browser/ui/alert-dialog.js +177 -0
  4. package/dist/browser/ui/alert.js +60 -0
  5. package/dist/browser/ui/aspect-ratio.js +15 -0
  6. package/dist/browser/ui/atoms/FilterSelect/FilterSelect.js +244 -0
  7. package/dist/browser/ui/atoms/FilterSelect/index.js +244 -0
  8. package/dist/browser/ui/atoms/FilterSelect/types.js +0 -0
  9. package/dist/browser/ui/atoms/LoadingSpinner/LoadingSpinner.js +89 -0
  10. package/dist/browser/ui/atoms/LoadingSpinner/index.js +89 -0
  11. package/dist/browser/ui/atoms/Pagination/Pagination.js +387 -0
  12. package/dist/browser/ui/atoms/Pagination/index.js +387 -0
  13. package/dist/browser/ui/atoms/Pagination/types.js +0 -0
  14. package/dist/browser/ui/atoms/SearchInput/SearchInput.js +123 -0
  15. package/dist/browser/ui/atoms/SearchInput/index.js +123 -0
  16. package/dist/browser/ui/atoms/SearchInput/types.js +0 -0
  17. package/dist/browser/ui/avatar.js +54 -0
  18. package/dist/browser/ui/badge.js +43 -0
  19. package/dist/browser/ui/breadcrumb.js +109 -0
  20. package/dist/browser/ui/button.js +56 -0
  21. package/dist/browser/ui/calendar.js +181 -0
  22. package/dist/browser/ui/card.js +87 -0
  23. package/dist/browser/ui/carousel.js +229 -0
  24. package/dist/browser/ui/checkbox.js +34 -0
  25. package/dist/browser/ui/collapsible.js +41 -0
  26. package/dist/browser/ui/command.js +266 -0
  27. package/dist/browser/ui/confirm-dialog.js +226 -0
  28. package/dist/browser/ui/context-menu.js +127 -0
  29. package/dist/browser/ui/cta.js +102 -0
  30. package/dist/browser/ui/date-picker.js +350 -0
  31. package/dist/browser/ui/date-range-picker.js +276 -0
  32. package/dist/browser/ui/datetime-picker.js +489 -0
  33. package/dist/browser/ui/dialog.js +140 -0
  34. package/dist/browser/ui/drawer.js +130 -0
  35. package/dist/browser/ui/dropdown-menu.js +214 -0
  36. package/dist/browser/ui/empty-state.js +209 -0
  37. package/dist/browser/ui/empty.js +90 -0
  38. package/dist/browser/ui/field.js +221 -0
  39. package/dist/browser/ui/focus-on-route-change.js +25 -0
  40. package/dist/browser/ui/form.js +156 -0
  41. package/dist/browser/ui/hover-card.js +51 -0
  42. package/dist/browser/ui/input-group.js +192 -0
  43. package/dist/browser/ui/input-otp.js +60 -0
  44. package/dist/browser/ui/input.js +22 -0
  45. package/dist/browser/ui/label.js +26 -0
  46. package/dist/browser/ui/link.js +24 -0
  47. package/dist/browser/ui/live-region.js +56 -0
  48. package/dist/browser/ui/loading-button.js +228 -0
  49. package/dist/browser/ui/map/MapBase.js +70 -0
  50. package/dist/browser/ui/map/MapGeoJsonOverlay.js +56 -0
  51. package/dist/browser/ui/map/MapHeatmapH3.js +66 -0
  52. package/dist/browser/ui/map/MapMarkers.js +45 -0
  53. package/dist/browser/ui/map/index.js +210 -0
  54. package/dist/browser/ui/marketing/FeatureGrid.js +50 -0
  55. package/dist/browser/ui/marketing/Hero.js +116 -0
  56. package/dist/browser/ui/marketing/PricingTable.js +127 -0
  57. package/dist/browser/ui/marketing/index.js +217 -0
  58. package/dist/browser/ui/menubar.js +231 -0
  59. package/dist/browser/ui/molecules/Autocomplete/index.js +584 -0
  60. package/dist/browser/ui/molecules/SearchAndFilter/SearchAndFilter.js +503 -0
  61. package/dist/browser/ui/molecules/SearchAndFilter/index.js +503 -0
  62. package/dist/browser/ui/molecules/SearchAndFilter/types.js +0 -0
  63. package/dist/browser/ui/molecules/SkeletonList.js +44 -0
  64. package/dist/browser/ui/nav-layout.js +298 -0
  65. package/dist/browser/ui/navigation-menu.js +128 -0
  66. package/dist/browser/ui/organisms/ErrorBoundary/ErrorBoundary.js +191 -0
  67. package/dist/browser/ui/organisms/ErrorBoundary/index.js +191 -0
  68. package/dist/browser/ui/organisms/ListPage/ListPage.js +1236 -0
  69. package/dist/browser/ui/organisms/ListPage/index.js +1236 -0
  70. package/dist/browser/ui/organisms/ListPage/types.js +0 -0
  71. package/dist/browser/ui/page-header.js +206 -0
  72. package/dist/browser/ui/pagination.js +156 -0
  73. package/dist/browser/ui/popover.js +59 -0
  74. package/dist/browser/ui/progress.js +32 -0
  75. package/dist/browser/ui/radio-group.js +45 -0
  76. package/dist/browser/ui/resizable.js +41 -0
  77. package/dist/browser/ui/route-announcer.js +28 -0
  78. package/dist/browser/ui/scroll-area.js +53 -0
  79. package/dist/browser/ui/section.js +65 -0
  80. package/dist/browser/ui/select.js +165 -0
  81. package/dist/browser/ui/separator.js +30 -0
  82. package/dist/browser/ui/sheet.js +136 -0
  83. package/dist/browser/ui/sidebar.js +806 -0
  84. package/dist/browser/ui/skeleton.js +30 -0
  85. package/dist/browser/ui/skip-link.js +27 -0
  86. package/dist/browser/ui/slider.js +50 -0
  87. package/dist/browser/ui/sonner.js +29 -0
  88. package/dist/browser/ui/stack.js +158 -0
  89. package/dist/browser/ui/stat-card-group.js +263 -0
  90. package/dist/browser/ui/stepper.js +185 -0
  91. package/dist/browser/ui/switch.js +31 -0
  92. package/dist/browser/ui/table.js +106 -0
  93. package/dist/browser/ui/tabs.js +59 -0
  94. package/dist/browser/ui/text.js +22 -0
  95. package/dist/browser/ui/textarea.js +21 -0
  96. package/dist/browser/ui/time-picker.js +186 -0
  97. package/dist/browser/ui/toast.js +79 -0
  98. package/dist/browser/ui/toaster.js +220 -0
  99. package/dist/browser/ui/toggle-group.js +96 -0
  100. package/dist/browser/ui/toggle.js +47 -0
  101. package/dist/browser/ui/tooltip.js +68 -0
  102. package/dist/browser/ui/typography.js +123 -0
  103. package/dist/browser/ui/use-media-query.js +26 -0
  104. package/dist/browser/ui/use-mobile.js +27 -0
  105. package/dist/browser/ui/use-reduced-motion.js +24 -0
  106. package/dist/browser/ui/use-toast.js +129 -0
  107. package/dist/browser/ui/useListState.js +76 -0
  108. package/dist/browser/ui/usecases/UseCaseCard.js +232 -0
  109. package/dist/browser/ui/usecases/UserStoryCard.js +186 -0
  110. package/dist/browser/ui/usecases/index.js +267 -0
  111. package/dist/browser/ui/utils.js +17 -0
  112. package/dist/browser/ui/visually-hidden.js +35 -0
  113. package/dist/index.d.ts +2 -1
  114. package/dist/index.d.ts.map +1 -0
  115. package/dist/index.js +8 -0
  116. package/dist/ui/accordion.d.ts +7 -24
  117. package/dist/ui/accordion.d.ts.map +1 -1
  118. package/dist/ui/accordion.js +60 -40
  119. package/dist/ui/alert-dialog.d.ts +14 -48
  120. package/dist/ui/alert-dialog.d.ts.map +1 -1
  121. package/dist/ui/alert-dialog.js +158 -71
  122. package/dist/ui/alert.d.ts +8 -23
  123. package/dist/ui/alert.d.ts.map +1 -1
  124. package/dist/ui/alert.js +50 -34
  125. package/dist/ui/aspect-ratio.d.ts +2 -6
  126. package/dist/ui/aspect-ratio.d.ts.map +1 -1
  127. package/dist/ui/aspect-ratio.js +8 -8
  128. package/dist/ui/atoms/FilterSelect/FilterSelect.d.ts +3 -7
  129. package/dist/ui/atoms/FilterSelect/FilterSelect.d.ts.map +1 -1
  130. package/dist/ui/atoms/FilterSelect/FilterSelect.js +237 -51
  131. package/dist/ui/atoms/FilterSelect/index.d.ts +3 -3
  132. package/dist/ui/atoms/FilterSelect/index.d.ts.map +1 -0
  133. package/dist/ui/atoms/FilterSelect/index.js +238 -2
  134. package/dist/ui/atoms/FilterSelect/types.d.ts +13 -16
  135. package/dist/ui/atoms/FilterSelect/types.d.ts.map +1 -1
  136. package/dist/ui/atoms/FilterSelect/types.js +1 -0
  137. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.d.ts +14 -17
  138. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.d.ts.map +1 -1
  139. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.js +81 -43
  140. package/dist/ui/atoms/LoadingSpinner/index.d.ts +2 -2
  141. package/dist/ui/atoms/LoadingSpinner/index.d.ts.map +1 -0
  142. package/dist/ui/atoms/LoadingSpinner/index.js +83 -2
  143. package/dist/ui/atoms/Pagination/Pagination.d.ts +3 -7
  144. package/dist/ui/atoms/Pagination/Pagination.d.ts.map +1 -1
  145. package/dist/ui/atoms/Pagination/Pagination.js +380 -155
  146. package/dist/ui/atoms/Pagination/index.d.ts +3 -3
  147. package/dist/ui/atoms/Pagination/index.d.ts.map +1 -0
  148. package/dist/ui/atoms/Pagination/index.js +381 -2
  149. package/dist/ui/atoms/Pagination/types.d.ts +11 -14
  150. package/dist/ui/atoms/Pagination/types.d.ts.map +1 -1
  151. package/dist/ui/atoms/Pagination/types.js +1 -0
  152. package/dist/ui/atoms/SearchInput/SearchInput.d.ts +3 -7
  153. package/dist/ui/atoms/SearchInput/SearchInput.d.ts.map +1 -1
  154. package/dist/ui/atoms/SearchInput/SearchInput.js +116 -48
  155. package/dist/ui/atoms/SearchInput/index.d.ts +3 -3
  156. package/dist/ui/atoms/SearchInput/index.d.ts.map +1 -0
  157. package/dist/ui/atoms/SearchInput/index.js +117 -2
  158. package/dist/ui/atoms/SearchInput/types.d.ts +8 -11
  159. package/dist/ui/atoms/SearchInput/types.d.ts.map +1 -1
  160. package/dist/ui/atoms/SearchInput/types.js +1 -0
  161. package/dist/ui/avatar.d.ts +6 -19
  162. package/dist/ui/avatar.d.ts.map +1 -1
  163. package/dist/ui/avatar.js +44 -28
  164. package/dist/ui/badge.d.ts +7 -17
  165. package/dist/ui/badge.d.ts.map +1 -1
  166. package/dist/ui/badge.js +34 -23
  167. package/dist/ui/breadcrumb.d.ts +11 -37
  168. package/dist/ui/breadcrumb.d.ts.map +1 -1
  169. package/dist/ui/breadcrumb.js +94 -62
  170. package/dist/ui/button.d.ts +14 -18
  171. package/dist/ui/button.d.ts.map +1 -1
  172. package/dist/ui/button.js +46 -50
  173. package/dist/ui/calendar.d.ts +7 -25
  174. package/dist/ui/calendar.d.ts.map +1 -1
  175. package/dist/ui/calendar.js +172 -105
  176. package/dist/ui/card.d.ts +9 -34
  177. package/dist/ui/card.d.ts.map +1 -1
  178. package/dist/ui/card.js +73 -49
  179. package/dist/ui/carousel.d.ts +13 -41
  180. package/dist/ui/carousel.d.ts.map +1 -1
  181. package/dist/ui/carousel.js +215 -127
  182. package/dist/ui/checkbox.d.ts +3 -10
  183. package/dist/ui/checkbox.d.ts.map +1 -1
  184. package/dist/ui/checkbox.js +25 -21
  185. package/dist/ui/collapsible.d.ts +5 -15
  186. package/dist/ui/collapsible.d.ts.map +1 -1
  187. package/dist/ui/collapsible.js +31 -23
  188. package/dist/ui/command.d.ts +18 -52
  189. package/dist/ui/command.d.ts.map +1 -1
  190. package/dist/ui/command.js +258 -87
  191. package/dist/ui/confirm-dialog.d.ts +13 -29
  192. package/dist/ui/confirm-dialog.d.ts.map +1 -1
  193. package/dist/ui/confirm-dialog.js +219 -32
  194. package/dist/ui/context-menu.d.ts +25 -32
  195. package/dist/ui/context-menu.d.ts.map +1 -1
  196. package/dist/ui/context-menu.js +109 -71
  197. package/dist/ui/cta.d.ts +17 -21
  198. package/dist/ui/cta.d.ts.map +1 -1
  199. package/dist/ui/cta.js +94 -36
  200. package/dist/ui/date-picker.d.ts +10 -24
  201. package/dist/ui/date-picker.d.ts.map +1 -1
  202. package/dist/ui/date-picker.js +342 -98
  203. package/dist/ui/date-range-picker.d.ts +11 -23
  204. package/dist/ui/date-range-picker.d.ts.map +1 -1
  205. package/dist/ui/date-range-picker.js +268 -51
  206. package/dist/ui/datetime-picker.d.ts +11 -26
  207. package/dist/ui/datetime-picker.d.ts.map +1 -1
  208. package/dist/ui/datetime-picker.js +479 -39
  209. package/dist/ui/dialog.d.ts +15 -47
  210. package/dist/ui/dialog.d.ts.map +1 -1
  211. package/dist/ui/dialog.js +122 -77
  212. package/dist/ui/drawer.d.ts +13 -44
  213. package/dist/ui/drawer.d.ts.map +1 -1
  214. package/dist/ui/drawer.js +113 -70
  215. package/dist/ui/dropdown-menu.d.ts +25 -77
  216. package/dist/ui/dropdown-menu.d.ts.map +1 -1
  217. package/dist/ui/dropdown-menu.js +191 -109
  218. package/dist/ui/empty-state.d.ts +13 -26
  219. package/dist/ui/empty-state.d.ts.map +1 -1
  220. package/dist/ui/empty-state.js +201 -40
  221. package/dist/ui/empty.d.ts +11 -35
  222. package/dist/ui/empty.d.ts.map +1 -1
  223. package/dist/ui/empty.js +76 -53
  224. package/dist/ui/field.d.ts +24 -64
  225. package/dist/ui/field.d.ts.map +1 -1
  226. package/dist/ui/field.js +202 -107
  227. package/dist/ui/focus-on-route-change.d.ts +2 -7
  228. package/dist/ui/focus-on-route-change.d.ts.map +1 -1
  229. package/dist/ui/focus-on-route-change.js +18 -15
  230. package/dist/ui/form.d.ts +24 -44
  231. package/dist/ui/form.d.ts.map +1 -1
  232. package/dist/ui/form.js +141 -84
  233. package/dist/ui/hover-card.d.ts +6 -19
  234. package/dist/ui/hover-card.d.ts.map +1 -1
  235. package/dist/ui/hover-card.js +41 -31
  236. package/dist/ui/input-group.d.ts +14 -41
  237. package/dist/ui/input-group.d.ts.map +1 -1
  238. package/dist/ui/input-group.js +177 -79
  239. package/dist/ui/input-otp.d.ts +32 -36
  240. package/dist/ui/input-otp.d.ts.map +1 -1
  241. package/dist/ui/input-otp.js +47 -38
  242. package/dist/ui/input.d.ts +4 -12
  243. package/dist/ui/input.d.ts.map +1 -1
  244. package/dist/ui/input.js +14 -14
  245. package/dist/ui/label.d.ts +3 -10
  246. package/dist/ui/label.d.ts.map +1 -1
  247. package/dist/ui/label.js +18 -16
  248. package/dist/ui/link.d.ts +3 -7
  249. package/dist/ui/link.d.ts.map +1 -1
  250. package/dist/ui/link.js +14 -13
  251. package/dist/ui/live-region.d.ts +8 -14
  252. package/dist/ui/live-region.d.ts.map +1 -1
  253. package/dist/ui/live-region.js +47 -43
  254. package/dist/ui/loading-button.d.ts +7 -17
  255. package/dist/ui/loading-button.d.ts.map +1 -1
  256. package/dist/ui/loading-button.js +221 -19
  257. package/dist/ui/map/MapBase.d.ts +20 -25
  258. package/dist/ui/map/MapBase.d.ts.map +1 -1
  259. package/dist/ui/map/MapBase.js +62 -43
  260. package/dist/ui/map/MapGeoJsonOverlay.d.ts +9 -14
  261. package/dist/ui/map/MapGeoJsonOverlay.d.ts.map +1 -1
  262. package/dist/ui/map/MapGeoJsonOverlay.js +47 -33
  263. package/dist/ui/map/MapHeatmapH3.d.ts +10 -15
  264. package/dist/ui/map/MapHeatmapH3.d.ts.map +1 -1
  265. package/dist/ui/map/MapHeatmapH3.js +55 -44
  266. package/dist/ui/map/MapMarkers.d.ts +11 -18
  267. package/dist/ui/map/MapMarkers.d.ts.map +1 -1
  268. package/dist/ui/map/MapMarkers.js +36 -35
  269. package/dist/ui/map/index.d.ts +5 -5
  270. package/dist/ui/map/index.d.ts.map +1 -0
  271. package/dist/ui/map/index.js +204 -5
  272. package/dist/ui/marketing/FeatureGrid.d.ts +10 -19
  273. package/dist/ui/marketing/FeatureGrid.d.ts.map +1 -1
  274. package/dist/ui/marketing/FeatureGrid.js +42 -32
  275. package/dist/ui/marketing/Hero.d.ts +16 -27
  276. package/dist/ui/marketing/Hero.d.ts.map +1 -1
  277. package/dist/ui/marketing/Hero.js +108 -50
  278. package/dist/ui/marketing/PricingTable.d.ts +15 -23
  279. package/dist/ui/marketing/PricingTable.d.ts.map +1 -1
  280. package/dist/ui/marketing/PricingTable.js +119 -57
  281. package/dist/ui/marketing/index.d.ts +4 -4
  282. package/dist/ui/marketing/index.d.ts.map +1 -0
  283. package/dist/ui/marketing/index.js +211 -4
  284. package/dist/ui/menubar.d.ts +26 -84
  285. package/dist/ui/menubar.d.ts.map +1 -1
  286. package/dist/ui/menubar.js +223 -134
  287. package/dist/ui/molecules/Autocomplete/index.d.ts +1 -6
  288. package/dist/ui/molecules/Autocomplete/index.d.ts.map +1 -1
  289. package/dist/ui/molecules/Autocomplete/index.js +574 -80
  290. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.d.ts +3 -7
  291. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.d.ts.map +1 -1
  292. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js +496 -101
  293. package/dist/ui/molecules/SearchAndFilter/index.d.ts +3 -3
  294. package/dist/ui/molecules/SearchAndFilter/index.d.ts.map +1 -0
  295. package/dist/ui/molecules/SearchAndFilter/index.js +497 -2
  296. package/dist/ui/molecules/SearchAndFilter/types.d.ts +18 -22
  297. package/dist/ui/molecules/SearchAndFilter/types.d.ts.map +1 -1
  298. package/dist/ui/molecules/SearchAndFilter/types.js +1 -0
  299. package/dist/ui/molecules/SkeletonList.d.ts +5 -13
  300. package/dist/ui/molecules/SkeletonList.d.ts.map +1 -1
  301. package/dist/ui/molecules/SkeletonList.js +36 -12
  302. package/dist/ui/nav-layout.d.ts +44 -67
  303. package/dist/ui/nav-layout.d.ts.map +1 -1
  304. package/dist/ui/nav-layout.js +287 -127
  305. package/dist/ui/navigation-menu.d.ts +14 -46
  306. package/dist/ui/navigation-menu.d.ts.map +1 -1
  307. package/dist/ui/navigation-menu.js +113 -73
  308. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.d.ts +18 -22
  309. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.d.ts.map +1 -1
  310. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.js +182 -103
  311. package/dist/ui/organisms/ErrorBoundary/index.d.ts +3 -2
  312. package/dist/ui/organisms/ErrorBoundary/index.d.ts.map +1 -0
  313. package/dist/ui/organisms/ErrorBoundary/index.js +185 -2
  314. package/dist/ui/organisms/ListPage/ListPage.d.ts +2 -28
  315. package/dist/ui/organisms/ListPage/ListPage.d.ts.map +1 -1
  316. package/dist/ui/organisms/ListPage/ListPage.js +1229 -196
  317. package/dist/ui/organisms/ListPage/index.d.ts +3 -3
  318. package/dist/ui/organisms/ListPage/index.d.ts.map +1 -0
  319. package/dist/ui/organisms/ListPage/index.js +1230 -2
  320. package/dist/ui/organisms/ListPage/types.d.ts +34 -38
  321. package/dist/ui/organisms/ListPage/types.d.ts.map +1 -1
  322. package/dist/ui/organisms/ListPage/types.js +1 -0
  323. package/dist/ui/page-header.d.ts +12 -24
  324. package/dist/ui/page-header.d.ts.map +1 -1
  325. package/dist/ui/page-header.js +198 -37
  326. package/dist/ui/pagination.d.ts +17 -38
  327. package/dist/ui/pagination.d.ts.map +1 -1
  328. package/dist/ui/pagination.js +142 -56
  329. package/dist/ui/popover.d.ts +7 -22
  330. package/dist/ui/popover.d.ts.map +1 -1
  331. package/dist/ui/popover.js +48 -33
  332. package/dist/ui/progress.d.ts +3 -11
  333. package/dist/ui/progress.d.ts.map +1 -1
  334. package/dist/ui/progress.js +24 -21
  335. package/dist/ui/radio-group.d.ts +4 -14
  336. package/dist/ui/radio-group.d.ts.map +1 -1
  337. package/dist/ui/radio-group.js +35 -27
  338. package/dist/ui/resizable.d.ts +22 -34
  339. package/dist/ui/resizable.d.ts.map +1 -1
  340. package/dist/ui/resizable.js +33 -22
  341. package/dist/ui/route-announcer.d.ts +3 -10
  342. package/dist/ui/route-announcer.d.ts.map +1 -1
  343. package/dist/ui/route-announcer.js +20 -19
  344. package/dist/ui/scroll-area.d.ts +4 -16
  345. package/dist/ui/scroll-area.d.ts.map +1 -1
  346. package/dist/ui/scroll-area.js +44 -36
  347. package/dist/ui/section.d.ts +20 -24
  348. package/dist/ui/section.d.ts.map +1 -1
  349. package/dist/ui/section.js +56 -59
  350. package/dist/ui/select.d.ts +15 -51
  351. package/dist/ui/select.d.ts.map +1 -1
  352. package/dist/ui/select.js +147 -87
  353. package/dist/ui/separator.d.ts +3 -12
  354. package/dist/ui/separator.d.ts.map +1 -1
  355. package/dist/ui/separator.js +22 -18
  356. package/dist/ui/sheet.d.ts +13 -40
  357. package/dist/ui/sheet.d.ts.map +1 -1
  358. package/dist/ui/sheet.js +117 -72
  359. package/dist/ui/sidebar.d.ts +65 -162
  360. package/dist/ui/sidebar.d.ts.map +1 -1
  361. package/dist/ui/sidebar.js +794 -372
  362. package/dist/ui/skeleton.d.ts +2 -9
  363. package/dist/ui/skeleton.d.ts.map +1 -1
  364. package/dist/ui/skeleton.js +22 -12
  365. package/dist/ui/skip-link.d.ts +6 -15
  366. package/dist/ui/skip-link.d.ts.map +1 -1
  367. package/dist/ui/skip-link.js +20 -15
  368. package/dist/ui/slider.d.ts +3 -14
  369. package/dist/ui/slider.d.ts.map +1 -1
  370. package/dist/ui/slider.js +42 -37
  371. package/dist/ui/sonner.d.ts +2 -8
  372. package/dist/ui/sonner.d.ts.map +1 -1
  373. package/dist/ui/sonner.js +21 -21
  374. package/dist/ui/stack.d.ts +40 -44
  375. package/dist/ui/stack.d.ts.map +1 -1
  376. package/dist/ui/stack.js +143 -148
  377. package/dist/ui/stat-card-group.d.ts +9 -17
  378. package/dist/ui/stat-card-group.d.ts.map +1 -1
  379. package/dist/ui/stat-card-group.js +255 -35
  380. package/dist/ui/stepper.d.ts +10 -20
  381. package/dist/ui/stepper.d.ts.map +1 -1
  382. package/dist/ui/stepper.js +176 -33
  383. package/dist/ui/switch.d.ts +5 -13
  384. package/dist/ui/switch.d.ts.map +1 -1
  385. package/dist/ui/switch.js +23 -20
  386. package/dist/ui/table.d.ts +10 -38
  387. package/dist/ui/table.d.ts.map +1 -1
  388. package/dist/ui/table.js +91 -61
  389. package/dist/ui/tabs.d.ts +7 -23
  390. package/dist/ui/tabs.d.ts.map +1 -1
  391. package/dist/ui/tabs.js +48 -34
  392. package/dist/ui/text.d.ts +5 -13
  393. package/dist/ui/text.d.ts.map +1 -1
  394. package/dist/ui/text.js +14 -13
  395. package/dist/ui/textarea.d.ts +4 -11
  396. package/dist/ui/textarea.d.ts.map +1 -1
  397. package/dist/ui/textarea.js +13 -13
  398. package/dist/ui/time-picker.d.ts +8 -20
  399. package/dist/ui/time-picker.d.ts.map +1 -1
  400. package/dist/ui/time-picker.js +176 -76
  401. package/dist/ui/toast.d.ts +15 -19
  402. package/dist/ui/toast.d.ts.map +1 -1
  403. package/dist/ui/toast.js +63 -51
  404. package/dist/ui/toaster.d.ts +1 -6
  405. package/dist/ui/toaster.d.ts.map +1 -1
  406. package/dist/ui/toaster.js +212 -24
  407. package/dist/ui/toggle-group.d.ts +6 -22
  408. package/dist/ui/toggle-group.d.ts.map +1 -1
  409. package/dist/ui/toggle-group.js +85 -42
  410. package/dist/ui/toggle.d.ts +7 -17
  411. package/dist/ui/toggle.d.ts.map +1 -1
  412. package/dist/ui/toggle.js +38 -37
  413. package/dist/ui/tooltip.d.ts +7 -23
  414. package/dist/ui/tooltip.d.ts.map +1 -1
  415. package/dist/ui/tooltip.js +57 -34
  416. package/dist/ui/typography.d.ts +13 -61
  417. package/dist/ui/typography.d.ts.map +1 -1
  418. package/dist/ui/typography.js +95 -64
  419. package/dist/ui/use-media-query.d.ts +1 -4
  420. package/dist/ui/use-media-query.d.ts.map +1 -1
  421. package/dist/ui/use-media-query.js +18 -17
  422. package/dist/ui/use-mobile.d.ts +1 -4
  423. package/dist/ui/use-mobile.d.ts.map +1 -1
  424. package/dist/ui/use-mobile.js +19 -18
  425. package/dist/ui/use-reduced-motion.d.ts +1 -4
  426. package/dist/ui/use-reduced-motion.d.ts.map +1 -1
  427. package/dist/ui/use-reduced-motion.js +16 -15
  428. package/dist/ui/use-toast.d.ts +28 -33
  429. package/dist/ui/use-toast.d.ts.map +1 -1
  430. package/dist/ui/use-toast.js +113 -111
  431. package/dist/ui/useListState.d.ts +23 -31
  432. package/dist/ui/useListState.d.ts.map +1 -1
  433. package/dist/ui/useListState.js +69 -73
  434. package/dist/ui/usecases/UseCaseCard.d.ts +7 -18
  435. package/dist/ui/usecases/UseCaseCard.d.ts.map +1 -1
  436. package/dist/ui/usecases/UseCaseCard.js +225 -33
  437. package/dist/ui/usecases/UserStoryCard.d.ts +5 -14
  438. package/dist/ui/usecases/UserStoryCard.d.ts.map +1 -1
  439. package/dist/ui/usecases/UserStoryCard.js +179 -34
  440. package/dist/ui/usecases/index.d.ts +3 -3
  441. package/dist/ui/usecases/index.d.ts.map +1 -0
  442. package/dist/ui/usecases/index.js +261 -3
  443. package/dist/ui/utils.d.ts +2 -6
  444. package/dist/ui/utils.d.ts.map +1 -1
  445. package/dist/ui/utils.js +8 -7
  446. package/dist/ui/visually-hidden.d.ts +5 -8
  447. package/dist/ui/visually-hidden.d.ts.map +1 -1
  448. package/dist/ui/visually-hidden.js +26 -27
  449. package/package.json +872 -236
  450. package/dist/ui/accordion.js.map +0 -1
  451. package/dist/ui/alert-dialog.js.map +0 -1
  452. package/dist/ui/alert.js.map +0 -1
  453. package/dist/ui/aspect-ratio.js.map +0 -1
  454. package/dist/ui/atoms/FilterSelect/FilterSelect.js.map +0 -1
  455. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.js.map +0 -1
  456. package/dist/ui/atoms/Pagination/Pagination.js.map +0 -1
  457. package/dist/ui/atoms/SearchInput/SearchInput.js.map +0 -1
  458. package/dist/ui/avatar.js.map +0 -1
  459. package/dist/ui/badge.js.map +0 -1
  460. package/dist/ui/breadcrumb.js.map +0 -1
  461. package/dist/ui/button.js.map +0 -1
  462. package/dist/ui/calendar.js.map +0 -1
  463. package/dist/ui/card.js.map +0 -1
  464. package/dist/ui/carousel.js.map +0 -1
  465. package/dist/ui/checkbox.js.map +0 -1
  466. package/dist/ui/collapsible.js.map +0 -1
  467. package/dist/ui/command.js.map +0 -1
  468. package/dist/ui/confirm-dialog.js.map +0 -1
  469. package/dist/ui/context-menu.js.map +0 -1
  470. package/dist/ui/cta.js.map +0 -1
  471. package/dist/ui/date-picker.js.map +0 -1
  472. package/dist/ui/date-range-picker.js.map +0 -1
  473. package/dist/ui/datetime-picker.js.map +0 -1
  474. package/dist/ui/dialog.js.map +0 -1
  475. package/dist/ui/drawer.js.map +0 -1
  476. package/dist/ui/dropdown-menu.js.map +0 -1
  477. package/dist/ui/empty-state.js.map +0 -1
  478. package/dist/ui/empty.js.map +0 -1
  479. package/dist/ui/field.js.map +0 -1
  480. package/dist/ui/focus-on-route-change.js.map +0 -1
  481. package/dist/ui/form.js.map +0 -1
  482. package/dist/ui/hover-card.js.map +0 -1
  483. package/dist/ui/input-group.js.map +0 -1
  484. package/dist/ui/input-otp.js.map +0 -1
  485. package/dist/ui/input.js.map +0 -1
  486. package/dist/ui/label.js.map +0 -1
  487. package/dist/ui/link.js.map +0 -1
  488. package/dist/ui/live-region.js.map +0 -1
  489. package/dist/ui/loading-button.js.map +0 -1
  490. package/dist/ui/map/MapBase.js.map +0 -1
  491. package/dist/ui/map/MapGeoJsonOverlay.js.map +0 -1
  492. package/dist/ui/map/MapHeatmapH3.js.map +0 -1
  493. package/dist/ui/map/MapMarkers.js.map +0 -1
  494. package/dist/ui/marketing/FeatureGrid.js.map +0 -1
  495. package/dist/ui/marketing/Hero.js.map +0 -1
  496. package/dist/ui/marketing/PricingTable.js.map +0 -1
  497. package/dist/ui/menubar.js.map +0 -1
  498. package/dist/ui/molecules/Autocomplete/index.js.map +0 -1
  499. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js.map +0 -1
  500. package/dist/ui/molecules/SkeletonList.js.map +0 -1
  501. package/dist/ui/nav-layout.js.map +0 -1
  502. package/dist/ui/navigation-menu.js.map +0 -1
  503. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.js.map +0 -1
  504. package/dist/ui/organisms/ListPage/ListPage.js.map +0 -1
  505. package/dist/ui/page-header.js.map +0 -1
  506. package/dist/ui/pagination.js.map +0 -1
  507. package/dist/ui/popover.js.map +0 -1
  508. package/dist/ui/progress.js.map +0 -1
  509. package/dist/ui/radio-group.js.map +0 -1
  510. package/dist/ui/resizable.js.map +0 -1
  511. package/dist/ui/route-announcer.js.map +0 -1
  512. package/dist/ui/scroll-area.js.map +0 -1
  513. package/dist/ui/section.js.map +0 -1
  514. package/dist/ui/select.js.map +0 -1
  515. package/dist/ui/separator.js.map +0 -1
  516. package/dist/ui/sheet.js.map +0 -1
  517. package/dist/ui/sidebar.js.map +0 -1
  518. package/dist/ui/skeleton.js.map +0 -1
  519. package/dist/ui/skip-link.js.map +0 -1
  520. package/dist/ui/slider.js.map +0 -1
  521. package/dist/ui/sonner.js.map +0 -1
  522. package/dist/ui/stack.js.map +0 -1
  523. package/dist/ui/stat-card-group.js.map +0 -1
  524. package/dist/ui/stepper.js.map +0 -1
  525. package/dist/ui/switch.js.map +0 -1
  526. package/dist/ui/table.js.map +0 -1
  527. package/dist/ui/tabs.js.map +0 -1
  528. package/dist/ui/text.js.map +0 -1
  529. package/dist/ui/textarea.js.map +0 -1
  530. package/dist/ui/time-picker.js.map +0 -1
  531. package/dist/ui/toast.js.map +0 -1
  532. package/dist/ui/toaster.js.map +0 -1
  533. package/dist/ui/toggle-group.js.map +0 -1
  534. package/dist/ui/toggle.js.map +0 -1
  535. package/dist/ui/tooltip.js.map +0 -1
  536. package/dist/ui/typography.js.map +0 -1
  537. package/dist/ui/use-media-query.js.map +0 -1
  538. package/dist/ui/use-mobile.js.map +0 -1
  539. package/dist/ui/use-reduced-motion.js.map +0 -1
  540. package/dist/ui/use-toast.js.map +0 -1
  541. package/dist/ui/useListState.js.map +0 -1
  542. package/dist/ui/usecases/UseCaseCard.js.map +0 -1
  543. package/dist/ui/usecases/UserStoryCard.js.map +0 -1
  544. package/dist/ui/utils.js.map +0 -1
  545. package/dist/ui/visually-hidden.js.map +0 -1
@@ -1,103 +1,498 @@
1
- import { Button } from "../../button.js";
2
- import { Collapsible, CollapsibleContent, CollapsibleTrigger } from "../../collapsible.js";
3
- import { FilterSelect } from "../../atoms/FilterSelect/FilterSelect.js";
4
- import { SearchInput } from "../../atoms/SearchInput/SearchInput.js";
5
- import React, { useState } from "react";
6
- import { ChevronDown, ChevronUp, Filter } from "lucide-react";
7
- import { jsx, jsxs } from "react/jsx-runtime";
1
+ // @bun
2
+ var __require = import.meta.require;
8
3
 
9
- //#region ui/molecules/SearchAndFilter/SearchAndFilter.tsx
10
- const SearchAndFilter = ({ searchValue, onSearchChange, searchPlaceholder, filters = [], isLoading = false, disabled = false, className = "", collapsible = true, defaultCollapsed = false }) => {
11
- const [isCollapsed, setIsCollapsed] = useState(defaultCollapsed);
12
- const hasFilters = filters.length > 0;
13
- const activeFiltersCount = filters.filter((f) => f.value).length;
14
- const shouldUseCollapsible = collapsible && hasFilters;
15
- console.log("SearchAndFilter", { filters });
16
- const FilterComponents = () => /* @__PURE__ */ jsx("div", {
17
- className: "grid grid-cols-1 gap-4 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4",
18
- children: filters.map((filter) => /* @__PURE__ */ jsx(FilterSelect, {
19
- value: filter.value,
20
- options: filter.options,
21
- onChange: filter.onChange,
22
- label: filter.label,
23
- disabled: disabled || isLoading,
24
- showCounts: filter.showCounts,
25
- className: "min-w-0"
26
- }, filter.key))
27
- });
28
- return /* @__PURE__ */ jsxs("div", {
29
- className: `space-y-4 ${className}`,
30
- children: [
31
- /* @__PURE__ */ jsxs("div", {
32
- className: "flex flex-col gap-4 sm:flex-row",
33
- children: [/* @__PURE__ */ jsx("div", {
34
- className: "flex-1",
35
- children: /* @__PURE__ */ jsx(SearchInput, {
36
- value: searchValue,
37
- onChange: onSearchChange,
38
- placeholder: searchPlaceholder,
39
- disabled: disabled || isLoading,
40
- className: "w-full"
41
- })
42
- }), shouldUseCollapsible && /* @__PURE__ */ jsxs(Collapsible, {
43
- open: !isCollapsed,
44
- onOpenChange: setIsCollapsed,
45
- className: "sm:hidden",
46
- children: [/* @__PURE__ */ jsx(CollapsibleTrigger, {
47
- asChild: true,
48
- children: /* @__PURE__ */ jsxs(Button, {
49
- variant: "outline",
50
- className: "sm:hidden",
51
- disabled: disabled || isLoading,
52
- children: [
53
- /* @__PURE__ */ jsx(Filter, { className: "mr-2 h-4 w-4" }),
54
- "Filtres",
55
- activeFiltersCount > 0 && /* @__PURE__ */ jsx("span", {
56
- className: "bg-primary text-primary-foreground ml-2 flex h-5 w-5 items-center justify-center rounded-full text-sm",
57
- children: activeFiltersCount
58
- }),
59
- isCollapsed ? /* @__PURE__ */ jsx(ChevronDown, { className: "ml-2 h-4 w-4" }) : /* @__PURE__ */ jsx(ChevronUp, { className: "ml-2 h-4 w-4" })
60
- ]
61
- })
62
- }), /* @__PURE__ */ jsx(CollapsibleContent, {
63
- className: "mt-4 space-y-4",
64
- children: /* @__PURE__ */ jsx(FilterComponents, {})
65
- })]
66
- })]
67
- }),
68
- hasFilters && /* @__PURE__ */ jsx("div", {
69
- className: "hidden sm:block",
70
- children: /* @__PURE__ */ jsx(FilterComponents, {})
71
- }),
72
- activeFiltersCount > 0 && /* @__PURE__ */ jsxs("div", {
73
- className: "flex flex-wrap items-center gap-2",
74
- children: [/* @__PURE__ */ jsx("span", {
75
- className: "text-muted-foreground text-base",
76
- children: "Filtres actifs:"
77
- }), filters.filter((f) => f.value).map((filter) => {
78
- const selectedOption = filter.options.find((opt) => opt.value === filter.value);
79
- return /* @__PURE__ */ jsxs(Button, {
80
- variant: "secondary",
81
- size: "sm",
82
- onClick: () => filter.onChange(""),
83
- disabled: disabled || isLoading,
84
- className: "h-7 px-2 text-sm",
85
- children: [
86
- filter.label,
87
- ": ",
88
- selectedOption?.label,
89
- /* @__PURE__ */ jsx("span", {
90
- className: "ml-1",
91
- children: "×"
92
- })
93
- ]
94
- }, filter.key);
95
- })]
96
- })
97
- ]
98
- });
4
+ // ui/button.tsx
5
+ import * as React from "react";
6
+ import { Slot } from "@radix-ui/react-slot";
7
+ import { cva } from "class-variance-authority";
8
+ import { cn } from "@contractspec/lib.ui-kit-core/utils";
9
+ import { jsxDEV } from "react/jsx-dev-runtime";
10
+ var buttonVariants = cva("inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-hidden focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive", {
11
+ variants: {
12
+ variant: {
13
+ default: "bg-primary text-primary-foreground hover:bg-primary/90",
14
+ destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
15
+ outline: "border bg-background shadow-2xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
16
+ secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
17
+ ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
18
+ link: "text-primary underline-offset-4 hover:underline"
19
+ },
20
+ size: {
21
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
22
+ sm: "h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",
23
+ lg: "h-10 rounded-md px-6 has-[>svg]:px-4",
24
+ icon: "size-9"
25
+ }
26
+ },
27
+ defaultVariants: {
28
+ variant: "default",
29
+ size: "default"
30
+ }
31
+ });
32
+ var Button = React.forwardRef(({ className, variant, size, asChild = false, ...props }, ref) => {
33
+ if (asChild) {
34
+ return /* @__PURE__ */ jsxDEV(Slot, {
35
+ "data-slot": "button",
36
+ className: cn(buttonVariants({ variant, size, className })),
37
+ ...props
38
+ }, undefined, false, undefined, this);
39
+ }
40
+ return /* @__PURE__ */ jsxDEV("button", {
41
+ ref,
42
+ "data-slot": "button",
43
+ className: cn(buttonVariants({ variant, size, className })),
44
+ ...props
45
+ }, undefined, false, undefined, this);
46
+ });
47
+ Button.displayName = "Button";
48
+ // ui/select.tsx
49
+ import * as SelectPrimitive from "@radix-ui/react-select";
50
+ import { CheckIcon, ChevronDownIcon, ChevronUpIcon } from "lucide-react";
51
+ import { cn as cn2 } from "@contractspec/lib.ui-kit-core/utils";
52
+ import { jsxDEV as jsxDEV2 } from "react/jsx-dev-runtime";
53
+ "use client";
54
+ function Select({
55
+ ...props
56
+ }) {
57
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Root, {
58
+ "data-slot": "select",
59
+ ...props
60
+ }, undefined, false, undefined, this);
61
+ }
62
+ function SelectGroup({
63
+ ...props
64
+ }) {
65
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Group, {
66
+ "data-slot": "select-group",
67
+ ...props
68
+ }, undefined, false, undefined, this);
69
+ }
70
+ function SelectValue({
71
+ ...props
72
+ }) {
73
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Value, {
74
+ "data-slot": "select-value",
75
+ ...props
76
+ }, undefined, false, undefined, this);
77
+ }
78
+ function SelectTrigger({
79
+ className,
80
+ size = "default",
81
+ children,
82
+ ...props
83
+ }) {
84
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Trigger, {
85
+ "data-slot": "select-trigger",
86
+ "data-size": size,
87
+ className: cn2("aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive border-input focus-visible:border-ring focus-visible:ring-ring/50 data-placeholder:text-muted-foreground dark:bg-input/30 dark:hover:bg-input/50 [&_svg:not([class*='text-'])]:text-muted-foreground flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-2xs outline-hidden transition-[color,box-shadow] focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4", className),
88
+ ...props,
89
+ children: [
90
+ children,
91
+ /* @__PURE__ */ jsxDEV2(SelectPrimitive.Icon, {
92
+ asChild: true,
93
+ children: /* @__PURE__ */ jsxDEV2(ChevronDownIcon, {
94
+ className: "size-4 opacity-50"
95
+ }, undefined, false, undefined, this)
96
+ }, undefined, false, undefined, this)
97
+ ]
98
+ }, undefined, true, undefined, this);
99
+ }
100
+ function SelectContent({
101
+ className,
102
+ children,
103
+ position = "popper",
104
+ ...props
105
+ }) {
106
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Portal, {
107
+ children: /* @__PURE__ */ jsxDEV2(SelectPrimitive.Content, {
108
+ "data-slot": "select-content",
109
+ className: cn2("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-(--radix-select-content-available-height) min-w-32 origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md", position === "popper" && "data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1", className),
110
+ position,
111
+ ...props,
112
+ children: [
113
+ /* @__PURE__ */ jsxDEV2(SelectScrollUpButton, {}, undefined, false, undefined, this),
114
+ /* @__PURE__ */ jsxDEV2(SelectPrimitive.Viewport, {
115
+ className: cn2("p-1", position === "popper" && "h-(--radix-select-trigger-height) w-full min-w-(--radix-select-trigger-width) scroll-my-1"),
116
+ children
117
+ }, undefined, false, undefined, this),
118
+ /* @__PURE__ */ jsxDEV2(SelectScrollDownButton, {}, undefined, false, undefined, this)
119
+ ]
120
+ }, undefined, true, undefined, this)
121
+ }, undefined, false, undefined, this);
122
+ }
123
+ function SelectLabel({
124
+ className,
125
+ ...props
126
+ }) {
127
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Label, {
128
+ "data-slot": "select-label",
129
+ className: cn2("text-muted-foreground px-2 py-1.5 text-xs", className),
130
+ ...props
131
+ }, undefined, false, undefined, this);
132
+ }
133
+ function SelectItem({
134
+ className,
135
+ children,
136
+ ...props
137
+ }) {
138
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Item, {
139
+ "data-slot": "select-item",
140
+ className: cn2("focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-xs py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-disabled:pointer-events-none data-disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2", className),
141
+ ...props,
142
+ children: [
143
+ /* @__PURE__ */ jsxDEV2("span", {
144
+ className: "absolute right-2 flex size-3.5 items-center justify-center",
145
+ children: /* @__PURE__ */ jsxDEV2(SelectPrimitive.ItemIndicator, {
146
+ children: /* @__PURE__ */ jsxDEV2(CheckIcon, {
147
+ className: "size-4"
148
+ }, undefined, false, undefined, this)
149
+ }, undefined, false, undefined, this)
150
+ }, undefined, false, undefined, this),
151
+ /* @__PURE__ */ jsxDEV2(SelectPrimitive.ItemText, {
152
+ children
153
+ }, undefined, false, undefined, this)
154
+ ]
155
+ }, undefined, true, undefined, this);
156
+ }
157
+ function SelectSeparator({
158
+ className,
159
+ ...props
160
+ }) {
161
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Separator, {
162
+ "data-slot": "select-separator",
163
+ className: cn2("bg-border pointer-events-none -mx-1 my-1 h-px", className),
164
+ ...props
165
+ }, undefined, false, undefined, this);
166
+ }
167
+ function SelectScrollUpButton({
168
+ className,
169
+ ...props
170
+ }) {
171
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.ScrollUpButton, {
172
+ "data-slot": "select-scroll-up-button",
173
+ className: cn2("flex cursor-default items-center justify-center py-1", className),
174
+ ...props,
175
+ children: /* @__PURE__ */ jsxDEV2(ChevronUpIcon, {
176
+ className: "size-4"
177
+ }, undefined, false, undefined, this)
178
+ }, undefined, false, undefined, this);
179
+ }
180
+ function SelectScrollDownButton({
181
+ className,
182
+ ...props
183
+ }) {
184
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.ScrollDownButton, {
185
+ "data-slot": "select-scroll-down-button",
186
+ className: cn2("flex cursor-default items-center justify-center py-1", className),
187
+ ...props,
188
+ children: /* @__PURE__ */ jsxDEV2(ChevronDownIcon, {
189
+ className: "size-4"
190
+ }, undefined, false, undefined, this)
191
+ }, undefined, false, undefined, this);
192
+ }
193
+ // ui/label.tsx
194
+ import * as LabelPrimitive from "@radix-ui/react-label";
195
+ import { cn as cn3 } from "@contractspec/lib.ui-kit-core/utils";
196
+ import { jsxDEV as jsxDEV3 } from "react/jsx-dev-runtime";
197
+ "use client";
198
+ function Label2({
199
+ className,
200
+ ...props
201
+ }) {
202
+ return /* @__PURE__ */ jsxDEV3(LabelPrimitive.Root, {
203
+ "data-slot": "label",
204
+ className: cn3("flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50", className),
205
+ ...props
206
+ }, undefined, false, undefined, this);
207
+ }
208
+ // ui/atoms/FilterSelect/FilterSelect.tsx
209
+ import { jsxDEV as jsxDEV4 } from "react/jsx-dev-runtime";
210
+ var FilterSelect = ({
211
+ value,
212
+ options,
213
+ onChange,
214
+ placeholder = "S\xE9lectionner...",
215
+ label,
216
+ disabled = false,
217
+ className = "",
218
+ showCounts = false
219
+ }) => {
220
+ return /* @__PURE__ */ jsxDEV4("div", {
221
+ className: `space-y-2 ${className}`,
222
+ children: [
223
+ label && /* @__PURE__ */ jsxDEV4(Label2, {
224
+ className: "text-foreground text-base font-medium",
225
+ children: label
226
+ }, undefined, false, undefined, this),
227
+ /* @__PURE__ */ jsxDEV4(Select, {
228
+ value,
229
+ onValueChange: onChange,
230
+ disabled,
231
+ children: [
232
+ /* @__PURE__ */ jsxDEV4(SelectTrigger, {
233
+ className: "w-full",
234
+ children: /* @__PURE__ */ jsxDEV4(SelectValue, {
235
+ placeholder
236
+ }, undefined, false, undefined, this)
237
+ }, undefined, false, undefined, this),
238
+ /* @__PURE__ */ jsxDEV4(SelectContent, {
239
+ className: "bg-background",
240
+ children: [
241
+ /* @__PURE__ */ jsxDEV4(SelectItem, {
242
+ value: "all",
243
+ children: [
244
+ "Tous",
245
+ showCounts && /* @__PURE__ */ jsxDEV4("span", {
246
+ className: "text-muted-foreground ml-2 text-sm",
247
+ children: [
248
+ "(",
249
+ options.reduce((sum, option) => sum + (option.count || 0), 0),
250
+ ")"
251
+ ]
252
+ }, undefined, true, undefined, this)
253
+ ]
254
+ }, undefined, true, undefined, this),
255
+ options.map((option) => /* @__PURE__ */ jsxDEV4(SelectItem, {
256
+ value: option.value,
257
+ children: /* @__PURE__ */ jsxDEV4("div", {
258
+ className: "flex w-full items-center justify-between",
259
+ children: [
260
+ /* @__PURE__ */ jsxDEV4("span", {
261
+ children: option.label
262
+ }, undefined, false, undefined, this),
263
+ showCounts && option.count !== undefined && /* @__PURE__ */ jsxDEV4("span", {
264
+ className: "text-muted-foreground ml-2 text-sm",
265
+ children: [
266
+ "(",
267
+ option.count,
268
+ ")"
269
+ ]
270
+ }, undefined, true, undefined, this)
271
+ ]
272
+ }, undefined, true, undefined, this)
273
+ }, option.value, false, undefined, this))
274
+ ]
275
+ }, undefined, true, undefined, this)
276
+ ]
277
+ }, undefined, true, undefined, this)
278
+ ]
279
+ }, undefined, true, undefined, this);
280
+ };
281
+ // ui/input.tsx
282
+ import { cn as cn4 } from "@contractspec/lib.ui-kit-core/utils";
283
+ import { jsxDEV as jsxDEV5 } from "react/jsx-dev-runtime";
284
+ function Input({ className, type, ...props }) {
285
+ return /* @__PURE__ */ jsxDEV5("input", {
286
+ type,
287
+ "data-slot": "input",
288
+ className: cn4("file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm", "focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]", "aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive", className),
289
+ ...props
290
+ }, undefined, false, undefined, this);
291
+ }
292
+ // ui/atoms/SearchInput/SearchInput.tsx
293
+ import { Search, X } from "lucide-react";
294
+ import { jsxDEV as jsxDEV6 } from "react/jsx-dev-runtime";
295
+ var SearchInput = ({
296
+ value,
297
+ onChange,
298
+ placeholder = "Rechercher...",
299
+ onClear,
300
+ disabled = false,
301
+ className = "",
302
+ autoFocus = false
303
+ }) => {
304
+ const handleClear = () => {
305
+ onChange("");
306
+ onClear?.();
307
+ };
308
+ return /* @__PURE__ */ jsxDEV6("div", {
309
+ className: `relative w-full ${className}`,
310
+ children: [
311
+ /* @__PURE__ */ jsxDEV6("div", {
312
+ className: "pointer-events-none absolute inset-y-0 left-0 flex items-center pl-3",
313
+ children: /* @__PURE__ */ jsxDEV6(Search, {
314
+ className: "text-muted-foreground h-4 w-4"
315
+ }, undefined, false, undefined, this)
316
+ }, undefined, false, undefined, this),
317
+ /* @__PURE__ */ jsxDEV6(Input, {
318
+ type: "text",
319
+ value,
320
+ onChange: (e) => onChange(e.target.value),
321
+ placeholder,
322
+ disabled,
323
+ autoFocus,
324
+ className: "pr-10 pl-10"
325
+ }, undefined, false, undefined, this),
326
+ value && /* @__PURE__ */ jsxDEV6("div", {
327
+ className: "absolute inset-y-0 right-0 flex items-center pr-3",
328
+ children: /* @__PURE__ */ jsxDEV6(Button, {
329
+ type: "button",
330
+ variant: "ghost",
331
+ size: "sm",
332
+ onClick: handleClear,
333
+ disabled,
334
+ className: "h-6 w-6 p-0 hover:bg-transparent",
335
+ children: [
336
+ /* @__PURE__ */ jsxDEV6(X, {
337
+ className: "text-muted-foreground hover:text-foreground h-4 w-4"
338
+ }, undefined, false, undefined, this),
339
+ /* @__PURE__ */ jsxDEV6("span", {
340
+ className: "sr-only",
341
+ children: "Effacer la recherche"
342
+ }, undefined, false, undefined, this)
343
+ ]
344
+ }, undefined, true, undefined, this)
345
+ }, undefined, false, undefined, this)
346
+ ]
347
+ }, undefined, true, undefined, this);
348
+ };
349
+ // ui/collapsible.tsx
350
+ import * as CollapsiblePrimitive from "@radix-ui/react-collapsible";
351
+ import { jsxDEV as jsxDEV7 } from "react/jsx-dev-runtime";
352
+ "use client";
353
+ function Collapsible({
354
+ ...props
355
+ }) {
356
+ return /* @__PURE__ */ jsxDEV7(CollapsiblePrimitive.Root, {
357
+ "data-slot": "collapsible",
358
+ ...props
359
+ }, undefined, false, undefined, this);
360
+ }
361
+ function CollapsibleTrigger2({
362
+ ...props
363
+ }) {
364
+ return /* @__PURE__ */ jsxDEV7(CollapsiblePrimitive.CollapsibleTrigger, {
365
+ "data-slot": "collapsible-trigger",
366
+ ...props
367
+ }, undefined, false, undefined, this);
368
+ }
369
+ function CollapsibleContent2({
370
+ ...props
371
+ }) {
372
+ return /* @__PURE__ */ jsxDEV7(CollapsiblePrimitive.CollapsibleContent, {
373
+ "data-slot": "collapsible-content",
374
+ ...props
375
+ }, undefined, false, undefined, this);
376
+ }
377
+ // ui/molecules/SearchAndFilter/SearchAndFilter.tsx
378
+ import { useState } from "react";
379
+ import { ChevronDown, ChevronUp, Filter } from "lucide-react";
380
+ import { jsxDEV as jsxDEV8 } from "react/jsx-dev-runtime";
381
+ var SearchAndFilter = ({
382
+ searchValue,
383
+ onSearchChange,
384
+ searchPlaceholder,
385
+ filters = [],
386
+ isLoading = false,
387
+ disabled = false,
388
+ className = "",
389
+ collapsible = true,
390
+ defaultCollapsed = false
391
+ }) => {
392
+ const [isCollapsed, setIsCollapsed] = useState(defaultCollapsed);
393
+ const hasFilters = filters.length > 0;
394
+ const activeFiltersCount = filters.filter((f) => f.value).length;
395
+ const shouldUseCollapsible = collapsible && hasFilters;
396
+ console.log("SearchAndFilter", { filters });
397
+ const FilterComponents = () => /* @__PURE__ */ jsxDEV8("div", {
398
+ className: "grid grid-cols-1 gap-4 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4",
399
+ children: filters.map((filter) => /* @__PURE__ */ jsxDEV8(FilterSelect, {
400
+ value: filter.value,
401
+ options: filter.options,
402
+ onChange: filter.onChange,
403
+ label: filter.label,
404
+ disabled: disabled || isLoading,
405
+ showCounts: filter.showCounts,
406
+ className: "min-w-0"
407
+ }, filter.key, false, undefined, this))
408
+ }, undefined, false, undefined, this);
409
+ return /* @__PURE__ */ jsxDEV8("div", {
410
+ className: `space-y-4 ${className}`,
411
+ children: [
412
+ /* @__PURE__ */ jsxDEV8("div", {
413
+ className: "flex flex-col gap-4 sm:flex-row",
414
+ children: [
415
+ /* @__PURE__ */ jsxDEV8("div", {
416
+ className: "flex-1",
417
+ children: /* @__PURE__ */ jsxDEV8(SearchInput, {
418
+ value: searchValue,
419
+ onChange: onSearchChange,
420
+ placeholder: searchPlaceholder,
421
+ disabled: disabled || isLoading,
422
+ className: "w-full"
423
+ }, undefined, false, undefined, this)
424
+ }, undefined, false, undefined, this),
425
+ shouldUseCollapsible && /* @__PURE__ */ jsxDEV8(Collapsible, {
426
+ open: !isCollapsed,
427
+ onOpenChange: setIsCollapsed,
428
+ className: "sm:hidden",
429
+ children: [
430
+ /* @__PURE__ */ jsxDEV8(CollapsibleTrigger2, {
431
+ asChild: true,
432
+ children: /* @__PURE__ */ jsxDEV8(Button, {
433
+ variant: "outline",
434
+ className: "sm:hidden",
435
+ disabled: disabled || isLoading,
436
+ children: [
437
+ /* @__PURE__ */ jsxDEV8(Filter, {
438
+ className: "mr-2 h-4 w-4"
439
+ }, undefined, false, undefined, this),
440
+ "Filtres",
441
+ activeFiltersCount > 0 && /* @__PURE__ */ jsxDEV8("span", {
442
+ className: "bg-primary text-primary-foreground ml-2 flex h-5 w-5 items-center justify-center rounded-full text-sm",
443
+ children: activeFiltersCount
444
+ }, undefined, false, undefined, this),
445
+ isCollapsed ? /* @__PURE__ */ jsxDEV8(ChevronDown, {
446
+ className: "ml-2 h-4 w-4"
447
+ }, undefined, false, undefined, this) : /* @__PURE__ */ jsxDEV8(ChevronUp, {
448
+ className: "ml-2 h-4 w-4"
449
+ }, undefined, false, undefined, this)
450
+ ]
451
+ }, undefined, true, undefined, this)
452
+ }, undefined, false, undefined, this),
453
+ /* @__PURE__ */ jsxDEV8(CollapsibleContent2, {
454
+ className: "mt-4 space-y-4",
455
+ children: /* @__PURE__ */ jsxDEV8(FilterComponents, {}, undefined, false, undefined, this)
456
+ }, undefined, false, undefined, this)
457
+ ]
458
+ }, undefined, true, undefined, this)
459
+ ]
460
+ }, undefined, true, undefined, this),
461
+ hasFilters && /* @__PURE__ */ jsxDEV8("div", {
462
+ className: "hidden sm:block",
463
+ children: /* @__PURE__ */ jsxDEV8(FilterComponents, {}, undefined, false, undefined, this)
464
+ }, undefined, false, undefined, this),
465
+ activeFiltersCount > 0 && /* @__PURE__ */ jsxDEV8("div", {
466
+ className: "flex flex-wrap items-center gap-2",
467
+ children: [
468
+ /* @__PURE__ */ jsxDEV8("span", {
469
+ className: "text-muted-foreground text-base",
470
+ children: "Filtres actifs:"
471
+ }, undefined, false, undefined, this),
472
+ filters.filter((f) => f.value).map((filter) => {
473
+ const selectedOption = filter.options.find((opt) => opt.value === filter.value);
474
+ return /* @__PURE__ */ jsxDEV8(Button, {
475
+ variant: "secondary",
476
+ size: "sm",
477
+ onClick: () => filter.onChange(""),
478
+ disabled: disabled || isLoading,
479
+ className: "h-7 px-2 text-sm",
480
+ children: [
481
+ filter.label,
482
+ ": ",
483
+ selectedOption?.label,
484
+ /* @__PURE__ */ jsxDEV8("span", {
485
+ className: "ml-1",
486
+ children: "\xD7"
487
+ }, undefined, false, undefined, this)
488
+ ]
489
+ }, filter.key, true, undefined, this);
490
+ })
491
+ ]
492
+ }, undefined, true, undefined, this)
493
+ ]
494
+ }, undefined, true, undefined, this);
495
+ };
496
+ export {
497
+ SearchAndFilter
99
498
  };
100
-
101
- //#endregion
102
- export { SearchAndFilter };
103
- //# sourceMappingURL=SearchAndFilter.js.map
@@ -1,3 +1,3 @@
1
- import { SearchAndFilterProps } from "./types.js";
2
- import { SearchAndFilter } from "./SearchAndFilter.js";
3
- export { SearchAndFilter, type SearchAndFilterProps };
1
+ export { SearchAndFilter } from './SearchAndFilter';
2
+ export type { SearchAndFilterProps } from './types';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../ui/molecules/SearchAndFilter/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,YAAY,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC"}