@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,24 +1,433 @@
1
- import { StoryObj, Meta } from "@storybook/react-vite";
2
- import { within, expect } from "storybook/test";
1
+ import { StoryObj, Meta } from '@storybook/react-vite'
2
+ import { within, expect } from 'storybook/test'
3
3
 
4
- import Img from "./img";
4
+ import Img from './img'
5
5
 
6
6
  const meta: Meta<typeof Img> = {
7
- title: "FP.REACT Components/Img",
7
+ title: 'FP.REACT Components/Img',
8
8
  component: Img,
9
- tags: ["version:1.0.0"],
10
- args: {
11
- src: "//",
9
+ tags: ['version:2.0.0', 'accessibility', 'responsive'],
10
+ argTypes: {
11
+ src: {
12
+ control: 'text',
13
+ description: 'Image source URL',
14
+ },
15
+ alt: {
16
+ control: 'text',
17
+ description:
18
+ 'Alternative text (empty string for decorative, descriptive text for semantic)',
19
+ },
20
+ width: {
21
+ control: 'number',
22
+ description: 'Image width in pixels',
23
+ },
24
+ height: {
25
+ control: 'number',
26
+ description: 'Image height in pixels',
27
+ },
28
+ loading: {
29
+ control: 'radio',
30
+ options: ['lazy', 'eager'],
31
+ description: 'Loading strategy',
32
+ },
33
+ fetchpriority: {
34
+ control: 'radio',
35
+ options: ['low', 'high', 'auto'],
36
+ description: 'Fetch priority hint',
37
+ },
38
+ decoding: {
39
+ control: 'radio',
40
+ options: ['auto', 'async', 'sync'],
41
+ description: 'Decoding hint',
42
+ },
43
+ },
44
+ parameters: {
45
+ docs: {
46
+ description: {
47
+ component:
48
+ 'A semantic image component with accessibility and performance best practices. Supports responsive images, lazy loading, and error handling.',
49
+ },
50
+ },
12
51
  },
13
- } as Story;
52
+ } satisfies Meta<typeof Img>
14
53
 
15
- export default meta;
16
- type Story = StoryObj<typeof Img>;
54
+ export default meta
55
+ type Story = StoryObj<typeof Img>
17
56
 
