@fpkit/acss 0.5.12 → 0.6.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 (398) hide show
  1. package/README.md +89 -0
  2. package/libs/chunk-2NRIP6RB.cjs +17 -0
  3. package/libs/chunk-2NRIP6RB.cjs.map +1 -0
  4. package/libs/chunk-33PNJ4LO.cjs +15 -0
  5. package/libs/chunk-33PNJ4LO.cjs.map +1 -0
  6. package/libs/chunk-4BZKFPEC.cjs +17 -0
  7. package/libs/chunk-4BZKFPEC.cjs.map +1 -0
  8. package/libs/{chunk-O6QZBB6G.js → chunk-5QD3DWFI.js} +5 -5
  9. package/libs/chunk-5QD3DWFI.js.map +1 -0
  10. package/libs/chunk-6SAHIYCZ.js +7 -0
  11. package/libs/chunk-6SAHIYCZ.js.map +1 -0
  12. package/libs/{chunk-KKLTUJFB.cjs → chunk-6WTC4JXH.cjs} +5 -5
  13. package/libs/chunk-6WTC4JXH.cjs.map +1 -0
  14. package/libs/chunk-75QHTLFO.js +7 -0
  15. package/libs/chunk-75QHTLFO.js.map +1 -0
  16. package/libs/{chunk-YWOYVRFT.js → chunk-7XPFW7CB.js} +3 -3
  17. package/libs/chunk-BFK62VX5.js +5 -0
  18. package/libs/chunk-BFK62VX5.js.map +1 -0
  19. package/libs/{chunk-ICCKQ2GC.cjs → chunk-DKTHCQ5P.cjs} +4 -4
  20. package/libs/{chunk-6TE5QEVE.cjs → chunk-E2AJURUW.cjs} +3 -3
  21. package/libs/chunk-E2AJURUW.cjs.map +1 -0
  22. package/libs/chunk-ENTCUJ3A.cjs +13 -0
  23. package/libs/chunk-ENTCUJ3A.cjs.map +1 -0
  24. package/libs/chunk-F5EYMVQM.js +10 -0
  25. package/libs/chunk-F5EYMVQM.js.map +1 -0
  26. package/libs/chunk-FVROL3V5.js +9 -0
  27. package/libs/chunk-FVROL3V5.js.map +1 -0
  28. package/libs/chunk-GT77BX4L.cjs +17 -0
  29. package/libs/chunk-GT77BX4L.cjs.map +1 -0
  30. package/libs/chunk-GUJSMQ3V.cjs +16 -0
  31. package/libs/chunk-GUJSMQ3V.cjs.map +1 -0
  32. package/libs/chunk-HHLNOC5T.js +7 -0
  33. package/libs/chunk-HHLNOC5T.js.map +1 -0
  34. package/libs/chunk-HRRHPLER.js +8 -0
  35. package/libs/chunk-HRRHPLER.js.map +1 -0
  36. package/libs/chunk-IEB64SWY.js +8 -0
  37. package/libs/chunk-IEB64SWY.js.map +1 -0
  38. package/libs/{chunk-LIQJ7ZZR.js → chunk-IQ76HGVP.js} +2 -2
  39. package/libs/chunk-IRLFZ3OL.js +9 -0
  40. package/libs/chunk-IRLFZ3OL.js.map +1 -0
  41. package/libs/chunk-KK47SYZI.js +8 -0
  42. package/libs/chunk-KK47SYZI.js.map +1 -0
  43. package/libs/chunk-O3JIHC5M.cjs +15 -0
  44. package/libs/chunk-O3JIHC5M.cjs.map +1 -0
  45. package/libs/chunk-O5XAJ7BY.cjs +18 -0
  46. package/libs/chunk-O5XAJ7BY.cjs.map +1 -0
  47. package/libs/chunk-OVWLQYMK.js +10 -0
  48. package/libs/chunk-OVWLQYMK.js.map +1 -0
  49. package/libs/chunk-PNWIRCG3.cjs +7 -0
  50. package/libs/chunk-PNWIRCG3.cjs.map +1 -0
  51. package/libs/chunk-QVW6W76L.cjs +18 -0
  52. package/libs/chunk-QVW6W76L.cjs.map +1 -0
  53. package/libs/chunk-T4T6GWYQ.cjs +17 -0
  54. package/libs/chunk-T4T6GWYQ.cjs.map +1 -0
  55. package/libs/chunk-TON2YGMD.cjs +9 -0
  56. package/libs/chunk-TON2YGMD.cjs.map +1 -0
  57. package/libs/chunk-UEPAWMDF.js +8 -0
  58. package/libs/chunk-UEPAWMDF.js.map +1 -0
  59. package/libs/{chunk-LT5KZ2QW.cjs → chunk-US2I5GI7.cjs} +3 -3
  60. package/libs/{chunk-E3XP6BEX.cjs → chunk-W2UIN7EV.cjs} +3 -3
  61. package/libs/chunk-W5TKWBFC.cjs +18 -0
  62. package/libs/chunk-W5TKWBFC.cjs.map +1 -0
  63. package/libs/chunk-WXBFBWYF.cjs +16 -0
  64. package/libs/chunk-WXBFBWYF.cjs.map +1 -0
  65. package/libs/chunk-X3JCTEPD.js +11 -0
  66. package/libs/chunk-X3JCTEPD.js.map +1 -0
  67. package/libs/chunk-X5LGFCWG.js +9 -0
  68. package/libs/chunk-X5LGFCWG.js.map +1 -0
  69. package/libs/{chunk-5M57K4SW.js → chunk-Y2PFDELK.js} +2 -2
  70. package/libs/chunk-ZFJ4U45S.js +10 -0
  71. package/libs/chunk-ZFJ4U45S.js.map +1 -0
  72. package/libs/{component-props-a8a2f97e.d.ts → component-props-67d978a2.d.ts} +4 -4
  73. package/libs/components/alert/alert.css +1 -1
  74. package/libs/components/alert/alert.css.map +1 -1
  75. package/libs/components/alert/alert.min.css +2 -2
  76. package/libs/components/badge/badge.css +1 -1
  77. package/libs/components/badge/badge.css.map +1 -1
  78. package/libs/components/badge/badge.min.css +2 -2
  79. package/libs/components/breadcrumbs/breadcrumb.cjs +9 -5
  80. package/libs/components/breadcrumbs/breadcrumb.d.cts +275 -36
  81. package/libs/components/breadcrumbs/breadcrumb.d.ts +275 -36
  82. package/libs/components/breadcrumbs/breadcrumb.js +3 -3
  83. package/libs/components/button.cjs +6 -4
  84. package/libs/components/button.d.cts +97 -4
  85. package/libs/components/button.d.ts +97 -4
  86. package/libs/components/button.js +4 -2
  87. package/libs/components/buttons/button.css +1 -1
  88. package/libs/components/buttons/button.css.map +1 -1
  89. package/libs/components/buttons/button.min.css +2 -2
  90. package/libs/components/card.cjs +7 -7
  91. package/libs/components/card.d.cts +278 -34
  92. package/libs/components/card.d.ts +278 -34
  93. package/libs/components/card.js +2 -2
  94. package/libs/components/cards/card.css +1 -1
  95. package/libs/components/cards/card.css.map +1 -1
  96. package/libs/components/cards/card.min.css +2 -2
  97. package/libs/components/details/details.css +1 -1
  98. package/libs/components/details/details.css.map +1 -1
  99. package/libs/components/details/details.min.css +2 -2
  100. package/libs/components/dialog/dialog.cjs +9 -7
  101. package/libs/components/dialog/dialog.css +1 -1
  102. package/libs/components/dialog/dialog.css.map +1 -1
  103. package/libs/components/dialog/dialog.d.cts +88 -34
  104. package/libs/components/dialog/dialog.d.ts +88 -34
  105. package/libs/components/dialog/dialog.js +7 -5
  106. package/libs/components/dialog/dialog.min.css +2 -2
  107. package/libs/components/form/fields.cjs +4 -4
  108. package/libs/components/form/fields.d.cts +16 -7
  109. package/libs/components/form/fields.d.ts +16 -7
  110. package/libs/components/form/fields.js +2 -2
  111. package/libs/components/form/inputs.cjs +6 -4
  112. package/libs/components/form/inputs.d.cts +50 -2
  113. package/libs/components/form/inputs.d.ts +50 -2
  114. package/libs/components/form/inputs.js +4 -2
  115. package/libs/components/form/textarea.cjs +5 -4
  116. package/libs/components/form/textarea.d.cts +32 -23
  117. package/libs/components/form/textarea.d.ts +32 -23
  118. package/libs/components/form/textarea.js +3 -2
  119. package/libs/components/heading/heading.cjs +3 -3
  120. package/libs/components/heading/heading.d.cts +3 -14
  121. package/libs/components/heading/heading.d.ts +3 -14
  122. package/libs/components/heading/heading.js +2 -2
  123. package/libs/components/icons/icon.cjs +4 -4
  124. package/libs/components/icons/icon.d.cts +183 -39
  125. package/libs/components/icons/icon.d.ts +183 -39
  126. package/libs/components/icons/icon.js +2 -2
  127. package/libs/components/images/img.css +1 -1
  128. package/libs/components/images/img.css.map +1 -1
  129. package/libs/components/images/img.min.css +2 -2
  130. package/libs/components/link/link.cjs +4 -4
  131. package/libs/components/link/link.css +1 -1
  132. package/libs/components/link/link.css.map +1 -1
  133. package/libs/components/link/link.d.cts +3 -19
  134. package/libs/components/link/link.d.ts +3 -19
  135. package/libs/components/link/link.js +2 -2
  136. package/libs/components/link/link.min.css +2 -2
  137. package/libs/components/list/list.cjs +5 -5
  138. package/libs/components/list/list.css +1 -0
  139. package/libs/components/list/list.css.map +1 -0
  140. package/libs/components/list/list.d.cts +120 -33
  141. package/libs/components/list/list.d.ts +120 -33
  142. package/libs/components/list/list.js +2 -2
  143. package/libs/components/list/list.min.css +3 -0
  144. package/libs/components/modal.cjs +6 -4
  145. package/libs/components/modal.d.cts +8 -8
  146. package/libs/components/modal.d.ts +8 -8
  147. package/libs/components/modal.js +5 -3
  148. package/libs/components/nav/nav.cjs +7 -7
  149. package/libs/components/nav/nav.css +1 -1
  150. package/libs/components/nav/nav.css.map +1 -1
  151. package/libs/components/nav/nav.d.cts +550 -34
  152. package/libs/components/nav/nav.d.ts +550 -34
  153. package/libs/components/nav/nav.js +3 -3
  154. package/libs/components/nav/nav.min.css +2 -2
  155. package/libs/components/popover/popover.d.cts +5 -5
  156. package/libs/components/popover/popover.d.ts +5 -5
  157. package/libs/components/tables/table.cjs +5 -5
  158. package/libs/components/tables/table.d.cts +8 -8
  159. package/libs/components/tables/table.d.ts +8 -8
  160. package/libs/components/tables/table.js +2 -2
  161. package/libs/components/tag/tag.css +1 -1
  162. package/libs/components/tag/tag.css.map +1 -1
  163. package/libs/components/tag/tag.min.css +2 -2
  164. package/libs/components/text/text.cjs +5 -5
  165. package/libs/components/text/text.d.cts +5 -5
  166. package/libs/components/text/text.d.ts +5 -5
  167. package/libs/components/text/text.js +2 -2
  168. package/libs/form.types-d25ebfac.d.ts +233 -0
  169. package/libs/heading-7446cb46.d.ts +250 -0
  170. package/libs/hooks.cjs +12 -0
  171. package/libs/hooks.d.cts +140 -1
  172. package/libs/hooks.d.ts +140 -1
  173. package/libs/hooks.js +4 -0
  174. package/libs/icons.cjs +3 -3
  175. package/libs/icons.d.cts +2 -2
  176. package/libs/icons.d.ts +2 -2
  177. package/libs/icons.js +2 -2
  178. package/libs/index.cjs +117 -94
  179. package/libs/index.cjs.map +1 -1
  180. package/libs/index.css +1 -1
  181. package/libs/index.css.map +1 -1
  182. package/libs/index.d.cts +834 -61
  183. package/libs/index.d.ts +834 -61
  184. package/libs/index.js +36 -22
  185. package/libs/index.js.map +1 -1
  186. package/libs/link-5192f411.d.ts +323 -0
  187. package/libs/list.types-d26de310.d.ts +245 -0
  188. package/libs/ui-d01b50d4.d.ts +289 -0
  189. package/package.json +4 -87
  190. package/src/components/README-UI.mdx +416 -0
  191. package/src/components/alert/ACCESSIBILITY.md +319 -0
  192. package/src/components/alert/README.mdx +475 -19
  193. package/src/components/alert/alert.scss +110 -6
  194. package/src/components/alert/alert.stories.tsx +372 -0
  195. package/src/components/alert/alert.test.tsx +762 -0
  196. package/src/components/alert/alert.tsx +331 -66
  197. package/src/components/alert/views/alert-actions.tsx +13 -0
  198. package/src/components/alert/views/alert-content.tsx +17 -0
  199. package/src/components/alert/views/alert-icon.tsx +53 -0
  200. package/src/components/alert/views/alert-screen-reader-text.tsx +30 -0
  201. package/src/components/alert/views/alert-title.tsx +23 -0
  202. package/src/components/alert/views/alert-view.tsx +158 -0
  203. package/src/components/alert/views/index.ts +12 -0
  204. package/src/components/badge/badge.mdx +186 -49
  205. package/src/components/badge/badge.scss +20 -2
  206. package/src/components/badge/badge.stories.tsx +160 -14
  207. package/src/components/badge/badge.test.tsx +179 -0
  208. package/src/components/badge/badge.tsx +97 -4
  209. package/src/components/breadcrumbs/README.mdx +364 -45
  210. package/src/components/breadcrumbs/__snapshots__/breadcrumb.test.tsx.snap +152 -0
  211. package/src/components/breadcrumbs/breadcrumb.stories.tsx +7 -3
  212. package/src/components/breadcrumbs/breadcrumb.test.tsx +490 -0
  213. package/src/components/breadcrumbs/breadcrumb.tsx +430 -170
  214. package/src/components/buttons/README.mdx +102 -1
  215. package/src/components/buttons/button.scss +34 -31
  216. package/src/components/buttons/button.stories.tsx +141 -0
  217. package/src/components/buttons/button.tsx +82 -52
  218. package/src/components/cards/README.mdx +657 -0
  219. package/src/components/cards/card.scss +22 -0
  220. package/src/components/cards/card.stories.tsx +167 -5
  221. package/src/components/cards/card.test.tsx +360 -20
  222. package/src/components/cards/card.tsx +200 -79
  223. package/src/components/cards/card.types.ts +135 -0
  224. package/src/components/cards/card.utils.ts +79 -0
  225. package/src/components/details/ACCESSIBILITY-REVIEW-LIVE.md +1050 -0
  226. package/src/components/details/ACCESSIBILITY-REVIEW.md +502 -0
  227. package/src/components/details/README.mdx +437 -69
  228. package/src/components/details/details.scss +16 -7
  229. package/src/components/details/details.test.tsx +385 -0
  230. package/src/components/details/details.tsx +101 -69
  231. package/src/components/details/details.types.ts +76 -0
  232. package/src/components/dialog/README.mdx +513 -110
  233. package/src/components/dialog/dialog-a11y-review.md +653 -0
  234. package/src/components/dialog/dialog-modal.tsx +79 -56
  235. package/src/components/dialog/dialog.scss +53 -3
  236. package/src/components/dialog/dialog.stories.tsx +10 -7
  237. package/src/components/dialog/dialog.test.tsx +450 -0
  238. package/src/components/dialog/dialog.tsx +69 -59
  239. package/src/components/dialog/dialog.types.ts +133 -0
  240. package/src/components/dialog/views/dialog-footer.tsx +54 -11
  241. package/src/components/dialog/views/dialog-header.tsx +20 -15
  242. package/src/components/form/README.mdx +725 -43
  243. package/src/components/form/WCAG-REVIEW.md +654 -0
  244. package/src/components/form/fields.tsx +10 -1
  245. package/src/components/form/form.stories.tsx +604 -23
  246. package/src/components/form/form.tsx +204 -63
  247. package/src/components/form/form.types.ts +378 -0
  248. package/src/components/form/input.stories.tsx +71 -3
  249. package/src/components/form/inputs.tsx +159 -67
  250. package/src/components/form/select.tsx +122 -66
  251. package/src/components/form/textarea.tsx +120 -73
  252. package/src/components/fp.tsx +86 -11
  253. package/src/components/heading/heading.stories.tsx +44 -4
  254. package/src/components/heading/heading.tsx +89 -23
  255. package/src/components/icons/README.mdx +332 -0
  256. package/src/components/icons/icon.stories.tsx +74 -1
  257. package/src/components/icons/icon.tsx +89 -1
  258. package/src/components/icons/types.ts +47 -0
  259. package/src/components/images/README.mdx +340 -24
  260. package/src/components/images/img.scss +19 -3
  261. package/src/components/images/img.stories.tsx +424 -15
  262. package/src/components/images/img.test.tsx +354 -25
  263. package/src/components/images/img.tsx +186 -63
  264. package/src/components/images/img.types.ts +211 -0
  265. package/src/components/link/README.mdx +923 -0
  266. package/src/components/link/link.scss +79 -26
  267. package/src/components/link/link.stories.tsx +383 -30
  268. package/src/components/link/link.test.tsx +677 -0
  269. package/src/components/link/link.tsx +163 -57
  270. package/src/components/link/link.types.ts +261 -0
  271. package/src/components/list/README.mdx +764 -0
  272. package/src/components/list/list.scss +285 -0
  273. package/src/components/list/list.stories.tsx +514 -27
  274. package/src/components/list/list.test.tsx +554 -0
  275. package/src/components/list/list.tsx +153 -51
  276. package/src/components/list/list.types.ts +255 -0
  277. package/src/components/nav/ACCESSIBILITY.md +649 -0
  278. package/src/components/nav/README.mdx +782 -0
  279. package/src/components/nav/nav.scss +32 -1
  280. package/src/components/nav/nav.stories.tsx +44 -6
  281. package/src/components/nav/nav.tsx +302 -51
  282. package/src/components/nav/nav.types.ts +308 -0
  283. package/src/components/tag/README.mdx +426 -0
  284. package/src/components/tag/tag.scss +101 -27
  285. package/src/components/tag/tag.stories.tsx +384 -10
  286. package/src/components/tag/tag.test.tsx +210 -0
  287. package/src/components/tag/tag.tsx +106 -9
  288. package/src/components/tag/tag.types.ts +107 -0
  289. package/src/components/title/MIGRATION.md +199 -0
  290. package/src/components/title/README.md +326 -0
  291. package/src/components/title/README.mdx +452 -0
  292. package/src/components/title/title.stories.tsx +393 -0
  293. package/src/components/title/title.test.tsx +251 -0
  294. package/src/components/title/title.tsx +219 -0
  295. package/src/components/ui.stories.tsx +894 -0
  296. package/src/components/ui.test.tsx +559 -0
  297. package/src/components/ui.tsx +274 -18
  298. package/src/components/word-count/README.md +240 -0
  299. package/src/hooks/use-disabled-state.test.tsx +536 -0
  300. package/src/hooks/use-disabled-state.ts +246 -0
  301. package/src/hooks/useDisabledState.md +393 -0
  302. package/src/hooks.ts +7 -0
  303. package/src/index.scss +2 -0
  304. package/src/index.ts +12 -3
  305. package/src/sass/_globals.scss +2 -7
  306. package/src/sass/_properties.scss +1 -0
  307. package/src/styles/alert/alert.css +92 -4
  308. package/src/styles/alert/alert.css.map +1 -1
  309. package/src/styles/badge/badge.css +20 -2
  310. package/src/styles/badge/badge.css.map +1 -1
  311. package/src/styles/buttons/button.css +31 -31
  312. package/src/styles/buttons/button.css.map +1 -1
  313. package/src/styles/cards/card.css +16 -0
  314. package/src/styles/cards/card.css.map +1 -1
  315. package/src/styles/details/details.css +19 -8
  316. package/src/styles/details/details.css.map +1 -1
  317. package/src/styles/dialog/dialog.css +43 -2
  318. package/src/styles/dialog/dialog.css.map +1 -1
  319. package/src/styles/images/img.css +15 -3
  320. package/src/styles/images/img.css.map +1 -1
  321. package/src/styles/index.css +691 -128
  322. package/src/styles/index.css.map +1 -1
  323. package/src/styles/link/link.css +45 -28
  324. package/src/styles/link/link.css.map +1 -1
  325. package/src/styles/list/list.css +214 -0
  326. package/src/styles/list/list.css.map +1 -0
  327. package/src/styles/nav/nav.css +21 -1
  328. package/src/styles/nav/nav.css.map +1 -1
  329. package/src/styles/tag/tag.css +113 -35
  330. package/src/styles/tag/tag.css.map +1 -1
  331. package/src/styles/utilities/_disabled.scss +58 -0
  332. package/src/test/setup.d.ts +9 -0
  333. package/src/test/setup.ts +53 -1
  334. package/src/types/shared.ts +43 -6
  335. package/src/utils/accessibility.ts +109 -0
  336. package/libs/chunk-5ZM4XL44.js +0 -8
  337. package/libs/chunk-5ZM4XL44.js.map +0 -1
  338. package/libs/chunk-6BVXFW7U.cjs +0 -15
  339. package/libs/chunk-6BVXFW7U.cjs.map +0 -1
  340. package/libs/chunk-6TE5QEVE.cjs.map +0 -1
  341. package/libs/chunk-7K76RW2A.cjs +0 -18
  342. package/libs/chunk-7K76RW2A.cjs.map +0 -1
  343. package/libs/chunk-BHRQBJRY.js +0 -8
  344. package/libs/chunk-BHRQBJRY.js.map +0 -1
  345. package/libs/chunk-BIP2NY53.js +0 -8
  346. package/libs/chunk-BIP2NY53.js.map +0 -1
  347. package/libs/chunk-BSPKFLO4.js +0 -8
  348. package/libs/chunk-BSPKFLO4.js.map +0 -1
  349. package/libs/chunk-BV5CLH44.cjs +0 -18
  350. package/libs/chunk-BV5CLH44.cjs.map +0 -1
  351. package/libs/chunk-DKGJHKGW.js +0 -9
  352. package/libs/chunk-DKGJHKGW.js.map +0 -1
  353. package/libs/chunk-DV56L5YX.cjs +0 -18
  354. package/libs/chunk-DV56L5YX.cjs.map +0 -1
  355. package/libs/chunk-ECLD37WN.cjs +0 -16
  356. package/libs/chunk-ECLD37WN.cjs.map +0 -1
  357. package/libs/chunk-EQ67LF46.js +0 -9
  358. package/libs/chunk-EQ67LF46.js.map +0 -1
  359. package/libs/chunk-HYBZBN4G.js +0 -8
  360. package/libs/chunk-HYBZBN4G.js.map +0 -1
  361. package/libs/chunk-IYUN2EW3.cjs +0 -15
  362. package/libs/chunk-IYUN2EW3.cjs.map +0 -1
  363. package/libs/chunk-KKLTUJFB.cjs.map +0 -1
  364. package/libs/chunk-LHVJKDMA.cjs +0 -15
  365. package/libs/chunk-LHVJKDMA.cjs.map +0 -1
  366. package/libs/chunk-LL7HTLMS.cjs +0 -15
  367. package/libs/chunk-LL7HTLMS.cjs.map +0 -1
  368. package/libs/chunk-M5QL5TAE.cjs +0 -14
  369. package/libs/chunk-M5QL5TAE.cjs.map +0 -1
  370. package/libs/chunk-NE6YXTMC.js +0 -7
  371. package/libs/chunk-NE6YXTMC.js.map +0 -1
  372. package/libs/chunk-NHYXGV3L.js +0 -8
  373. package/libs/chunk-NHYXGV3L.js.map +0 -1
  374. package/libs/chunk-O6QZBB6G.js.map +0 -1
  375. package/libs/chunk-P7TTEYCD.js +0 -7
  376. package/libs/chunk-P7TTEYCD.js.map +0 -1
  377. package/libs/chunk-PPOOBUOS.js +0 -8
  378. package/libs/chunk-PPOOBUOS.js.map +0 -1
  379. package/libs/chunk-QCMV4VQZ.js +0 -8
  380. package/libs/chunk-QCMV4VQZ.js.map +0 -1
  381. package/libs/chunk-QVV34QEH.cjs +0 -32
  382. package/libs/chunk-QVV34QEH.cjs.map +0 -1
  383. package/libs/chunk-S7BABR7Z.cjs +0 -13
  384. package/libs/chunk-S7BABR7Z.cjs.map +0 -1
  385. package/libs/chunk-SXVZSWX6.js +0 -11
  386. package/libs/chunk-SXVZSWX6.js.map +0 -1
  387. package/libs/chunk-X3EVB7VS.cjs +0 -15
  388. package/libs/chunk-X3EVB7VS.cjs.map +0 -1
  389. package/libs/inputs-f3a216db.d.ts +0 -45
  390. package/libs/ui-9a6f9f8d.d.ts +0 -24
  391. package/src/components/cards/README.md +0 -80
  392. package/src/components/dialog/hooks/useClickOutside.ts +0 -33
  393. /package/libs/{chunk-YWOYVRFT.js.map → chunk-7XPFW7CB.js.map} +0 -0
  394. /package/libs/{chunk-ICCKQ2GC.cjs.map → chunk-DKTHCQ5P.cjs.map} +0 -0
  395. /package/libs/{chunk-LIQJ7ZZR.js.map → chunk-IQ76HGVP.js.map} +0 -0
  396. /package/libs/{chunk-LT5KZ2QW.cjs.map → chunk-US2I5GI7.cjs.map} +0 -0
  397. /package/libs/{chunk-E3XP6BEX.cjs.map → chunk-W2UIN7EV.cjs.map} +0 -0
  398. /package/libs/{chunk-5M57K4SW.js.map → chunk-Y2PFDELK.js.map} +0 -0
