@contractspec/lib.ui-kit-web 1.57.0 → 1.58.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (545) hide show
  1. package/dist/browser/index.js +13 -0
  2. package/dist/browser/ui/accordion.js +73 -0
  3. package/dist/browser/ui/alert-dialog.js +177 -0
  4. package/dist/browser/ui/alert.js +60 -0
  5. package/dist/browser/ui/aspect-ratio.js +15 -0
  6. package/dist/browser/ui/atoms/FilterSelect/FilterSelect.js +244 -0
  7. package/dist/browser/ui/atoms/FilterSelect/index.js +244 -0
  8. package/dist/browser/ui/atoms/FilterSelect/types.js +0 -0
  9. package/dist/browser/ui/atoms/LoadingSpinner/LoadingSpinner.js +89 -0
  10. package/dist/browser/ui/atoms/LoadingSpinner/index.js +89 -0
  11. package/dist/browser/ui/atoms/Pagination/Pagination.js +387 -0
  12. package/dist/browser/ui/atoms/Pagination/index.js +387 -0
  13. package/dist/browser/ui/atoms/Pagination/types.js +0 -0
  14. package/dist/browser/ui/atoms/SearchInput/SearchInput.js +123 -0
  15. package/dist/browser/ui/atoms/SearchInput/index.js +123 -0
  16. package/dist/browser/ui/atoms/SearchInput/types.js +0 -0
  17. package/dist/browser/ui/avatar.js +54 -0
  18. package/dist/browser/ui/badge.js +43 -0
  19. package/dist/browser/ui/breadcrumb.js +109 -0
  20. package/dist/browser/ui/button.js +56 -0
  21. package/dist/browser/ui/calendar.js +181 -0
  22. package/dist/browser/ui/card.js +87 -0
  23. package/dist/browser/ui/carousel.js +229 -0
  24. package/dist/browser/ui/checkbox.js +34 -0
  25. package/dist/browser/ui/collapsible.js +41 -0
  26. package/dist/browser/ui/command.js +266 -0
  27. package/dist/browser/ui/confirm-dialog.js +226 -0
  28. package/dist/browser/ui/context-menu.js +127 -0
  29. package/dist/browser/ui/cta.js +102 -0
  30. package/dist/browser/ui/date-picker.js +350 -0
  31. package/dist/browser/ui/date-range-picker.js +276 -0
  32. package/dist/browser/ui/datetime-picker.js +489 -0
  33. package/dist/browser/ui/dialog.js +140 -0
  34. package/dist/browser/ui/drawer.js +130 -0
  35. package/dist/browser/ui/dropdown-menu.js +214 -0
  36. package/dist/browser/ui/empty-state.js +209 -0
  37. package/dist/browser/ui/empty.js +90 -0
  38. package/dist/browser/ui/field.js +221 -0
  39. package/dist/browser/ui/focus-on-route-change.js +25 -0
  40. package/dist/browser/ui/form.js +156 -0
  41. package/dist/browser/ui/hover-card.js +51 -0
  42. package/dist/browser/ui/input-group.js +192 -0
  43. package/dist/browser/ui/input-otp.js +60 -0
  44. package/dist/browser/ui/input.js +22 -0
  45. package/dist/browser/ui/label.js +26 -0
  46. package/dist/browser/ui/link.js +24 -0
  47. package/dist/browser/ui/live-region.js +56 -0
  48. package/dist/browser/ui/loading-button.js +228 -0
  49. package/dist/browser/ui/map/MapBase.js +70 -0
  50. package/dist/browser/ui/map/MapGeoJsonOverlay.js +56 -0
  51. package/dist/browser/ui/map/MapHeatmapH3.js +66 -0
  52. package/dist/browser/ui/map/MapMarkers.js +45 -0
  53. package/dist/browser/ui/map/index.js +210 -0
  54. package/dist/browser/ui/marketing/FeatureGrid.js +50 -0
  55. package/dist/browser/ui/marketing/Hero.js +116 -0
  56. package/dist/browser/ui/marketing/PricingTable.js +127 -0
  57. package/dist/browser/ui/marketing/index.js +217 -0
  58. package/dist/browser/ui/menubar.js +231 -0
  59. package/dist/browser/ui/molecules/Autocomplete/index.js +584 -0
  60. package/dist/browser/ui/molecules/SearchAndFilter/SearchAndFilter.js +503 -0
  61. package/dist/browser/ui/molecules/SearchAndFilter/index.js +503 -0
  62. package/dist/browser/ui/molecules/SearchAndFilter/types.js +0 -0
  63. package/dist/browser/ui/molecules/SkeletonList.js +44 -0
  64. package/dist/browser/ui/nav-layout.js +298 -0
  65. package/dist/browser/ui/navigation-menu.js +128 -0
  66. package/dist/browser/ui/organisms/ErrorBoundary/ErrorBoundary.js +191 -0
  67. package/dist/browser/ui/organisms/ErrorBoundary/index.js +191 -0
  68. package/dist/browser/ui/organisms/ListPage/ListPage.js +1236 -0
  69. package/dist/browser/ui/organisms/ListPage/index.js +1236 -0
  70. package/dist/browser/ui/organisms/ListPage/types.js +0 -0
  71. package/dist/browser/ui/page-header.js +206 -0
  72. package/dist/browser/ui/pagination.js +156 -0
  73. package/dist/browser/ui/popover.js +59 -0
  74. package/dist/browser/ui/progress.js +32 -0
  75. package/dist/browser/ui/radio-group.js +45 -0
  76. package/dist/browser/ui/resizable.js +41 -0
  77. package/dist/browser/ui/route-announcer.js +28 -0
  78. package/dist/browser/ui/scroll-area.js +53 -0
  79. package/dist/browser/ui/section.js +65 -0
  80. package/dist/browser/ui/select.js +165 -0
  81. package/dist/browser/ui/separator.js +30 -0
  82. package/dist/browser/ui/sheet.js +136 -0
  83. package/dist/browser/ui/sidebar.js +806 -0
  84. package/dist/browser/ui/skeleton.js +30 -0
  85. package/dist/browser/ui/skip-link.js +27 -0
  86. package/dist/browser/ui/slider.js +50 -0
  87. package/dist/browser/ui/sonner.js +29 -0
  88. package/dist/browser/ui/stack.js +158 -0
  89. package/dist/browser/ui/stat-card-group.js +263 -0
  90. package/dist/browser/ui/stepper.js +185 -0
  91. package/dist/browser/ui/switch.js +31 -0
  92. package/dist/browser/ui/table.js +106 -0
  93. package/dist/browser/ui/tabs.js +59 -0
  94. package/dist/browser/ui/text.js +22 -0
  95. package/dist/browser/ui/textarea.js +21 -0
  96. package/dist/browser/ui/time-picker.js +186 -0
  97. package/dist/browser/ui/toast.js +79 -0
  98. package/dist/browser/ui/toaster.js +220 -0
  99. package/dist/browser/ui/toggle-group.js +96 -0
  100. package/dist/browser/ui/toggle.js +47 -0
  101. package/dist/browser/ui/tooltip.js +68 -0
  102. package/dist/browser/ui/typography.js +123 -0
  103. package/dist/browser/ui/use-media-query.js +26 -0
  104. package/dist/browser/ui/use-mobile.js +27 -0
  105. package/dist/browser/ui/use-reduced-motion.js +24 -0
  106. package/dist/browser/ui/use-toast.js +129 -0
  107. package/dist/browser/ui/useListState.js +76 -0
  108. package/dist/browser/ui/usecases/UseCaseCard.js +232 -0
  109. package/dist/browser/ui/usecases/UserStoryCard.js +186 -0
  110. package/dist/browser/ui/usecases/index.js +267 -0
  111. package/dist/browser/ui/utils.js +17 -0
  112. package/dist/browser/ui/visually-hidden.js +35 -0
  113. package/dist/index.d.ts +2 -1
  114. package/dist/index.d.ts.map +1 -0
  115. package/dist/index.js +8 -0
  116. package/dist/ui/accordion.d.ts +7 -24
  117. package/dist/ui/accordion.d.ts.map +1 -1
  118. package/dist/ui/accordion.js +60 -40
  119. package/dist/ui/alert-dialog.d.ts +14 -48
  120. package/dist/ui/alert-dialog.d.ts.map +1 -1
  121. package/dist/ui/alert-dialog.js +158 -71
  122. package/dist/ui/alert.d.ts +8 -23
  123. package/dist/ui/alert.d.ts.map +1 -1
  124. package/dist/ui/alert.js +50 -34
  125. package/dist/ui/aspect-ratio.d.ts +2 -6
  126. package/dist/ui/aspect-ratio.d.ts.map +1 -1
  127. package/dist/ui/aspect-ratio.js +8 -8
  128. package/dist/ui/atoms/FilterSelect/FilterSelect.d.ts +3 -7
  129. package/dist/ui/atoms/FilterSelect/FilterSelect.d.ts.map +1 -1
  130. package/dist/ui/atoms/FilterSelect/FilterSelect.js +237 -51
  131. package/dist/ui/atoms/FilterSelect/index.d.ts +3 -3
  132. package/dist/ui/atoms/FilterSelect/index.d.ts.map +1 -0
  133. package/dist/ui/atoms/FilterSelect/index.js +238 -2
  134. package/dist/ui/atoms/FilterSelect/types.d.ts +13 -16
  135. package/dist/ui/atoms/FilterSelect/types.d.ts.map +1 -1
  136. package/dist/ui/atoms/FilterSelect/types.js +1 -0
  137. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.d.ts +14 -17
  138. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.d.ts.map +1 -1
  139. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.js +81 -43
  140. package/dist/ui/atoms/LoadingSpinner/index.d.ts +2 -2
  141. package/dist/ui/atoms/LoadingSpinner/index.d.ts.map +1 -0
  142. package/dist/ui/atoms/LoadingSpinner/index.js +83 -2
  143. package/dist/ui/atoms/Pagination/Pagination.d.ts +3 -7
  144. package/dist/ui/atoms/Pagination/Pagination.d.ts.map +1 -1
  145. package/dist/ui/atoms/Pagination/Pagination.js +380 -155
  146. package/dist/ui/atoms/Pagination/index.d.ts +3 -3
  147. package/dist/ui/atoms/Pagination/index.d.ts.map +1 -0
  148. package/dist/ui/atoms/Pagination/index.js +381 -2
  149. package/dist/ui/atoms/Pagination/types.d.ts +11 -14
  150. package/dist/ui/atoms/Pagination/types.d.ts.map +1 -1
  151. package/dist/ui/atoms/Pagination/types.js +1 -0
  152. package/dist/ui/atoms/SearchInput/SearchInput.d.ts +3 -7
  153. package/dist/ui/atoms/SearchInput/SearchInput.d.ts.map +1 -1
  154. package/dist/ui/atoms/SearchInput/SearchInput.js +116 -48
  155. package/dist/ui/atoms/SearchInput/index.d.ts +3 -3
  156. package/dist/ui/atoms/SearchInput/index.d.ts.map +1 -0
  157. package/dist/ui/atoms/SearchInput/index.js +117 -2
  158. package/dist/ui/atoms/SearchInput/types.d.ts +8 -11
  159. package/dist/ui/atoms/SearchInput/types.d.ts.map +1 -1
  160. package/dist/ui/atoms/SearchInput/types.js +1 -0
  161. package/dist/ui/avatar.d.ts +6 -19
  162. package/dist/ui/avatar.d.ts.map +1 -1
  163. package/dist/ui/avatar.js +44 -28
  164. package/dist/ui/badge.d.ts +7 -17
  165. package/dist/ui/badge.d.ts.map +1 -1
  166. package/dist/ui/badge.js +34 -23
  167. package/dist/ui/breadcrumb.d.ts +11 -37
  168. package/dist/ui/breadcrumb.d.ts.map +1 -1
  169. package/dist/ui/breadcrumb.js +94 -62
  170. package/dist/ui/button.d.ts +14 -18
  171. package/dist/ui/button.d.ts.map +1 -1
  172. package/dist/ui/button.js +46 -50
  173. package/dist/ui/calendar.d.ts +7 -25
  174. package/dist/ui/calendar.d.ts.map +1 -1
  175. package/dist/ui/calendar.js +172 -105
  176. package/dist/ui/card.d.ts +9 -34
  177. package/dist/ui/card.d.ts.map +1 -1
  178. package/dist/ui/card.js +73 -49
  179. package/dist/ui/carousel.d.ts +13 -41
  180. package/dist/ui/carousel.d.ts.map +1 -1
  181. package/dist/ui/carousel.js +215 -127
  182. package/dist/ui/checkbox.d.ts +3 -10
  183. package/dist/ui/checkbox.d.ts.map +1 -1
  184. package/dist/ui/checkbox.js +25 -21
  185. package/dist/ui/collapsible.d.ts +5 -15
  186. package/dist/ui/collapsible.d.ts.map +1 -1
  187. package/dist/ui/collapsible.js +31 -23
  188. package/dist/ui/command.d.ts +18 -52
  189. package/dist/ui/command.d.ts.map +1 -1
  190. package/dist/ui/command.js +258 -87
  191. package/dist/ui/confirm-dialog.d.ts +13 -29
  192. package/dist/ui/confirm-dialog.d.ts.map +1 -1
  193. package/dist/ui/confirm-dialog.js +219 -32
  194. package/dist/ui/context-menu.d.ts +25 -32
  195. package/dist/ui/context-menu.d.ts.map +1 -1
  196. package/dist/ui/context-menu.js +109 -71
  197. package/dist/ui/cta.d.ts +17 -21
  198. package/dist/ui/cta.d.ts.map +1 -1
  199. package/dist/ui/cta.js +94 -36
  200. package/dist/ui/date-picker.d.ts +10 -24
  201. package/dist/ui/date-picker.d.ts.map +1 -1
  202. package/dist/ui/date-picker.js +342 -98
  203. package/dist/ui/date-range-picker.d.ts +11 -23
  204. package/dist/ui/date-range-picker.d.ts.map +1 -1
  205. package/dist/ui/date-range-picker.js +268 -51
  206. package/dist/ui/datetime-picker.d.ts +11 -26
  207. package/dist/ui/datetime-picker.d.ts.map +1 -1
  208. package/dist/ui/datetime-picker.js +479 -39
  209. package/dist/ui/dialog.d.ts +15 -47
  210. package/dist/ui/dialog.d.ts.map +1 -1
  211. package/dist/ui/dialog.js +122 -77
  212. package/dist/ui/drawer.d.ts +13 -44
  213. package/dist/ui/drawer.d.ts.map +1 -1
  214. package/dist/ui/drawer.js +113 -70
  215. package/dist/ui/dropdown-menu.d.ts +25 -77
  216. package/dist/ui/dropdown-menu.d.ts.map +1 -1
  217. package/dist/ui/dropdown-menu.js +191 -109
  218. package/dist/ui/empty-state.d.ts +13 -26
  219. package/dist/ui/empty-state.d.ts.map +1 -1
  220. package/dist/ui/empty-state.js +201 -40
  221. package/dist/ui/empty.d.ts +11 -35
  222. package/dist/ui/empty.d.ts.map +1 -1
  223. package/dist/ui/empty.js +76 -53
  224. package/dist/ui/field.d.ts +24 -64
  225. package/dist/ui/field.d.ts.map +1 -1
  226. package/dist/ui/field.js +202 -107
  227. package/dist/ui/focus-on-route-change.d.ts +2 -7
  228. package/dist/ui/focus-on-route-change.d.ts.map +1 -1
  229. package/dist/ui/focus-on-route-change.js +18 -15
  230. package/dist/ui/form.d.ts +24 -44
  231. package/dist/ui/form.d.ts.map +1 -1
  232. package/dist/ui/form.js +141 -84
  233. package/dist/ui/hover-card.d.ts +6 -19
  234. package/dist/ui/hover-card.d.ts.map +1 -1
  235. package/dist/ui/hover-card.js +41 -31
  236. package/dist/ui/input-group.d.ts +14 -41
  237. package/dist/ui/input-group.d.ts.map +1 -1
  238. package/dist/ui/input-group.js +177 -79
  239. package/dist/ui/input-otp.d.ts +32 -36
  240. package/dist/ui/input-otp.d.ts.map +1 -1
  241. package/dist/ui/input-otp.js +47 -38
  242. package/dist/ui/input.d.ts +4 -12
  243. package/dist/ui/input.d.ts.map +1 -1
  244. package/dist/ui/input.js +14 -14
  245. package/dist/ui/label.d.ts +3 -10
  246. package/dist/ui/label.d.ts.map +1 -1
  247. package/dist/ui/label.js +18 -16
  248. package/dist/ui/link.d.ts +3 -7
  249. package/dist/ui/link.d.ts.map +1 -1
  250. package/dist/ui/link.js +14 -13
  251. package/dist/ui/live-region.d.ts +8 -14
  252. package/dist/ui/live-region.d.ts.map +1 -1
  253. package/dist/ui/live-region.js +47 -43
  254. package/dist/ui/loading-button.d.ts +7 -17
  255. package/dist/ui/loading-button.d.ts.map +1 -1
  256. package/dist/ui/loading-button.js +221 -19
  257. package/dist/ui/map/MapBase.d.ts +20 -25
  258. package/dist/ui/map/MapBase.d.ts.map +1 -1
  259. package/dist/ui/map/MapBase.js +62 -43
  260. package/dist/ui/map/MapGeoJsonOverlay.d.ts +9 -14
  261. package/dist/ui/map/MapGeoJsonOverlay.d.ts.map +1 -1
  262. package/dist/ui/map/MapGeoJsonOverlay.js +47 -33
  263. package/dist/ui/map/MapHeatmapH3.d.ts +10 -15
  264. package/dist/ui/map/MapHeatmapH3.d.ts.map +1 -1
  265. package/dist/ui/map/MapHeatmapH3.js +55 -44
  266. package/dist/ui/map/MapMarkers.d.ts +11 -18
  267. package/dist/ui/map/MapMarkers.d.ts.map +1 -1
  268. package/dist/ui/map/MapMarkers.js +36 -35
  269. package/dist/ui/map/index.d.ts +5 -5
  270. package/dist/ui/map/index.d.ts.map +1 -0
  271. package/dist/ui/map/index.js +204 -5
  272. package/dist/ui/marketing/FeatureGrid.d.ts +10 -19
  273. package/dist/ui/marketing/FeatureGrid.d.ts.map +1 -1
  274. package/dist/ui/marketing/FeatureGrid.js +42 -32
  275. package/dist/ui/marketing/Hero.d.ts +16 -27
  276. package/dist/ui/marketing/Hero.d.ts.map +1 -1
  277. package/dist/ui/marketing/Hero.js +108 -50
  278. package/dist/ui/marketing/PricingTable.d.ts +15 -23
  279. package/dist/ui/marketing/PricingTable.d.ts.map +1 -1
  280. package/dist/ui/marketing/PricingTable.js +119 -57
  281. package/dist/ui/marketing/index.d.ts +4 -4
  282. package/dist/ui/marketing/index.d.ts.map +1 -0
  283. package/dist/ui/marketing/index.js +211 -4
  284. package/dist/ui/menubar.d.ts +26 -84
  285. package/dist/ui/menubar.d.ts.map +1 -1
  286. package/dist/ui/menubar.js +223 -134
  287. package/dist/ui/molecules/Autocomplete/index.d.ts +1 -6
  288. package/dist/ui/molecules/Autocomplete/index.d.ts.map +1 -1
  289. package/dist/ui/molecules/Autocomplete/index.js +574 -80
  290. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.d.ts +3 -7
  291. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.d.ts.map +1 -1
  292. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js +496 -101
  293. package/dist/ui/molecules/SearchAndFilter/index.d.ts +3 -3
  294. package/dist/ui/molecules/SearchAndFilter/index.d.ts.map +1 -0
  295. package/dist/ui/molecules/SearchAndFilter/index.js +497 -2
  296. package/dist/ui/molecules/SearchAndFilter/types.d.ts +18 -22
  297. package/dist/ui/molecules/SearchAndFilter/types.d.ts.map +1 -1
  298. package/dist/ui/molecules/SearchAndFilter/types.js +1 -0
  299. package/dist/ui/molecules/SkeletonList.d.ts +5 -13
  300. package/dist/ui/molecules/SkeletonList.d.ts.map +1 -1
  301. package/dist/ui/molecules/SkeletonList.js +36 -12
  302. package/dist/ui/nav-layout.d.ts +44 -67
  303. package/dist/ui/nav-layout.d.ts.map +1 -1
  304. package/dist/ui/nav-layout.js +287 -127
  305. package/dist/ui/navigation-menu.d.ts +14 -46
  306. package/dist/ui/navigation-menu.d.ts.map +1 -1
  307. package/dist/ui/navigation-menu.js +113 -73
  308. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.d.ts +18 -22
  309. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.d.ts.map +1 -1
  310. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.js +182 -103
  311. package/dist/ui/organisms/ErrorBoundary/index.d.ts +3 -2
  312. package/dist/ui/organisms/ErrorBoundary/index.d.ts.map +1 -0
  313. package/dist/ui/organisms/ErrorBoundary/index.js +185 -2
  314. package/dist/ui/organisms/ListPage/ListPage.d.ts +2 -28
  315. package/dist/ui/organisms/ListPage/ListPage.d.ts.map +1 -1
  316. package/dist/ui/organisms/ListPage/ListPage.js +1229 -196
  317. package/dist/ui/organisms/ListPage/index.d.ts +3 -3
  318. package/dist/ui/organisms/ListPage/index.d.ts.map +1 -0
  319. package/dist/ui/organisms/ListPage/index.js +1230 -2
  320. package/dist/ui/organisms/ListPage/types.d.ts +34 -38
  321. package/dist/ui/organisms/ListPage/types.d.ts.map +1 -1
  322. package/dist/ui/organisms/ListPage/types.js +1 -0
  323. package/dist/ui/page-header.d.ts +12 -24
  324. package/dist/ui/page-header.d.ts.map +1 -1
  325. package/dist/ui/page-header.js +198 -37
  326. package/dist/ui/pagination.d.ts +17 -38
  327. package/dist/ui/pagination.d.ts.map +1 -1
  328. package/dist/ui/pagination.js +142 -56
  329. package/dist/ui/popover.d.ts +7 -22
  330. package/dist/ui/popover.d.ts.map +1 -1
  331. package/dist/ui/popover.js +48 -33
  332. package/dist/ui/progress.d.ts +3 -11
  333. package/dist/ui/progress.d.ts.map +1 -1
  334. package/dist/ui/progress.js +24 -21
  335. package/dist/ui/radio-group.d.ts +4 -14
  336. package/dist/ui/radio-group.d.ts.map +1 -1
  337. package/dist/ui/radio-group.js +35 -27
  338. package/dist/ui/resizable.d.ts +22 -34
  339. package/dist/ui/resizable.d.ts.map +1 -1
  340. package/dist/ui/resizable.js +33 -22
  341. package/dist/ui/route-announcer.d.ts +3 -10
  342. package/dist/ui/route-announcer.d.ts.map +1 -1
  343. package/dist/ui/route-announcer.js +20 -19
  344. package/dist/ui/scroll-area.d.ts +4 -16
  345. package/dist/ui/scroll-area.d.ts.map +1 -1
  346. package/dist/ui/scroll-area.js +44 -36
  347. package/dist/ui/section.d.ts +20 -24
  348. package/dist/ui/section.d.ts.map +1 -1
  349. package/dist/ui/section.js +56 -59
  350. package/dist/ui/select.d.ts +15 -51
  351. package/dist/ui/select.d.ts.map +1 -1
  352. package/dist/ui/select.js +147 -87
  353. package/dist/ui/separator.d.ts +3 -12
  354. package/dist/ui/separator.d.ts.map +1 -1
  355. package/dist/ui/separator.js +22 -18
  356. package/dist/ui/sheet.d.ts +13 -40
  357. package/dist/ui/sheet.d.ts.map +1 -1
  358. package/dist/ui/sheet.js +117 -72
  359. package/dist/ui/sidebar.d.ts +65 -162
  360. package/dist/ui/sidebar.d.ts.map +1 -1
  361. package/dist/ui/sidebar.js +794 -372
  362. package/dist/ui/skeleton.d.ts +2 -9
  363. package/dist/ui/skeleton.d.ts.map +1 -1
  364. package/dist/ui/skeleton.js +22 -12
  365. package/dist/ui/skip-link.d.ts +6 -15
  366. package/dist/ui/skip-link.d.ts.map +1 -1
  367. package/dist/ui/skip-link.js +20 -15
  368. package/dist/ui/slider.d.ts +3 -14
  369. package/dist/ui/slider.d.ts.map +1 -1
  370. package/dist/ui/slider.js +42 -37
  371. package/dist/ui/sonner.d.ts +2 -8
  372. package/dist/ui/sonner.d.ts.map +1 -1
  373. package/dist/ui/sonner.js +21 -21
  374. package/dist/ui/stack.d.ts +40 -44
  375. package/dist/ui/stack.d.ts.map +1 -1
  376. package/dist/ui/stack.js +143 -148
  377. package/dist/ui/stat-card-group.d.ts +9 -17
  378. package/dist/ui/stat-card-group.d.ts.map +1 -1
  379. package/dist/ui/stat-card-group.js +255 -35
  380. package/dist/ui/stepper.d.ts +10 -20
  381. package/dist/ui/stepper.d.ts.map +1 -1
  382. package/dist/ui/stepper.js +176 -33
  383. package/dist/ui/switch.d.ts +5 -13
  384. package/dist/ui/switch.d.ts.map +1 -1
  385. package/dist/ui/switch.js +23 -20
  386. package/dist/ui/table.d.ts +10 -38
  387. package/dist/ui/table.d.ts.map +1 -1
  388. package/dist/ui/table.js +91 -61
  389. package/dist/ui/tabs.d.ts +7 -23
  390. package/dist/ui/tabs.d.ts.map +1 -1
  391. package/dist/ui/tabs.js +48 -34
  392. package/dist/ui/text.d.ts +5 -13
  393. package/dist/ui/text.d.ts.map +1 -1
  394. package/dist/ui/text.js +14 -13
  395. package/dist/ui/textarea.d.ts +4 -11
  396. package/dist/ui/textarea.d.ts.map +1 -1
  397. package/dist/ui/textarea.js +13 -13
  398. package/dist/ui/time-picker.d.ts +8 -20
  399. package/dist/ui/time-picker.d.ts.map +1 -1
  400. package/dist/ui/time-picker.js +176 -76
  401. package/dist/ui/toast.d.ts +15 -19
  402. package/dist/ui/toast.d.ts.map +1 -1
  403. package/dist/ui/toast.js +63 -51
  404. package/dist/ui/toaster.d.ts +1 -6
  405. package/dist/ui/toaster.d.ts.map +1 -1
  406. package/dist/ui/toaster.js +212 -24
  407. package/dist/ui/toggle-group.d.ts +6 -22
  408. package/dist/ui/toggle-group.d.ts.map +1 -1
  409. package/dist/ui/toggle-group.js +85 -42
  410. package/dist/ui/toggle.d.ts +7 -17
  411. package/dist/ui/toggle.d.ts.map +1 -1
  412. package/dist/ui/toggle.js +38 -37
  413. package/dist/ui/tooltip.d.ts +7 -23
  414. package/dist/ui/tooltip.d.ts.map +1 -1
  415. package/dist/ui/tooltip.js +57 -34
  416. package/dist/ui/typography.d.ts +13 -61
  417. package/dist/ui/typography.d.ts.map +1 -1
  418. package/dist/ui/typography.js +95 -64
  419. package/dist/ui/use-media-query.d.ts +1 -4
  420. package/dist/ui/use-media-query.d.ts.map +1 -1
  421. package/dist/ui/use-media-query.js +18 -17
  422. package/dist/ui/use-mobile.d.ts +1 -4
  423. package/dist/ui/use-mobile.d.ts.map +1 -1
  424. package/dist/ui/use-mobile.js +19 -18
  425. package/dist/ui/use-reduced-motion.d.ts +1 -4
  426. package/dist/ui/use-reduced-motion.d.ts.map +1 -1
  427. package/dist/ui/use-reduced-motion.js +16 -15
  428. package/dist/ui/use-toast.d.ts +28 -33
  429. package/dist/ui/use-toast.d.ts.map +1 -1
  430. package/dist/ui/use-toast.js +113 -111
  431. package/dist/ui/useListState.d.ts +23 -31
  432. package/dist/ui/useListState.d.ts.map +1 -1
  433. package/dist/ui/useListState.js +69 -73
  434. package/dist/ui/usecases/UseCaseCard.d.ts +7 -18
  435. package/dist/ui/usecases/UseCaseCard.d.ts.map +1 -1
  436. package/dist/ui/usecases/UseCaseCard.js +225 -33
  437. package/dist/ui/usecases/UserStoryCard.d.ts +5 -14
  438. package/dist/ui/usecases/UserStoryCard.d.ts.map +1 -1
  439. package/dist/ui/usecases/UserStoryCard.js +179 -34
  440. package/dist/ui/usecases/index.d.ts +3 -3
  441. package/dist/ui/usecases/index.d.ts.map +1 -0
  442. package/dist/ui/usecases/index.js +261 -3
  443. package/dist/ui/utils.d.ts +2 -6
  444. package/dist/ui/utils.d.ts.map +1 -1
  445. package/dist/ui/utils.js +8 -7
  446. package/dist/ui/visually-hidden.d.ts +5 -8
  447. package/dist/ui/visually-hidden.d.ts.map +1 -1
  448. package/dist/ui/visually-hidden.js +26 -27
  449. package/package.json +872 -236
  450. package/dist/ui/accordion.js.map +0 -1
  451. package/dist/ui/alert-dialog.js.map +0 -1
  452. package/dist/ui/alert.js.map +0 -1
  453. package/dist/ui/aspect-ratio.js.map +0 -1
  454. package/dist/ui/atoms/FilterSelect/FilterSelect.js.map +0 -1
  455. package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.js.map +0 -1
  456. package/dist/ui/atoms/Pagination/Pagination.js.map +0 -1
  457. package/dist/ui/atoms/SearchInput/SearchInput.js.map +0 -1
  458. package/dist/ui/avatar.js.map +0 -1
  459. package/dist/ui/badge.js.map +0 -1
  460. package/dist/ui/breadcrumb.js.map +0 -1
  461. package/dist/ui/button.js.map +0 -1
  462. package/dist/ui/calendar.js.map +0 -1
  463. package/dist/ui/card.js.map +0 -1
  464. package/dist/ui/carousel.js.map +0 -1
  465. package/dist/ui/checkbox.js.map +0 -1
  466. package/dist/ui/collapsible.js.map +0 -1
  467. package/dist/ui/command.js.map +0 -1
  468. package/dist/ui/confirm-dialog.js.map +0 -1
  469. package/dist/ui/context-menu.js.map +0 -1
  470. package/dist/ui/cta.js.map +0 -1
  471. package/dist/ui/date-picker.js.map +0 -1
  472. package/dist/ui/date-range-picker.js.map +0 -1
  473. package/dist/ui/datetime-picker.js.map +0 -1
  474. package/dist/ui/dialog.js.map +0 -1
  475. package/dist/ui/drawer.js.map +0 -1
  476. package/dist/ui/dropdown-menu.js.map +0 -1
  477. package/dist/ui/empty-state.js.map +0 -1
  478. package/dist/ui/empty.js.map +0 -1
  479. package/dist/ui/field.js.map +0 -1
  480. package/dist/ui/focus-on-route-change.js.map +0 -1
  481. package/dist/ui/form.js.map +0 -1
  482. package/dist/ui/hover-card.js.map +0 -1
  483. package/dist/ui/input-group.js.map +0 -1
  484. package/dist/ui/input-otp.js.map +0 -1
  485. package/dist/ui/input.js.map +0 -1
  486. package/dist/ui/label.js.map +0 -1
  487. package/dist/ui/link.js.map +0 -1
  488. package/dist/ui/live-region.js.map +0 -1
  489. package/dist/ui/loading-button.js.map +0 -1
  490. package/dist/ui/map/MapBase.js.map +0 -1
  491. package/dist/ui/map/MapGeoJsonOverlay.js.map +0 -1
  492. package/dist/ui/map/MapHeatmapH3.js.map +0 -1
  493. package/dist/ui/map/MapMarkers.js.map +0 -1
  494. package/dist/ui/marketing/FeatureGrid.js.map +0 -1
  495. package/dist/ui/marketing/Hero.js.map +0 -1
  496. package/dist/ui/marketing/PricingTable.js.map +0 -1
  497. package/dist/ui/menubar.js.map +0 -1
  498. package/dist/ui/molecules/Autocomplete/index.js.map +0 -1
  499. package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js.map +0 -1
  500. package/dist/ui/molecules/SkeletonList.js.map +0 -1
  501. package/dist/ui/nav-layout.js.map +0 -1
  502. package/dist/ui/navigation-menu.js.map +0 -1
  503. package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.js.map +0 -1
  504. package/dist/ui/organisms/ListPage/ListPage.js.map +0 -1
  505. package/dist/ui/page-header.js.map +0 -1
  506. package/dist/ui/pagination.js.map +0 -1
  507. package/dist/ui/popover.js.map +0 -1
  508. package/dist/ui/progress.js.map +0 -1
  509. package/dist/ui/radio-group.js.map +0 -1
  510. package/dist/ui/resizable.js.map +0 -1
  511. package/dist/ui/route-announcer.js.map +0 -1
  512. package/dist/ui/scroll-area.js.map +0 -1
  513. package/dist/ui/section.js.map +0 -1
  514. package/dist/ui/select.js.map +0 -1
  515. package/dist/ui/separator.js.map +0 -1
  516. package/dist/ui/sheet.js.map +0 -1
  517. package/dist/ui/sidebar.js.map +0 -1
  518. package/dist/ui/skeleton.js.map +0 -1
  519. package/dist/ui/skip-link.js.map +0 -1
  520. package/dist/ui/slider.js.map +0 -1
  521. package/dist/ui/sonner.js.map +0 -1
  522. package/dist/ui/stack.js.map +0 -1
  523. package/dist/ui/stat-card-group.js.map +0 -1
  524. package/dist/ui/stepper.js.map +0 -1
  525. package/dist/ui/switch.js.map +0 -1
  526. package/dist/ui/table.js.map +0 -1
  527. package/dist/ui/tabs.js.map +0 -1
  528. package/dist/ui/text.js.map +0 -1
  529. package/dist/ui/textarea.js.map +0 -1
  530. package/dist/ui/time-picker.js.map +0 -1
  531. package/dist/ui/toast.js.map +0 -1
  532. package/dist/ui/toaster.js.map +0 -1
  533. package/dist/ui/toggle-group.js.map +0 -1
  534. package/dist/ui/toggle.js.map +0 -1
  535. package/dist/ui/tooltip.js.map +0 -1
  536. package/dist/ui/typography.js.map +0 -1
  537. package/dist/ui/use-media-query.js.map +0 -1
  538. package/dist/ui/use-mobile.js.map +0 -1
  539. package/dist/ui/use-reduced-motion.js.map +0 -1
  540. package/dist/ui/use-toast.js.map +0 -1
  541. package/dist/ui/useListState.js.map +0 -1
  542. package/dist/ui/usecases/UseCaseCard.js.map +0 -1
  543. package/dist/ui/usecases/UserStoryCard.js.map +0 -1
  544. package/dist/ui/utils.js.map +0 -1
  545. package/dist/ui/visually-hidden.js.map +0 -1
