@contractspec/lib.ui-kit-web 1.57.0 → 1.59.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
@@ -0,0 +1,1236 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined")
5
+ return require.apply(this, arguments);
6
+ throw Error('Dynamic require of "' + x + '" is not supported');
7
+ });
8
+
9
+ // ui/button.tsx
10
+ import * as React from "react";
11
+ import { Slot } from "@radix-ui/react-slot";
12
+ import { cva } from "class-variance-authority";
13
+ import { cn } from "@contractspec/lib.ui-kit-core/utils";
14
+ import { jsxDEV } from "react/jsx-dev-runtime";
15
+ 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", {
16
+ variants: {
17
+ variant: {
18
+ default: "bg-primary text-primary-foreground hover:bg-primary/90",
19
+ destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
20
+ 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",
21
+ secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
22
+ ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
23
+ link: "text-primary underline-offset-4 hover:underline"
24
+ },
25
+ size: {
26
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
27
+ sm: "h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",
28
+ lg: "h-10 rounded-md px-6 has-[>svg]:px-4",
29
+ icon: "size-9"
30
+ }
31
+ },
32
+ defaultVariants: {
33
+ variant: "default",
34
+ size: "default"
35
+ }
36
+ });
37
+ var Button = React.forwardRef(({ className, variant, size, asChild = false, ...props }, ref) => {
38
+ if (asChild) {
39
+ return /* @__PURE__ */ jsxDEV(Slot, {
40
+ "data-slot": "button",
41
+ className: cn(buttonVariants({ variant, size, className })),
42
+ ...props
43
+ }, undefined, false, undefined, this);
44
+ }
45
+ return /* @__PURE__ */ jsxDEV("button", {
46
+ ref,
47
+ "data-slot": "button",
48
+ className: cn(buttonVariants({ variant, size, className })),
49
+ ...props
50
+ }, undefined, false, undefined, this);
51
+ });
52
+ Button.displayName = "Button";
53
+ // ui/select.tsx
54
+ import * as SelectPrimitive from "@radix-ui/react-select";
55
+ import { CheckIcon, ChevronDownIcon, ChevronUpIcon } from "lucide-react";
56
+ import { cn as cn2 } from "@contractspec/lib.ui-kit-core/utils";
57
+ import { jsxDEV as jsxDEV2 } from "react/jsx-dev-runtime";
58
+ "use client";
59
+ function Select({
60
+ ...props
61
+ }) {
62
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Root, {
63
+ "data-slot": "select",
64
+ ...props
65
+ }, undefined, false, undefined, this);
66
+ }
67
+ function SelectGroup({
68
+ ...props
69
+ }) {
70
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Group, {
71
+ "data-slot": "select-group",
72
+ ...props
73
+ }, undefined, false, undefined, this);
74
+ }
75
+ function SelectValue({
76
+ ...props
77
+ }) {
78
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Value, {
79
+ "data-slot": "select-value",
80
+ ...props
81
+ }, undefined, false, undefined, this);
82
+ }
83
+ function SelectTrigger({
84
+ className,
85
+ size = "default",
86
+ children,
87
+ ...props
88
+ }) {
89
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Trigger, {
90
+ "data-slot": "select-trigger",
91
+ "data-size": size,
92
+ 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),
93
+ ...props,
94
+ children: [
95
+ children,
96
+ /* @__PURE__ */ jsxDEV2(SelectPrimitive.Icon, {
97
+ asChild: true,
98
+ children: /* @__PURE__ */ jsxDEV2(ChevronDownIcon, {
99
+ className: "size-4 opacity-50"
100
+ }, undefined, false, undefined, this)
101
+ }, undefined, false, undefined, this)
102
+ ]
103
+ }, undefined, true, undefined, this);
104
+ }
105
+ function SelectContent({
106
+ className,
107
+ children,
108
+ position = "popper",
109
+ ...props
110
+ }) {
111
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Portal, {
112
+ children: /* @__PURE__ */ jsxDEV2(SelectPrimitive.Content, {
113
+ "data-slot": "select-content",
114
+ 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),
115
+ position,
116
+ ...props,
117
+ children: [
118
+ /* @__PURE__ */ jsxDEV2(SelectScrollUpButton, {}, undefined, false, undefined, this),
119
+ /* @__PURE__ */ jsxDEV2(SelectPrimitive.Viewport, {
120
+ className: cn2("p-1", position === "popper" && "h-(--radix-select-trigger-height) w-full min-w-(--radix-select-trigger-width) scroll-my-1"),
121
+ children
122
+ }, undefined, false, undefined, this),
123
+ /* @__PURE__ */ jsxDEV2(SelectScrollDownButton, {}, undefined, false, undefined, this)
124
+ ]
125
+ }, undefined, true, undefined, this)
126
+ }, undefined, false, undefined, this);
127
+ }
128
+ function SelectLabel({
129
+ className,
130
+ ...props
131
+ }) {
132
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Label, {
133
+ "data-slot": "select-label",
134
+ className: cn2("text-muted-foreground px-2 py-1.5 text-xs", className),
135
+ ...props
136
+ }, undefined, false, undefined, this);
137
+ }
138
+ function SelectItem({
139
+ className,
140
+ children,
141
+ ...props
142
+ }) {
143
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Item, {
144
+ "data-slot": "select-item",
145
+ 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),
146
+ ...props,
147
+ children: [
148
+ /* @__PURE__ */ jsxDEV2("span", {
149
+ className: "absolute right-2 flex size-3.5 items-center justify-center",
150
+ children: /* @__PURE__ */ jsxDEV2(SelectPrimitive.ItemIndicator, {
151
+ children: /* @__PURE__ */ jsxDEV2(CheckIcon, {
152
+ className: "size-4"
153
+ }, undefined, false, undefined, this)
154
+ }, undefined, false, undefined, this)
155
+ }, undefined, false, undefined, this),
156
+ /* @__PURE__ */ jsxDEV2(SelectPrimitive.ItemText, {
157
+ children
158
+ }, undefined, false, undefined, this)
159
+ ]
160
+ }, undefined, true, undefined, this);
161
+ }
162
+ function SelectSeparator({
163
+ className,
164
+ ...props
165
+ }) {
166
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.Separator, {
167
+ "data-slot": "select-separator",
168
+ className: cn2("bg-border pointer-events-none -mx-1 my-1 h-px", className),
169
+ ...props
170
+ }, undefined, false, undefined, this);
171
+ }
172
+ function SelectScrollUpButton({
173
+ className,
174
+ ...props
175
+ }) {
176
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.ScrollUpButton, {
177
+ "data-slot": "select-scroll-up-button",
178
+ className: cn2("flex cursor-default items-center justify-center py-1", className),
179
+ ...props,
180
+ children: /* @__PURE__ */ jsxDEV2(ChevronUpIcon, {
181
+ className: "size-4"
182
+ }, undefined, false, undefined, this)
183
+ }, undefined, false, undefined, this);
184
+ }
185
+ function SelectScrollDownButton({
186
+ className,
187
+ ...props
188
+ }) {
189
+ return /* @__PURE__ */ jsxDEV2(SelectPrimitive.ScrollDownButton, {
190
+ "data-slot": "select-scroll-down-button",
191
+ className: cn2("flex cursor-default items-center justify-center py-1", className),
192
+ ...props,
193
+ children: /* @__PURE__ */ jsxDEV2(ChevronDownIcon, {
194
+ className: "size-4"
195
+ }, undefined, false, undefined, this)
196
+ }, undefined, false, undefined, this);
197
+ }
198
+ // ui/label.tsx
199
+ import * as LabelPrimitive from "@radix-ui/react-label";
200
+ import { cn as cn3 } from "@contractspec/lib.ui-kit-core/utils";
201
+ import { jsxDEV as jsxDEV3 } from "react/jsx-dev-runtime";
202
+ "use client";
203
+ function Label2({
204
+ className,
205
+ ...props
206
+ }) {
207
+ return /* @__PURE__ */ jsxDEV3(LabelPrimitive.Root, {
208
+ "data-slot": "label",
209
+ 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),
210
+ ...props
211
+ }, undefined, false, undefined, this);
212
+ }
213
+ // ui/atoms/FilterSelect/FilterSelect.tsx
214
+ import { jsxDEV as jsxDEV4 } from "react/jsx-dev-runtime";
215
+ var FilterSelect = ({
216
+ value,
217
+ options,
218
+ onChange,
219
+ placeholder = "Sélectionner...",
220
+ label,
221
+ disabled = false,
222
+ className = "",
223
+ showCounts = false
224
+ }) => {
225
+ return /* @__PURE__ */ jsxDEV4("div", {
226
+ className: `space-y-2 ${className}`,
227
+ children: [
228
+ label && /* @__PURE__ */ jsxDEV4(Label2, {
229
+ className: "text-foreground text-base font-medium",
230
+ children: label
231
+ }, undefined, false, undefined, this),
232
+ /* @__PURE__ */ jsxDEV4(Select, {
233
+ value,
234
+ onValueChange: onChange,
235
+ disabled,
236
+ children: [
237
+ /* @__PURE__ */ jsxDEV4(SelectTrigger, {
238
+ className: "w-full",
239
+ children: /* @__PURE__ */ jsxDEV4(SelectValue, {
240
+ placeholder
241
+ }, undefined, false, undefined, this)
242
+ }, undefined, false, undefined, this),
243
+ /* @__PURE__ */ jsxDEV4(SelectContent, {
244
+ className: "bg-background",
245
+ children: [
246
+ /* @__PURE__ */ jsxDEV4(SelectItem, {
247
+ value: "all",
248
+ children: [
249
+ "Tous",
250
+ showCounts && /* @__PURE__ */ jsxDEV4("span", {
251
+ className: "text-muted-foreground ml-2 text-sm",
252
+ children: [
253
+ "(",
254
+ options.reduce((sum, option) => sum + (option.count || 0), 0),
255
+ ")"
256
+ ]
257
+ }, undefined, true, undefined, this)
258
+ ]
259
+ }, undefined, true, undefined, this),
260
+ options.map((option) => /* @__PURE__ */ jsxDEV4(SelectItem, {
261
+ value: option.value,
262
+ children: /* @__PURE__ */ jsxDEV4("div", {
263
+ className: "flex w-full items-center justify-between",
264
+ children: [
265
+ /* @__PURE__ */ jsxDEV4("span", {
266
+ children: option.label
267
+ }, undefined, false, undefined, this),
268
+ showCounts && option.count !== undefined && /* @__PURE__ */ jsxDEV4("span", {
269
+ className: "text-muted-foreground ml-2 text-sm",
270
+ children: [
271
+ "(",
272
+ option.count,
273
+ ")"
274
+ ]
275
+ }, undefined, true, undefined, this)
276
+ ]
277
+ }, undefined, true, undefined, this)
278
+ }, option.value, false, undefined, this))
279
+ ]
280
+ }, undefined, true, undefined, this)
281
+ ]
282
+ }, undefined, true, undefined, this)
283
+ ]
284
+ }, undefined, true, undefined, this);
285
+ };
286
+ // ui/atoms/Pagination/Pagination.tsx
287
+ import {
288
+ ChevronLeft,
289
+ ChevronRight,
290
+ ChevronsLeft,
291
+ ChevronsRight
292
+ } from "lucide-react";
293
+ import { jsxDEV as jsxDEV5 } from "react/jsx-dev-runtime";
294
+ var Pagination = ({
295
+ currentPage,
296
+ totalPages,
297
+ totalItems,
298
+ itemsPerPage,
299
+ onPageChange,
300
+ onItemsPerPageChange,
301
+ disabled = false,
302
+ className = "",
303
+ showItemsPerPage = true,
304
+ itemsPerPageOptions = [10, 25, 50, 100]
305
+ }) => {
306
+ const startItem = (currentPage - 1) * itemsPerPage + 1;
307
+ const endItem = Math.min(currentPage * itemsPerPage, totalItems);
308
+ const canGoPrevious = currentPage > 1 && !disabled;
309
+ const canGoNext = currentPage < totalPages && !disabled;
310
+ const getVisiblePageNumbers = () => {
311
+ if (totalPages <= 7) {
312
+ return Array.from({ length: totalPages }, (_, i) => i + 1);
313
+ }
314
+ if (currentPage <= 3) {
315
+ return [1, 2, 3, 4, 5, -1, totalPages];
316
+ }
317
+ if (currentPage >= totalPages - 2) {
318
+ return [
319
+ 1,
320
+ -1,
321
+ totalPages - 4,
322
+ totalPages - 3,
323
+ totalPages - 2,
324
+ totalPages - 1,
325
+ totalPages
326
+ ];
327
+ }
328
+ return [
329
+ 1,
330
+ -1,
331
+ currentPage - 1,
332
+ currentPage,
333
+ currentPage + 1,
334
+ -1,
335
+ totalPages
336
+ ];
337
+ };
338
+ if (totalPages === 0)
339
+ return null;
340
+ return /* @__PURE__ */ jsxDEV5("div", {
341
+ className: `flex flex-col items-center justify-between gap-4 sm:flex-row ${className}`,
342
+ children: [
343
+ /* @__PURE__ */ jsxDEV5("div", {
344
+ className: "text-muted-foreground order-2 text-base sm:order-1",
345
+ children: [
346
+ "Affichage de ",
347
+ startItem,
348
+ " à ",
349
+ endItem,
350
+ " sur ",
351
+ totalItems,
352
+ " résultats"
353
+ ]
354
+ }, undefined, true, undefined, this),
355
+ /* @__PURE__ */ jsxDEV5("div", {
356
+ className: "order-1 flex items-center gap-2 sm:order-2",
357
+ children: [
358
+ /* @__PURE__ */ jsxDEV5(Button, {
359
+ variant: "outline",
360
+ size: "sm",
361
+ onClick: () => onPageChange(1),
362
+ disabled: !canGoPrevious,
363
+ className: "hidden h-8 w-8 p-0 sm:flex",
364
+ children: [
365
+ /* @__PURE__ */ jsxDEV5(ChevronsLeft, {
366
+ className: "h-4 w-4"
367
+ }, undefined, false, undefined, this),
368
+ /* @__PURE__ */ jsxDEV5("span", {
369
+ className: "sr-only",
370
+ children: "Première page"
371
+ }, undefined, false, undefined, this)
372
+ ]
373
+ }, undefined, true, undefined, this),
374
+ /* @__PURE__ */ jsxDEV5(Button, {
375
+ variant: "outline",
376
+ size: "sm",
377
+ onClick: () => onPageChange(currentPage - 1),
378
+ disabled: !canGoPrevious,
379
+ className: "h-8 w-8 p-0",
380
+ children: [
381
+ /* @__PURE__ */ jsxDEV5(ChevronLeft, {
382
+ className: "h-4 w-4"
383
+ }, undefined, false, undefined, this),
384
+ /* @__PURE__ */ jsxDEV5("span", {
385
+ className: "sr-only",
386
+ children: "Page précédente"
387
+ }, undefined, false, undefined, this)
388
+ ]
389
+ }, undefined, true, undefined, this),
390
+ /* @__PURE__ */ jsxDEV5("div", {
391
+ className: "flex items-center gap-1",
392
+ children: getVisiblePageNumbers().map((page, index) => {
393
+ if (page === -1) {
394
+ return /* @__PURE__ */ jsxDEV5("span", {
395
+ className: "text-muted-foreground px-2 py-1",
396
+ children: "..."
397
+ }, `ellipsis-${index}`, false, undefined, this);
398
+ }
399
+ return /* @__PURE__ */ jsxDEV5(Button, {
400
+ variant: page === currentPage ? "default" : "outline",
401
+ size: "sm",
402
+ onClick: () => onPageChange(page),
403
+ disabled,
404
+ className: "h-8 min-w-8 px-2",
405
+ children: page
406
+ }, page, false, undefined, this);
407
+ })
408
+ }, undefined, false, undefined, this),
409
+ /* @__PURE__ */ jsxDEV5(Button, {
410
+ variant: "outline",
411
+ size: "sm",
412
+ onClick: () => onPageChange(currentPage + 1),
413
+ disabled: !canGoNext,
414
+ className: "h-8 w-8 p-0",
415
+ children: [
416
+ /* @__PURE__ */ jsxDEV5(ChevronRight, {
417
+ className: "h-4 w-4"
418
+ }, undefined, false, undefined, this),
419
+ /* @__PURE__ */ jsxDEV5("span", {
420
+ className: "sr-only",
421
+ children: "Page suivante"
422
+ }, undefined, false, undefined, this)
423
+ ]
424
+ }, undefined, true, undefined, this),
425
+ /* @__PURE__ */ jsxDEV5(Button, {
426
+ variant: "outline",
427
+ size: "sm",
428
+ onClick: () => onPageChange(totalPages),
429
+ disabled: !canGoNext,
430
+ className: "hidden h-8 w-8 p-0 sm:flex",
431
+ children: [
432
+ /* @__PURE__ */ jsxDEV5(ChevronsRight, {
433
+ className: "h-4 w-4"
434
+ }, undefined, false, undefined, this),
435
+ /* @__PURE__ */ jsxDEV5("span", {
436
+ className: "sr-only",
437
+ children: "Dernière page"
438
+ }, undefined, false, undefined, this)
439
+ ]
440
+ }, undefined, true, undefined, this)
441
+ ]
442
+ }, undefined, true, undefined, this),
443
+ showItemsPerPage && onItemsPerPageChange && /* @__PURE__ */ jsxDEV5("div", {
444
+ className: "order-3 flex items-center gap-2 text-base",
445
+ children: [
446
+ /* @__PURE__ */ jsxDEV5("span", {
447
+ className: "text-muted-foreground",
448
+ children: "Afficher:"
449
+ }, undefined, false, undefined, this),
450
+ /* @__PURE__ */ jsxDEV5(Select, {
451
+ value: itemsPerPage.toString(),
452
+ onValueChange: (value) => onItemsPerPageChange(parseInt(value)),
453
+ disabled,
454
+ children: [
455
+ /* @__PURE__ */ jsxDEV5(SelectTrigger, {
456
+ className: "h-8 w-16",
457
+ children: /* @__PURE__ */ jsxDEV5(SelectValue, {}, undefined, false, undefined, this)
458
+ }, undefined, false, undefined, this),
459
+ /* @__PURE__ */ jsxDEV5(SelectContent, {
460
+ className: "bg-background",
461
+ children: itemsPerPageOptions.map((option) => /* @__PURE__ */ jsxDEV5(SelectItem, {
462
+ value: option.toString(),
463
+ children: option
464
+ }, option, false, undefined, this))
465
+ }, undefined, false, undefined, this)
466
+ ]
467
+ }, undefined, true, undefined, this)
468
+ ]
469
+ }, undefined, true, undefined, this)
470
+ ]
471
+ }, undefined, true, undefined, this);
472
+ };
473
+ // ui/input.tsx
474
+ import { cn as cn4 } from "@contractspec/lib.ui-kit-core/utils";
475
+ import { jsxDEV as jsxDEV6 } from "react/jsx-dev-runtime";
476
+ function Input({ className, type, ...props }) {
477
+ return /* @__PURE__ */ jsxDEV6("input", {
478
+ type,
479
+ "data-slot": "input",
480
+ 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),
481
+ ...props
482
+ }, undefined, false, undefined, this);
483
+ }
484
+ // ui/atoms/SearchInput/SearchInput.tsx
485
+ import { Search, X } from "lucide-react";
486
+ import { jsxDEV as jsxDEV7 } from "react/jsx-dev-runtime";
487
+ var SearchInput = ({
488
+ value,
489
+ onChange,
490
+ placeholder = "Rechercher...",
491
+ onClear,
492
+ disabled = false,
493
+ className = "",
494
+ autoFocus = false
495
+ }) => {
496
+ const handleClear = () => {
497
+ onChange("");
498
+ onClear?.();
499
+ };
500
+ return /* @__PURE__ */ jsxDEV7("div", {
501
+ className: `relative w-full ${className}`,
502
+ children: [
503
+ /* @__PURE__ */ jsxDEV7("div", {
504
+ className: "pointer-events-none absolute inset-y-0 left-0 flex items-center pl-3",
505
+ children: /* @__PURE__ */ jsxDEV7(Search, {
506
+ className: "text-muted-foreground h-4 w-4"
507
+ }, undefined, false, undefined, this)
508
+ }, undefined, false, undefined, this),
509
+ /* @__PURE__ */ jsxDEV7(Input, {
510
+ type: "text",
511
+ value,
512
+ onChange: (e) => onChange(e.target.value),
513
+ placeholder,
514
+ disabled,
515
+ autoFocus,
516
+ className: "pr-10 pl-10"
517
+ }, undefined, false, undefined, this),
518
+ value && /* @__PURE__ */ jsxDEV7("div", {
519
+ className: "absolute inset-y-0 right-0 flex items-center pr-3",
520
+ children: /* @__PURE__ */ jsxDEV7(Button, {
521
+ type: "button",
522
+ variant: "ghost",
523
+ size: "sm",
524
+ onClick: handleClear,
525
+ disabled,
526
+ className: "h-6 w-6 p-0 hover:bg-transparent",
527
+ children: [
528
+ /* @__PURE__ */ jsxDEV7(X, {
529
+ className: "text-muted-foreground hover:text-foreground h-4 w-4"
530
+ }, undefined, false, undefined, this),
531
+ /* @__PURE__ */ jsxDEV7("span", {
532
+ className: "sr-only",
533
+ children: "Effacer la recherche"
534
+ }, undefined, false, undefined, this)
535
+ ]
536
+ }, undefined, true, undefined, this)
537
+ }, undefined, false, undefined, this)
538
+ ]
539
+ }, undefined, true, undefined, this);
540
+ };
541
+ // ui/card.tsx
542
+ import { cn as cn5 } from "@contractspec/lib.ui-kit-core/utils";
543
+ import { jsxDEV as jsxDEV8 } from "react/jsx-dev-runtime";
544
+ function Card({ className, ...props }) {
545
+ return /* @__PURE__ */ jsxDEV8("div", {
546
+ "data-slot": "card",
547
+ className: cn5("bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-2xs", className),
548
+ ...props
549
+ }, undefined, false, undefined, this);
550
+ }
551
+ function CardHeader({
552
+ className,
553
+ ...props
554
+ }) {
555
+ return /* @__PURE__ */ jsxDEV8("div", {
556
+ "data-slot": "card-header",
557
+ className: cn5("@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6", className),
558
+ ...props
559
+ }, undefined, false, undefined, this);
560
+ }
561
+ function CardTitle({
562
+ className,
563
+ ...props
564
+ }) {
565
+ return /* @__PURE__ */ jsxDEV8("div", {
566
+ "data-slot": "card-title",
567
+ className: cn5("leading-none font-semibold", className),
568
+ ...props
569
+ }, undefined, false, undefined, this);
570
+ }
571
+ function CardDescription({
572
+ className,
573
+ ...props
574
+ }) {
575
+ return /* @__PURE__ */ jsxDEV8("div", {
576
+ "data-slot": "card-description",
577
+ className: cn5("text-muted-foreground text-sm", className),
578
+ ...props
579
+ }, undefined, false, undefined, this);
580
+ }
581
+ function CardAction({
582
+ className,
583
+ ...props
584
+ }) {
585
+ return /* @__PURE__ */ jsxDEV8("div", {
586
+ "data-slot": "card-action",
587
+ className: cn5("col-start-2 row-span-2 row-start-1 self-start justify-self-end", className),
588
+ ...props
589
+ }, undefined, false, undefined, this);
590
+ }
591
+ function CardContent({
592
+ className,
593
+ ...props
594
+ }) {
595
+ return /* @__PURE__ */ jsxDEV8("div", {
596
+ "data-slot": "card-content",
597
+ className: cn5("px-6", className),
598
+ ...props
599
+ }, undefined, false, undefined, this);
600
+ }
601
+ function CardFooter({
602
+ className,
603
+ ...props
604
+ }) {
605
+ return /* @__PURE__ */ jsxDEV8("div", {
606
+ "data-slot": "card-footer",
607
+ className: cn5("flex items-center px-6 [.border-t]:pt-6", className),
608
+ ...props
609
+ }, undefined, false, undefined, this);
610
+ }
611
+ // ui/collapsible.tsx
612
+ import * as CollapsiblePrimitive from "@radix-ui/react-collapsible";
613
+ import { jsxDEV as jsxDEV9 } from "react/jsx-dev-runtime";
614
+ "use client";
615
+ function Collapsible({
616
+ ...props
617
+ }) {
618
+ return /* @__PURE__ */ jsxDEV9(CollapsiblePrimitive.Root, {
619
+ "data-slot": "collapsible",
620
+ ...props
621
+ }, undefined, false, undefined, this);
622
+ }
623
+ function CollapsibleTrigger2({
624
+ ...props
625
+ }) {
626
+ return /* @__PURE__ */ jsxDEV9(CollapsiblePrimitive.CollapsibleTrigger, {
627
+ "data-slot": "collapsible-trigger",
628
+ ...props
629
+ }, undefined, false, undefined, this);
630
+ }
631
+ function CollapsibleContent2({
632
+ ...props
633
+ }) {
634
+ return /* @__PURE__ */ jsxDEV9(CollapsiblePrimitive.CollapsibleContent, {
635
+ "data-slot": "collapsible-content",
636
+ ...props
637
+ }, undefined, false, undefined, this);
638
+ }
639
+ // ui/stack.tsx
640
+ import * as React2 from "react";
641
+ import { cva as cva2 } from "class-variance-authority";
642
+ import { cn as cn6 } from "@contractspec/lib.ui-kit-core/utils";
643
+ import { jsxDEV as jsxDEV10 } from "react/jsx-dev-runtime";
644
+ var vStackVariants = cva2("flex flex-col", {
645
+ variants: {
646
+ gap: {
647
+ none: "gap-0",
648
+ xs: "gap-1",
649
+ sm: "gap-2",
650
+ md: "gap-3",
651
+ lg: "gap-4",
652
+ xl: "gap-6",
653
+ "2xl": "gap-8"
654
+ },
655
+ align: {
656
+ start: "items-start",
657
+ center: "items-center",
658
+ end: "items-end",
659
+ stretch: "items-stretch"
660
+ },
661
+ justify: {
662
+ start: "justify-start",
663
+ center: "justify-center",
664
+ end: "justify-end",
665
+ between: "justify-between",
666
+ around: "justify-around",
667
+ evenly: "justify-evenly"
668
+ }
669
+ },
670
+ defaultVariants: {
671
+ gap: "md",
672
+ align: "stretch",
673
+ justify: "start"
674
+ }
675
+ });
676
+ var VStack = React2.forwardRef(({ className, gap, align, justify, as = "div", ...props }, ref) => {
677
+ const Comp = as;
678
+ return /* @__PURE__ */ jsxDEV10(Comp, {
679
+ ref,
680
+ className: cn6(vStackVariants({ gap, align, justify }), className),
681
+ ...props
682
+ }, undefined, false, undefined, this);
683
+ });
684
+ VStack.displayName = "VStack";
685
+ var hStackVariants = cva2("flex flex-row", {
686
+ variants: {
687
+ gap: {
688
+ none: "gap-0",
689
+ xs: "gap-1",
690
+ sm: "gap-2",
691
+ md: "gap-3",
692
+ lg: "gap-4",
693
+ xl: "gap-6",
694
+ "2xl": "gap-8"
695
+ },
696
+ align: {
697
+ start: "items-start",
698
+ center: "items-center",
699
+ end: "items-end",
700
+ stretch: "items-stretch",
701
+ baseline: "items-baseline"
702
+ },
703
+ justify: {
704
+ start: "justify-start",
705
+ center: "justify-center",
706
+ end: "justify-end",
707
+ between: "justify-between",
708
+ around: "justify-around",
709
+ evenly: "justify-evenly"
710
+ },
711
+ wrap: {
712
+ nowrap: "flex-nowrap",
713
+ wrap: "flex-wrap",
714
+ wrapReverse: "flex-wrap-reverse"
715
+ }
716
+ },
717
+ defaultVariants: {
718
+ gap: "md",
719
+ align: "center",
720
+ justify: "start",
721
+ wrap: "wrap"
722
+ }
723
+ });
724
+ var HStack = React2.forwardRef(({ className, gap, align, justify, wrap, as = "div", ...props }, ref) => {
725
+ const Comp = as;
726
+ return /* @__PURE__ */ jsxDEV10(Comp, {
727
+ ref,
728
+ className: cn6(hStackVariants({ gap, align, justify, wrap }), className),
729
+ ...props
730
+ }, undefined, false, undefined, this);
731
+ });
732
+ HStack.displayName = "HStack";
733
+ var boxVariants = cva2("flex flex-row", {
734
+ variants: {
735
+ gap: {
736
+ none: "gap-0",
737
+ xs: "gap-1",
738
+ sm: "gap-2",
739
+ md: "gap-3",
740
+ lg: "gap-4",
741
+ xl: "gap-6",
742
+ "2xl": "gap-8"
743
+ },
744
+ align: {
745
+ start: "items-start",
746
+ center: "items-center",
747
+ end: "items-end",
748
+ stretch: "items-stretch",
749
+ baseline: "items-baseline"
750
+ },
751
+ justify: {
752
+ start: "justify-start",
753
+ center: "justify-center",
754
+ end: "justify-end",
755
+ between: "justify-between",
756
+ around: "justify-around",
757
+ evenly: "justify-evenly"
758
+ },
759
+ wrap: {
760
+ nowrap: "flex-nowrap",
761
+ wrap: "flex-wrap",
762
+ wrapReverse: "flex-wrap-reverse"
763
+ }
764
+ },
765
+ defaultVariants: {
766
+ gap: "md",
767
+ align: "center",
768
+ justify: "center",
769
+ wrap: "nowrap"
770
+ }
771
+ });
772
+ var Box = React2.forwardRef(({ className, gap, align, justify, wrap, as = "div", ...props }, ref) => {
773
+ const Comp = as;
774
+ return /* @__PURE__ */ jsxDEV10(Comp, {
775
+ ref,
776
+ className: cn6(boxVariants({ gap, align, justify, wrap }), className),
777
+ ...props
778
+ }, undefined, false, undefined, this);
779
+ });
780
+ Box.displayName = "Box";
781
+ // ui/separator.tsx
782
+ import * as SeparatorPrimitive from "@radix-ui/react-separator";
783
+ import { cn as cn7 } from "@contractspec/lib.ui-kit-core/utils";
784
+ import { jsxDEV as jsxDEV11 } from "react/jsx-dev-runtime";
785
+ "use client";
786
+ function Separator2({
787
+ className,
788
+ orientation = "horizontal",
789
+ decorative = true,
790
+ ...props
791
+ }) {
792
+ return /* @__PURE__ */ jsxDEV11(SeparatorPrimitive.Root, {
793
+ "data-slot": "separator",
794
+ decorative,
795
+ orientation,
796
+ className: cn7("bg-border shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px", className),
797
+ ...props
798
+ }, undefined, false, undefined, this);
799
+ }
800
+ // ui/molecules/SearchAndFilter/SearchAndFilter.tsx
801
+ import { useState } from "react";
802
+ import { ChevronDown, ChevronUp, Filter } from "lucide-react";
803
+ import { jsxDEV as jsxDEV12 } from "react/jsx-dev-runtime";
804
+ var SearchAndFilter = ({
805
+ searchValue,
806
+ onSearchChange,
807
+ searchPlaceholder,
808
+ filters = [],
809
+ isLoading = false,
810
+ disabled = false,
811
+ className = "",
812
+ collapsible = true,
813
+ defaultCollapsed = false
814
+ }) => {
815
+ const [isCollapsed, setIsCollapsed] = useState(defaultCollapsed);
816
+ const hasFilters = filters.length > 0;
817
+ const activeFiltersCount = filters.filter((f) => f.value).length;
818
+ const shouldUseCollapsible = collapsible && hasFilters;
819
+ console.log("SearchAndFilter", { filters });
820
+ const FilterComponents = () => /* @__PURE__ */ jsxDEV12("div", {
821
+ className: "grid grid-cols-1 gap-4 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4",
822
+ children: filters.map((filter) => /* @__PURE__ */ jsxDEV12(FilterSelect, {
823
+ value: filter.value,
824
+ options: filter.options,
825
+ onChange: filter.onChange,
826
+ label: filter.label,
827
+ disabled: disabled || isLoading,
828
+ showCounts: filter.showCounts,
829
+ className: "min-w-0"
830
+ }, filter.key, false, undefined, this))
831
+ }, undefined, false, undefined, this);
832
+ return /* @__PURE__ */ jsxDEV12("div", {
833
+ className: `space-y-4 ${className}`,
834
+ children: [
835
+ /* @__PURE__ */ jsxDEV12("div", {
836
+ className: "flex flex-col gap-4 sm:flex-row",
837
+ children: [
838
+ /* @__PURE__ */ jsxDEV12("div", {
839
+ className: "flex-1",
840
+ children: /* @__PURE__ */ jsxDEV12(SearchInput, {
841
+ value: searchValue,
842
+ onChange: onSearchChange,
843
+ placeholder: searchPlaceholder,
844
+ disabled: disabled || isLoading,
845
+ className: "w-full"
846
+ }, undefined, false, undefined, this)
847
+ }, undefined, false, undefined, this),
848
+ shouldUseCollapsible && /* @__PURE__ */ jsxDEV12(Collapsible, {
849
+ open: !isCollapsed,
850
+ onOpenChange: setIsCollapsed,
851
+ className: "sm:hidden",
852
+ children: [
853
+ /* @__PURE__ */ jsxDEV12(CollapsibleTrigger2, {
854
+ asChild: true,
855
+ children: /* @__PURE__ */ jsxDEV12(Button, {
856
+ variant: "outline",
857
+ className: "sm:hidden",
858
+ disabled: disabled || isLoading,
859
+ children: [
860
+ /* @__PURE__ */ jsxDEV12(Filter, {
861
+ className: "mr-2 h-4 w-4"
862
+ }, undefined, false, undefined, this),
863
+ "Filtres",
864
+ activeFiltersCount > 0 && /* @__PURE__ */ jsxDEV12("span", {
865
+ className: "bg-primary text-primary-foreground ml-2 flex h-5 w-5 items-center justify-center rounded-full text-sm",
866
+ children: activeFiltersCount
867
+ }, undefined, false, undefined, this),
868
+ isCollapsed ? /* @__PURE__ */ jsxDEV12(ChevronDown, {
869
+ className: "ml-2 h-4 w-4"
870
+ }, undefined, false, undefined, this) : /* @__PURE__ */ jsxDEV12(ChevronUp, {
871
+ className: "ml-2 h-4 w-4"
872
+ }, undefined, false, undefined, this)
873
+ ]
874
+ }, undefined, true, undefined, this)
875
+ }, undefined, false, undefined, this),
876
+ /* @__PURE__ */ jsxDEV12(CollapsibleContent2, {
877
+ className: "mt-4 space-y-4",
878
+ children: /* @__PURE__ */ jsxDEV12(FilterComponents, {}, undefined, false, undefined, this)
879
+ }, undefined, false, undefined, this)
880
+ ]
881
+ }, undefined, true, undefined, this)
882
+ ]
883
+ }, undefined, true, undefined, this),
884
+ hasFilters && /* @__PURE__ */ jsxDEV12("div", {
885
+ className: "hidden sm:block",
886
+ children: /* @__PURE__ */ jsxDEV12(FilterComponents, {}, undefined, false, undefined, this)
887
+ }, undefined, false, undefined, this),
888
+ activeFiltersCount > 0 && /* @__PURE__ */ jsxDEV12("div", {
889
+ className: "flex flex-wrap items-center gap-2",
890
+ children: [
891
+ /* @__PURE__ */ jsxDEV12("span", {
892
+ className: "text-muted-foreground text-base",
893
+ children: "Filtres actifs:"
894
+ }, undefined, false, undefined, this),
895
+ filters.filter((f) => f.value).map((filter) => {
896
+ const selectedOption = filter.options.find((opt) => opt.value === filter.value);
897
+ return /* @__PURE__ */ jsxDEV12(Button, {
898
+ variant: "secondary",
899
+ size: "sm",
900
+ onClick: () => filter.onChange(""),
901
+ disabled: disabled || isLoading,
902
+ className: "h-7 px-2 text-sm",
903
+ children: [
904
+ filter.label,
905
+ ": ",
906
+ selectedOption?.label,
907
+ /* @__PURE__ */ jsxDEV12("span", {
908
+ className: "ml-1",
909
+ children: "×"
910
+ }, undefined, false, undefined, this)
911
+ ]
912
+ }, filter.key, true, undefined, this);
913
+ })
914
+ ]
915
+ }, undefined, true, undefined, this)
916
+ ]
917
+ }, undefined, true, undefined, this);
918
+ };
919
+ // ui/organisms/ListPage/ListPage.tsx
920
+ import Link from "next/link";
921
+ import { AlertTriangle, Loader2, Plus, RefreshCcw } from "lucide-react";
922
+ import { jsxDEV as jsxDEV13, Fragment } from "react/jsx-dev-runtime";
923
+ function ListPage({
924
+ title,
925
+ description,
926
+ header,
927
+ items,
928
+ totalItems,
929
+ totalPages,
930
+ isLoading,
931
+ isFetching,
932
+ error,
933
+ listState,
934
+ searchPlaceholder,
935
+ filters = [],
936
+ onRefresh,
937
+ primaryAction,
938
+ toolbar,
939
+ renderItem,
940
+ renderEmpty,
941
+ renderStats,
942
+ className = "",
943
+ itemClassName = ""
944
+ }) {
945
+ const {
946
+ searchQuery,
947
+ setSearchQuery,
948
+ filters: filterValues,
949
+ setFilter,
950
+ currentPage,
951
+ itemsPerPage,
952
+ setCurrentPage,
953
+ setItemsPerPage
954
+ } = listState;
955
+ if (isLoading && !items.length) {
956
+ return /* @__PURE__ */ jsxDEV13(VStack, {
957
+ className: `space-y-4 md:space-y-6 ${className}`,
958
+ children: [
959
+ header ? header : /* @__PURE__ */ jsxDEV13(VStack, {
960
+ className: "gap-1",
961
+ children: [
962
+ /* @__PURE__ */ jsxDEV13("h1", {
963
+ className: "text-2xl font-bold md:text-3xl",
964
+ children: title
965
+ }, undefined, false, undefined, this),
966
+ description && /* @__PURE__ */ jsxDEV13("p", {
967
+ className: "text-muted-foreground text-base",
968
+ children: description
969
+ }, undefined, false, undefined, this)
970
+ ]
971
+ }, undefined, true, undefined, this),
972
+ /* @__PURE__ */ jsxDEV13("div", {
973
+ className: "flex min-h-[400px] items-center justify-center",
974
+ children: /* @__PURE__ */ jsxDEV13(Card, {
975
+ children: /* @__PURE__ */ jsxDEV13(CardContent, {
976
+ className: "flex items-center gap-4 p-6",
977
+ children: [
978
+ /* @__PURE__ */ jsxDEV13(Loader2, {
979
+ className: "text-primary h-8 w-8 animate-spin"
980
+ }, undefined, false, undefined, this),
981
+ /* @__PURE__ */ jsxDEV13("div", {
982
+ children: [
983
+ /* @__PURE__ */ jsxDEV13("h3", {
984
+ className: "font-medium",
985
+ children: "Chargement..."
986
+ }, undefined, false, undefined, this),
987
+ /* @__PURE__ */ jsxDEV13("p", {
988
+ className: "text-muted-foreground text-base",
989
+ children: "Récupération des données en cours"
990
+ }, undefined, false, undefined, this)
991
+ ]
992
+ }, undefined, true, undefined, this)
993
+ ]
994
+ }, undefined, true, undefined, this)
995
+ }, undefined, false, undefined, this)
996
+ }, undefined, false, undefined, this)
997
+ ]
998
+ }, undefined, true, undefined, this);
999
+ }
1000
+ if (error && !items.length) {
1001
+ return /* @__PURE__ */ jsxDEV13(VStack, {
1002
+ className: `space-y-4 md:space-y-6 ${className}`,
1003
+ children: [
1004
+ header ? header : /* @__PURE__ */ jsxDEV13(VStack, {
1005
+ className: "gap-1",
1006
+ children: [
1007
+ /* @__PURE__ */ jsxDEV13("h1", {
1008
+ className: "text-2xl font-bold md:text-3xl",
1009
+ children: title
1010
+ }, undefined, false, undefined, this),
1011
+ description && /* @__PURE__ */ jsxDEV13("p", {
1012
+ className: "text-muted-foreground text-base",
1013
+ children: description
1014
+ }, undefined, false, undefined, this)
1015
+ ]
1016
+ }, undefined, true, undefined, this),
1017
+ /* @__PURE__ */ jsxDEV13("div", {
1018
+ className: "flex min-h-[400px] items-center justify-center",
1019
+ children: /* @__PURE__ */ jsxDEV13(Card, {
1020
+ children: /* @__PURE__ */ jsxDEV13(CardContent, {
1021
+ className: "flex flex-col items-center gap-4 p-6 text-center",
1022
+ children: [
1023
+ /* @__PURE__ */ jsxDEV13(AlertTriangle, {
1024
+ className: "text-destructive h-12 w-12"
1025
+ }, undefined, false, undefined, this),
1026
+ /* @__PURE__ */ jsxDEV13("div", {
1027
+ children: [
1028
+ /* @__PURE__ */ jsxDEV13("h3", {
1029
+ className: "font-medium",
1030
+ children: "Erreur de chargement"
1031
+ }, undefined, false, undefined, this),
1032
+ /* @__PURE__ */ jsxDEV13("p", {
1033
+ className: "text-muted-foreground text-base",
1034
+ children: error.message || "Une erreur est survenue"
1035
+ }, undefined, false, undefined, this)
1036
+ ]
1037
+ }, undefined, true, undefined, this),
1038
+ onRefresh && /* @__PURE__ */ jsxDEV13(Button, {
1039
+ onClick: onRefresh,
1040
+ variant: "outline",
1041
+ size: "sm",
1042
+ children: [
1043
+ /* @__PURE__ */ jsxDEV13(RefreshCcw, {
1044
+ className: "mr-2 h-4 w-4"
1045
+ }, undefined, false, undefined, this),
1046
+ "Réessayer"
1047
+ ]
1048
+ }, undefined, true, undefined, this)
1049
+ ]
1050
+ }, undefined, true, undefined, this)
1051
+ }, undefined, false, undefined, this)
1052
+ }, undefined, false, undefined, this)
1053
+ ]
1054
+ }, undefined, true, undefined, this);
1055
+ }
1056
+ const filterConfigs = filters.map((filter) => ({
1057
+ key: filter.key,
1058
+ label: filter.label,
1059
+ value: filterValues[filter.key] || "",
1060
+ options: filter.options,
1061
+ onChange: (value) => {
1062
+ setFilter(filter.key, value === "all" ? "" : value);
1063
+ },
1064
+ showCounts: filter.showCounts
1065
+ }));
1066
+ return /* @__PURE__ */ jsxDEV13(VStack, {
1067
+ className: `space-y-4 md:space-y-6 ${className}`,
1068
+ children: [
1069
+ header ? header : /* @__PURE__ */ jsxDEV13(HStack, {
1070
+ className: "items-center justify-between",
1071
+ children: [
1072
+ /* @__PURE__ */ jsxDEV13(VStack, {
1073
+ className: "gap-1",
1074
+ children: [
1075
+ /* @__PURE__ */ jsxDEV13("h1", {
1076
+ className: "text-2xl font-bold md:text-3xl",
1077
+ children: title
1078
+ }, undefined, false, undefined, this),
1079
+ description && /* @__PURE__ */ jsxDEV13("p", {
1080
+ className: "text-muted-foreground text-base",
1081
+ children: description
1082
+ }, undefined, false, undefined, this)
1083
+ ]
1084
+ }, undefined, true, undefined, this),
1085
+ /* @__PURE__ */ jsxDEV13(HStack, {
1086
+ className: "items-center gap-4",
1087
+ children: [
1088
+ toolbar,
1089
+ (isLoading || isFetching) && /* @__PURE__ */ jsxDEV13("div", {
1090
+ className: "text-muted-foreground flex items-center gap-2 text-base",
1091
+ children: [
1092
+ /* @__PURE__ */ jsxDEV13(Loader2, {
1093
+ className: "h-4 w-4 animate-spin"
1094
+ }, undefined, false, undefined, this),
1095
+ /* @__PURE__ */ jsxDEV13("span", {
1096
+ className: "hidden sm:inline",
1097
+ children: "Mise à jour..."
1098
+ }, undefined, false, undefined, this)
1099
+ ]
1100
+ }, undefined, true, undefined, this),
1101
+ onRefresh && /* @__PURE__ */ jsxDEV13(Button, {
1102
+ variant: "outline",
1103
+ size: "sm",
1104
+ onClick: onRefresh,
1105
+ disabled: Boolean(isLoading),
1106
+ "aria-label": "Rafraîchir",
1107
+ children: [
1108
+ /* @__PURE__ */ jsxDEV13(RefreshCcw, {
1109
+ className: `mr-2 h-4 w-4 ${isLoading || isFetching ? "animate-spin" : ""}`
1110
+ }, undefined, false, undefined, this),
1111
+ /* @__PURE__ */ jsxDEV13("span", {
1112
+ className: "hidden sm:inline",
1113
+ children: "Rafraîchir"
1114
+ }, undefined, false, undefined, this)
1115
+ ]
1116
+ }, undefined, true, undefined, this),
1117
+ primaryAction && /* @__PURE__ */ jsxDEV13(Fragment, {
1118
+ children: primaryAction.href ? /* @__PURE__ */ jsxDEV13(Link, {
1119
+ href: primaryAction.href,
1120
+ children: /* @__PURE__ */ jsxDEV13(Button, {
1121
+ children: [
1122
+ primaryAction.icon || /* @__PURE__ */ jsxDEV13(Plus, {
1123
+ className: "mr-2 h-4 w-4"
1124
+ }, undefined, false, undefined, this),
1125
+ /* @__PURE__ */ jsxDEV13("span", {
1126
+ className: "hidden sm:inline",
1127
+ children: primaryAction.label
1128
+ }, undefined, false, undefined, this),
1129
+ /* @__PURE__ */ jsxDEV13("span", {
1130
+ className: "sm:hidden",
1131
+ children: "Nouveau"
1132
+ }, undefined, false, undefined, this)
1133
+ ]
1134
+ }, undefined, true, undefined, this)
1135
+ }, undefined, false, undefined, this) : /* @__PURE__ */ jsxDEV13(Button, {
1136
+ onClick: primaryAction.onClick,
1137
+ children: [
1138
+ primaryAction.icon || /* @__PURE__ */ jsxDEV13(Plus, {
1139
+ className: "mr-2 h-4 w-4"
1140
+ }, undefined, false, undefined, this),
1141
+ /* @__PURE__ */ jsxDEV13("span", {
1142
+ className: "hidden sm:inline",
1143
+ children: primaryAction.label
1144
+ }, undefined, false, undefined, this),
1145
+ /* @__PURE__ */ jsxDEV13("span", {
1146
+ className: "sm:hidden",
1147
+ children: "Nouveau"
1148
+ }, undefined, false, undefined, this)
1149
+ ]
1150
+ }, undefined, true, undefined, this)
1151
+ }, undefined, false, undefined, this)
1152
+ ]
1153
+ }, undefined, true, undefined, this)
1154
+ ]
1155
+ }, undefined, true, undefined, this),
1156
+ renderStats && /* @__PURE__ */ jsxDEV13(Fragment, {
1157
+ children: [
1158
+ renderStats(items),
1159
+ /* @__PURE__ */ jsxDEV13(Separator2, {}, undefined, false, undefined, this)
1160
+ ]
1161
+ }, undefined, true, undefined, this),
1162
+ /* @__PURE__ */ jsxDEV13(SearchAndFilter, {
1163
+ searchValue: searchQuery,
1164
+ onSearchChange: setSearchQuery,
1165
+ searchPlaceholder,
1166
+ filters: filterConfigs,
1167
+ isLoading
1168
+ }, undefined, false, undefined, this),
1169
+ items.length === 0 && !isLoading ? renderEmpty ? renderEmpty() : /* @__PURE__ */ jsxDEV13(Card, {
1170
+ children: /* @__PURE__ */ jsxDEV13(CardContent, {
1171
+ className: "flex flex-col items-center gap-4 p-8 text-center",
1172
+ children: [
1173
+ /* @__PURE__ */ jsxDEV13("div", {
1174
+ className: "bg-muted flex h-12 w-12 items-center justify-center rounded-full",
1175
+ children: /* @__PURE__ */ jsxDEV13("div", {
1176
+ className: "bg-muted-foreground/20 h-6 w-6 rounded-full"
1177
+ }, undefined, false, undefined, this)
1178
+ }, undefined, false, undefined, this),
1179
+ /* @__PURE__ */ jsxDEV13("div", {
1180
+ children: [
1181
+ /* @__PURE__ */ jsxDEV13("h3", {
1182
+ className: "font-medium",
1183
+ children: "Aucun élément trouvé"
1184
+ }, undefined, false, undefined, this),
1185
+ /* @__PURE__ */ jsxDEV13("p", {
1186
+ className: "text-muted-foreground text-base",
1187
+ children: searchQuery || Object.values(filterValues).some((v) => v) ? "Essayez de modifier vos critères de recherche" : "Commencez par créer votre premier élément"
1188
+ }, undefined, false, undefined, this)
1189
+ ]
1190
+ }, undefined, true, undefined, this),
1191
+ primaryAction && !searchQuery && !Object.values(filterValues).some((v) => v) && /* @__PURE__ */ jsxDEV13(Fragment, {
1192
+ children: primaryAction.href ? /* @__PURE__ */ jsxDEV13(Link, {
1193
+ href: primaryAction.href,
1194
+ children: /* @__PURE__ */ jsxDEV13(Button, {
1195
+ children: [
1196
+ primaryAction.icon || /* @__PURE__ */ jsxDEV13(Plus, {
1197
+ className: "mr-2 h-4 w-4"
1198
+ }, undefined, false, undefined, this),
1199
+ primaryAction.label
1200
+ ]
1201
+ }, undefined, true, undefined, this)
1202
+ }, undefined, false, undefined, this) : /* @__PURE__ */ jsxDEV13(Button, {
1203
+ onClick: primaryAction.onClick,
1204
+ children: [
1205
+ primaryAction.icon || /* @__PURE__ */ jsxDEV13(Plus, {
1206
+ className: "mr-2 h-4 w-4"
1207
+ }, undefined, false, undefined, this),
1208
+ primaryAction.label
1209
+ ]
1210
+ }, undefined, true, undefined, this)
1211
+ }, undefined, false, undefined, this)
1212
+ ]
1213
+ }, undefined, true, undefined, this)
1214
+ }, undefined, false, undefined, this) : /* @__PURE__ */ jsxDEV13(Fragment, {
1215
+ children: [
1216
+ /* @__PURE__ */ jsxDEV13("div", {
1217
+ className: `space-y-4 ${itemClassName}`,
1218
+ children: items.map((item, index) => renderItem(item, index))
1219
+ }, undefined, false, undefined, this),
1220
+ totalPages > 1 && /* @__PURE__ */ jsxDEV13(Pagination, {
1221
+ currentPage,
1222
+ totalPages,
1223
+ totalItems,
1224
+ itemsPerPage,
1225
+ onPageChange: setCurrentPage,
1226
+ onItemsPerPageChange: setItemsPerPage,
1227
+ disabled: isLoading
1228
+ }, undefined, false, undefined, this)
1229
+ ]
1230
+ }, undefined, true, undefined, this)
1231
+ ]
1232
+ }, undefined, true, undefined, this);
1233
+ }
1234
+ export {
1235
+ ListPage
1236
+ };