@@ -1,56 +1,300 @@
1
- import React__default from 'react';
2
- import { F as FP } from '../ui-9a6f9f8d.js';
1
+ import React from 'react';
2
+ import { U as UI } from '../ui-d01b50d4.js';
3
3
 
4
- type CardProps = {
5
- elm?: 'div' | 'aside' | 'section' | 'article';
6
- title?: React__default.ReactNode;
7
- footer?: React__default.ReactNode;
8
- } & React__default.ComponentProps<typeof FP>;
4
+ /**
5
+ * Base props shared across all Card sub-components.
6
+ *
7
+ * This interface provides common styling and structural props
8
+ * that all Card sub-components support.
9
+ */
10
+ interface CardSubComponentProps {
11
+ /** CSS class names to apply */
12
+ className?: string;
13
+ /** Inline styles to apply */
14
+ style?: React.CSSProperties;
15
+ /** Child elements to render */
16
+ children?: React.ReactNode;
17
+ }
18
+ /**
19
+ * Props for the Card.Title sub-component.
20
+ *
21
+ * @extends CardSubComponentProps
22
+ */
23
+ interface CardTitleProps extends CardSubComponentProps {
24
+ /**
25
+ * HTML element to render as.
26
+ * @default 'h3'
27
+ */
28
+ as?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
29
+ /**
30
+ * HTML id attribute for the title.
31
+ * Useful for aria-labelledby references.
32
+ */
33
+ id?: string;
34
+ }
35
+ /**
36
+ * Props for the Card.Content sub-component.
37
+ *
38
+ * @extends CardSubComponentProps
39
+ */
40
+ interface CardContentProps extends CardSubComponentProps {
41
+ /**
42
+ * HTML element to render as.
43
+ * Use 'article' for standalone content, 'div' for generic containers.
44
+ * @default 'article'
45
+ */
46
+ as?: 'article' | 'div' | 'section';
47
+ }
48
+ /**
49
+ * Props for the Card.Footer sub-component.
50
+ *
51
+ * @extends CardSubComponentProps
52
+ */
53
+ interface CardFooterProps extends CardSubComponentProps {
54
+ /**
55
+ * HTML element to render as.
56
+ * @default 'div'
57
+ */
58
+ as?: 'div' | 'footer';
59
+ }
60
+ /**
61
+ * Props for the main Card component.
62
+ *
63
+ * Extends all props from the UI component while adding Card-specific functionality.
64
+ * Supports polymorphic rendering via the `as` prop.
65
+ *
66
+ * @extends React.ComponentProps<typeof UI>
67
+ */
68
+ interface CardProps extends React.ComponentProps<typeof UI> {
69
+ /**
70
+ * HTML element to render the Card as.
71
+ * Inherits from UI component's polymorphic `as` prop.
72
+ * @default 'div'
73
+ */
74
+ as?: React.ElementType;
75
+ /**
76
+ * ARIA role for the card.
77
+ * Use 'article' for standalone content, 'region' with aria-label for landmarks.
78
+ * @example
79
+ * ```tsx
80
+ * <Card role="article">...</Card>
81
+ * <Card role="region" aria-label="User profile">...</Card>
82
+ * ```
83
+ */
84
+ role?: string;
85
+ /**
86
+ * Accessible label for the card.
87
+ * Required when using interactive cards or role="region".
88
+ * @example
89
+ * ```tsx
90
+ * <Card role="region" aria-label="Featured products">...</Card>
91
+ * ```
92
+ */
93
+ 'aria-label'?: string;
94
+ /**
95
+ * ID of element that labels this card.
96
+ * @example
97
+ * ```tsx
98
+ * <Card aria-labelledby="card-title-1">
99
+ * <Card.Title id="card-title-1">Title</Card.Title>
100
+ * </Card>
101
+ * ```
102
+ */
103
+ 'aria-labelledby'?: string;
104
+ /**
105
+ * ID of element that describes this card.
106
+ */
107
+ 'aria-describedby'?: string;
108
+ /**
109
+ * Makes the card interactive with keyboard support.
110
+ * Adds tabIndex, role="button", and keyboard event handlers.
111
+ * @default false
112
+ */
113
+ interactive?: boolean;
114
+ /**
115
+ * Click handler for interactive cards.
116
+ * When provided without `interactive`, a warning will be logged in development.
117
+ */
118
+ onClick?: (event: React.MouseEvent | React.KeyboardEvent) => void;
119
+ /**
120
+ * Tab index for keyboard navigation.
121
+ * Automatically set to 0 when `interactive` is true.
122
+ */
123
+ tabIndex?: number;
124
+ }
125
+
126
+ /**
127
+ * Card.Title - Title sub-component for Card
128
+ *
129
+ * Renders a heading element for the card title. Defaults to h3 for proper
130
+ * document outline, but can be customized via the `as` prop.
131
+ *
132
+ * ## Accessibility
133
+ * - Use appropriate heading level based on document structure
134
+ * - Combine with `aria-labelledby` on parent Card for accessible names
135
+ *
136
+ * @example
137
+ * ```tsx
138
+ * <Card aria-labelledby="card-title-1">
139
+ * <Card.Title id="card-title-1">Featured Product</Card.Title>
140
+ * </Card>
141
+ * ```
142
+ *
143
+ * @example
144
+ * ```tsx
145
+ * // Custom heading level
146
+ * <Card.Title as="h2">Section Title</Card.Title>
147
+ * ```
148
+ */
9
149
  declare const Title: {
10
- ({ children, className, styles, as, ...props }: React__default.PropsWithChildren<{
11
- className?: string | undefined;
12
- styles?: React__default.CSSProperties | undefined;
13
- as?: React__default.ElementType<any> | undefined;
14
- }>): React__default.JSX.Element;
150
+ ({ children, className, style, as, ...props }: CardTitleProps): React.JSX.Element;
15
151
  displayName: string;
16
152
  };