@@ -0,0 +1,27 @@
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/use-mobile.tsx
10
+ import * as React from "react";
11
+ var MOBILE_BREAKPOINT = 640;
12
+ function useIsMobile() {
13
+ const [isMobile, setIsMobile] = React.useState(undefined);
14
+ React.useEffect(() => {
15
+ const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`);
16
+ const onChange = () => {
17
+ setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);
18
+ };
19
+ mql.addEventListener("change", onChange);
20
+ setIsMobile(window.innerWidth < MOBILE_BREAKPOINT);
21
+ return () => mql.removeEventListener("change", onChange);
22
+ }, []);
23
+ return !!isMobile;
24
+ }
25
+ export {
26
+ useIsMobile
27
+ };
@@ -0,0 +1,24 @@
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/use-reduced-motion.ts
10
+ import * as React from "react";
11
+ function useReducedMotion() {
12
+ const [reduced, setReduced] = React.useState(false);
13
+ React.useEffect(() => {
14
+ const mql = window.matchMedia("(prefers-reduced-motion: reduce)");
15
+ const onChange = () => setReduced(mql.matches);
16
+ onChange();
17
+ mql.addEventListener("change", onChange);
18
+ return () => mql.removeEventListener("change", onChange);
19
+ }, []);
20
+ return reduced;
21
+ }
22
+ export {
23
+ useReducedMotion
24
+ };
@@ -0,0 +1,129 @@
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/use-toast.ts
10
+ import * as React from "react";
11
+ "use client";
12
+ var TOAST_LIMIT = 1;
13
+ var TOAST_REMOVE_DELAY = 1e6;
14
+ var count = 0;
15
+ function genId() {
16
+ count = (count + 1) % Number.MAX_SAFE_INTEGER;
17
+ return count.toString();
18
+ }
19
+ var toastTimeouts = new Map;
20
+ var addToRemoveQueue = (toastId) => {
21
+ if (toastTimeouts.has(toastId)) {
22
+ return;
23
+ }
24
+ const timeout = setTimeout(() => {
25
+ toastTimeouts.delete(toastId);
26
+ dispatch({
27
+ type: "REMOVE_TOAST",
28
+ toastId
29
+ });
30
+ }, TOAST_REMOVE_DELAY);
31
+ toastTimeouts.set(toastId, timeout);
32
+ };
33
+ var reducer = (state, action) => {
34
+ switch (action.type) {
35
+ case "ADD_TOAST":
36
+ return {
37
+ ...state,
38
+ toasts: [action.toast, ...state.toasts].slice(0, TOAST_LIMIT)
39
+ };
40
+ case "UPDATE_TOAST":
41
+ return {
42
+ ...state,
43
+ toasts: state.toasts.map((t) => t.id === action.toast.id ? { ...t, ...action.toast } : t)
44
+ };
45
+ case "DISMISS_TOAST": {
46
+ const { toastId } = action;
47
+ if (toastId) {
48
+ addToRemoveQueue(toastId);
49
+ } else {
50
+ state.toasts.forEach((toast) => {
51
+ addToRemoveQueue(toast.id);
52
+ });
53
+ }
54
+ return {
55
+ ...state,
56
+ toasts: state.toasts.map((t) => t.id === toastId || toastId === undefined ? {
57
+ ...t,
58
+ open: false
59
+ } : t)
60
+ };
61
+ }
62
+ case "REMOVE_TOAST":
63
+ if (action.toastId === undefined) {
64
+ return {
65
+ ...state,
66
+ toasts: []
67
+ };
68
+ }
69
+ return {
70
+ ...state,
71
+ toasts: state.toasts.filter((t) => t.id !== action.toastId)
72
+ };
73
+ }
74
+ };
75
+ var listeners = [];
76
+ var memoryState = { toasts: [] };
77
+ function dispatch(action) {
78
+ memoryState = reducer(memoryState, action);
79
+ listeners.forEach((listener) => {
80
+ listener(memoryState);
81
+ });
82
+ }
83
+ function toast({ ...props }) {
84
+ const id = genId();
85
+ const update = (props2) => dispatch({
86
+ type: "UPDATE_TOAST",
87
+ toast: { ...props2, id }
88
+ });
89
+ const dismiss = () => dispatch({ type: "DISMISS_TOAST", toastId: id });
90
+ dispatch({
91
+ type: "ADD_TOAST",
92
+ toast: {
93
+ ...props,
94
+ id,
95
+ open: true,
96
+ onOpenChange: (open) => {
97
+ if (!open)
98
+ dismiss();
99
+ }
100
+ }
101
+ });
102
+ return {
103
+ id,
104
+ dismiss,
105
+ update
106
+ };
107
+ }
108
+ function useToast() {
109
+ const [state, setState] = React.useState(memoryState);
110
+ React.useEffect(() => {
111
+ listeners.push(setState);
112
+ return () => {
113
+ const index = listeners.indexOf(setState);
114
+ if (index > -1) {
115
+ listeners.splice(index, 1);
116
+ }
117
+ };
118
+ }, [state]);
119
+ return {
120
+ ...state,
121
+ toast,
122
+ dismiss: (toastId) => dispatch({ type: "DISMISS_TOAST", toastId })
123
+ };
124
+ }
125
+ export {
126
+ useToast,
127
+ toast,
128
+ reducer
129
+ };
@@ -0,0 +1,76 @@
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/useListState.tsx
10
+ import { useCallback, useMemo, useState } from "react";
11
+ var useListState = ({
12
+ initialSearch = "",
13
+ initialFilters = {},
14
+ initialPage = 1,
15
+ initialItemsPerPage = 25
16
+ } = {}) => {
17
+ const [searchQuery, setSearchQuery] = useState(initialSearch);
18
+ const [filters, setFilters] = useState(initialFilters);
19
+ const [currentPage, setCurrentPage] = useState(initialPage);
20
+ const [itemsPerPage, setItemsPerPage] = useState(initialItemsPerPage);
21
+ const setFilter = useCallback((key, value) => {
22
+ setFilters((prev) => ({
23
+ ...prev,
24
+ [key]: value
25
+ }));
26
+ setCurrentPage(1);
27
+ }, []);
28
+ const clearFilters = useCallback(() => {
29
+ setFilters({});
30
+ setCurrentPage(1);
31
+ }, []);
32
+ const handleSetSearchQuery = useCallback((query) => {
33
+ setSearchQuery(query);
34
+ setCurrentPage(1);
35
+ }, []);
36
+ const handleSetItemsPerPage = useCallback((newItemsPerPage) => {
37
+ setItemsPerPage(newItemsPerPage);
38
+ setCurrentPage(1);
39
+ }, []);
40
+ const resetAll = useCallback(() => {
41
+ setSearchQuery(initialSearch);
42
+ setFilters(initialFilters);
43
+ setCurrentPage(initialPage);
44
+ setItemsPerPage(initialItemsPerPage);
45
+ }, [initialSearch, initialFilters, initialPage, initialItemsPerPage]);
46
+ const queryParams = useMemo(() => {
47
+ const baseParams = {
48
+ search: searchQuery,
49
+ page: currentPage,
50
+ limit: itemsPerPage
51
+ };
52
+ const filterParams = {};
53
+ Object.entries(filters).forEach(([key, value]) => {
54
+ if (value) {
55
+ filterParams[key] = value;
56
+ }
57
+ });
58
+ return { ...baseParams, ...filterParams };
59
+ }, [searchQuery, filters, currentPage, itemsPerPage]);
60
+ return {
61
+ searchQuery,
62
+ setSearchQuery: handleSetSearchQuery,
63
+ filters,
64
+ setFilter,
65
+ clearFilters,
66
+ currentPage,
67
+ itemsPerPage,
68
+ setCurrentPage,
69
+ setItemsPerPage: handleSetItemsPerPage,
70
+ queryParams,
71
+ resetAll
72
+ };
73
+ };
74
+ export {
75
+ useListState
76
+ };
@@ -0,0 +1,232 @@
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/stack.tsx
54
+ import * as React2 from "react";
55
+ import { cva as cva2 } from "class-variance-authority";
56
+ import { cn as cn2 } from "@contractspec/lib.ui-kit-core/utils";
57
+ import { jsxDEV as jsxDEV2 } from "react/jsx-dev-runtime";
58
+ var vStackVariants = cva2("flex flex-col", {
59
+ variants: {
60
+ gap: {
61
+ none: "gap-0",
62
+ xs: "gap-1",
63
+ sm: "gap-2",
64
+ md: "gap-3",
65
+ lg: "gap-4",
66
+ xl: "gap-6",
67
+ "2xl": "gap-8"
68
+ },
69
+ align: {
70
+ start: "items-start",
71
+ center: "items-center",
72
+ end: "items-end",
73
+ stretch: "items-stretch"
74
+ },
75
+ justify: {
76
+ start: "justify-start",
77
+ center: "justify-center",
78
+ end: "justify-end",
79
+ between: "justify-between",
80
+ around: "justify-around",
81
+ evenly: "justify-evenly"
82
+ }
83
+ },
84
+ defaultVariants: {
85
+ gap: "md",
86
+ align: "stretch",
87
+ justify: "start"
88
+ }
89
+ });
90
+ var VStack = React2.forwardRef(({ className, gap, align, justify, as = "div", ...props }, ref) => {
91
+ const Comp = as;
92
+ return /* @__PURE__ */ jsxDEV2(Comp, {
93
+ ref,
94
+ className: cn2(vStackVariants({ gap, align, justify }), className),
95
+ ...props
96
+ }, undefined, false, undefined, this);
97
+ });
98
+ VStack.displayName = "VStack";
99
+ var hStackVariants = cva2("flex flex-row", {
100
+ variants: {
101
+ gap: {
102
+ none: "gap-0",
103
+ xs: "gap-1",
104
+ sm: "gap-2",
105
+ md: "gap-3",
106
+ lg: "gap-4",
107
+ xl: "gap-6",
108
+ "2xl": "gap-8"
109
+ },
110
+ align: {
111
+ start: "items-start",
112
+ center: "items-center",
113
+ end: "items-end",
114
+ stretch: "items-stretch",
115
+ baseline: "items-baseline"
116
+ },
117
+ justify: {
118
+ start: "justify-start",
119
+ center: "justify-center",
120
+ end: "justify-end",
121
+ between: "justify-between",
122
+ around: "justify-around",
123
+ evenly: "justify-evenly"
124
+ },
125
+ wrap: {
126
+ nowrap: "flex-nowrap",
127
+ wrap: "flex-wrap",
128
+ wrapReverse: "flex-wrap-reverse"
129
+ }
130
+ },
131
+ defaultVariants: {
132
+ gap: "md",
133
+ align: "center",
134
+ justify: "start",
135
+ wrap: "wrap"
136
+ }
137
+ });
138
+ var HStack = React2.forwardRef(({ className, gap, align, justify, wrap, as = "div", ...props }, ref) => {
139
+ const Comp = as;
140
+ return /* @__PURE__ */ jsxDEV2(Comp, {
141
+ ref,
142
+ className: cn2(hStackVariants({ gap, align, justify, wrap }), className),
143
+ ...props
144
+ }, undefined, false, undefined, this);
145
+ });
146
+ HStack.displayName = "HStack";
147
+ var boxVariants = cva2("flex flex-row", {
148
+ variants: {
149
+ gap: {
150
+ none: "gap-0",
151
+ xs: "gap-1",
152
+ sm: "gap-2",
153
+ md: "gap-3",
154
+ lg: "gap-4",
155
+ xl: "gap-6",
156
+ "2xl": "gap-8"
157
+ },
158
+ align: {
159
+ start: "items-start",
160
+ center: "items-center",
161
+ end: "items-end",
162
+ stretch: "items-stretch",
163
+ baseline: "items-baseline"
164
+ },
165
+ justify: {
166
+ start: "justify-start",
167
+ center: "justify-center",
168
+ end: "justify-end",
169
+ between: "justify-between",
170
+ around: "justify-around",
171
+ evenly: "justify-evenly"
172
+ },
173
+ wrap: {
174
+ nowrap: "flex-nowrap",
175
+ wrap: "flex-wrap",
176
+ wrapReverse: "flex-wrap-reverse"
177
+ }
178
+ },
179
+ defaultVariants: {
180
+ gap: "md",
181
+ align: "center",
182
+ justify: "center",
183
+ wrap: "nowrap"
184
+ }
185
+ });
186
+ var Box = React2.forwardRef(({ className, gap, align, justify, wrap, as = "div", ...props }, ref) => {
187
+ const Comp = as;
188
+ return /* @__PURE__ */ jsxDEV2(Comp, {
189
+ ref,
190
+ className: cn2(boxVariants({ gap, align, justify, wrap }), className),
191
+ ...props
192
+ }, undefined, false, undefined, this);
193
+ });
194
+ Box.displayName = "Box";
195
+ // ui/usecases/UseCaseCard.tsx
196
+ import { jsxDEV as jsxDEV3 } from "react/jsx-dev-runtime";
197
+ function UseCaseCard({
198
+ title,
199
+ summary,
200
+ ctaHref,
201
+ ctaLabel = "Learn more",
202
+ onCtaClick
203
+ }) {
204
+ return /* @__PURE__ */ jsxDEV3(VStack, {
205
+ className: "rounded-lg border p-4",
206
+ gap: "sm",
207
+ children: [
208
+ /* @__PURE__ */ jsxDEV3("div", {
209
+ className: "text-lg font-semibold",
210
+ children: title
211
+ }, undefined, false, undefined, this),
212
+ summary && /* @__PURE__ */ jsxDEV3("div", {
213
+ className: "text-muted-foreground text-base",
214
+ children: summary
215
+ }, undefined, false, undefined, this),
216
+ ctaHref && /* @__PURE__ */ jsxDEV3(HStack, {
217
+ children: /* @__PURE__ */ jsxDEV3("a", {
218
+ href: ctaHref,
219
+ onClick: onCtaClick,
220
+ children: /* @__PURE__ */ jsxDEV3(Button, {
221
+ size: "sm",
222
+ variant: "outline",
223
+ children: ctaLabel
224
+ }, undefined, false, undefined, this)
225
+ }, undefined, false, undefined, this)
226
+ }, undefined, false, undefined, this)
227
+ ]
228
+ }, undefined, true, undefined, this);
229
+ }
230
+ export {
231
+ UseCaseCard
232
+ };
@@ -0,0 +1,186 @@
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/stack.tsx
10
+ import * as React from "react";
11
+ import { cva } from "class-variance-authority";
12
+ import { cn } from "@contractspec/lib.ui-kit-core/utils";
13
+ import { jsxDEV } from "react/jsx-dev-runtime";
14
+ var vStackVariants = cva("flex flex-col", {
15
+ variants: {
16
+ gap: {
17
+ none: "gap-0",
18
+ xs: "gap-1",
19
+ sm: "gap-2",
20
+ md: "gap-3",
21
+ lg: "gap-4",
22
+ xl: "gap-6",
23
+ "2xl": "gap-8"
24
+ },
25
+ align: {
26
+ start: "items-start",
27
+ center: "items-center",
28
+ end: "items-end",
29
+ stretch: "items-stretch"
30
+ },
31
+ justify: {
32
+ start: "justify-start",
33
+ center: "justify-center",
34
+ end: "justify-end",
35
+ between: "justify-between",
36
+ around: "justify-around",
37
+ evenly: "justify-evenly"
38
+ }
39
+ },
40
+ defaultVariants: {
41
+ gap: "md",
42
+ align: "stretch",
43
+ justify: "start"
44
+ }
45
+ });
46
+ var VStack = React.forwardRef(({ className, gap, align, justify, as = "div", ...props }, ref) => {
47
+ const Comp = as;
48
+ return /* @__PURE__ */ jsxDEV(Comp, {
49
+ ref,
50
+ className: cn(vStackVariants({ gap, align, justify }), className),
51
+ ...props
52
+ }, undefined, false, undefined, this);
53
+ });
54
+ VStack.displayName = "VStack";
55
+ var hStackVariants = cva("flex flex-row", {
56
+ variants: {
57
+ gap: {
58
+ none: "gap-0",
59
+ xs: "gap-1",
60
+ sm: "gap-2",
61
+ md: "gap-3",
62
+ lg: "gap-4",
63
+ xl: "gap-6",
64
+ "2xl": "gap-8"
65
+ },
66
+ align: {
67
+ start: "items-start",
68
+ center: "items-center",
69
+ end: "items-end",
70
+ stretch: "items-stretch",
71
+ baseline: "items-baseline"
72
+ },
73
+ justify: {
74
+ start: "justify-start",
75
+ center: "justify-center",
76
+ end: "justify-end",
77
+ between: "justify-between",
78
+ around: "justify-around",
79
+ evenly: "justify-evenly"
80
+ },
81
+ wrap: {
82
+ nowrap: "flex-nowrap",
83
+ wrap: "flex-wrap",
84
+ wrapReverse: "flex-wrap-reverse"
85
+ }
86
+ },
87
+ defaultVariants: {
88
+ gap: "md",
89
+ align: "center",
90
+ justify: "start",
91
+ wrap: "wrap"
92
+ }
93
+ });
94
+ var HStack = React.forwardRef(({ className, gap, align, justify, wrap, as = "div", ...props }, ref) => {
95
+ const Comp = as;
96
+ return /* @__PURE__ */ jsxDEV(Comp, {
97
+ ref,
98
+ className: cn(hStackVariants({ gap, align, justify, wrap }), className),
99
+ ...props
100
+ }, undefined, false, undefined, this);
101
+ });
102
+ HStack.displayName = "HStack";
103
+ var boxVariants = cva("flex flex-row", {
104
+ variants: {
105
+ gap: {
106
+ none: "gap-0",
107
+ xs: "gap-1",
108
+ sm: "gap-2",
109
+ md: "gap-3",
110
+ lg: "gap-4",
111
+ xl: "gap-6",
112
+ "2xl": "gap-8"
113
+ },
114
+ align: {
115
+ start: "items-start",
116
+ center: "items-center",
117
+ end: "items-end",
118
+ stretch: "items-stretch",
119
+ baseline: "items-baseline"
120
+ },
121
+ justify: {
122
+ start: "justify-start",
123
+ center: "justify-center",
124
+ end: "justify-end",
125
+ between: "justify-between",
126
+ around: "justify-around",
127
+ evenly: "justify-evenly"
128
+ },
129
+ wrap: {
130
+ nowrap: "flex-nowrap",
131
+ wrap: "flex-wrap",
132
+ wrapReverse: "flex-wrap-reverse"
133
+ }
134
+ },
135
+ defaultVariants: {
136
+ gap: "md",
137
+ align: "center",
138
+ justify: "center",
139
+ wrap: "nowrap"
140
+ }
141
+ });
142
+ var Box = React.forwardRef(({ className, gap, align, justify, wrap, as = "div", ...props }, ref) => {
143
+ const Comp = as;
144
+ return /* @__PURE__ */ jsxDEV(Comp, {
145
+ ref,
146
+ className: cn(boxVariants({ gap, align, justify, wrap }), className),
147
+ ...props
148
+ }, undefined, false, undefined, this);
149
+ });
150
+ Box.displayName = "Box";
151
+ // ui/usecases/UserStoryCard.tsx
152
+ import { jsxDEV as jsxDEV2 } from "react/jsx-dev-runtime";
153
+ function UserStoryCard({
154
+ title,
155
+ body,
156
+ outcome
157
+ }) {
158
+ return /* @__PURE__ */ jsxDEV2(VStack, {
159
+ className: "rounded-lg border p-4",
160
+ gap: "sm",
161
+ children: [
162
+ /* @__PURE__ */ jsxDEV2("div", {
163
+ className: "text-lg font-semibold",
164
+ children: title
165
+ }, undefined, false, undefined, this),
166
+ body && /* @__PURE__ */ jsxDEV2("div", {
167
+ className: "text-muted-foreground text-base",
168
+ children: body
169
+ }, undefined, false, undefined, this),
170
+ outcome && /* @__PURE__ */ jsxDEV2("div", {
171
+ className: "text-base",
172
+ children: [
173
+ /* @__PURE__ */ jsxDEV2("span", {
174
+ className: "font-medium",
175
+ children: "Outcome:"
176
+ }, undefined, false, undefined, this),
177
+ " ",
178
+ outcome
179
+ ]
180
+ }, undefined, true, undefined, this)
181
+ ]
182
+ }, undefined, true, undefined, this);
183
+ }
184
+ export {
185
+ UserStoryCard
186
+ };