@dsn-starter-kit/components-react 1.0.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 (641) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +181 -0
  3. package/dist/ActionGroup/ActionGroup.css +55 -0
  4. package/dist/ActionGroup/ActionGroup.d.ts +41 -0
  5. package/dist/ActionGroup/ActionGroup.d.ts.map +1 -0
  6. package/dist/ActionGroup/ActionGroup.js +36 -0
  7. package/dist/ActionGroup/ActionGroup.js.map +1 -0
  8. package/dist/ActionGroup/index.d.ts +3 -0
  9. package/dist/ActionGroup/index.d.ts.map +1 -0
  10. package/dist/ActionGroup/index.js +2 -0
  11. package/dist/ActionGroup/index.js.map +1 -0
  12. package/dist/Alert/Alert.css +145 -0
  13. package/dist/Alert/Alert.d.ts +69 -0
  14. package/dist/Alert/Alert.d.ts.map +1 -0
  15. package/dist/Alert/Alert.js +57 -0
  16. package/dist/Alert/Alert.js.map +1 -0
  17. package/dist/Alert/index.d.ts +3 -0
  18. package/dist/Alert/index.d.ts.map +1 -0
  19. package/dist/Alert/index.js +2 -0
  20. package/dist/Alert/index.js.map +1 -0
  21. package/dist/Backdrop/Backdrop.css +30 -0
  22. package/dist/Backdrop/Backdrop.d.ts +26 -0
  23. package/dist/Backdrop/Backdrop.d.ts.map +1 -0
  24. package/dist/Backdrop/Backdrop.js +23 -0
  25. package/dist/Backdrop/Backdrop.js.map +1 -0
  26. package/dist/Backdrop/index.d.ts +3 -0
  27. package/dist/Backdrop/index.d.ts.map +1 -0
  28. package/dist/Backdrop/index.js +2 -0
  29. package/dist/Backdrop/index.js.map +1 -0
  30. package/dist/Body/Body.css +14 -0
  31. package/dist/Body/Body.d.ts +27 -0
  32. package/dist/Body/Body.d.ts.map +1 -0
  33. package/dist/Body/Body.js +27 -0
  34. package/dist/Body/Body.js.map +1 -0
  35. package/dist/Body/index.d.ts +3 -0
  36. package/dist/Body/index.d.ts.map +1 -0
  37. package/dist/Body/index.js +2 -0
  38. package/dist/Body/index.js.map +1 -0
  39. package/dist/BreadcrumbNavigation/BreadcrumbNavigation.css +216 -0
  40. package/dist/BreadcrumbNavigation/BreadcrumbNavigation.d.ts +43 -0
  41. package/dist/BreadcrumbNavigation/BreadcrumbNavigation.d.ts.map +1 -0
  42. package/dist/BreadcrumbNavigation/BreadcrumbNavigation.js +42 -0
  43. package/dist/BreadcrumbNavigation/BreadcrumbNavigation.js.map +1 -0
  44. package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.d.ts +32 -0
  45. package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.d.ts.map +1 -0
  46. package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.js +20 -0
  47. package/dist/BreadcrumbNavigation/BreadcrumbNavigationItem.js.map +1 -0
  48. package/dist/BreadcrumbNavigation/index.d.ts +3 -0
  49. package/dist/BreadcrumbNavigation/index.d.ts.map +1 -0
  50. package/dist/BreadcrumbNavigation/index.js +3 -0
  51. package/dist/BreadcrumbNavigation/index.js.map +1 -0
  52. package/dist/BreakoutSection/BreakoutSection.css +19 -0
  53. package/dist/BreakoutSection/BreakoutSection.d.ts +30 -0
  54. package/dist/BreakoutSection/BreakoutSection.d.ts.map +1 -0
  55. package/dist/BreakoutSection/BreakoutSection.js +27 -0
  56. package/dist/BreakoutSection/BreakoutSection.js.map +1 -0
  57. package/dist/BreakoutSection/index.d.ts +3 -0
  58. package/dist/BreakoutSection/index.d.ts.map +1 -0
  59. package/dist/BreakoutSection/index.js +2 -0
  60. package/dist/BreakoutSection/index.js.map +1 -0
  61. package/dist/Button/Button.css +337 -0
  62. package/dist/Button/Button.d.ts +90 -0
  63. package/dist/Button/Button.d.ts.map +1 -0
  64. package/dist/Button/Button.js +53 -0
  65. package/dist/Button/Button.js.map +1 -0
  66. package/dist/Button/index.d.ts +3 -0
  67. package/dist/Button/index.d.ts.map +1 -0
  68. package/dist/Button/index.js +2 -0
  69. package/dist/Button/index.js.map +1 -0
  70. package/dist/ButtonLink/ButtonLink.css +29 -0
  71. package/dist/ButtonLink/ButtonLink.d.ts +92 -0
  72. package/dist/ButtonLink/ButtonLink.d.ts.map +1 -0
  73. package/dist/ButtonLink/ButtonLink.js +50 -0
  74. package/dist/ButtonLink/ButtonLink.js.map +1 -0
  75. package/dist/ButtonLink/index.d.ts +3 -0
  76. package/dist/ButtonLink/index.d.ts.map +1 -0
  77. package/dist/ButtonLink/index.js +2 -0
  78. package/dist/ButtonLink/index.js.map +1 -0
  79. package/dist/Card/Card.css +169 -0
  80. package/dist/Card/Card.d.ts +105 -0
  81. package/dist/Card/Card.d.ts.map +1 -0
  82. package/dist/Card/Card.js +80 -0
  83. package/dist/Card/Card.js.map +1 -0
  84. package/dist/Card/index.d.ts +3 -0
  85. package/dist/Card/index.d.ts.map +1 -0
  86. package/dist/Card/index.js +2 -0
  87. package/dist/Card/index.js.map +1 -0
  88. package/dist/Checkbox/Checkbox.css +239 -0
  89. package/dist/Checkbox/Checkbox.d.ts +18 -0
  90. package/dist/Checkbox/Checkbox.d.ts.map +1 -0
  91. package/dist/Checkbox/Checkbox.js +24 -0
  92. package/dist/Checkbox/Checkbox.js.map +1 -0
  93. package/dist/Checkbox/index.d.ts +3 -0
  94. package/dist/Checkbox/index.d.ts.map +1 -0
  95. package/dist/Checkbox/index.js +2 -0
  96. package/dist/Checkbox/index.js.map +1 -0
  97. package/dist/CheckboxGroup/CheckboxGroup.css +10 -0
  98. package/dist/CheckboxGroup/CheckboxGroup.d.ts +37 -0
  99. package/dist/CheckboxGroup/CheckboxGroup.d.ts.map +1 -0
  100. package/dist/CheckboxGroup/CheckboxGroup.js +37 -0
  101. package/dist/CheckboxGroup/CheckboxGroup.js.map +1 -0
  102. package/dist/CheckboxGroup/index.d.ts +3 -0
  103. package/dist/CheckboxGroup/index.d.ts.map +1 -0
  104. package/dist/CheckboxGroup/index.js +2 -0
  105. package/dist/CheckboxGroup/index.js.map +1 -0
  106. package/dist/CheckboxOption/CheckboxOption.css +17 -0
  107. package/dist/CheckboxOption/CheckboxOption.d.ts +14 -0
  108. package/dist/CheckboxOption/CheckboxOption.d.ts.map +1 -0
  109. package/dist/CheckboxOption/CheckboxOption.js +15 -0
  110. package/dist/CheckboxOption/CheckboxOption.js.map +1 -0
  111. package/dist/CheckboxOption/index.d.ts +3 -0
  112. package/dist/CheckboxOption/index.d.ts.map +1 -0
  113. package/dist/CheckboxOption/index.js +2 -0
  114. package/dist/CheckboxOption/index.js.map +1 -0
  115. package/dist/Container/Container.css +48 -0
  116. package/dist/Container/Container.d.ts +41 -0
  117. package/dist/Container/Container.d.ts.map +1 -0
  118. package/dist/Container/Container.js +33 -0
  119. package/dist/Container/Container.js.map +1 -0
  120. package/dist/Container/index.d.ts +3 -0
  121. package/dist/Container/index.d.ts.map +1 -0
  122. package/dist/Container/index.js +2 -0
  123. package/dist/Container/index.js.map +1 -0
  124. package/dist/DateInput/DateInput.css +37 -0
  125. package/dist/DateInput/DateInput.d.ts +37 -0
  126. package/dist/DateInput/DateInput.d.ts.map +1 -0
  127. package/dist/DateInput/DateInput.js +52 -0
  128. package/dist/DateInput/DateInput.js.map +1 -0
  129. package/dist/DateInput/index.d.ts +3 -0
  130. package/dist/DateInput/index.d.ts.map +1 -0
  131. package/dist/DateInput/index.js +2 -0
  132. package/dist/DateInput/index.js.map +1 -0
  133. package/dist/DateInputGroup/DateInputGroup.css +30 -0
  134. package/dist/DateInputGroup/DateInputGroup.d.ts +65 -0
  135. package/dist/DateInputGroup/DateInputGroup.d.ts.map +1 -0
  136. package/dist/DateInputGroup/DateInputGroup.js +53 -0
  137. package/dist/DateInputGroup/DateInputGroup.js.map +1 -0
  138. package/dist/DateInputGroup/index.d.ts +3 -0
  139. package/dist/DateInputGroup/index.d.ts.map +1 -0
  140. package/dist/DateInputGroup/index.js +2 -0
  141. package/dist/DateInputGroup/index.js.map +1 -0
  142. package/dist/Details/Details.css +134 -0
  143. package/dist/Details/Details.d.ts +46 -0
  144. package/dist/Details/Details.d.ts.map +1 -0
  145. package/dist/Details/Details.js +37 -0
  146. package/dist/Details/Details.js.map +1 -0
  147. package/dist/Details/index.d.ts +3 -0
  148. package/dist/Details/index.d.ts.map +1 -0
  149. package/dist/Details/index.js +2 -0
  150. package/dist/Details/index.js.map +1 -0
  151. package/dist/DotBadge/DotBadge.css +98 -0
  152. package/dist/DotBadge/DotBadge.d.ts +40 -0
  153. package/dist/DotBadge/DotBadge.d.ts.map +1 -0
  154. package/dist/DotBadge/DotBadge.js +33 -0
  155. package/dist/DotBadge/DotBadge.js.map +1 -0
  156. package/dist/DotBadge/index.d.ts +2 -0
  157. package/dist/DotBadge/index.d.ts.map +1 -0
  158. package/dist/DotBadge/index.js +2 -0
  159. package/dist/DotBadge/index.js.map +1 -0
  160. package/dist/Drawer/Drawer.css +258 -0
  161. package/dist/Drawer/Drawer.d.ts +109 -0
  162. package/dist/Drawer/Drawer.d.ts.map +1 -0
  163. package/dist/Drawer/Drawer.js +115 -0
  164. package/dist/Drawer/Drawer.js.map +1 -0
  165. package/dist/Drawer/index.d.ts +3 -0
  166. package/dist/Drawer/index.d.ts.map +1 -0
  167. package/dist/Drawer/index.js +2 -0
  168. package/dist/Drawer/index.js.map +1 -0
  169. package/dist/EmailInput/EmailInput.css +4 -0
  170. package/dist/EmailInput/EmailInput.d.ts +38 -0
  171. package/dist/EmailInput/EmailInput.d.ts.map +1 -0
  172. package/dist/EmailInput/EmailInput.js +27 -0
  173. package/dist/EmailInput/EmailInput.js.map +1 -0
  174. package/dist/EmailInput/index.d.ts +3 -0
  175. package/dist/EmailInput/index.d.ts.map +1 -0
  176. package/dist/EmailInput/index.js +2 -0
  177. package/dist/EmailInput/index.js.map +1 -0
  178. package/dist/File/File.css +206 -0
  179. package/dist/File/File.d.ts +116 -0
  180. package/dist/File/File.d.ts.map +1 -0
  181. package/dist/File/File.js +100 -0
  182. package/dist/File/File.js.map +1 -0
  183. package/dist/File/index.d.ts +3 -0
  184. package/dist/File/index.d.ts.map +1 -0
  185. package/dist/File/index.js +2 -0
  186. package/dist/File/index.js.map +1 -0
  187. package/dist/FileInput/FileInput.css +112 -0
  188. package/dist/FileInput/FileInput.d.ts +36 -0
  189. package/dist/FileInput/FileInput.d.ts.map +1 -0
  190. package/dist/FileInput/FileInput.js +31 -0
  191. package/dist/FileInput/FileInput.js.map +1 -0
  192. package/dist/FileInput/index.d.ts +3 -0
  193. package/dist/FileInput/index.d.ts.map +1 -0
  194. package/dist/FileInput/index.js +2 -0
  195. package/dist/FileInput/index.js.map +1 -0
  196. package/dist/FormField/FormField.css +16 -0
  197. package/dist/FormField/FormField.d.ts +85 -0
  198. package/dist/FormField/FormField.d.ts.map +1 -0
  199. package/dist/FormField/FormField.js +60 -0
  200. package/dist/FormField/FormField.js.map +1 -0
  201. package/dist/FormField/index.d.ts +3 -0
  202. package/dist/FormField/index.d.ts.map +1 -0
  203. package/dist/FormField/index.js +2 -0
  204. package/dist/FormField/index.js.map +1 -0
  205. package/dist/FormFieldDescription/FormFieldDescription.css +25 -0
  206. package/dist/FormFieldDescription/FormFieldDescription.d.ts +47 -0
  207. package/dist/FormFieldDescription/FormFieldDescription.d.ts.map +1 -0
  208. package/dist/FormFieldDescription/FormFieldDescription.js +37 -0
  209. package/dist/FormFieldDescription/FormFieldDescription.js.map +1 -0
  210. package/dist/FormFieldDescription/index.d.ts +3 -0
  211. package/dist/FormFieldDescription/index.d.ts.map +1 -0
  212. package/dist/FormFieldDescription/index.js +2 -0
  213. package/dist/FormFieldDescription/index.js.map +1 -0
  214. package/dist/FormFieldErrorMessage/FormFieldErrorMessage.css +38 -0
  215. package/dist/FormFieldErrorMessage/FormFieldErrorMessage.d.ts +40 -0
  216. package/dist/FormFieldErrorMessage/FormFieldErrorMessage.d.ts.map +1 -0
  217. package/dist/FormFieldErrorMessage/FormFieldErrorMessage.js +32 -0
  218. package/dist/FormFieldErrorMessage/FormFieldErrorMessage.js.map +1 -0
  219. package/dist/FormFieldErrorMessage/index.d.ts +3 -0
  220. package/dist/FormFieldErrorMessage/index.d.ts.map +1 -0
  221. package/dist/FormFieldErrorMessage/index.js +2 -0
  222. package/dist/FormFieldErrorMessage/index.js.map +1 -0
  223. package/dist/FormFieldLabel/FormFieldLabel.css +48 -0
  224. package/dist/FormFieldLabel/FormFieldLabel.d.ts +38 -0
  225. package/dist/FormFieldLabel/FormFieldLabel.d.ts.map +1 -0
  226. package/dist/FormFieldLabel/FormFieldLabel.js +30 -0
  227. package/dist/FormFieldLabel/FormFieldLabel.js.map +1 -0
  228. package/dist/FormFieldLabel/index.d.ts +3 -0
  229. package/dist/FormFieldLabel/index.d.ts.map +1 -0
  230. package/dist/FormFieldLabel/index.js +2 -0
  231. package/dist/FormFieldLabel/index.js.map +1 -0
  232. package/dist/FormFieldLegend/FormFieldLegend.css +7 -0
  233. package/dist/FormFieldLegend/FormFieldLegend.d.ts +39 -0
  234. package/dist/FormFieldLegend/FormFieldLegend.d.ts.map +1 -0
  235. package/dist/FormFieldLegend/FormFieldLegend.js +31 -0
  236. package/dist/FormFieldLegend/FormFieldLegend.js.map +1 -0
  237. package/dist/FormFieldLegend/index.d.ts +2 -0
  238. package/dist/FormFieldLegend/index.d.ts.map +1 -0
  239. package/dist/FormFieldLegend/index.js +2 -0
  240. package/dist/FormFieldLegend/index.js.map +1 -0
  241. package/dist/FormFieldStatus/FormFieldStatus.css +66 -0
  242. package/dist/FormFieldStatus/FormFieldStatus.d.ts +52 -0
  243. package/dist/FormFieldStatus/FormFieldStatus.d.ts.map +1 -0
  244. package/dist/FormFieldStatus/FormFieldStatus.js +44 -0
  245. package/dist/FormFieldStatus/FormFieldStatus.js.map +1 -0
  246. package/dist/FormFieldStatus/index.d.ts +3 -0
  247. package/dist/FormFieldStatus/index.d.ts.map +1 -0
  248. package/dist/FormFieldStatus/index.js +2 -0
  249. package/dist/FormFieldStatus/index.js.map +1 -0
  250. package/dist/FormFieldset/FormFieldset.css +24 -0
  251. package/dist/FormFieldset/FormFieldset.d.ts +83 -0
  252. package/dist/FormFieldset/FormFieldset.d.ts.map +1 -0
  253. package/dist/FormFieldset/FormFieldset.js +59 -0
  254. package/dist/FormFieldset/FormFieldset.js.map +1 -0
  255. package/dist/FormFieldset/index.d.ts +2 -0
  256. package/dist/FormFieldset/index.d.ts.map +1 -0
  257. package/dist/FormFieldset/index.js +2 -0
  258. package/dist/FormFieldset/index.js.map +1 -0
  259. package/dist/Grid/Grid.css +573 -0
  260. package/dist/Grid/Grid.d.ts +35 -0
  261. package/dist/Grid/Grid.d.ts.map +1 -0
  262. package/dist/Grid/Grid.js +29 -0
  263. package/dist/Grid/Grid.js.map +1 -0
  264. package/dist/Grid/GridItem.d.ts +84 -0
  265. package/dist/Grid/GridItem.d.ts.map +1 -0
  266. package/dist/Grid/GridItem.js +39 -0
  267. package/dist/Grid/GridItem.js.map +1 -0
  268. package/dist/Grid/index.d.ts +5 -0
  269. package/dist/Grid/index.d.ts.map +1 -0
  270. package/dist/Grid/index.js +3 -0
  271. package/dist/Grid/index.js.map +1 -0
  272. package/dist/Heading/Heading.css +81 -0
  273. package/dist/Heading/Heading.d.ts +38 -0
  274. package/dist/Heading/Heading.d.ts.map +1 -0
  275. package/dist/Heading/Heading.js +24 -0
  276. package/dist/Heading/Heading.js.map +1 -0
  277. package/dist/Heading/index.d.ts +3 -0
  278. package/dist/Heading/index.d.ts.map +1 -0
  279. package/dist/Heading/index.js +2 -0
  280. package/dist/Heading/index.js.map +1 -0
  281. package/dist/Hero/Hero.css +205 -0
  282. package/dist/Hero/Hero.d.ts +45 -0
  283. package/dist/Hero/Hero.d.ts.map +1 -0
  284. package/dist/Hero/Hero.js +33 -0
  285. package/dist/Hero/Hero.js.map +1 -0
  286. package/dist/Hero/index.d.ts +3 -0
  287. package/dist/Hero/index.d.ts.map +1 -0
  288. package/dist/Hero/index.js +2 -0
  289. package/dist/Hero/index.js.map +1 -0
  290. package/dist/Icon/Icon.css +57 -0
  291. package/dist/Icon/Icon.d.ts +48 -0
  292. package/dist/Icon/Icon.d.ts.map +1 -0
  293. package/dist/Icon/Icon.js +42 -0
  294. package/dist/Icon/Icon.js.map +1 -0
  295. package/dist/Icon/icon-registry.generated.d.ts +4 -0
  296. package/dist/Icon/icon-registry.generated.d.ts.map +1 -0
  297. package/dist/Icon/icon-registry.generated.js +105 -0
  298. package/dist/Icon/icon-registry.generated.js.map +1 -0
  299. package/dist/Icon/index.d.ts +3 -0
  300. package/dist/Icon/index.d.ts.map +1 -0
  301. package/dist/Icon/index.js +2 -0
  302. package/dist/Icon/index.js.map +1 -0
  303. package/dist/Image/Image.css +123 -0
  304. package/dist/Image/Image.d.ts +54 -0
  305. package/dist/Image/Image.d.ts.map +1 -0
  306. package/dist/Image/Image.js +53 -0
  307. package/dist/Image/Image.js.map +1 -0
  308. package/dist/Image/index.d.ts +3 -0
  309. package/dist/Image/index.d.ts.map +1 -0
  310. package/dist/Image/index.js +2 -0
  311. package/dist/Image/index.js.map +1 -0
  312. package/dist/Link/Link.css +113 -0
  313. package/dist/Link/Link.d.ts +80 -0
  314. package/dist/Link/Link.d.ts.map +1 -0
  315. package/dist/Link/Link.js +58 -0
  316. package/dist/Link/Link.js.map +1 -0
  317. package/dist/Link/index.d.ts +3 -0
  318. package/dist/Link/index.d.ts.map +1 -0
  319. package/dist/Link/index.js +2 -0
  320. package/dist/Link/index.js.map +1 -0
  321. package/dist/LinkButton/LinkButton.css +40 -0
  322. package/dist/LinkButton/LinkButton.d.ts +52 -0
  323. package/dist/LinkButton/LinkButton.d.ts.map +1 -0
  324. package/dist/LinkButton/LinkButton.js +34 -0
  325. package/dist/LinkButton/LinkButton.js.map +1 -0
  326. package/dist/LinkButton/index.d.ts +3 -0
  327. package/dist/LinkButton/index.d.ts.map +1 -0
  328. package/dist/LinkButton/index.js +2 -0
  329. package/dist/LinkButton/index.js.map +1 -0
  330. package/dist/Logo/Logo.css +33 -0
  331. package/dist/Logo/Logo.d.ts +33 -0
  332. package/dist/Logo/Logo.d.ts.map +1 -0
  333. package/dist/Logo/Logo.js +32 -0
  334. package/dist/Logo/Logo.js.map +1 -0
  335. package/dist/Logo/index.d.ts +2 -0
  336. package/dist/Logo/index.d.ts.map +1 -0
  337. package/dist/Logo/index.js +2 -0
  338. package/dist/Logo/index.js.map +1 -0
  339. package/dist/Menu/Menu.css +57 -0
  340. package/dist/Menu/Menu.d.ts +56 -0
  341. package/dist/Menu/Menu.d.ts.map +1 -0
  342. package/dist/Menu/Menu.js +38 -0
  343. package/dist/Menu/Menu.js.map +1 -0
  344. package/dist/Menu/index.d.ts +2 -0
  345. package/dist/Menu/index.d.ts.map +1 -0
  346. package/dist/Menu/index.js +2 -0
  347. package/dist/Menu/index.js.map +1 -0
  348. package/dist/MenuButton/MenuButton.css +106 -0
  349. package/dist/MenuButton/MenuButton.d.ts +54 -0
  350. package/dist/MenuButton/MenuButton.d.ts.map +1 -0
  351. package/dist/MenuButton/MenuButton.js +37 -0
  352. package/dist/MenuButton/MenuButton.js.map +1 -0
  353. package/dist/MenuButton/index.d.ts +2 -0
  354. package/dist/MenuButton/index.d.ts.map +1 -0
  355. package/dist/MenuButton/index.js +2 -0
  356. package/dist/MenuButton/index.js.map +1 -0
  357. package/dist/MenuLink/MenuLink.css +212 -0
  358. package/dist/MenuLink/MenuLink.d.ts +96 -0
  359. package/dist/MenuLink/MenuLink.d.ts.map +1 -0
  360. package/dist/MenuLink/MenuLink.js +50 -0
  361. package/dist/MenuLink/MenuLink.js.map +1 -0
  362. package/dist/MenuLink/index.d.ts +2 -0
  363. package/dist/MenuLink/index.d.ts.map +1 -0
  364. package/dist/MenuLink/index.js +2 -0
  365. package/dist/MenuLink/index.js.map +1 -0
  366. package/dist/ModalDialog/ModalDialog.css +199 -0
  367. package/dist/ModalDialog/ModalDialog.d.ts +95 -0
  368. package/dist/ModalDialog/ModalDialog.d.ts.map +1 -0
  369. package/dist/ModalDialog/ModalDialog.js +93 -0
  370. package/dist/ModalDialog/ModalDialog.js.map +1 -0
  371. package/dist/ModalDialog/index.d.ts +3 -0
  372. package/dist/ModalDialog/index.d.ts.map +1 -0
  373. package/dist/ModalDialog/index.js +2 -0
  374. package/dist/ModalDialog/index.js.map +1 -0
  375. package/dist/Note/Note.css +169 -0
  376. package/dist/Note/Note.d.ts +78 -0
  377. package/dist/Note/Note.d.ts.map +1 -0
  378. package/dist/Note/Note.js +68 -0
  379. package/dist/Note/Note.js.map +1 -0
  380. package/dist/Note/index.d.ts +3 -0
  381. package/dist/Note/index.d.ts.map +1 -0
  382. package/dist/Note/index.js +2 -0
  383. package/dist/Note/index.js.map +1 -0
  384. package/dist/NumberBadge/NumberBadge.css +83 -0
  385. package/dist/NumberBadge/NumberBadge.d.ts +42 -0
  386. package/dist/NumberBadge/NumberBadge.d.ts.map +1 -0
  387. package/dist/NumberBadge/NumberBadge.js +46 -0
  388. package/dist/NumberBadge/NumberBadge.js.map +1 -0
  389. package/dist/NumberBadge/index.d.ts +2 -0
  390. package/dist/NumberBadge/index.d.ts.map +1 -0
  391. package/dist/NumberBadge/index.js +2 -0
  392. package/dist/NumberBadge/index.js.map +1 -0
  393. package/dist/NumberInput/NumberInput.css +4 -0
  394. package/dist/NumberInput/NumberInput.d.ts +45 -0
  395. package/dist/NumberInput/NumberInput.d.ts.map +1 -0
  396. package/dist/NumberInput/NumberInput.js +27 -0
  397. package/dist/NumberInput/NumberInput.js.map +1 -0
  398. package/dist/NumberInput/index.d.ts +3 -0
  399. package/dist/NumberInput/index.d.ts.map +1 -0
  400. package/dist/NumberInput/index.js +2 -0
  401. package/dist/NumberInput/index.js.map +1 -0
  402. package/dist/OptionLabel/OptionLabel.css +18 -0
  403. package/dist/OptionLabel/OptionLabel.d.ts +13 -0
  404. package/dist/OptionLabel/OptionLabel.d.ts.map +1 -0
  405. package/dist/OptionLabel/OptionLabel.js +13 -0
  406. package/dist/OptionLabel/OptionLabel.js.map +1 -0
  407. package/dist/OptionLabel/index.d.ts +3 -0
  408. package/dist/OptionLabel/index.d.ts.map +1 -0
  409. package/dist/OptionLabel/index.js +2 -0
  410. package/dist/OptionLabel/index.js.map +1 -0
  411. package/dist/OrderedList/OrderedList.css +37 -0
  412. package/dist/OrderedList/OrderedList.d.ts +32 -0
  413. package/dist/OrderedList/OrderedList.d.ts.map +1 -0
  414. package/dist/OrderedList/OrderedList.js +28 -0
  415. package/dist/OrderedList/OrderedList.js.map +1 -0
  416. package/dist/OrderedList/index.d.ts +3 -0
  417. package/dist/OrderedList/index.d.ts.map +1 -0
  418. package/dist/OrderedList/index.js +2 -0
  419. package/dist/OrderedList/index.js.map +1 -0
  420. package/dist/PageBody/PageBody.css +69 -0
  421. package/dist/PageBody/PageBody.d.ts +33 -0
  422. package/dist/PageBody/PageBody.d.ts.map +1 -0
  423. package/dist/PageBody/PageBody.js +28 -0
  424. package/dist/PageBody/PageBody.js.map +1 -0
  425. package/dist/PageBody/index.d.ts +2 -0
  426. package/dist/PageBody/index.d.ts.map +1 -0
  427. package/dist/PageBody/index.js +2 -0
  428. package/dist/PageBody/index.js.map +1 -0
  429. package/dist/PageFooter/PageFooter.css +102 -0
  430. package/dist/PageFooter/PageFooter.d.ts +55 -0
  431. package/dist/PageFooter/PageFooter.d.ts.map +1 -0
  432. package/dist/PageFooter/PageFooter.js +45 -0
  433. package/dist/PageFooter/PageFooter.js.map +1 -0
  434. package/dist/PageFooter/index.d.ts +2 -0
  435. package/dist/PageFooter/index.d.ts.map +1 -0
  436. package/dist/PageFooter/index.js +2 -0
  437. package/dist/PageFooter/index.js.map +1 -0
  438. package/dist/PageHeader/PageHeader.css +517 -0
  439. package/dist/PageHeader/PageHeader.d.ts +190 -0
  440. package/dist/PageHeader/PageHeader.d.ts.map +1 -0
  441. package/dist/PageHeader/PageHeader.js +115 -0
  442. package/dist/PageHeader/PageHeader.js.map +1 -0
  443. package/dist/PageHeader/index.d.ts +2 -0
  444. package/dist/PageHeader/index.d.ts.map +1 -0
  445. package/dist/PageHeader/index.js +2 -0
  446. package/dist/PageHeader/index.js.map +1 -0
  447. package/dist/PageLayout/PageLayout.css +6 -0
  448. package/dist/PageLayout/PageLayout.d.ts +38 -0
  449. package/dist/PageLayout/PageLayout.d.ts.map +1 -0
  450. package/dist/PageLayout/PageLayout.js +33 -0
  451. package/dist/PageLayout/PageLayout.js.map +1 -0
  452. package/dist/PageLayout/index.d.ts +2 -0
  453. package/dist/PageLayout/index.d.ts.map +1 -0
  454. package/dist/PageLayout/index.js +2 -0
  455. package/dist/PageLayout/index.js.map +1 -0
  456. package/dist/Paragraph/Paragraph.css +38 -0
  457. package/dist/Paragraph/Paragraph.d.ts +35 -0
  458. package/dist/Paragraph/Paragraph.d.ts.map +1 -0
  459. package/dist/Paragraph/Paragraph.js +25 -0
  460. package/dist/Paragraph/Paragraph.js.map +1 -0
  461. package/dist/Paragraph/index.d.ts +3 -0
  462. package/dist/Paragraph/index.d.ts.map +1 -0
  463. package/dist/Paragraph/index.js +2 -0
  464. package/dist/Paragraph/index.js.map +1 -0
  465. package/dist/PasswordInput/PasswordInput.css +4 -0
  466. package/dist/PasswordInput/PasswordInput.d.ts +52 -0
  467. package/dist/PasswordInput/PasswordInput.d.ts.map +1 -0
  468. package/dist/PasswordInput/PasswordInput.js +32 -0
  469. package/dist/PasswordInput/PasswordInput.js.map +1 -0
  470. package/dist/PasswordInput/index.d.ts +3 -0
  471. package/dist/PasswordInput/index.d.ts.map +1 -0
  472. package/dist/PasswordInput/index.js +2 -0
  473. package/dist/PasswordInput/index.js.map +1 -0
  474. package/dist/Popover/Popover.css +233 -0
  475. package/dist/Popover/Popover.d.ts +117 -0
  476. package/dist/Popover/Popover.d.ts.map +1 -0
  477. package/dist/Popover/Popover.js +219 -0
  478. package/dist/Popover/Popover.js.map +1 -0
  479. package/dist/Popover/index.d.ts +3 -0
  480. package/dist/Popover/index.d.ts.map +1 -0
  481. package/dist/Popover/index.js +2 -0
  482. package/dist/Popover/index.js.map +1 -0
  483. package/dist/ProgressBar/ProgressBar.css +91 -0
  484. package/dist/ProgressBar/ProgressBar.d.ts +53 -0
  485. package/dist/ProgressBar/ProgressBar.d.ts.map +1 -0
  486. package/dist/ProgressBar/ProgressBar.js +36 -0
  487. package/dist/ProgressBar/ProgressBar.js.map +1 -0
  488. package/dist/ProgressBar/index.d.ts +2 -0
  489. package/dist/ProgressBar/index.d.ts.map +1 -0
  490. package/dist/ProgressBar/index.js +2 -0
  491. package/dist/ProgressBar/index.js.map +1 -0
  492. package/dist/Radio/Radio.css +169 -0
  493. package/dist/Radio/Radio.d.ts +14 -0
  494. package/dist/Radio/Radio.d.ts.map +1 -0
  495. package/dist/Radio/Radio.js +14 -0
  496. package/dist/Radio/Radio.js.map +1 -0
  497. package/dist/Radio/index.d.ts +3 -0
  498. package/dist/Radio/index.d.ts.map +1 -0
  499. package/dist/Radio/index.js +2 -0
  500. package/dist/Radio/index.js.map +1 -0
  501. package/dist/RadioGroup/RadioGroup.css +10 -0
  502. package/dist/RadioGroup/RadioGroup.d.ts +37 -0
  503. package/dist/RadioGroup/RadioGroup.d.ts.map +1 -0
  504. package/dist/RadioGroup/RadioGroup.js +37 -0
  505. package/dist/RadioGroup/RadioGroup.js.map +1 -0
  506. package/dist/RadioGroup/index.d.ts +3 -0
  507. package/dist/RadioGroup/index.d.ts.map +1 -0
  508. package/dist/RadioGroup/index.js +2 -0
  509. package/dist/RadioGroup/index.js.map +1 -0
  510. package/dist/RadioOption/RadioOption.css +17 -0
  511. package/dist/RadioOption/RadioOption.d.ts +14 -0
  512. package/dist/RadioOption/RadioOption.d.ts.map +1 -0
  513. package/dist/RadioOption/RadioOption.js +15 -0
  514. package/dist/RadioOption/RadioOption.js.map +1 -0
  515. package/dist/RadioOption/index.d.ts +3 -0
  516. package/dist/RadioOption/index.d.ts.map +1 -0
  517. package/dist/RadioOption/index.js +2 -0
  518. package/dist/RadioOption/index.js.map +1 -0
  519. package/dist/SearchInput/SearchInput.css +59 -0
  520. package/dist/SearchInput/SearchInput.d.ts +40 -0
  521. package/dist/SearchInput/SearchInput.d.ts.map +1 -0
  522. package/dist/SearchInput/SearchInput.js +31 -0
  523. package/dist/SearchInput/SearchInput.js.map +1 -0
  524. package/dist/SearchInput/index.d.ts +3 -0
  525. package/dist/SearchInput/index.d.ts.map +1 -0
  526. package/dist/SearchInput/index.js +2 -0
  527. package/dist/SearchInput/index.js.map +1 -0
  528. package/dist/Select/Select.css +86 -0
  529. package/dist/Select/Select.d.ts +52 -0
  530. package/dist/Select/Select.d.ts.map +1 -0
  531. package/dist/Select/Select.js +43 -0
  532. package/dist/Select/Select.js.map +1 -0
  533. package/dist/Select/index.d.ts +3 -0
  534. package/dist/Select/index.d.ts.map +1 -0
  535. package/dist/Select/index.js +2 -0
  536. package/dist/Select/index.js.map +1 -0
  537. package/dist/SkipLink/SkipLink.css +58 -0
  538. package/dist/SkipLink/SkipLink.d.ts +35 -0
  539. package/dist/SkipLink/SkipLink.d.ts.map +1 -0
  540. package/dist/SkipLink/SkipLink.js +23 -0
  541. package/dist/SkipLink/SkipLink.js.map +1 -0
  542. package/dist/SkipLink/index.d.ts +2 -0
  543. package/dist/SkipLink/index.d.ts.map +1 -0
  544. package/dist/SkipLink/index.js +2 -0
  545. package/dist/SkipLink/index.js.map +1 -0
  546. package/dist/Spinner/Spinner.css +101 -0
  547. package/dist/Spinner/Spinner.d.ts +43 -0
  548. package/dist/Spinner/Spinner.d.ts.map +1 -0
  549. package/dist/Spinner/Spinner.js +30 -0
  550. package/dist/Spinner/Spinner.js.map +1 -0
  551. package/dist/Spinner/index.d.ts +2 -0
  552. package/dist/Spinner/index.d.ts.map +1 -0
  553. package/dist/Spinner/index.js +2 -0
  554. package/dist/Spinner/index.js.map +1 -0
  555. package/dist/Stack/Stack.css +59 -0
  556. package/dist/Stack/Stack.d.ts +35 -0
  557. package/dist/Stack/Stack.d.ts.map +1 -0
  558. package/dist/Stack/Stack.js +29 -0
  559. package/dist/Stack/Stack.js.map +1 -0
  560. package/dist/Stack/index.d.ts +3 -0
  561. package/dist/Stack/index.d.ts.map +1 -0
  562. package/dist/Stack/index.js +2 -0
  563. package/dist/Stack/index.js.map +1 -0
  564. package/dist/StatusBadge/StatusBadge.css +87 -0
  565. package/dist/StatusBadge/StatusBadge.d.ts +50 -0
  566. package/dist/StatusBadge/StatusBadge.d.ts.map +1 -0
  567. package/dist/StatusBadge/StatusBadge.js +40 -0
  568. package/dist/StatusBadge/StatusBadge.js.map +1 -0
  569. package/dist/StatusBadge/index.d.ts +2 -0
  570. package/dist/StatusBadge/index.d.ts.map +1 -0
  571. package/dist/StatusBadge/index.js +2 -0
  572. package/dist/StatusBadge/index.js.map +1 -0
  573. package/dist/SummaryList/SummaryList.css +151 -0
  574. package/dist/SummaryList/SummaryList.d.ts +49 -0
  575. package/dist/SummaryList/SummaryList.d.ts.map +1 -0
  576. package/dist/SummaryList/SummaryList.js +31 -0
  577. package/dist/SummaryList/SummaryList.js.map +1 -0
  578. package/dist/SummaryList/index.d.ts +3 -0
  579. package/dist/SummaryList/index.d.ts.map +1 -0
  580. package/dist/SummaryList/index.js +2 -0
  581. package/dist/SummaryList/index.js.map +1 -0
  582. package/dist/Table/Table.css +243 -0
  583. package/dist/Table/Table.d.ts +61 -0
  584. package/dist/Table/Table.d.ts.map +1 -0
  585. package/dist/Table/Table.js +37 -0
  586. package/dist/Table/Table.js.map +1 -0
  587. package/dist/Table/index.d.ts +3 -0
  588. package/dist/Table/index.d.ts.map +1 -0
  589. package/dist/Table/index.js +2 -0
  590. package/dist/Table/index.js.map +1 -0
  591. package/dist/TelephoneInput/TelephoneInput.css +4 -0
  592. package/dist/TelephoneInput/TelephoneInput.d.ts +38 -0
  593. package/dist/TelephoneInput/TelephoneInput.d.ts.map +1 -0
  594. package/dist/TelephoneInput/TelephoneInput.js +27 -0
  595. package/dist/TelephoneInput/TelephoneInput.js.map +1 -0
  596. package/dist/TelephoneInput/index.d.ts +3 -0
  597. package/dist/TelephoneInput/index.d.ts.map +1 -0
  598. package/dist/TelephoneInput/index.js +2 -0
  599. package/dist/TelephoneInput/index.js.map +1 -0
  600. package/dist/TextArea/TextArea.css +126 -0
  601. package/dist/TextArea/TextArea.d.ts +44 -0
  602. package/dist/TextArea/TextArea.d.ts.map +1 -0
  603. package/dist/TextArea/TextArea.js +33 -0
  604. package/dist/TextArea/TextArea.js.map +1 -0
  605. package/dist/TextArea/index.d.ts +3 -0
  606. package/dist/TextArea/index.d.ts.map +1 -0
  607. package/dist/TextArea/index.js +2 -0
  608. package/dist/TextArea/index.js.map +1 -0
  609. package/dist/TextInput/TextInput.css +122 -0
  610. package/dist/TextInput/TextInput.d.ts +44 -0
  611. package/dist/TextInput/TextInput.d.ts.map +1 -0
  612. package/dist/TextInput/TextInput.js +33 -0
  613. package/dist/TextInput/TextInput.js.map +1 -0
  614. package/dist/TextInput/index.d.ts +3 -0
  615. package/dist/TextInput/index.d.ts.map +1 -0
  616. package/dist/TextInput/index.js +2 -0
  617. package/dist/TextInput/index.js.map +1 -0
  618. package/dist/TimeInput/TimeInput.css +37 -0
  619. package/dist/TimeInput/TimeInput.d.ts +37 -0
  620. package/dist/TimeInput/TimeInput.d.ts.map +1 -0
  621. package/dist/TimeInput/TimeInput.js +52 -0
  622. package/dist/TimeInput/TimeInput.js.map +1 -0
  623. package/dist/TimeInput/index.d.ts +3 -0
  624. package/dist/TimeInput/index.d.ts.map +1 -0
  625. package/dist/TimeInput/index.js +2 -0
  626. package/dist/TimeInput/index.js.map +1 -0
  627. package/dist/UnorderedList/UnorderedList.css +38 -0
  628. package/dist/UnorderedList/UnorderedList.d.ts +26 -0
  629. package/dist/UnorderedList/UnorderedList.d.ts.map +1 -0
  630. package/dist/UnorderedList/UnorderedList.js +22 -0
  631. package/dist/UnorderedList/UnorderedList.js.map +1 -0
  632. package/dist/UnorderedList/index.d.ts +3 -0
  633. package/dist/UnorderedList/index.d.ts.map +1 -0
  634. package/dist/UnorderedList/index.js +2 -0
  635. package/dist/UnorderedList/index.js.map +1 -0
  636. package/dist/index.css +7036 -0
  637. package/dist/index.d.ts +76 -0
  638. package/dist/index.d.ts.map +1 -0
  639. package/dist/index.js +86 -0
  640. package/dist/index.js.map +1 -0
  641. package/package.json +57 -0