153
+ /**
154
+ * Card.Content - Content sub-component for Card
155
+ *
156
+ * Renders the main content area of the card. Defaults to `<article>` for
157
+ * standalone content, but can be changed to `div` or `section` via the `as` prop.
158
+ *
159
+ * ## Semantic HTML Guidelines
160
+ * - Use `article` (default) for self-contained, syndicate-able content
161
+ * - Use `div` for generic content containers
162
+ * - Use `section` for thematic groupings with a heading
163
+ *
164
+ * @example
165
+ * ```tsx
166
+ * <Card>
167
+ * <Card.Title>Article Title</Card.Title>
168
+ * <Card.Content>
169
+ * <p>This is standalone content...</p>
170
+ * </Card.Content>
171
+ * </Card>
172
+ * ```
173
+ *
174
+ * @example
175
+ * ```tsx
176
+ * // Generic container (not standalone content)
177
+ * <Card.Content as="div">
178
+ * <p>Generic content...</p>
179
+ * </Card.Content>
180
+ * ```
181
+ */
17
182
  declare const Content: {
18
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
19
- className?: string | undefined;
20
- styles?: React__default.CSSProperties | undefined;
21
- }>): React__default.JSX.Element;
183
+ ({ children, className, style, as, ...props }: CardContentProps): React.JSX.Element;
22
184
  displayName: string;
