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