@@ -0,0 +1,42 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { classNames } from '@dsn-starter-kit/core';
4
+ import { iconMap } from './icon-registry.generated';
5
+ import './Icon.css';
6
+ export { iconMap };
7
+ /**
8
+ * Icon component using individual Tabler Icon SVG imports
9
+ * Only icons you use will be included in your bundle (tree-shaking)
10
+ *
11
+ * @example
12
+ * ```tsx
13
+ * // Decorative icon (no label needed)
14
+ * <Icon name="check" size="md" />
15
+ *
16
+ * // Standalone icon (needs label)
17
+ * <Icon name="settings" size="lg" aria-label="Open settings" />
18
+ *
19
+ * // Icon with text (mark as decorative)
20
+ * <span>
21
+ * <Icon name="check" size="sm" />
22
+ * Task complete
23
+ * </span>
24
+ * ```
25
+ */
26
+ export const Icon = React.forwardRef(({ name, size = 'md', className, 'aria-label': ariaLabel, ...props }, ref) => {
27
+ const IconComponent = iconMap[name];
28
+ if (!IconComponent) {
29
+ if (process.env.NODE_ENV !== 'production') {
30
+ console.warn(`[DSN Icon] Icon "${name}" not found. Available icons: ${Object.keys(iconMap).join(', ')}`);
31
+ }
32
+ return null;
33
+ }
34
+ const classes = classNames('dsn-icon', size !== 'md' && `dsn-icon--${size}`, className);
35
+ // If no aria-label is provided, mark as decorative
36
+ const ariaProps = ariaLabel
37
+ ? { 'aria-label': ariaLabel, role: 'img' }
38
+ : { 'aria-hidden': true };
39
+ return (_jsx(IconComponent, { ref: ref, className: classes, ...ariaProps, ...props }));
40
+ });
41
+ Icon.displayName = 'Icon';
42
+ //# sourceMappingURL=Icon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Icon.js","sourceRoot":"","sources":["../../src/Icon/Icon.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAGpD,OAAO,YAAY,CAAC;AAGpB,OAAO,EAAE,OAAO,EAAE,CAAC;AA8BnB;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,CAClC,CACE,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EACnE,GAAG,EACH,EAAE;IACF,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,EAAE,CAAC;YAC1C,OAAO,CAAC,IAAI,CACV,oBAAoB,IAAI,iCAAiC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC3F,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,OAAO,GAAG,UAAU,CACxB,UAAU,EACV,IAAI,KAAK,IAAI,IAAI,aAAa,IAAI,EAAE,EACpC,SAAS,CACV,CAAC;IAEF,mDAAmD;IACnD,MAAM,SAAS,GAAG,SAAS;QACzB,CAAC,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE;QAC1C,CAAC,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;IAE5B,OAAO,CACL,KAAC,aAAa,IAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,OAAO,KAAM,SAAS,KAAM,KAAK,GAAI,CAC1E,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ export type IconName = 'alert-triangle' | 'archive' | 'arrow-down' | 'arrow-left' | 'arrow-narrow-down' | 'arrow-narrow-up' | 'arrow-right' | 'arrow-up' | 'arrows-sort' | 'bell' | 'calendar-event' | 'check' | 'chevron-down' | 'chevron-left' | 'chevron-right' | 'chevron-up' | 'circle-check' | 'clock' | 'dots-vertical' | 'download' | 'edit' | 'exclamation-circle' | 'external-link' | 'eye' | 'file-description' | 'folder' | 'heart-filled' | 'heart' | 'home' | 'info-circle' | 'loader' | 'mail' | 'menu' | 'message-circle' | 'minus' | 'paperclip' | 'pencil' | 'photo' | 'plus' | 'printer' | 'search' | 'selector' | 'settings' | 'sort-ascending' | 'sort-descending' | 'star-filled' | 'star' | 'trash' | 'upload' | 'user' | 'x';
3
+ export declare const iconMap: Record<IconName, React.FC<React.SVGProps<SVGSVGElement>>>;
4
+ //# sourceMappingURL=icon-registry.generated.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icon-registry.generated.d.ts","sourceRoot":"","sources":["../../src/Icon/icon-registry.generated.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAsD1B,MAAM,MAAM,QAAQ,GAChB,gBAAgB,GAChB,SAAS,GACT,YAAY,GACZ,YAAY,GACZ,mBAAmB,GACnB,iBAAiB,GACjB,aAAa,GACb,UAAU,GACV,aAAa,GACb,MAAM,GACN,gBAAgB,GAChB,OAAO,GACP,cAAc,GACd,cAAc,GACd,eAAe,GACf,YAAY,GACZ,cAAc,GACd,OAAO,GACP,eAAe,GACf,UAAU,GACV,MAAM,GACN,oBAAoB,GACpB,eAAe,GACf,KAAK,GACL,kBAAkB,GAClB,QAAQ,GACR,cAAc,GACd,OAAO,GACP,MAAM,GACN,aAAa,GACb,QAAQ,GACR,MAAM,GACN,MAAM,GACN,gBAAgB,GAChB,OAAO,GACP,WAAW,GACX,QAAQ,GACR,OAAO,GACP,MAAM,GACN,SAAS,GACT,QAAQ,GACR,UAAU,GACV,UAAU,GACV,gBAAgB,GAChB,iBAAiB,GACjB,aAAa,GACb,MAAM,GACN,OAAO,GACP,QAAQ,GACR,MAAM,GACN,GAAG,CAAC;AAER,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAoD7E,CAAC"}
@@ -0,0 +1,105 @@
1
+ import AlertTriangleIcon from '../../../components-html/assets/icons/alert-triangle.svg?react';
2
+ import ArchiveIcon from '../../../components-html/assets/icons/archive.svg?react';
3
+ import ArrowDownIcon from '../../../components-html/assets/icons/arrow-down.svg?react';
4
+ import ArrowLeftIcon from '../../../components-html/assets/icons/arrow-left.svg?react';
5
+ import ArrowNarrowDownIcon from '../../../components-html/assets/icons/arrow-narrow-down.svg?react';
6
+ import ArrowNarrowUpIcon from '../../../components-html/assets/icons/arrow-narrow-up.svg?react';
7
+ import ArrowRightIcon from '../../../components-html/assets/icons/arrow-right.svg?react';
8
+ import ArrowUpIcon from '../../../components-html/assets/icons/arrow-up.svg?react';
9
+ import ArrowsSortIcon from '../../../components-html/assets/icons/arrows-sort.svg?react';
10
+ import BellIcon from '../../../components-html/assets/icons/bell.svg?react';
11
+ import CalendarEventIcon from '../../../components-html/assets/icons/calendar-event.svg?react';
12
+ import CheckIcon from '../../../components-html/assets/icons/check.svg?react';
13
+ import ChevronDownIcon from '../../../components-html/assets/icons/chevron-down.svg?react';
14
+ import ChevronLeftIcon from '../../../components-html/assets/icons/chevron-left.svg?react';
15
+ import ChevronRightIcon from '../../../components-html/assets/icons/chevron-right.svg?react';
16
+ import ChevronUpIcon from '../../../components-html/assets/icons/chevron-up.svg?react';
17
+ import CircleCheckIcon from '../../../components-html/assets/icons/circle-check.svg?react';
18
+ import ClockIcon from '../../../components-html/assets/icons/clock.svg?react';
19
+ import DotsVerticalIcon from '../../../components-html/assets/icons/dots-vertical.svg?react';
20
+ import DownloadIcon from '../../../components-html/assets/icons/download.svg?react';
21
+ import EditIcon from '../../../components-html/assets/icons/edit.svg?react';
22
+ import ExclamationCircleIcon from '../../../components-html/assets/icons/exclamation-circle.svg?react';
23
+ import ExternalLinkIcon from '../../../components-html/assets/icons/external-link.svg?react';
24
+ import EyeIcon from '../../../components-html/assets/icons/eye.svg?react';
25
+ import FileDescriptionIcon from '../../../components-html/assets/icons/file-description.svg?react';
26
+ import FolderIcon from '../../../components-html/assets/icons/folder.svg?react';
27
+ import HeartFilledIcon from '../../../components-html/assets/icons/heart-filled.svg?react';
28
+ import HeartIcon from '../../../components-html/assets/icons/heart.svg?react';
29
+ import HomeIcon from '../../../components-html/assets/icons/home.svg?react';
30
+ import InfoCircleIcon from '../../../components-html/assets/icons/info-circle.svg?react';
31
+ import LoaderIcon from '../../../components-html/assets/icons/loader.svg?react';
32
+ import MailIcon from '../../../components-html/assets/icons/mail.svg?react';
33
+ import MenuIcon from '../../../components-html/assets/icons/menu.svg?react';
34
+ import MessageCircleIcon from '../../../components-html/assets/icons/message-circle.svg?react';
35
+ import MinusIcon from '../../../components-html/assets/icons/minus.svg?react';
36
+ import PaperclipIcon from '../../../components-html/assets/icons/paperclip.svg?react';
37
+ import PencilIcon from '../../../components-html/assets/icons/pencil.svg?react';
38
+ import PhotoIcon from '../../../components-html/assets/icons/photo.svg?react';
39
+ import PlusIcon from '../../../components-html/assets/icons/plus.svg?react';
40
+ import PrinterIcon from '../../../components-html/assets/icons/printer.svg?react';
41
+ import SearchIcon from '../../../components-html/assets/icons/search.svg?react';
42
+ import SelectorIcon from '../../../components-html/assets/icons/selector.svg?react';
43
+ import SettingsIcon from '../../../components-html/assets/icons/settings.svg?react';
44
+ import SortAscendingIcon from '../../../components-html/assets/icons/sort-ascending.svg?react';
45
+ import SortDescendingIcon from '../../../components-html/assets/icons/sort-descending.svg?react';
46
+ import StarFilledIcon from '../../../components-html/assets/icons/star-filled.svg?react';
47
+ import StarIcon from '../../../components-html/assets/icons/star.svg?react';
48
+ import TrashIcon from '../../../components-html/assets/icons/trash.svg?react';
49
+ import UploadIcon from '../../../components-html/assets/icons/upload.svg?react';
50
+ import UserIcon from '../../../components-html/assets/icons/user.svg?react';
51
+ import XIcon from '../../../components-html/assets/icons/x.svg?react';
52
+ export const iconMap = {
53
+ 'alert-triangle': AlertTriangleIcon,
54
+ 'archive': ArchiveIcon,
55
+ 'arrow-down': ArrowDownIcon,
56
+ 'arrow-left': ArrowLeftIcon,
57
+ 'arrow-narrow-down': ArrowNarrowDownIcon,
58
+ 'arrow-narrow-up': ArrowNarrowUpIcon,
59
+ 'arrow-right': ArrowRightIcon,
60
+ 'arrow-up': ArrowUpIcon,
61
+ 'arrows-sort': ArrowsSortIcon,
62
+ 'bell': BellIcon,
63
+ 'calendar-event': CalendarEventIcon,
64
+ 'check': CheckIcon,
65
+ 'chevron-down': ChevronDownIcon,
66
+ 'chevron-left': ChevronLeftIcon,
67
+ 'chevron-right': ChevronRightIcon,
68
+ 'chevron-up': ChevronUpIcon,
69
+ 'circle-check': CircleCheckIcon,
70
+ 'clock': ClockIcon,
71
+ 'dots-vertical': DotsVerticalIcon,
72
+ 'download': DownloadIcon,
73
+ 'edit': EditIcon,
74
+ 'exclamation-circle': ExclamationCircleIcon,
75
+ 'external-link': ExternalLinkIcon,
76
+ 'eye': EyeIcon,
77
+ 'file-description': FileDescriptionIcon,
78
+ 'folder': FolderIcon,
79
+ 'heart-filled': HeartFilledIcon,
80
+ 'heart': HeartIcon,
81
+ 'home': HomeIcon,
82
+ 'info-circle': InfoCircleIcon,
83
+ 'loader': LoaderIcon,
84
+ 'mail': MailIcon,
85
+ 'menu': MenuIcon,
86
+ 'message-circle': MessageCircleIcon,
87
+ 'minus': MinusIcon,
88
+ 'paperclip': PaperclipIcon,
89
+ 'pencil': PencilIcon,
90
+ 'photo': PhotoIcon,
91
+ 'plus': PlusIcon,
92
+ 'printer': PrinterIcon,
93
+ 'search': SearchIcon,
94
+ 'selector': SelectorIcon,
95
+ 'settings': SettingsIcon,
96
+ 'sort-ascending': SortAscendingIcon,
97
+ 'sort-descending': SortDescendingIcon,
98
+ 'star-filled': StarFilledIcon,
99
+ 'star': StarIcon,
100
+ 'trash': TrashIcon,
101
+ 'upload': UploadIcon,
102
+ 'user': UserIcon,
103
+ 'x': XIcon,
104
+ };
105
+ //# sourceMappingURL=icon-registry.generated.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icon-registry.generated.js","sourceRoot":"","sources":["../../src/Icon/icon-registry.generated.ts"],"names":[],"mappings":"AAIA,OAAO,iBAAiB,MAAM,gEAAgE,CAAC;AAC/F,OAAO,WAAW,MAAM,yDAAyD,CAAC;AAClF,OAAO,aAAa,MAAM,4DAA4D,CAAC;AACvF,OAAO,aAAa,MAAM,4DAA4D,CAAC;AACvF,OAAO,mBAAmB,MAAM,mEAAmE,CAAC;AACpG,OAAO,iBAAiB,MAAM,iEAAiE,CAAC;AAChG,OAAO,cAAc,MAAM,6DAA6D,CAAC;AACzF,OAAO,WAAW,MAAM,0DAA0D,CAAC;AACnF,OAAO,cAAc,MAAM,6DAA6D,CAAC;AACzF,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,iBAAiB,MAAM,gEAAgE,CAAC;AAC/F,OAAO,SAAS,MAAM,uDAAuD,CAAC;AAC9E,OAAO,eAAe,MAAM,8DAA8D,CAAC;AAC3F,OAAO,eAAe,MAAM,8DAA8D,CAAC;AAC3F,OAAO,gBAAgB,MAAM,+DAA+D,CAAC;AAC7F,OAAO,aAAa,MAAM,4DAA4D,CAAC;AACvF,OAAO,eAAe,MAAM,8DAA8D,CAAC;AAC3F,OAAO,SAAS,MAAM,uDAAuD,CAAC;AAC9E,OAAO,gBAAgB,MAAM,+DAA+D,CAAC;AAC7F,OAAO,YAAY,MAAM,0DAA0D,CAAC;AACpF,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,qBAAqB,MAAM,oEAAoE,CAAC;AACvG,OAAO,gBAAgB,MAAM,+DAA+D,CAAC;AAC7F,OAAO,OAAO,MAAM,qDAAqD,CAAC;AAC1E,OAAO,mBAAmB,MAAM,kEAAkE,CAAC;AACnG,OAAO,UAAU,MAAM,wDAAwD,CAAC;AAChF,OAAO,eAAe,MAAM,8DAA8D,CAAC;AAC3F,OAAO,SAAS,MAAM,uDAAuD,CAAC;AAC9E,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,cAAc,MAAM,6DAA6D,CAAC;AACzF,OAAO,UAAU,MAAM,wDAAwD,CAAC;AAChF,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,iBAAiB,MAAM,gEAAgE,CAAC;AAC/F,OAAO,SAAS,MAAM,uDAAuD,CAAC;AAC9E,OAAO,aAAa,MAAM,2DAA2D,CAAC;AACtF,OAAO,UAAU,MAAM,wDAAwD,CAAC;AAChF,OAAO,SAAS,MAAM,uDAAuD,CAAC;AAC9E,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,WAAW,MAAM,yDAAyD,CAAC;AAClF,OAAO,UAAU,MAAM,wDAAwD,CAAC;AAChF,OAAO,YAAY,MAAM,0DAA0D,CAAC;AACpF,OAAO,YAAY,MAAM,0DAA0D,CAAC;AACpF,OAAO,iBAAiB,MAAM,gEAAgE,CAAC;AAC/F,OAAO,kBAAkB,MAAM,iEAAiE,CAAC;AACjG,OAAO,cAAc,MAAM,6DAA6D,CAAC;AACzF,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,SAAS,MAAM,uDAAuD,CAAC;AAC9E,OAAO,UAAU,MAAM,wDAAwD,CAAC;AAChF,OAAO,QAAQ,MAAM,sDAAsD,CAAC;AAC5E,OAAO,KAAK,MAAM,mDAAmD,CAAC;AAuDtE,MAAM,CAAC,MAAM,OAAO,GAA8D;IAChF,gBAAgB,EAAE,iBAAiB;IACnC,SAAS,EAAE,WAAW;IACtB,YAAY,EAAE,aAAa;IAC3B,YAAY,EAAE,aAAa;IAC3B,mBAAmB,EAAE,mBAAmB;IACxC,iBAAiB,EAAE,iBAAiB;IACpC,aAAa,EAAE,cAAc;IAC7B,UAAU,EAAE,WAAW;IACvB,aAAa,EAAE,cAAc;IAC7B,MAAM,EAAE,QAAQ;IAChB,gBAAgB,EAAE,iBAAiB;IACnC,OAAO,EAAE,SAAS;IAClB,cAAc,EAAE,eAAe;IAC/B,cAAc,EAAE,eAAe;IAC/B,eAAe,EAAE,gBAAgB;IACjC,YAAY,EAAE,aAAa;IAC3B,cAAc,EAAE,eAAe;IAC/B,OAAO,EAAE,SAAS;IAClB,eAAe,EAAE,gBAAgB;IACjC,UAAU,EAAE,YAAY;IACxB,MAAM,EAAE,QAAQ;IAChB,oBAAoB,EAAE,qBAAqB;IAC3C,eAAe,EAAE,gBAAgB;IACjC,KAAK,EAAE,OAAO;IACd,kBAAkB,EAAE,mBAAmB;IACvC,QAAQ,EAAE,UAAU;IACpB,cAAc,EAAE,eAAe;IAC/B,OAAO,EAAE,SAAS;IAClB,MAAM,EAAE,QAAQ;IAChB,aAAa,EAAE,cAAc;IAC7B,QAAQ,EAAE,UAAU;IACpB,MAAM,EAAE,QAAQ;IAChB,MAAM,EAAE,QAAQ;IAChB,gBAAgB,EAAE,iBAAiB;IACnC,OAAO,EAAE,SAAS;IAClB,WAAW,EAAE,aAAa;IAC1B,QAAQ,EAAE,UAAU;IACpB,OAAO,EAAE,SAAS;IAClB,MAAM,EAAE,QAAQ;IAChB,SAAS,EAAE,WAAW;IACtB,QAAQ,EAAE,UAAU;IACpB,UAAU,EAAE,YAAY;IACxB,UAAU,EAAE,YAAY;IACxB,gBAAgB,EAAE,iBAAiB;IACnC,iBAAiB,EAAE,kBAAkB;IACrC,aAAa,EAAE,cAAc;IAC7B,MAAM,EAAE,QAAQ;IAChB,OAAO,EAAE,SAAS;IAClB,QAAQ,EAAE,UAAU;IACpB,MAAM,EAAE,QAAQ;IAChB,GAAG,EAAE,KAAK;CACX,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { Icon, iconMap } from './Icon';
2
+ export type { IconProps, IconName, IconSize } from './Icon';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Icon/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACvC,YAAY,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { Icon, iconMap } from './Icon';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Icon/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,123 @@
1
+ /**
2
+ * Image component styles for React
3
+ * Re-exports the base Image styles from components-html
4
+ */
5
+
6
+ /**
7
+ * Image Component
8
+ * Performante, toegankelijke wrapper rond het native <img> element.
9
+ * Ondersteunt vaste beeldverhoudingen, lazy loading en optioneel bijschrift.
10
+ *
11
+ * Usage:
12
+ * <!-- Basis -->
13
+ * <figure class="dsn-image">
14
+ * <img
15
+ * class="dsn-image__img"
16
+ * src="afbeelding.jpg"
17
+ * alt="Beschrijving van de afbeelding"
18
+ * width="800"
19
+ * height="600"
20
+ * loading="lazy"
21
+ * decoding="async"
22
+ * />
23
+ * </figure>
24
+ *
25
+ * <!-- Met vaste beeldverhouding -->
26
+ * <figure class="dsn-image dsn-image--ratio-16-9">
27
+ * <img
28
+ * class="dsn-image__img"
29
+ * src="hero.jpg"
30
+ * alt="Beschrijving"
31
+ * width="1600"
32
+ * height="900"
33
+ * loading="lazy"
34
+ * decoding="async"
35
+ * />
36
+ * </figure>
37
+ *
38
+ * <!-- Met bijschrift -->
39
+ * <figure class="dsn-image">
40
+ * <img
41
+ * class="dsn-image__img"
42
+ * src="foto.jpg"
43
+ * alt="Beschrijving van de foto"
44
+ * width="800"
45
+ * height="600"
46
+ * loading="lazy"
47
+ * decoding="async"
48
+ * />
49
+ * <figcaption class="dsn-image__caption">Bijschrift bij de afbeelding</figcaption>
50
+ * </figure>
51
+ *
52
+ * <!-- Decoratief (aria-hidden op figure) -->
53
+ * <figure class="dsn-image" aria-hidden="true">
54
+ * <img
55
+ * class="dsn-image__img"
56
+ * src="decoratief.jpg"
57
+ * alt=""
58
+ * width="800"
59
+ * height="600"
60
+ * loading="lazy"
61
+ * decoding="async"
62
+ * />
63
+ * </figure>
64
+ */
65
+
66
+ /* ===========================
67
+ Root container
68
+ =========================== */
69
+ .dsn-image {
70
+ display: block;
71
+ margin: 0;
72
+ }
73
+
74
+ /* ===========================
75
+ Image element
76
+ =========================== */
77
+ .dsn-image__img {
78
+ display: block;
79
+ width: 100%;
80
+ height: auto;
81
+ object-fit: cover;
82
+ border-radius: var(--dsn-image-border-radius);
83
+ }
84
+
85
+ /* ===========================
86
+ Aspect ratio modifiers
87
+ Aspect-ratio forceert de weergaveverhouding;
88
+ object-fit: cover snijdt de rest bij.
89
+ =========================== */
90
+ .dsn-image--ratio-16-9 .dsn-image__img {
91
+ aspect-ratio: 16 / 9;
92
+ height: 100%;
93
+ }
94
+
95
+ .dsn-image--ratio-4-3 .dsn-image__img {
96
+ aspect-ratio: 4 / 3;
97
+ height: 100%;
98
+ }
99
+
100
+ .dsn-image--ratio-1-1 .dsn-image__img {
101
+ aspect-ratio: 1 / 1;
102
+ height: 100%;
103
+ }
104
+
105
+ /* ===========================
106
+ Object-fit: contain modifier
107
+ Toont de volledige afbeelding zonder bijsnijden.
108
+ =========================== */
109
+ .dsn-image--object-fit-contain .dsn-image__img {
110
+ object-fit: contain;
111
+ }
112
+
113
+ /* ===========================
114
+ Caption
115
+ =========================== */
116
+ .dsn-image__caption {
117
+ display: block;
118
+ margin-block-start: var(--dsn-image-caption-margin-block-start);
119
+ color: var(--dsn-image-caption-color);
120
+ font-size: var(--dsn-image-caption-font-size);
121
+ line-height: var(--dsn-image-caption-line-height);
122
+ }
123
+
@@ -0,0 +1,54 @@
1
+ import React from 'react';
2
+ import './Image.css';
3
+ export interface ImageProps extends React.HTMLAttributes<HTMLElement> {
4
+ /** Verplicht. URL van de afbeelding */
5
+ src: string;
6
+ /** Verplicht. Alternatieve tekst. Lege string (`""`) voor decoratieve afbeeldingen — activeert automatisch `aria-hidden="true"` op de figure */
7
+ alt: string;
8
+ /** Verplicht. Intrinsieke breedte in pixels (voorkomt CLS) */
9
+ width: number;
10
+ /** Verplicht. Intrinsieke hoogte in pixels (voorkomt CLS) */
11
+ height: number;
12
+ /** Forceert beeldverhouding via CSS `aspect-ratio` + `object-fit: cover` */
13
+ ratio?: '16:9' | '4:3' | '1:1';
14
+ /** Hoe de afbeelding het ratio-kader vult. @default 'cover' */
15
+ objectFit?: 'cover' | 'contain';
16
+ /**
17
+ * LCP-modus: `loading="eager"` + `fetchpriority="high"`.
18
+ * Gebruik maximaal één keer per pagina voor de primaire LCP-afbeelding.
19
+ * @default false
20
+ */
21
+ priority?: boolean;
22
+ /** Optioneel bijschrift, rendert als `<figcaption>` */
23
+ caption?: React.ReactNode;
24
+ /** Pass-through naar native `srcset` attribuut */
25
+ srcSet?: string;
26
+ /** Pass-through naar native `sizes` attribuut */
27
+ sizes?: string;
28
+ }
29
+ /**
30
+ * Image component
31
+ * Performante, toegankelijke wrapper rond het native `<img>` element.
32
+ * Biedt ingebakken lazy loading, expliciete ondersteuning voor LCP/hero-afbeeldingen
33
+ * via een `priority` prop, en vaste beeldverhoudingen via de CSS `aspect-ratio` property.
34
+ *
35
+ * @example
36
+ * ```tsx
37
+ * // Basis
38
+ * <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} />
39
+ *
40
+ * // Met vaste beeldverhouding
41
+ * <Image src="/hero.jpg" alt="Hero" width={1600} height={900} ratio="16:9" />
42
+ *
43
+ * // LCP / hero-afbeelding — max. één keer per pagina
44
+ * <Image src="/hero.jpg" alt="Pagina hero" width={1600} height={900} ratio="16:9" priority />
45
+ *
46
+ * // Met bijschrift
47
+ * <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} caption="Bijschrift" />
48
+ *
49
+ * // Decoratief — alt="" activeert automatisch aria-hidden="true" op de figure
50
+ * <Image src="/decoratief.jpg" alt="" width={800} height={600} />
51
+ * ```
52
+ */
53
+ export declare const Image: React.ForwardRefExoticComponent<ImageProps & React.RefAttributes<HTMLElement>>;
54
+ //# sourceMappingURL=Image.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Image.d.ts","sourceRoot":"","sources":["../../src/Image/Image.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,aAAa,CAAC;AAQrB,MAAM,WAAW,UAAW,SAAQ,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;IACnE,uCAAuC;IACvC,GAAG,EAAE,MAAM,CAAC;IAEZ,gJAAgJ;IAChJ,GAAG,EAAE,MAAM,CAAC;IAEZ,8DAA8D;IAC9D,KAAK,EAAE,MAAM,CAAC;IAEd,6DAA6D;IAC7D,MAAM,EAAE,MAAM,CAAC;IAEf,4EAA4E;IAC5E,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,GAAG,KAAK,CAAC;IAE/B,+DAA+D;IAC/D,SAAS,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IAEhC;;;;OAIG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB,uDAAuD;IACvD,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE1B,kDAAkD;IAClD,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,iDAAiD;IACjD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAQD;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,eAAO,MAAM,KAAK,gFAuDjB,CAAC"}
@@ -0,0 +1,53 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { classNames } from '@dsn-starter-kit/core';
4
+ import './Image.css';
5
+ const ratioClassMap = {
6
+ '16:9': 'dsn-image--ratio-16-9',
7
+ '4:3': 'dsn-image--ratio-4-3',
8
+ '1:1': 'dsn-image--ratio-1-1',
9
+ };
10
+ /**
11
+ * Image component
12
+ * Performante, toegankelijke wrapper rond het native `<img>` element.
13
+ * Biedt ingebakken lazy loading, expliciete ondersteuning voor LCP/hero-afbeeldingen
14
+ * via een `priority` prop, en vaste beeldverhoudingen via de CSS `aspect-ratio` property.
15
+ *
16
+ * @example
17
+ * ```tsx
18
+ * // Basis
19
+ * <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} />
20
+ *
21
+ * // Met vaste beeldverhouding
22
+ * <Image src="/hero.jpg" alt="Hero" width={1600} height={900} ratio="16:9" />
23
+ *
24
+ * // LCP / hero-afbeelding — max. één keer per pagina
25
+ * <Image src="/hero.jpg" alt="Pagina hero" width={1600} height={900} ratio="16:9" priority />
26
+ *
27
+ * // Met bijschrift
28
+ * <Image src="/foto.jpg" alt="Beschrijving" width={800} height={600} caption="Bijschrift" />
29
+ *
30
+ * // Decoratief — alt="" activeert automatisch aria-hidden="true" op de figure
31
+ * <Image src="/decoratief.jpg" alt="" width={800} height={600} />
32
+ * ```
33
+ */
34
+ export const Image = React.forwardRef(({ className, src, alt, width, height, ratio, objectFit = 'cover', priority = false, caption, srcSet, sizes, ...props }, ref) => {
35
+ const isDecorative = alt === '';
36
+ const figureClasses = classNames('dsn-image', ratio && ratioClassMap[ratio], objectFit === 'contain' && 'dsn-image--object-fit-contain', className);
37
+ const imgProps = {
38
+ className: 'dsn-image__img',
39
+ src,
40
+ alt,
41
+ width,
42
+ height,
43
+ decoding: 'async',
44
+ ...(priority
45
+ ? { loading: 'eager', fetchpriority: 'high' }
46
+ : { loading: 'lazy' }),
47
+ ...(srcSet && { srcSet }),
48
+ ...(sizes && { sizes }),
49
+ };
50
+ return (_jsxs("figure", { ref: ref, className: figureClasses, ...(isDecorative && { 'aria-hidden': true }), ...props, children: [_jsx("img", { ...imgProps }), caption && (_jsx("figcaption", { className: "dsn-image__caption", children: caption }))] }));
51
+ });
52
+ Image.displayName = 'Image';
53
+ //# sourceMappingURL=Image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Image.js","sourceRoot":"","sources":["../../src/Image/Image.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,aAAa,CAAC;AA4CrB,MAAM,aAAa,GAAqD;IACtE,MAAM,EAAE,uBAAuB;IAC/B,KAAK,EAAE,sBAAsB;IAC7B,KAAK,EAAE,sBAAsB;CAC9B,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CACnC,CACE,EACE,SAAS,EACT,GAAG,EACH,GAAG,EACH,KAAK,EACL,MAAM,EACN,KAAK,EACL,SAAS,GAAG,OAAO,EACnB,QAAQ,GAAG,KAAK,EAChB,OAAO,EACP,MAAM,EACN,KAAK,EACL,GAAG,KAAK,EACT,EACD,GAAG,EACH,EAAE;IACF,MAAM,YAAY,GAAG,GAAG,KAAK,EAAE,CAAC;IAEhC,MAAM,aAAa,GAAG,UAAU,CAC9B,WAAW,EACX,KAAK,IAAI,aAAa,CAAC,KAAK,CAAC,EAC7B,SAAS,KAAK,SAAS,IAAI,+BAA+B,EAC1D,SAAS,CACV,CAAC;IAEF,MAAM,QAAQ,GAAa;QACzB,SAAS,EAAE,gBAAgB;QAC3B,GAAG;QACH,GAAG;QACH,KAAK;QACL,MAAM;QACN,QAAQ,EAAE,OAAO;QACjB,GAAG,CAAC,QAAQ;YACV,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE;YAC7C,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QACxB,GAAG,CAAC,MAAM,IAAI,EAAE,MAAM,EAAE,CAAC;QACzB,GAAG,CAAC,KAAK,IAAI,EAAE,KAAK,EAAE,CAAC;KACxB,CAAC;IAEF,OAAO,CACL,kBACE,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,aAAa,KACpB,CAAC,YAAY,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,KACzC,KAAK,aAET,iBAAS,QAAQ,GAAI,EACpB,OAAO,IAAI,CACV,qBAAY,SAAS,EAAC,oBAAoB,YAAE,OAAO,GAAc,CAClE,IACM,CACV,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { Image } from './Image';
2
+ export type { ImageProps } from './Image';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Image/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { Image } from './Image';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Image/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC"}
@@ -0,0 +1,113 @@
1
+ /**
2
+ * Link Component Styles for React
3
+ * Re-exports the base Link styles from components-html
4
+ */
5
+
6
+ /**
7
+ * Link Component
8
+ * Uses component tokens for consistent styling
9
+ */
10
+
11
+ .dsn-link {
12
+ /* Layout */
13
+ display: inline-flex;
14
+ align-self: flex-start;
15
+ align-items: center;
16
+ gap: var(--dsn-link-gap);
17
+ position: relative; /* Ankerpunt voor DotBadge */
18
+
19
+ /* Typography */
20
+ color: var(--dsn-link-color);
21
+ text-decoration-line: var(--dsn-link-text-decoration-line);
22
+ text-decoration-color: var(--dsn-link-text-decoration-color);
23
+ text-decoration-thickness: var(--dsn-link-text-decoration-thickness);
24
+ text-underline-offset: var(--dsn-link-text-underline-offset);
25
+ font: inherit;
26
+
27
+ /* Interaction */
28
+ cursor: pointer;
29
+ transition:
30
+ color var(--dsn-transition-duration-normal)
31
+ var(--dsn-transition-easing-default),
32
+ text-decoration-color var(--dsn-transition-duration-normal)
33
+ var(--dsn-transition-easing-default);
34
+ }
35
+
36
+ /* Icon sizing */
37
+ .dsn-link > .dsn-icon {
38
+ width: var(--dsn-link-icon-size);
39
+ height: var(--dsn-link-icon-size);
40
+ flex-shrink: 0;
41
+ }
42
+
43
+ /* Size Variants */
44
+ .dsn-link--size-small {
45
+ font-size: var(--dsn-link-size-small-font-size);
46
+ gap: var(--dsn-link-size-small-gap);
47
+ }
48
+
49
+ .dsn-link--size-default {
50
+ font-size: var(--dsn-link-size-default-font-size);
51
+ gap: var(--dsn-link-size-default-gap);
52
+ }
53
+
54
+ .dsn-link--size-large {
55
+ font-size: var(--dsn-link-size-large-font-size);
56
+ gap: var(--dsn-link-size-large-gap);
57
+ }
58
+
59
+ /* Icon sizing per link size */
60
+ .dsn-link--size-small > .dsn-icon {
61
+ width: var(--dsn-link-size-small-icon-size);
62
+ height: var(--dsn-link-size-small-icon-size);
63
+ }
64
+
65
+ .dsn-link--size-default > .dsn-icon {
66
+ width: var(--dsn-link-size-default-icon-size);
67
+ height: var(--dsn-link-size-default-icon-size);
68
+ }
69
+
70
+ .dsn-link--size-large > .dsn-icon {
71
+ width: var(--dsn-link-size-large-icon-size);
72
+ height: var(--dsn-link-size-large-icon-size);
73
+ }
74
+
75
+ /* Hover */
76
+ .dsn-link:hover:not([aria-disabled='true']) {
77
+ color: var(--dsn-link-hover-color);
78
+ text-decoration-line: var(--dsn-link-hover-text-decoration-line);
79
+ }
80
+
81
+ /* Active */
82
+ .dsn-link:active:not([aria-disabled='true']) {
83
+ color: var(--dsn-link-active-color);
84
+ }
85
+
86
+ /* Focus */
87
+ .dsn-link:focus-visible {
88
+ background-color: var(--dsn-focus-background-color);
89
+ color: var(--dsn-focus-color);
90
+ text-decoration: none;
91
+ outline: var(--dsn-focus-outline-width) var(--dsn-focus-outline-style)
92
+ var(--dsn-focus-outline-color);
93
+ outline-offset: var(--dsn-focus-outline-offset);
94
+ box-shadow: 0 0 0
95
+ calc(var(--dsn-focus-outline-offset) + var(--dsn-focus-outline-width))
96
+ var(--dsn-focus-inverse-outline-color);
97
+ box-decoration-break: clone;
98
+ }
99
+
100
+ /* Current page */
101
+ .dsn-link[aria-current='page'] {
102
+ cursor: default;
103
+ text-decoration-line: none;
104
+ }
105
+
106
+ /* Disabled */
107
+ .dsn-link[aria-disabled='true'] {
108
+ color: var(--dsn-link-disabled-color);
109
+ text-decoration-line: none;
110
+ cursor: not-allowed;
111
+ pointer-events: none;
112
+ }
113
+
@@ -0,0 +1,80 @@
1
+ import React from 'react';
2
+ import './Link.css';
3
+ export type LinkSize = 'small' | 'default' | 'large';
4
+ export interface LinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {
5
+ /**
6
+ * Whether the link is disabled
7
+ * @default false
8
+ */
9
+ disabled?: boolean;
10
+ /**
11
+ * Whether the link represents the current page
12
+ * @default false
13
+ */
14
+ current?: boolean;
15
+ /**
16
+ * Link size — controls font-size, gap, and icon size.
17
+ * When omitted, the link inherits the surrounding font (ideal for inline usage in paragraphs).
18
+ */
19
+ size?: LinkSize;
20
+ /**
21
+ * Icon element rendered before the link text
22
+ */
23
+ iconStart?: React.ReactNode;
24
+ /**
25
+ * Icon element rendered after the link text
26
+ */
27
+ iconEnd?: React.ReactNode;
28
+ /**
29
+ * Whether the link opens in a new tab.
30
+ * Automatically adds target="_blank", rel="noopener noreferrer",
31
+ * and an inline "(opent nieuw tabblad)" hint.
32
+ * @default false
33
+ */
34
+ external?: boolean;
35
+ /**
36
+ * Additional CSS class names
37
+ */
38
+ className?: string;
39
+ /**
40
+ * Link content
41
+ */
42
+ children?: React.ReactNode;
43
+ }
44
+ /**
45
+ * Link component with icon support and size variants
46
+ *
47
+ * @example
48
+ * ```tsx
49
+ * // Basic usage (inherits font from parent)
50
+ * <Link href="/about">About us</Link>
51
+ *
52
+ * // With explicit size
53
+ * <Link href="/about" size="small">Small link</Link>
54
+ * <Link href="/about" size="default">Default link</Link>
55
+ * <Link href="/about" size="large">Large link</Link>
56
+ *
57
+ * // With icon before text
58
+ * <Link href="/download" iconStart={<Icon name="download" />}>
59
+ * Download
60
+ * </Link>
61
+ *
62
+ * // With icon after text
63
+ * <Link href="/next" iconEnd={<Icon name="arrow-right" />}>
64
+ * Next page
65
+ * </Link>
66
+ *
67
+ * // External link (opens in new tab with visible hint)
68
+ * <Link href="https://example.com" external>
69
+ * External site
70
+ * </Link>
71
+ *
72
+ * // Current page
73
+ * <Link href="/dashboard" current>Dashboard</Link>
74
+ *
75
+ * // Disabled
76
+ * <Link disabled>Unavailable</Link>
77
+ * ```
78
+ */
79
+ export declare const Link: React.ForwardRefExoticComponent<LinkProps & React.RefAttributes<HTMLAnchorElement>>;
80
+ //# sourceMappingURL=Link.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Link.d.ts","sourceRoot":"","sources":["../../src/Link/Link.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,YAAY,CAAC;AAEpB,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,SAAS,GAAG,OAAO,CAAC;AAErD,MAAM,WAAW,SAAU,SAAQ,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC;IAC9E;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;;OAGG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;IAElB;;;OAGG;IACH,IAAI,CAAC,EAAE,QAAQ,CAAC;IAEhB;;OAEG;IACH,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE5B;;OAEG;IACH,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAE1B;;;;;OAKG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC5B;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,eAAO,MAAM,IAAI,qFA6DhB,CAAC"}