23
185
  };
186
+ /**
187
+ * Card.Footer - Footer sub-component for Card
188
+ *
189
+ * Renders a footer section for the card. Use for actions, metadata, or
190
+ * supplementary information.
191
+ *
192
+ * @example
193
+ * ```tsx
194
+ * <Card>
195
+ * <Card.Title>Product</Card.Title>
196
+ * <Card.Content>Description...</Card.Content>
197
+ * <Card.Footer>
198
+ * <button>Add to Cart</button>
199
+ * <span>$29.99</span>
200
+ * </Card.Footer>
201
+ * </Card>
202
+ * ```
203
+ *
204
+ * @example
205
+ * ```tsx
206
+ * // Semantic footer element
207
+ * <Card.Footer as="footer">
208
+ * <p>Last updated: 2024-01-15</p>
209
+ * </Card.Footer>
210
+ * ```
211
+ */
24
212
  declare const Footer: {
25
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
26
- className?: string | undefined;
27
- styles?: React__default.CSSProperties | undefined;
28
- }>): React__default.JSX.Element;
213
+ ({ children, className, style, as, ...props }: CardFooterProps): React.JSX.Element;
29
214
  displayName: string;
30
215
  };
216
+ /**
217
+ * Card - A flexible, accessible card component with compound component pattern
218
+ *
219
+ * The Card component provides a container for grouping related content and actions.
220
+ * It follows the compound component pattern, exposing `Card.Title`, `Card.Content`,
221
+ * and `Card.Footer` sub-components for structured layouts.
222
+ *
223
+ * ## Features
224
+ * - **Polymorphic rendering**: Render as any HTML element via `as` prop
225
+ * - **Compound components**: Structured sub-components for consistent layouts
226
+ * - **Interactive variant**: Built-in keyboard navigation and ARIA support
227
+ * - **Fully accessible**: WCAG 2.1 AA compliant with proper semantic HTML
228
+ *
229
+ * ## Accessibility
230
+ *
231
+ * ### Non-Interactive Cards
232
+ * - Use semantic HTML: `article` for standalone content, `section` for groupings
233
+ * - Provide accessible names with `aria-labelledby` referencing the title
234
+ *
235
+ * ### Interactive Cards (Clickable)
236
+ * - Set `interactive={true}` to enable keyboard navigation (Enter/Space)
237
+ * - Provide accessible name via `aria-label` or `aria-labelledby`
238
+ * - Ensure adequate focus indicators (handled by CSS)
239
+ *
240
+ * @example
241
+ * // Basic card with compound components
242
+ * ```tsx
243
+ * <Card>
244
+ * <Card.Title>Product Name</Card.Title>
245
+ * <Card.Content>
246
+ * <p>Product description goes here...</p>
247
+ * </Card.Content>
248
+ * <Card.Footer>
249
+ * <button>Buy Now</button>
250
+ * </Card.Footer>
251
+ * </Card>
252
+ * ```
253
+ *
254
+ * @example
255
+ * // Accessible interactive card
256
+ * ```tsx
257
+ * <Card
258
+ * interactive
259
+ * aria-label="View product details"
260
+ * onClick={() => navigate('/product/123')}
261
+ * >
262
+ * <Card.Title>Product Name</Card.Title>
263
+ * <Card.Content>Click anywhere to view details</Card.Content>
264
+ * </Card>
265
+ * ```
266
+ *
267
+ * @example
268
+ * // Semantic article card with accessible name
269
+ * ```tsx
270
+ * <Card as="article" aria-labelledby="article-title">
271
+ * <Card.Title id="article-title">Article Headline</Card.Title>
272
+ * <Card.Content>Article body...</Card.Content>
273
+ * </Card>
274
+ * ```
275
+ *
276
+ * @example
277
+ * // Card as a landmark region
278
+ * ```tsx
279
+ * <Card role="region" aria-label="Featured products">
280
+ * <Card.Title>Featured</Card.Title>
281
+ * <Card.Content>...</Card.Content>
282
+ * </Card>
283
+ * ```
284
+ */
31
285
  declare const Card: {
32
- ({ elm, styles, children, classes, id, ...props }: CardProps): React__default.JSX.Element;
286
+ ({ as, styles, children, classes, id, interactive, onClick, tabIndex, role, "aria-label": ariaLabel, "aria-labelledby": ariaLabelledBy, "aria-describedby": ariaDescribedBy, ...props }: CardProps): React.JSX.Element;
33
287
  displayName: string;
34
288
  Title: {
35
- ({ children, className, styles, as, ...props }: React__default.PropsWithChildren<{
36
- className?: string | undefined;
37
- styles?: React__default.CSSProperties | undefined;
38
- as?: React__default.ElementType<any> | undefined;
39
- }>): React__default.JSX.Element;
289
+ ({ children, className, style, as, ...props }: CardTitleProps): React.JSX.Element;
40
290
  displayName: string;
41
291
  };
42
292
  Content: {
43
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
44
- className?: string | undefined;
45
- styles?: React__default.CSSProperties | undefined;
46
- }>): React__default.JSX.Element;
293
+ ({ children, className, style, as, ...props }: CardContentProps): React.JSX.Element;
47
294
  displayName: string;