18
- export const ImgComponent: Story = {
19
- args: {},
57
+ /**
58
+ * Basic image with default settings.
59
+ * Uses lazy loading by default for optimal performance.
60
+ */
61
+ export const Default: Story = {
62
+ args: {
63
+ src: 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=800&auto=format&fit=crop',
64
+ alt: 'Beautiful landscape with mountains and lake',
65
+ width: 800,
66
+ },
20
67
  play: async ({ canvasElement }) => {
21
- const canvas = within(canvasElement);
22
- await expect(canvas.getByRole("img")).toBeInTheDocument();
68
+ const canvas = within(canvasElement)
69
+ const img = await canvas.findByRole('img')
70
+ await expect(img).toBeInTheDocument()
71
+ await expect(img).toHaveAttribute('loading', 'lazy')
72
+ },
73
+ }
74
+
75
+ /**
76
+ * Decorative image with empty alt attribute.
77
+ * Use for purely visual decoration that doesn't convey information.
78
+ */
79
+ export const DecorativeImage: Story = {
80
+ args: {
81
+ src: 'https://images.unsplash.com/photo-1557672172-298e090bd0f1?w=400&auto=format&fit=crop',
82
+ alt: '',
83
+ width: 400,
84
+ },
85
+ parameters: {
86
+ docs: {
87
+ description: {
88
+ story:
89
+ 'Decorative images should have an empty alt attribute (alt=""). These are images like borders, patterns, or visual separators that don\'t convey meaningful content.',
90
+ },
91
+ },
92
+ },
93
+ }
94
+
95
+ /**
96
+ * Semantic image with descriptive alt text.
97
+ * Provides context about the image content for accessibility.
98
+ */
99
+ export const SemanticImage: Story = {
100
+ args: {
101
+ src: 'https://images.unsplash.com/photo-1551288049-bebda4e38f71?w=800&auto=format&fit=crop',
102
+ alt: 'Sales dashboard showing bar chart with quarterly revenue growth trends',
103
+ width: 800,
104
+ },
105
+ parameters: {
106
+ docs: {
107
+ description: {
108
+ story:
109
+ 'Semantic images convey information and must have descriptive alt text that explains the content and context.',
110
+ },
111
+ },
112
+ },
113
+ }
114
+
115
+ /**
116
+ * Responsive image with srcSet and sizes.
117
+ * Allows browser to choose appropriate image based on viewport and pixel density.
118
+ */
119
+ export const ResponsiveImage: Story = {
120
+ args: {
121
+ src: 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=800&auto=format&fit=crop',
122
+ srcSet:
123
+ 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=320&auto=format&fit=crop 320w, ' +
124
+ 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=640&auto=format&fit=crop 640w, ' +
125
+ 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=1024&auto=format&fit=crop 1024w',
126
+ sizes: '(max-width: 640px) 100vw, (max-width: 1024px) 50vw, 800px',
127
+ alt: 'Responsive image adapts to different viewport sizes',
128
+ width: 800,
129
+ },
130
+ parameters: {
131
+ docs: {
132
+ description: {
133
+ story:
134
+ 'Responsive images use srcSet and sizes attributes to serve different image sizes based on viewport width, improving performance and bandwidth usage.',
135
+ },
136
+ },
137
+ },
138
+ }
139
+
140
+ /**
141
+ * Hero image with eager loading and high priority.
142
+ * Use for above-the-fold images that should load immediately.
143
+ */
144
+ export const HeroImage: Story = {
145
+ args: {
146
+ src: 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=1200&auto=format&fit=crop',
147
+ alt: 'Hero banner showcasing mountain landscape at sunset',
148
+ width: 1200,
149
+ height: 600,
150
+ loading: 'eager',
151
+ fetchpriority: 'high',
152
+ },
153
+ parameters: {
154
+ docs: {
155
+ description: {
156
+ story:
157
+ 'Hero images and other above-the-fold images should use loading="eager" and fetchpriority="high" to prioritize their loading.',
158
+ },
159
+ },
160
+ },
161
+ }
162
+
163
+ /**
164
+ * Default SVG gradient placeholder (automatic fallback).
165
+ * Demonstrates the built-in SVG placeholder that appears when images fail to load.
166
+ */
167
+ export const DefaultSvgPlaceholder: Story = {
168
+ args: {
169
+ src: 'https://invalid-url-will-fail.com/image.jpg',
170
+ alt: 'Failed image with default SVG placeholder',
171
+ width: 800,
172
+ height: 600,
173
+ },
174
+ parameters: {
175
+ docs: {
176
+ description: {
177
+ story:
178
+ 'When an image fails to load and no custom placeholder is provided, a beautiful SVG gradient placeholder is displayed automatically. The SVG is inline (no network requests), responsive, and shows the image dimensions for debugging.',
179
+ },
180
+ },
181
+ },
182
+ }
183
+
184
+ /**
185
+ * Image with custom placeholder fallback.
186
+ * Displays custom image when primary source fails to load.
187
+ */
188
+ export const CustomPlaceholder: Story = {
189
+ args: {
190
+ src: 'https://invalid-url-that-will-fail.com/image.jpg',
191
+ placeholder:
192
+ 'data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 400 300"%3E%3Crect fill="%23ef4444" width="400" height="300"/%3E%3Ctext x="50%25" y="50%25" text-anchor="middle" dominant-baseline="middle" fill="white" font-family="system-ui" font-size="20"%3ECustom Placeholder%3C/text%3E%3C/svg%3E',
193
+ alt: 'Product photo',
194
+ width: 400,
195
+ height: 300,
196
+ },
197
+ parameters: {
198
+ docs: {
199
+ description: {
200
+ story:
201
+ 'When an image fails to load, a custom placeholder can be displayed. This example uses a custom SVG placeholder with a red background.',
202
+ },
203
+ },
204
+ },
205
+ }
206
+
207
+ /**
208
+ * Image with custom error handler.
209
+ * Demonstrates error logging while still showing the default fallback.
210
+ */
211
+ export const CustomErrorHandler: Story = {
212
+ args: {
213
+ src: 'https://invalid-url.com/image.jpg',
214
+ alt: 'Failed image',
215
+ width: 400,
216
+ onError: (e) => {
217
+ // eslint-disable-next-line no-console
218
+ console.error('Image failed to load:', e.currentTarget.src)
219
+ // Log to analytics, show notification, etc.
220
+ // The default SVG placeholder will still be applied automatically
221
+ },
222
+ },
223
+ parameters: {
224
+ docs: {
225
+ description: {
226
+ story:
227
+ 'Custom error handlers can be provided via the onError prop for logging, analytics, or notifications. The default SVG placeholder is still applied automatically. Call e.preventDefault() in your handler if you want to prevent the default fallback.',
228
+ },
229
+ },
230
+ },
231
+ }
232
+
233
+ /**
234
+ * Image with custom error handler that prevents default fallback.
235
+ * Demonstrates full control over error handling.
236
+ */
237
+ export const CustomErrorHandlerWithPreventDefault: Story = {
238
+ args: {
239
+ src: 'https://invalid-url.com/image.jpg',
240
+ alt: 'Failed image with custom fallback',
241
+ width: 400,
242
+ onError: (e) => {
243
+ // eslint-disable-next-line no-console
244
+ console.error('Image failed to load:', e.currentTarget.src)
245
+
246
+ // Prevent default fallback and use custom image
247
+ e.preventDefault()
248
+ const customFallback = `data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 400 300"%3E%3Crect fill="%23f59e0b" width="400" height="300"/%3E%3Ctext x="50%25" y="50%25" text-anchor="middle" dominant-baseline="middle" fill="white" font-family="system-ui" font-size="18"%3ECustom Error Handler%3C/text%3E%3C/svg%3E`
249
+ e.currentTarget.src = customFallback
250
+ },
251
+ },
252
+ parameters: {
253
+ docs: {
254
+ description: {
255
+ story:
256
+ 'When you call e.preventDefault() in the onError handler, the default SVG placeholder is not applied, giving you full control over the fallback behavior. This example shows a custom amber/orange placeholder.',
257
+ },
258
+ },
259
+ },
260
+ }
261
+
262
+ /**
263
+ * Image with load callback.
264
+ * Executes custom logic when image successfully loads.
265
+ */
266
+ export const WithLoadCallback: Story = {
267
+ args: {
268
+ src: 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=600&auto=format&fit=crop',
269
+ alt: 'Image with load tracking',
270
+ width: 600,
271
+ onLoad: (e) => {
272
+ // eslint-disable-next-line no-console
273
+ console.log('Image loaded successfully:', e.currentTarget.src)
274
+ // Analytics tracking, performance monitoring, etc.
275
+ },
276
+ },
277
+ parameters: {
278
+ docs: {
279
+ description: {
280
+ story:
281
+ 'The onLoad callback fires when an image successfully loads, useful for analytics, performance tracking, or triggering animations.',
282
+ },
283
+ },
284
+ },
285
+ }
286
+
287
+ /**
288
+ * Small profile image with eager loading.
289
+ * Suitable for avatars, thumbnails, and small images.
290
+ */
291
+ export const ProfileImage: Story = {
292
+ args: {
293
+ src: 'https://images.unsplash.com/photo-1535713875002-d1d0cf377fde?w=150&auto=format&fit=crop&crop=faces',
294
+ alt: 'User profile photo',
295
+ width: 150,
296
+ height: 150,
297
+ loading: 'eager',
298
+ styles: { borderRadius: '50%' },
299
+ },
300
+ parameters: {
301
+ docs: {
302
+ description: {
303
+ story:
304
+ 'Small images like profile photos can use eager loading since they have minimal performance impact. Custom styles can be applied for circular avatars.',
305
+ },
306
+ },
307
+ },
308
+ }
309
+
310
+ /**
311
+ * Image with async decoding.
312
+ * Prevents blocking the main thread during image decoding.
313
+ */
314
+ export const AsyncDecoding: Story = {
315
+ args: {
316
+ src: 'https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=800&auto=format&fit=crop',
317
+ alt: 'Image with async decoding',
318
+ width: 800,
319
+ decoding: 'async',
320
+ },
321
+ parameters: {
322
+ docs: {
323
+ description: {
324
+ story:
325
+ 'Async decoding prevents image decoding from blocking the main thread, improving perceived performance especially for large images.',
326
+ },
327
+ },
328
+ },
329
+ }
330
+
331
+ /**
332
+ * SVG Placeholder Gallery - Different Dimensions.
333
+ * Demonstrates how the SVG placeholder adapts to various image sizes.
334
+ */
335
+ export const PlaceholderGallery: Story = {
336
+ render: () => (
337
+ <div style={{ display: 'grid', gridTemplateColumns: 'repeat(3, 1fr)', gap: '1rem' }}>
338
+ <Img
339
+ src="https://will-fail-1.jpg"
340
+ alt="Square placeholder"
341
+ width={400}
342
+ height={400}
343
+ />
344
+ <Img
345
+ src="https://will-fail-2.jpg"
346
+ alt="Landscape placeholder"
347
+ width={600}
348
+ height={400}
349
+ />
350
+ <Img
351
+ src="https://will-fail-3.jpg"
352
+ alt="Portrait placeholder"
353
+ width={400}
354
+ height={600}
355
+ />
356
+ <Img
357
+ src="https://will-fail-4.jpg"
358
+ alt="Wide placeholder"
359
+ width={800}
360
+ height={400}
361
+ />
362
+ <Img
363
+ src="https://will-fail-5.jpg"
364
+ alt="Small placeholder"
365
+ width={200}
366
+ height={200}
367
+ />
368
+ <Img
369
+ src="https://will-fail-6.jpg"
370
+ alt="Tall placeholder"
371
+ width={300}
372
+ height={500}
373
+ />
374
+ </div>
375
+ ),
376
+ parameters: {
377
+ docs: {
378
+ description: {
379
+ story:
380
+ 'Gallery of failed images showing the default SVG placeholder at various dimensions. The SVG gradient and elements scale proportionally for each size, demonstrating perfect responsiveness.',
381
+ },
382
+ },
383
+ },
384
+ }
385
+
386
+ /**
387
+ * Gallery of multiple images with lazy loading.
388
+ * Demonstrates efficient loading of multiple images.
389
+ */
390
+ export const ImageGallery: Story = {
391
+ render: () => (
392
+ <div style={{ display: 'grid', gridTemplateColumns: 'repeat(3, 1fr)', gap: '1rem' }}>
393
+ <Img
394
+ src="https://images.unsplash.com/photo-1682687220742-aba13b6e50ba?w=400&auto=format&fit=crop"
395
+ alt="Mountain landscape 1"
396
+ width={400}
397
+ />
398
+ <Img
399
+ src="https://images.unsplash.com/photo-1682687221038-404cb8830901?w=400&auto=format&fit=crop"
400
+ alt="Mountain landscape 2"
401
+ width={400}
402
+ />
403
+ <Img
404
+ src="https://images.unsplash.com/photo-1682687219356-e820ca126c92?w=400&auto=format&fit=crop"
405
+ alt="Mountain landscape 3"
406
+ width={400}
407
+ />
408
+ <Img
409
+ src="https://images.unsplash.com/photo-1682687220063-4742bd7f3b80?w=400&auto=format&fit=crop"
410
+ alt="Mountain landscape 4"
411
+ width={400}
412
+ />
413
+ <Img
414
+ src="https://images.unsplash.com/photo-1682687220923-c58b9a4592ae?w=400&auto=format&fit=crop"
415
+ alt="Mountain landscape 5"
416
+ width={400}
417
+ />
418
+ <Img
419
+ src="https://images.unsplash.com/photo-1682687220067-dced9a881b56?w=400&auto=format&fit=crop"
420
+ alt="Mountain landscape 6"
421
+ width={400}
422
+ />
423
+ </div>
424
+ ),
425
+ parameters: {
426
+ docs: {
427
+ description: {
428
+ story:
429
+ 'Gallery of images using lazy loading by default. Only images near the viewport will load, improving initial page load performance.',
430
+ },
431
+ },
23
432
  },
24
- };
433
+ }