48
295
  };
49
296
  Footer: {
50
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
51
- className?: string | undefined;
52
- styles?: React__default.CSSProperties | undefined;
53
- }>): React__default.JSX.Element;
297
+ ({ children, className, style, as, ...props }: CardFooterProps): React.JSX.Element;
54
298
  displayName: string;
55
299
  };
56
300
  };
@@ -1,56 +1,300 @@
1
- import React__default from 'react';
2
- import { F as FP } from '../ui-9a6f9f8d.js';
1
+ import React from 'react';
2
+ import { U as UI } from '../ui-d01b50d4.js';
3
3
 
4
- type CardProps = {
5
- elm?: 'div' | 'aside' | 'section' | 'article';
6
- title?: React__default.ReactNode;
7
- footer?: React__default.ReactNode;
8
- } & React__default.ComponentProps<typeof FP>;
4
+ /**
5
+ * Base props shared across all Card sub-components.
6
+ *
7
+ * This interface provides common styling and structural props
8
+ * that all Card sub-components support.
9
+ */
10
+ interface CardSubComponentProps {
11
+ /** CSS class names to apply */
12
+ className?: string;
13
+ /** Inline styles to apply */
14
+ style?: React.CSSProperties;
15
+ /** Child elements to render */
16
+ children?: React.ReactNode;
17
+ }
18
+ /**
19
+ * Props for the Card.Title sub-component.
20
+ *
21
+ * @extends CardSubComponentProps
22
+ */
23
+ interface CardTitleProps extends CardSubComponentProps {
24
+ /**
25
+ * HTML element to render as.
26
+ * @default 'h3'
27
+ */
28
+ as?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
29
+ /**
30
+ * HTML id attribute for the title.
31
+ * Useful for aria-labelledby references.
32
+ */
33
+ id?: string;
34
+ }
35
+ /**
36
+ * Props for the Card.Content sub-component.
37
+ *
38
+ * @extends CardSubComponentProps
39
+ */
40
+ interface CardContentProps extends CardSubComponentProps {
41
+ /**
42
+ * HTML element to render as.
43
+ * Use 'article' for standalone content, 'div' for generic containers.
44
+ * @default 'article'
45
+ */
46
+ as?: 'article' | 'div' | 'section';
47
+ }
48
+ /**
49
+ * Props for the Card.Footer sub-component.
50
+ *
51
+ * @extends CardSubComponentProps
52
+ */
53
+ interface CardFooterProps extends CardSubComponentProps {
54
+ /**
55
+ * HTML element to render as.
56
+ * @default 'div'
57
+ */
58
+ as?: 'div' | 'footer';
59
+ }
60
+ /**
61
+ * Props for the main Card component.
62
+ *
63
+ * Extends all props from the UI component while adding Card-specific functionality.
64
+ * Supports polymorphic rendering via the `as` prop.
65
+ *
66
+ * @extends React.ComponentProps<typeof UI>
67
+ */
68
+ interface CardProps extends React.ComponentProps<typeof UI> {
69
+ /**
70
+ * HTML element to render the Card as.
71
+ * Inherits from UI component's polymorphic `as` prop.
72
+ * @default 'div'
73
+ */
74
+ as?: React.ElementType;
75
+ /**
76
+ * ARIA role for the card.
77
+ * Use 'article' for standalone content, 'region' with aria-label for landmarks.
78
+ * @example
79
+ * ```tsx
80
+ * <Card role="article">...</Card>
81
+ * <Card role="region" aria-label="User profile">...</Card>
82
+ * ```
83
+ */
84
+ role?: string;
85
+ /**
86
+ * Accessible label for the card.
87
+ * Required when using interactive cards or role="region".
88
+ * @example
89
+ * ```tsx
90
+ * <Card role="region" aria-label="Featured products">...</Card>
91
+ * ```
92
+ */
93
+ 'aria-label'?: string;
94
+ /**
95
+ * ID of element that labels this card.
96
+ * @example
97
+ * ```tsx
98
+ * <Card aria-labelledby="card-title-1">
99
+ * <Card.Title id="card-title-1">Title</Card.Title>
100
+ * </Card>
101
+ * ```
102
+ */
103
+ 'aria-labelledby'?: string;
104
+ /**
105
+ * ID of element that describes this card.
106
+ */
107
+ 'aria-describedby'?: string;
108
+ /**
109
+ * Makes the card interactive with keyboard support.
110
+ * Adds tabIndex, role="button", and keyboard event handlers.
111
+ * @default false
112
+ */
113
+ interactive?: boolean;
114
+ /**
115
+ * Click handler for interactive cards.
116
+ * When provided without `interactive`, a warning will be logged in development.
117
+ */
118
+ onClick?: (event: React.MouseEvent | React.KeyboardEvent) => void;
119
+ /**
120
+ * Tab index for keyboard navigation.
121
+ * Automatically set to 0 when `interactive` is true.
122
+ */
123
+ tabIndex?: number;
124
+ }
125
+
126
+ /**
127
+ * Card.Title - Title sub-component for Card
128
+ *
129
+ * Renders a heading element for the card title. Defaults to h3 for proper
130
+ * document outline, but can be customized via the `as` prop.
131
+ *
132
+ * ## Accessibility
133
+ * - Use appropriate heading level based on document structure
134
+ * - Combine with `aria-labelledby` on parent Card for accessible names
135
+ *
136
+ * @example
137
+ * ```tsx
138
+ * <Card aria-labelledby="card-title-1">
139
+ * <Card.Title id="card-title-1">Featured Product</Card.Title>
140
+ * </Card>
141
+ * ```
142
+ *
143
+ * @example
144
+ * ```tsx
145
+ * // Custom heading level
146
+ * <Card.Title as="h2">Section Title</Card.Title>
147
+ * ```
148
+ */
9
149
  declare const Title: {
10
- ({ children, className, styles, as, ...props }: React__default.PropsWithChildren<{
11
- className?: string | undefined;
12
- styles?: React__default.CSSProperties | undefined;
13
- as?: React__default.ElementType<any> | undefined;
14
- }>): React__default.JSX.Element;
150
+ ({ children, className, style, as, ...props }: CardTitleProps): React.JSX.Element;
15
151
  displayName: string;
16
152
  };
153
+ /**
154
+ * Card.Content - Content sub-component for Card
155
+ *
156
+ * Renders the main content area of the card. Defaults to `<article>` for
157
+ * standalone content, but can be changed to `div` or `section` via the `as` prop.
158
+ *
159
+ * ## Semantic HTML Guidelines
160
+ * - Use `article` (default) for self-contained, syndicate-able content
161
+ * - Use `div` for generic content containers
162
+ * - Use `section` for thematic groupings with a heading
163
+ *
164
+ * @example
165
+ * ```tsx
166
+ * <Card>
167
+ * <Card.Title>Article Title</Card.Title>
168
+ * <Card.Content>
169
+ * <p>This is standalone content...</p>
170
+ * </Card.Content>
171
+ * </Card>
172
+ * ```
173
+ *
174
+ * @example
175
+ * ```tsx
176
+ * // Generic container (not standalone content)
177
+ * <Card.Content as="div">
178
+ * <p>Generic content...</p>
179
+ * </Card.Content>
180
+ * ```
181
+ */
17
182
  declare const Content: {
18
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
19
- className?: string | undefined;
20
- styles?: React__default.CSSProperties | undefined;
21
- }>): React__default.JSX.Element;
183
+ ({ children, className, style, as, ...props }: CardContentProps): React.JSX.Element;
22
184
  displayName: string;
23
185
  };
186
+ /**
187
+ * Card.Footer - Footer sub-component for Card
188
+ *
189
+ * Renders a footer section for the card. Use for actions, metadata, or
190
+ * supplementary information.
191
+ *
192
+ * @example
193
+ * ```tsx
194
+ * <Card>
195
+ * <Card.Title>Product</Card.Title>
196
+ * <Card.Content>Description...</Card.Content>
197
+ * <Card.Footer>
198
+ * <button>Add to Cart</button>
199
+ * <span>$29.99</span>
200
+ * </Card.Footer>
201
+ * </Card>
202
+ * ```
203
+ *
204
+ * @example
205
+ * ```tsx
206
+ * // Semantic footer element
207
+ * <Card.Footer as="footer">
208
+ * <p>Last updated: 2024-01-15</p>
209
+ * </Card.Footer>
210
+ * ```
211
+ */
24
212
  declare const Footer: {
25
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
26
- className?: string | undefined;
27
- styles?: React__default.CSSProperties | undefined;
28
- }>): React__default.JSX.Element;
213
+ ({ children, className, style, as, ...props }: CardFooterProps): React.JSX.Element;
29
214
  displayName: string;
30
215
  };
216
+ /**
217
+ * Card - A flexible, accessible card component with compound component pattern
218
+ *
219
+ * The Card component provides a container for grouping related content and actions.
220
+ * It follows the compound component pattern, exposing `Card.Title`, `Card.Content`,
221
+ * and `Card.Footer` sub-components for structured layouts.
222
+ *
223
+ * ## Features
224
+ * - **Polymorphic rendering**: Render as any HTML element via `as` prop
225
+ * - **Compound components**: Structured sub-components for consistent layouts
226
+ * - **Interactive variant**: Built-in keyboard navigation and ARIA support
227
+ * - **Fully accessible**: WCAG 2.1 AA compliant with proper semantic HTML
228
+ *
229
+ * ## Accessibility
230
+ *
231
+ * ### Non-Interactive Cards
232
+ * - Use semantic HTML: `article` for standalone content, `section` for groupings
233
+ * - Provide accessible names with `aria-labelledby` referencing the title
234
+ *
235
+ * ### Interactive Cards (Clickable)
236
+ * - Set `interactive={true}` to enable keyboard navigation (Enter/Space)
237
+ * - Provide accessible name via `aria-label` or `aria-labelledby`
238
+ * - Ensure adequate focus indicators (handled by CSS)
239
+ *
240
+ * @example
241
+ * // Basic card with compound components
242
+ * ```tsx
243
+ * <Card>
244
+ * <Card.Title>Product Name</Card.Title>
245
+ * <Card.Content>
246
+ * <p>Product description goes here...</p>
247
+ * </Card.Content>
248
+ * <Card.Footer>
249
+ * <button>Buy Now</button>
250
+ * </Card.Footer>
251
+ * </Card>
252
+ * ```
253
+ *
254
+ * @example
255
+ * // Accessible interactive card
256
+ * ```tsx
257
+ * <Card
258
+ * interactive
259
+ * aria-label="View product details"
260
+ * onClick={() => navigate('/product/123')}
261
+ * >
262
+ * <Card.Title>Product Name</Card.Title>
263
+ * <Card.Content>Click anywhere to view details</Card.Content>
264
+ * </Card>
265
+ * ```
266
+ *
267
+ * @example
268
+ * // Semantic article card with accessible name
269
+ * ```tsx
270
+ * <Card as="article" aria-labelledby="article-title">
271
+ * <Card.Title id="article-title">Article Headline</Card.Title>
272
+ * <Card.Content>Article body...</Card.Content>
273
+ * </Card>
274
+ * ```
275
+ *
276
+ * @example
277
+ * // Card as a landmark region
278
+ * ```tsx
279
+ * <Card role="region" aria-label="Featured products">
280
+ * <Card.Title>Featured</Card.Title>
281
+ * <Card.Content>...</Card.Content>
282
+ * </Card>
283
+ * ```
284
+ */
31
285
  declare const Card: {
32
- ({ elm, styles, children, classes, id, ...props }: CardProps): React__default.JSX.Element;
286
+ ({ as, styles, children, classes, id, interactive, onClick, tabIndex, role, "aria-label": ariaLabel, "aria-labelledby": ariaLabelledBy, "aria-describedby": ariaDescribedBy, ...props }: CardProps): React.JSX.Element;
33
287
  displayName: string;
34
288
  Title: {
35
- ({ children, className, styles, as, ...props }: React__default.PropsWithChildren<{
36
- className?: string | undefined;
37
- styles?: React__default.CSSProperties | undefined;
38
- as?: React__default.ElementType<any> | undefined;
39
- }>): React__default.JSX.Element;
289
+ ({ children, className, style, as, ...props }: CardTitleProps): React.JSX.Element;
40
290
  displayName: string;
41
291
  };
42
292
  Content: {
43
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
44
- className?: string | undefined;
45
- styles?: React__default.CSSProperties | undefined;
46
- }>): React__default.JSX.Element;
293
+ ({ children, className, style, as, ...props }: CardContentProps): React.JSX.Element;
47
294
  displayName: string;
48
295
  };
49
296
  Footer: {
50
- ({ children, className, styles, ...props }: React__default.PropsWithChildren<{
51
- className?: string | undefined;
52
- styles?: React__default.CSSProperties | undefined;
53
- }>): React__default.JSX.Element;
297
+ ({ children, className, style, as, ...props }: CardFooterProps): React.JSX.Element;
54
298
  displayName: string;
55
299
  };
56
300
  };
@@ -1,4 +1,4 @@
1
- export { d as Card, b as Content, c as Footer, a as Title, e as default } from '../chunk-BSPKFLO4.js';
2
- import '../chunk-NE6YXTMC.js';
1
+ export { d as Card, b as Content, c as Footer, a as Title, e as default } from '../chunk-KK47SYZI.js';
2
+ import '../chunk-HHLNOC5T.js';
3
3
  //# sourceMappingURL=out.js.map
4
4
  //# sourceMappingURL=card.js.map
@@ -1 +1 @@
1
- :root{--card-p: 2rem;--card-bg: #fff;--card-radius: calc(var(--card-p) / 4);--card-position: relative;--card-display: flex;--card-direction: column;--card-gap: 1rem}[data-card],[data-component~=card]{display:var(--card-display);flex-direction:var(--card-direction);gap:var(--card-gap);border-radius:var(--card-radius);background-color:var(--card-bg);text-align:var(--card-align, left)}[data-card] h3,[data-card] h2,[data-component~=card] h3,[data-component~=card] h2{margin-block-end:0;padding-block-end:0}[data-card]+div,[data-component~=card]+div{margin-block-start:0}[data-card]>article,[data-component~=card]>article{display:flex;flex-direction:column;flex:2}[data-card]>*:not(img),[data-component~=card]>*:not(img){padding-inline:var(--card-p)}[data-card]>*:last-child:not(img),[data-component~=card]>*:last-child:not(img){padding-block-end:var(--card-p)}[data-card]>*:first-child:not(img),[data-component~=card]>*:first-child:not(img){padding-block-start:calc(var(--card-p) - .5rem)}/*# sourceMappingURL=card.css.map */
1
+ :root{--card-p: 2rem;--card-bg: #fff;--card-radius: calc(var(--card-p) / 4);--card-position: relative;--card-display: flex;--card-direction: column;--card-gap: 1rem}[data-card],[data-component~=card]{display:var(--card-display);flex-direction:var(--card-direction);gap:var(--card-gap);border-radius:var(--card-radius);background-color:var(--card-bg);text-align:var(--card-align, left)}[data-card] h3,[data-card] h2,[data-component~=card] h3,[data-component~=card] h2{margin-block-end:0;padding-block-end:0}[data-card]+div,[data-component~=card]+div{margin-block-start:0}[data-card]>article,[data-component~=card]>article{display:flex;flex-direction:column;flex:2}[data-card]>*:not(img),[data-component~=card]>*:not(img){padding-inline:var(--card-p)}[data-card]>*:last-child:not(img),[data-component~=card]>*:last-child:not(img){padding-block-end:var(--card-p)}[data-card]>*:first-child:not(img),[data-component~=card]>*:first-child:not(img){padding-block-start:calc(var(--card-p) - .5rem)}[data-card=interactive]{cursor:pointer;transition:box-shadow .2s ease,transform .2s ease}[data-card=interactive]:hover{transform:translateY(-2px);box-shadow:0 .25rem .75rem rgba(0,0,0,.15)}[data-card=interactive]:focus-visible{outline:.125rem solid var(--focus-color, #0066CC);outline-offset:.125rem}[data-card=interactive]:focus:not(:focus-visible){outline:none}/*# sourceMappingURL=card.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../../src/components/cards/card.scss"],"names":[],"mappings":"AAAA,MACE,eACA,gBACA,uCACA,0BACA,qBACA,yBACA,iBAGF,mCAEE,4BACA,qCACA,oBACA,iCACA,gCACA,mCAEA,kFAEE,mBACA,oBAEF,2CACE,qBAEF,mDACE,aACA,sBACA,OAGF,yDACE,6BAEF,+EAEE,gCAEF,iFACE","file":"card.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../../src/components/cards/card.scss"],"names":[],"mappings":"AAAA,MACE,eACA,gBACA,uCACA,0BACA,qBACA,yBACA,iBAGF,mCAEE,4BACA,qCACA,oBACA,iCACA,gCACA,mCAEA,kFAEE,mBACA,oBAEF,2CACE,qBAEF,mDACE,aACA,sBACA,OAGF,yDACE,6BAEF,+EAEE,gCAEF,iFACE,gDAKJ,wBACE,eACA,kDAEA,8BACE,2BACA,2CAIF,sCACE,kDACA,uBAIF,kDACE","file":"card.css"}