@zvoove/unity-ui 2.29.0 → 2.30.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 (496) hide show
  1. package/dist/llms.txt +75 -29
  2. package/dist/theme.css +14 -0
  3. package/dist/unity-ui.cjs.js +1 -1
  4. package/dist/unity-ui.css +1 -1
  5. package/dist/unity-ui.d.ts +4951 -0
  6. package/dist/unity-ui.es.js +787 -746
  7. package/package.json +2 -2
  8. package/dist/components/Accordion/Accordion.d.ts +0 -6
  9. package/dist/components/Accordion/Accordion.styled.d.ts +0 -46
  10. package/dist/components/Accordion/Accordion.types.d.ts +0 -33
  11. package/dist/components/Accordion/index.d.ts +0 -2
  12. package/dist/components/ActionCard/ActionCard.d.ts +0 -6
  13. package/dist/components/ActionCard/ActionCard.styled.d.ts +0 -29
  14. package/dist/components/ActionCard/ActionCard.types.d.ts +0 -32
  15. package/dist/components/ActionCard/index.d.ts +0 -2
  16. package/dist/components/Avatar/Avatar/Avatar.d.ts +0 -3
  17. package/dist/components/Avatar/Avatar/Avatar.styled.d.ts +0 -53
  18. package/dist/components/Avatar/Avatar/Avatar.types.d.ts +0 -34
  19. package/dist/components/Avatar/Avatar/index.d.ts +0 -2
  20. package/dist/components/Avatar/AvatarGroup/AvatarGroup.d.ts +0 -3
  21. package/dist/components/Avatar/AvatarGroup/AvatarGroup.styled.d.ts +0 -3
  22. package/dist/components/Avatar/AvatarGroup/AvatarGroup.types.d.ts +0 -15
  23. package/dist/components/Avatar/AvatarGroup/index.d.ts +0 -2
  24. package/dist/components/Avatar/index.d.ts +0 -2
  25. package/dist/components/Badge/Badge.d.ts +0 -3
  26. package/dist/components/Badge/Badge.styled.d.ts +0 -28
  27. package/dist/components/Badge/Badge.types.d.ts +0 -19
  28. package/dist/components/Badge/index.d.ts +0 -2
  29. package/dist/components/Breadcrumbs/Breadcrumbs.d.ts +0 -4
  30. package/dist/components/Breadcrumbs/Breadcrumbs.styled.d.ts +0 -14
  31. package/dist/components/Breadcrumbs/Breadcrumbs.types.d.ts +0 -22
  32. package/dist/components/Breadcrumbs/index.d.ts +0 -2
  33. package/dist/components/Button/Button.d.ts +0 -9
  34. package/dist/components/Button/Button.styled.d.ts +0 -98
  35. package/dist/components/Button/Button.types.d.ts +0 -55
  36. package/dist/components/Button/index.d.ts +0 -2
  37. package/dist/components/Card/Card.d.ts +0 -10
  38. package/dist/components/Card/Card.styled.d.ts +0 -608
  39. package/dist/components/Card/Card.types.d.ts +0 -125
  40. package/dist/components/Card/index.d.ts +0 -2
  41. package/dist/components/ChatBubble/ChatBubble.d.ts +0 -3
  42. package/dist/components/ChatBubble/ChatBubble.styled.d.ts +0 -117
  43. package/dist/components/ChatBubble/ChatBubble.types.d.ts +0 -55
  44. package/dist/components/ChatBubble/ChatBubbleMedia.d.ts +0 -3
  45. package/dist/components/ChatBubble/index.d.ts +0 -3
  46. package/dist/components/Checkbox/Checkbox.d.ts +0 -3
  47. package/dist/components/Checkbox/Checkbox.styled.d.ts +0 -59
  48. package/dist/components/Checkbox/Checkbox.types.d.ts +0 -40
  49. package/dist/components/Checkbox/index.d.ts +0 -2
  50. package/dist/components/Chip/Chip.d.ts +0 -4
  51. package/dist/components/Chip/Chip.styled.d.ts +0 -114
  52. package/dist/components/Chip/Chip.types.d.ts +0 -63
  53. package/dist/components/Chip/index.d.ts +0 -2
  54. package/dist/components/CodeBlock/CodeBlock.d.ts +0 -6
  55. package/dist/components/CodeBlock/CodeBlock.highlighter.d.ts +0 -7
  56. package/dist/components/CodeBlock/CodeBlock.styled.d.ts +0 -65
  57. package/dist/components/CodeBlock/CodeBlock.types.d.ts +0 -28
  58. package/dist/components/CodeBlock/CodeBlock.utils.d.ts +0 -11
  59. package/dist/components/CodeBlock/index.d.ts +0 -3
  60. package/dist/components/ContentBlock/ContentBlock.d.ts +0 -6
  61. package/dist/components/ContentBlock/ContentBlock.styled.d.ts +0 -2
  62. package/dist/components/ContentBlock/ContentBlock.types.d.ts +0 -7
  63. package/dist/components/ContentBlock/index.d.ts +0 -2
  64. package/dist/components/DatePicker/DatePicker.d.ts +0 -3
  65. package/dist/components/DatePicker/DatePicker.styled.d.ts +0 -16
  66. package/dist/components/DatePicker/DatePicker.types.d.ts +0 -64
  67. package/dist/components/DatePicker/components/DateDialog/DateDialog.d.ts +0 -3
  68. package/dist/components/DatePicker/components/DateDialog/DateDialog.types.d.ts +0 -10
  69. package/dist/components/DatePicker/components/DateDialog/components/Calendar/Calendar.d.ts +0 -3
  70. package/dist/components/DatePicker/components/DateDialog/components/Calendar/Calendar.styled.d.ts +0 -16
  71. package/dist/components/DatePicker/components/DateDialog/components/Calendar/Calendar.types.d.ts +0 -61
  72. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/ActionButtons/ActionButtons.d.ts +0 -3
  73. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/ActionButtons/ActionButtons.styled.d.ts +0 -16
  74. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/ActionButtons/ActionButtons.types.d.ts +0 -30
  75. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/ActionButtons/index.d.ts +0 -2
  76. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/CalendarHeader/CalendarHeader.d.ts +0 -3
  77. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/CalendarHeader/CalendarHeader.styled.d.ts +0 -70
  78. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/CalendarHeader/CalendarHeader.types.d.ts +0 -46
  79. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/CalendarHeader/index.d.ts +0 -2
  80. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Carousel/Carousel.d.ts +0 -3
  81. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Carousel/Carousel.styled.d.ts +0 -45
  82. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Carousel/Carousel.types.d.ts +0 -30
  83. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Carousel/index.d.ts +0 -2
  84. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Day/Day.d.ts +0 -3
  85. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Day/Day.styled.d.ts +0 -22
  86. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Day/Day.types.d.ts +0 -11
  87. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/Day/index.d.ts +0 -2
  88. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/WeekDays/WeekDays.d.ts +0 -3
  89. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/WeekDays/WeekDays.styled.d.ts +0 -17
  90. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/WeekDays/WeekDays.types.d.ts +0 -4
  91. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/WeekDays/index.d.ts +0 -2
  92. package/dist/components/DatePicker/components/DateDialog/components/Calendar/components/index.d.ts +0 -5
  93. package/dist/components/DatePicker/components/DateDialog/components/Calendar/index.d.ts +0 -2
  94. package/dist/components/DatePicker/components/DateDialog/components/MonthSelector/MonthSelector.d.ts +0 -3
  95. package/dist/components/DatePicker/components/DateDialog/components/MonthSelector/MonthSelector.types.d.ts +0 -23
  96. package/dist/components/DatePicker/components/DateDialog/components/MonthSelector/index.d.ts +0 -2
  97. package/dist/components/DatePicker/components/DateDialog/components/SelectorList/SelectorList.d.ts +0 -3
  98. package/dist/components/DatePicker/components/DateDialog/components/SelectorList/SelectorList.styled.d.ts +0 -19
  99. package/dist/components/DatePicker/components/DateDialog/components/SelectorList/SelectorList.types.d.ts +0 -9
  100. package/dist/components/DatePicker/components/DateDialog/components/SelectorList/index.d.ts +0 -2
  101. package/dist/components/DatePicker/components/DateDialog/components/YearSelector/YearSelector.d.ts +0 -3
  102. package/dist/components/DatePicker/components/DateDialog/components/YearSelector/YearSelector.types.d.ts +0 -36
  103. package/dist/components/DatePicker/components/DateDialog/components/YearSelector/index.d.ts +0 -2
  104. package/dist/components/DatePicker/components/DateDialog/index.d.ts +0 -2
  105. package/dist/components/DatePicker/components/index.d.ts +0 -1
  106. package/dist/components/DatePicker/context/Context.types.d.ts +0 -15
  107. package/dist/components/DatePicker/context/DatePickerContext.d.ts +0 -3
  108. package/dist/components/DatePicker/context/DatePickerProvider.d.ts +0 -3
  109. package/dist/components/DatePicker/context/index.d.ts +0 -3
  110. package/dist/components/DatePicker/hooks/index.d.ts +0 -5
  111. package/dist/components/DatePicker/hooks/useDatePicker.d.ts +0 -2
  112. package/dist/components/DatePicker/hooks/useDateSelection.d.ts +0 -21
  113. package/dist/components/DatePicker/hooks/useDateUtils.d.ts +0 -31
  114. package/dist/components/DatePicker/hooks/useDialogFocus.d.ts +0 -1
  115. package/dist/components/DatePicker/hooks/useDialogPosition.d.ts +0 -19
  116. package/dist/components/DatePicker/index.d.ts +0 -2
  117. package/dist/components/DatePicker/utils/calendar.utils.d.ts +0 -26
  118. package/dist/components/DatePicker/utils/index.d.ts +0 -3
  119. package/dist/components/DatePicker/utils/locale.utils.d.ts +0 -38
  120. package/dist/components/DatePicker/utils/navigation.utils.d.ts +0 -13
  121. package/dist/components/Dialog/Dialog.d.ts +0 -3
  122. package/dist/components/Dialog/Dialog.styled.d.ts +0 -38
  123. package/dist/components/Dialog/Dialog.types.d.ts +0 -46
  124. package/dist/components/Dialog/DialogManager.d.ts +0 -41
  125. package/dist/components/Dialog/hooks/index.d.ts +0 -3
  126. package/dist/components/Dialog/hooks/useDialogAnimation.d.ts +0 -6
  127. package/dist/components/Dialog/hooks/useDialogEscape.d.ts +0 -2
  128. package/dist/components/Dialog/hooks/useDialogFocus.d.ts +0 -2
  129. package/dist/components/Dialog/index.d.ts +0 -3
  130. package/dist/components/Divider/Divider.d.ts +0 -3
  131. package/dist/components/Divider/Divider.styled.d.ts +0 -19
  132. package/dist/components/Divider/Divider.types.d.ts +0 -13
  133. package/dist/components/Divider/index.d.ts +0 -2
  134. package/dist/components/Expandable/Expandable.d.ts +0 -6
  135. package/dist/components/Expandable/Expandable.styled.d.ts +0 -16
  136. package/dist/components/Expandable/Expandable.types.d.ts +0 -12
  137. package/dist/components/Expandable/index.d.ts +0 -2
  138. package/dist/components/FloatSearch/FloatSearch.d.ts +0 -6
  139. package/dist/components/FloatSearch/FloatSearch.styled.d.ts +0 -51
  140. package/dist/components/FloatSearch/FloatSearch.types.d.ts +0 -108
  141. package/dist/components/FloatSearch/index.d.ts +0 -2
  142. package/dist/components/FormLabel/FormLabel.d.ts +0 -3
  143. package/dist/components/FormLabel/FormLabel.types.d.ts +0 -15
  144. package/dist/components/FormLabel/index.d.ts +0 -2
  145. package/dist/components/Grid/Grid.d.ts +0 -3
  146. package/dist/components/Grid/Grid.styled.d.ts +0 -274
  147. package/dist/components/Grid/Grid.types.d.ts +0 -80
  148. package/dist/components/Grid/index.d.ts +0 -2
  149. package/dist/components/Icon/CustomIcon.types.d.ts +0 -13
  150. package/dist/components/Icon/Icon.d.ts +0 -3
  151. package/dist/components/Icon/Icon.styled.d.ts +0 -61
  152. package/dist/components/Icon/Icon.types.d.ts +0 -619
  153. package/dist/components/Icon/custom/FileArchiveRar.d.ts +0 -3
  154. package/dist/components/Icon/custom/FileArchiveZip.d.ts +0 -3
  155. package/dist/components/Icon/custom/FileDesignAep.d.ts +0 -3
  156. package/dist/components/Icon/custom/FileDesignAi.d.ts +0 -3
  157. package/dist/components/Icon/custom/FileDesignFig.d.ts +0 -3
  158. package/dist/components/Icon/custom/FileDesignIndd.d.ts +0 -3
  159. package/dist/components/Icon/custom/FileDesignPsd.d.ts +0 -3
  160. package/dist/components/Icon/custom/FileDevelopmentCss.d.ts +0 -3
  161. package/dist/components/Icon/custom/FileDevelopmentDmg.d.ts +0 -3
  162. package/dist/components/Icon/custom/FileDevelopmentExe.d.ts +0 -3
  163. package/dist/components/Icon/custom/FileDevelopmentHtml.d.ts +0 -3
  164. package/dist/components/Icon/custom/FileDevelopmentJava.d.ts +0 -3
  165. package/dist/components/Icon/custom/FileDevelopmentJs.d.ts +0 -3
  166. package/dist/components/Icon/custom/FileDevelopmentJson.d.ts +0 -3
  167. package/dist/components/Icon/custom/FileDevelopmentRss.d.ts +0 -3
  168. package/dist/components/Icon/custom/FileDevelopmentSql.d.ts +0 -3
  169. package/dist/components/Icon/custom/FileDevelopmentXml.d.ts +0 -3
  170. package/dist/components/Icon/custom/FileDocumentCsv.d.ts +0 -3
  171. package/dist/components/Icon/custom/FileDocumentDoc.d.ts +0 -3
  172. package/dist/components/Icon/custom/FileDocumentDocx.d.ts +0 -3
  173. package/dist/components/Icon/custom/FileDocumentPdf.d.ts +0 -3
  174. package/dist/components/Icon/custom/FileDocumentPpt.d.ts +0 -3
  175. package/dist/components/Icon/custom/FileDocumentPptx.d.ts +0 -3
  176. package/dist/components/Icon/custom/FileDocumentTxt.d.ts +0 -3
  177. package/dist/components/Icon/custom/FileDocumentXls.d.ts +0 -3
  178. package/dist/components/Icon/custom/FileDocumentXlsx.d.ts +0 -3
  179. package/dist/components/Icon/custom/FileImageEps.d.ts +0 -3
  180. package/dist/components/Icon/custom/FileImageGif.d.ts +0 -3
  181. package/dist/components/Icon/custom/FileImageImg.d.ts +0 -3
  182. package/dist/components/Icon/custom/FileImageJpeg.d.ts +0 -3
  183. package/dist/components/Icon/custom/FileImageJpg.d.ts +0 -3
  184. package/dist/components/Icon/custom/FileImagePng.d.ts +0 -3
  185. package/dist/components/Icon/custom/FileImageSvg.d.ts +0 -3
  186. package/dist/components/Icon/custom/FileImageTiff.d.ts +0 -3
  187. package/dist/components/Icon/custom/FileImageWebp.d.ts +0 -3
  188. package/dist/components/Icon/custom/FileMediaAvi.d.ts +0 -3
  189. package/dist/components/Icon/custom/FileMediaMkv.d.ts +0 -3
  190. package/dist/components/Icon/custom/FileMediaMp3.d.ts +0 -3
  191. package/dist/components/Icon/custom/FileMediaMp4.d.ts +0 -3
  192. package/dist/components/Icon/custom/FileMediaMpeg.d.ts +0 -3
  193. package/dist/components/Icon/custom/FileMediaWav.d.ts +0 -3
  194. package/dist/components/Icon/custom/FileSimpleAudio.d.ts +0 -3
  195. package/dist/components/Icon/custom/FileSimpleCode.d.ts +0 -3
  196. package/dist/components/Icon/custom/FileSimpleDocument.d.ts +0 -3
  197. package/dist/components/Icon/custom/FileSimpleEmpty.d.ts +0 -3
  198. package/dist/components/Icon/custom/FileSimpleFolder.d.ts +0 -3
  199. package/dist/components/Icon/custom/FileSimpleImage.d.ts +0 -3
  200. package/dist/components/Icon/custom/FileSimplePdf.d.ts +0 -3
  201. package/dist/components/Icon/custom/FileSimpleSpreadSheet.d.ts +0 -3
  202. package/dist/components/Icon/custom/FileSimpleVideo.d.ts +0 -3
  203. package/dist/components/Icon/custom/FileSimpleVideo2.d.ts +0 -3
  204. package/dist/components/Icon/custom/FlagDe.d.ts +0 -4
  205. package/dist/components/Icon/custom/FlagEs.d.ts +0 -4
  206. package/dist/components/Icon/custom/FlagFr.d.ts +0 -4
  207. package/dist/components/Icon/custom/FlagGb.d.ts +0 -4
  208. package/dist/components/Icon/custom/FlagNl.d.ts +0 -4
  209. package/dist/components/Icon/custom/ZvooveLogo.d.ts +0 -6
  210. package/dist/components/Icon/custom/index.d.ts +0 -58
  211. package/dist/components/Icon/docs/components/IconCell.d.ts +0 -9
  212. package/dist/components/Icon/docs/components/IconDisplay.d.ts +0 -5
  213. package/dist/components/Icon/docs/components/IconSearch.d.ts +0 -1
  214. package/dist/components/Icon/index.d.ts +0 -3
  215. package/dist/components/ImageVisualizer/ImageVisualizer.d.ts +0 -6
  216. package/dist/components/ImageVisualizer/ImageVisualizer.styled.d.ts +0 -142
  217. package/dist/components/ImageVisualizer/ImageVisualizer.types.d.ts +0 -46
  218. package/dist/components/ImageVisualizer/index.d.ts +0 -2
  219. package/dist/components/InfoBox/InfoBox.constants.d.ts +0 -5
  220. package/dist/components/InfoBox/InfoBox.d.ts +0 -6
  221. package/dist/components/InfoBox/InfoBox.types.d.ts +0 -22
  222. package/dist/components/InfoBox/index.d.ts +0 -2
  223. package/dist/components/List/List.d.ts +0 -7
  224. package/dist/components/List/List.styled.d.ts +0 -40
  225. package/dist/components/List/List.types.d.ts +0 -32
  226. package/dist/components/List/index.d.ts +0 -2
  227. package/dist/components/ListMenu/ListMenu.d.ts +0 -7
  228. package/dist/components/ListMenu/ListMenu.styled.d.ts +0 -150
  229. package/dist/components/ListMenu/ListMenu.types.d.ts +0 -74
  230. package/dist/components/ListMenu/ListMenu.utils.d.ts +0 -13
  231. package/dist/components/ListMenu/index.d.ts +0 -3
  232. package/dist/components/MessageActions/MessageActions.d.ts +0 -3
  233. package/dist/components/MessageActions/MessageActions.styled.d.ts +0 -56
  234. package/dist/components/MessageActions/MessageActions.types.d.ts +0 -81
  235. package/dist/components/MessageActions/index.d.ts +0 -2
  236. package/dist/components/MidSectionMenus/MidSectionMenus.d.ts +0 -7
  237. package/dist/components/MidSectionMenus/MidSectionMenus.styled.d.ts +0 -98
  238. package/dist/components/MidSectionMenus/MidSectionMenus.types.d.ts +0 -67
  239. package/dist/components/MidSectionMenus/index.d.ts +0 -2
  240. package/dist/components/Pagination/Pagination.d.ts +0 -3
  241. package/dist/components/Pagination/Pagination.types.d.ts +0 -37
  242. package/dist/components/Pagination/index.d.ts +0 -2
  243. package/dist/components/PopUpMenu/PopUpMenu.constants.d.ts +0 -2
  244. package/dist/components/PopUpMenu/PopUpMenu.d.ts +0 -3
  245. package/dist/components/PopUpMenu/PopUpMenu.styled.d.ts +0 -161
  246. package/dist/components/PopUpMenu/PopUpMenu.types.d.ts +0 -258
  247. package/dist/components/PopUpMenu/PopUpMenu.utils.d.ts +0 -18
  248. package/dist/components/PopUpMenu/PopUpMenuContent.d.ts +0 -45
  249. package/dist/components/PopUpMenu/PopUpMenuManager.d.ts +0 -37
  250. package/dist/components/PopUpMenu/PopUpMenuPortal.d.ts +0 -12
  251. package/dist/components/PopUpMenu/index.d.ts +0 -2
  252. package/dist/components/PopUpMenu/usePopUpMenuHandlers.d.ts +0 -44
  253. package/dist/components/PopUpMenu/usePopUpMenuState.d.ts +0 -48
  254. package/dist/components/ProgressIndicator/ProgressIndicator.d.ts +0 -3
  255. package/dist/components/ProgressIndicator/ProgressIndicator.styled.d.ts +0 -103
  256. package/dist/components/ProgressIndicator/ProgressIndicator.types.d.ts +0 -31
  257. package/dist/components/ProgressIndicator/index.d.ts +0 -2
  258. package/dist/components/Radio/RadioButton/RadioButton.d.ts +0 -3
  259. package/dist/components/Radio/RadioButton/RadioButton.styled.d.ts +0 -45
  260. package/dist/components/Radio/RadioButton/RadioButton.types.d.ts +0 -32
  261. package/dist/components/Radio/RadioButton/index.d.ts +0 -2
  262. package/dist/components/Radio/RadioGroup/RadioGroup.d.ts +0 -11
  263. package/dist/components/Radio/RadioGroup/RadioGroup.styled.d.ts +0 -13
  264. package/dist/components/Radio/RadioGroup/RadioGroup.types.d.ts +0 -26
  265. package/dist/components/Radio/RadioGroup/index.d.ts +0 -2
  266. package/dist/components/Radio/index.d.ts +0 -2
  267. package/dist/components/ScoreCard/ScoreCard.d.ts +0 -3
  268. package/dist/components/ScoreCard/ScoreCard.styled.d.ts +0 -1
  269. package/dist/components/ScoreCard/ScoreCard.types.d.ts +0 -42
  270. package/dist/components/ScoreCard/index.d.ts +0 -2
  271. package/dist/components/Segment/SegmentButton/SegmentButton.d.ts +0 -3
  272. package/dist/components/Segment/SegmentButton/SegmentButton.styled.d.ts +0 -31
  273. package/dist/components/Segment/SegmentButton/SegmentButton.types.d.ts +0 -39
  274. package/dist/components/Segment/SegmentButton/index.d.ts +0 -2
  275. package/dist/components/Segment/SegmentGroup/SegmentGroup.d.ts +0 -6
  276. package/dist/components/Segment/SegmentGroup/SegmentGroup.styled.d.ts +0 -13
  277. package/dist/components/Segment/SegmentGroup/SegmentGroup.types.d.ts +0 -36
  278. package/dist/components/Segment/SegmentGroup/index.d.ts +0 -2
  279. package/dist/components/Segment/index.d.ts +0 -2
  280. package/dist/components/Select/Select.constants.d.ts +0 -17
  281. package/dist/components/Select/Select.d.ts +0 -3
  282. package/dist/components/Select/Select.styled.d.ts +0 -250
  283. package/dist/components/Select/Select.types.d.ts +0 -70
  284. package/dist/components/Select/Select.utils.d.ts +0 -51
  285. package/dist/components/Select/SelectDisplay.d.ts +0 -3
  286. package/dist/components/Select/SelectDisplay.types.d.ts +0 -43
  287. package/dist/components/Select/SelectManager.d.ts +0 -37
  288. package/dist/components/Select/index.d.ts +0 -2
  289. package/dist/components/Select/useSelectHandlers.d.ts +0 -40
  290. package/dist/components/Select/useSelectState.d.ts +0 -19
  291. package/dist/components/Shared/Backdrop/Backdrop.d.ts +0 -6
  292. package/dist/components/Shared/Backdrop/Backdrop.styled.d.ts +0 -16
  293. package/dist/components/Shared/Backdrop/Backdrop.types.d.ts +0 -23
  294. package/dist/components/Shared/Backdrop/index.d.ts +0 -2
  295. package/dist/components/Shared/ErrorMessage/ErrorMessage.d.ts +0 -3
  296. package/dist/components/Shared/ErrorMessage/ErrorMessage.styled.d.ts +0 -25
  297. package/dist/components/Shared/ErrorMessage/ErrorMessage.types.d.ts +0 -16
  298. package/dist/components/Shared/ErrorMessage/index.d.ts +0 -2
  299. package/dist/components/Shared/index.d.ts +0 -2
  300. package/dist/components/Sheet/Examples/SheetDefault.d.ts +0 -3
  301. package/dist/components/Sheet/Examples/SheetWithFooterAndHeader.d.ts +0 -3
  302. package/dist/components/Sheet/Sheet.d.ts +0 -6
  303. package/dist/components/Sheet/Sheet.styled.d.ts +0 -175
  304. package/dist/components/Sheet/Sheet.types.d.ts +0 -172
  305. package/dist/components/Sheet/SheetManager.d.ts +0 -37
  306. package/dist/components/Sheet/hooks/index.d.ts +0 -9
  307. package/dist/components/Sheet/hooks/useSheetAnimation.d.ts +0 -6
  308. package/dist/components/Sheet/hooks/useSheetClose.d.ts +0 -20
  309. package/dist/components/Sheet/hooks/useSheetEscape.d.ts +0 -2
  310. package/dist/components/Sheet/hooks/useSheetFocus.d.ts +0 -2
  311. package/dist/components/Sheet/hooks/useSheetRegistration.d.ts +0 -14
  312. package/dist/components/Sheet/hooks/useSheetResize.d.ts +0 -10
  313. package/dist/components/Sheet/hooks/useSheetScrollTracking.d.ts +0 -21
  314. package/dist/components/Sheet/hooks/useSheetSwipe.d.ts +0 -8
  315. package/dist/components/Sheet/hooks/useSheetWidth.d.ts +0 -20
  316. package/dist/components/Sheet/index.d.ts +0 -4
  317. package/dist/components/SideNavigation/SideNavigation.d.ts +0 -4
  318. package/dist/components/SideNavigation/SideNavigation.styled.d.ts +0 -249
  319. package/dist/components/SideNavigation/SideNavigation.types.d.ts +0 -128
  320. package/dist/components/SideNavigation/docs/MicroFrontendExample.d.ts +0 -37
  321. package/dist/components/SideNavigation/docs/ShellExample.d.ts +0 -9
  322. package/dist/components/SideNavigation/docs/ShellHomeContent.d.ts +0 -5
  323. package/dist/components/SideNavigation/docs/index.d.ts +0 -1
  324. package/dist/components/SideNavigation/docs/mfe/HubDashboardContent.d.ts +0 -5
  325. package/dist/components/SideNavigation/docs/mfe/ZainNewChatContent.d.ts +0 -8
  326. package/dist/components/SideNavigation/docs/mfe/apps/analytics.d.ts +0 -4
  327. package/dist/components/SideNavigation/docs/mfe/apps/api.d.ts +0 -4
  328. package/dist/components/SideNavigation/docs/mfe/apps/campaigns.d.ts +0 -4
  329. package/dist/components/SideNavigation/docs/mfe/apps/cashlink.d.ts +0 -4
  330. package/dist/components/SideNavigation/docs/mfe/apps/cockpit-x.d.ts +0 -4
  331. package/dist/components/SideNavigation/docs/mfe/apps/cockpit.d.ts +0 -4
  332. package/dist/components/SideNavigation/docs/mfe/apps/connect.d.ts +0 -4
  333. package/dist/components/SideNavigation/docs/mfe/apps/dms-plus.d.ts +0 -4
  334. package/dist/components/SideNavigation/docs/mfe/apps/index.d.ts +0 -59
  335. package/dist/components/SideNavigation/docs/mfe/apps/insights.d.ts +0 -4
  336. package/dist/components/SideNavigation/docs/mfe/apps/one.d.ts +0 -4
  337. package/dist/components/SideNavigation/docs/mfe/apps/payroll.d.ts +0 -4
  338. package/dist/components/SideNavigation/docs/mfe/apps/recruit.d.ts +0 -4
  339. package/dist/components/SideNavigation/docs/mfe/apps/safety-manager.d.ts +0 -4
  340. package/dist/components/SideNavigation/docs/mfe/apps/work-app.d.ts +0 -4
  341. package/dist/components/SideNavigation/docs/mfe/apps/zain.d.ts +0 -4
  342. package/dist/components/SideNavigation/docs/mfe/hubMenu.d.ts +0 -9
  343. package/dist/components/SideNavigation/docs/mfe/internalHomeNav.d.ts +0 -7
  344. package/dist/components/SideNavigation/docs/mfe/zainMenu.d.ts +0 -7
  345. package/dist/components/SideNavigation/index.d.ts +0 -2
  346. package/dist/components/SideNavigation/usePinnedSections.d.ts +0 -7
  347. package/dist/components/Skeleton/Skeleton.d.ts +0 -3
  348. package/dist/components/Skeleton/Skeleton.styled.d.ts +0 -43
  349. package/dist/components/Skeleton/Skeleton.types.d.ts +0 -20
  350. package/dist/components/Skeleton/index.d.ts +0 -2
  351. package/dist/components/Snackbar/Snackbar.constants.d.ts +0 -5
  352. package/dist/components/Snackbar/Snackbar.context.d.ts +0 -8
  353. package/dist/components/Snackbar/Snackbar.context.definition.d.ts +0 -2
  354. package/dist/components/Snackbar/Snackbar.d.ts +0 -32
  355. package/dist/components/Snackbar/Snackbar.styled.d.ts +0 -173
  356. package/dist/components/Snackbar/Snackbar.types.d.ts +0 -119
  357. package/dist/components/Snackbar/index.d.ts +0 -5
  358. package/dist/components/Snackbar/useSnackbar.d.ts +0 -20
  359. package/dist/components/Stack/Stack.d.ts +0 -4
  360. package/dist/components/Stack/Stack.styled.d.ts +0 -367
  361. package/dist/components/Stack/Stack.types.d.ts +0 -74
  362. package/dist/components/Stack/index.d.ts +0 -2
  363. package/dist/components/Switch/Switch.d.ts +0 -4
  364. package/dist/components/Switch/Switch.styled.d.ts +0 -68
  365. package/dist/components/Switch/Switch.types.d.ts +0 -54
  366. package/dist/components/Switch/index.d.ts +0 -2
  367. package/dist/components/Table/ExpandDetailExample/ExpandDetailExample.d.ts +0 -4
  368. package/dist/components/Table/Table.d.ts +0 -6
  369. package/dist/components/Table/Table.styled.d.ts +0 -77
  370. package/dist/components/Table/Table.types.d.ts +0 -114
  371. package/dist/components/Table/TableDocExample/RowActionButton.d.ts +0 -5
  372. package/dist/components/Table/TableDocExample/TableDocExample.constants.d.ts +0 -14
  373. package/dist/components/Table/TableDocExample/TableDocExample.d.ts +0 -4
  374. package/dist/components/Table/TableDocExample/index.d.ts +0 -1
  375. package/dist/components/Table/index.d.ts +0 -2
  376. package/dist/components/Tabs/TabItem.d.ts +0 -3
  377. package/dist/components/Tabs/Tabs.d.ts +0 -6
  378. package/dist/components/Tabs/Tabs.styled.d.ts +0 -161
  379. package/dist/components/Tabs/Tabs.types.d.ts +0 -60
  380. package/dist/components/Tabs/index.d.ts +0 -2
  381. package/dist/components/Tag/Tag.d.ts +0 -3
  382. package/dist/components/Tag/Tag.styled.d.ts +0 -73
  383. package/dist/components/Tag/Tag.types.d.ts +0 -28
  384. package/dist/components/Tag/index.d.ts +0 -2
  385. package/dist/components/TextField/TextField.d.ts +0 -3
  386. package/dist/components/TextField/TextField.styled.d.ts +0 -335
  387. package/dist/components/TextField/TextField.types.d.ts +0 -67
  388. package/dist/components/TextField/index.d.ts +0 -2
  389. package/dist/components/Textarea/Textarea.d.ts +0 -3
  390. package/dist/components/Textarea/Textarea.styled.d.ts +0 -67
  391. package/dist/components/Textarea/Textarea.types.d.ts +0 -32
  392. package/dist/components/Textarea/index.d.ts +0 -2
  393. package/dist/components/Tooltip/Tooltip.d.ts +0 -3
  394. package/dist/components/Tooltip/Tooltip.styled.d.ts +0 -51
  395. package/dist/components/Tooltip/Tooltip.types.d.ts +0 -22
  396. package/dist/components/Tooltip/TooltipPortal.d.ts +0 -8
  397. package/dist/components/Tooltip/index.d.ts +0 -2
  398. package/dist/components/TopBar/TopBar.d.ts +0 -3
  399. package/dist/components/TopBar/TopBar.styled.d.ts +0 -19
  400. package/dist/components/TopBar/TopBar.types.d.ts +0 -27
  401. package/dist/components/TopBar/index.d.ts +0 -2
  402. package/dist/components/Typography/Typography.d.ts +0 -3
  403. package/dist/components/Typography/Typography.styled.d.ts +0 -94
  404. package/dist/components/Typography/Typography.types.d.ts +0 -47
  405. package/dist/components/Typography/index.d.ts +0 -2
  406. package/dist/components/Uploader/Uploader.constants.d.ts +0 -12
  407. package/dist/components/Uploader/Uploader.context.d.ts +0 -185
  408. package/dist/components/Uploader/Uploader.d.ts +0 -3
  409. package/dist/components/Uploader/Uploader.types.d.ts +0 -238
  410. package/dist/components/Uploader/components/Announcer/Announcer.d.ts +0 -2
  411. package/dist/components/Uploader/components/Announcer/index.d.ts +0 -1
  412. package/dist/components/Uploader/components/DropZone/DropZone.d.ts +0 -3
  413. package/dist/components/Uploader/components/DropZone/DropZone.styled.d.ts +0 -68
  414. package/dist/components/Uploader/components/DropZone/index.d.ts +0 -1
  415. package/dist/components/Uploader/components/FileItem/FileItem.d.ts +0 -18
  416. package/dist/components/Uploader/components/FileItem/FileItem.styled.d.ts +0 -67
  417. package/dist/components/Uploader/components/FileItem/index.d.ts +0 -2
  418. package/dist/components/Uploader/components/FileItem/useFileItem.d.ts +0 -33
  419. package/dist/components/Uploader/components/FileList/FileList.d.ts +0 -12
  420. package/dist/components/Uploader/components/FileList/FileList.styled.d.ts +0 -1
  421. package/dist/components/Uploader/components/FileList/index.d.ts +0 -2
  422. package/dist/components/Uploader/components/RejectionList/RejectionList.d.ts +0 -12
  423. package/dist/components/Uploader/components/RejectionList/RejectionList.styled.d.ts +0 -10
  424. package/dist/components/Uploader/components/RejectionList/index.d.ts +0 -2
  425. package/dist/components/Uploader/components/index.d.ts +0 -5
  426. package/dist/components/Uploader/hooks/index.d.ts +0 -11
  427. package/dist/components/Uploader/hooks/useAnnouncements.d.ts +0 -10
  428. package/dist/components/Uploader/hooks/useDragAndDrop.d.ts +0 -17
  429. package/dist/components/Uploader/hooks/useFileInput.d.ts +0 -19
  430. package/dist/components/Uploader/hooks/useFileOperations.d.ts +0 -18
  431. package/dist/components/Uploader/hooks/useFileSelection.d.ts +0 -36
  432. package/dist/components/Uploader/hooks/useFileUpload.d.ts +0 -66
  433. package/dist/components/Uploader/hooks/useUploaderContext.d.ts +0 -3
  434. package/dist/components/Uploader/hooks/useUploaderRef.d.ts +0 -13
  435. package/dist/components/Uploader/hooks/useUploaderState.d.ts +0 -30
  436. package/dist/components/Uploader/hooks/useValidation.d.ts +0 -30
  437. package/dist/components/Uploader/index.d.ts +0 -6
  438. package/dist/components/Uploader/types/errors.d.ts +0 -28
  439. package/dist/components/Uploader/types/events.d.ts +0 -65
  440. package/dist/components/Uploader/types/file.d.ts +0 -116
  441. package/dist/components/Uploader/types/index.d.ts +0 -3
  442. package/dist/components/Uploader/utils/createFetchUpload.d.ts +0 -32
  443. package/dist/components/Uploader/utils/createXhrUpload.d.ts +0 -45
  444. package/dist/components/Uploader/utils/detectDuplicates.d.ts +0 -5
  445. package/dist/components/Uploader/utils/formatFileSize.d.ts +0 -3
  446. package/dist/components/Uploader/utils/generateId.d.ts +0 -1
  447. package/dist/components/Uploader/utils/getFileExtension.d.ts +0 -1
  448. package/dist/components/Uploader/utils/index.d.ts +0 -8
  449. package/dist/components/Uploader/utils/normalizeFile.d.ts +0 -3
  450. package/dist/components/Uploader/utils/validateFileType.d.ts +0 -1
  451. package/dist/components/UserArea/UserArea.d.ts +0 -3
  452. package/dist/components/UserArea/UserArea.styled.d.ts +0 -65
  453. package/dist/components/UserArea/UserArea.types.d.ts +0 -49
  454. package/dist/components/UserArea/index.d.ts +0 -2
  455. package/dist/components/ZvooveBrand/ZvooveBrand.d.ts +0 -6
  456. package/dist/components/ZvooveBrand/ZvooveBrand.types.d.ts +0 -22
  457. package/dist/components/ZvooveBrand/index.d.ts +0 -2
  458. package/dist/config.d.ts +0 -48
  459. package/dist/constants/align.d.ts +0 -3
  460. package/dist/constants/breakpoints.d.ts +0 -10
  461. package/dist/constants/colors.d.ts +0 -7
  462. package/dist/constants/direction.d.ts +0 -3
  463. package/dist/constants/dom.d.ts +0 -5
  464. package/dist/constants/gap.d.ts +0 -4
  465. package/dist/constants/index.d.ts +0 -11
  466. package/dist/constants/justify.d.ts +0 -3
  467. package/dist/constants/margin.d.ts +0 -16
  468. package/dist/constants/overflow.d.ts +0 -5
  469. package/dist/constants/padding.d.ts +0 -16
  470. package/dist/constants/wrap.d.ts +0 -3
  471. package/dist/docs/components/TokensTable.d.ts +0 -6
  472. package/dist/docs/components/WelcomeTile.d.ts +0 -8
  473. package/dist/docs/components/tokens.d.ts +0 -10
  474. package/dist/hooks/index.d.ts +0 -2
  475. package/dist/hooks/useBreakpoint.d.ts +0 -51
  476. package/dist/hooks/useClickOutside.d.ts +0 -4
  477. package/dist/index.d.ts +0 -52
  478. package/dist/libs/index.d.ts +0 -1
  479. package/dist/libs/tv.d.ts +0 -23
  480. package/dist/types/index.d.ts +0 -71
  481. package/dist/utils/checkIconSource.d.ts +0 -1
  482. package/dist/utils/containsOnlySizeProps.d.ts +0 -1
  483. package/dist/utils/formatFromStringToDate.d.ts +0 -1
  484. package/dist/utils/getComponentTagName.d.ts +0 -1
  485. package/dist/utils/getFlexProps.d.ts +0 -4
  486. package/dist/utils/getOverflowProps.d.ts +0 -23
  487. package/dist/utils/getResponsiveValue.d.ts +0 -35
  488. package/dist/utils/getSpacingProps.d.ts +0 -4
  489. package/dist/utils/index.d.ts +0 -15
  490. package/dist/utils/isDefined.d.ts +0 -1
  491. package/dist/utils/isValidSizeUnit.d.ts +0 -1
  492. package/dist/utils/linkify.d.ts +0 -2
  493. package/dist/utils/logs.d.ts +0 -6
  494. package/dist/utils/setupUserEvent.d.ts +0 -6
  495. package/dist/utils/typeGuards.d.ts +0 -21
  496. package/dist/utils/viewports.d.ts +0 -13
@@ -0,0 +1,4951 @@
1
+ import { ChangeEventHandler } from 'react';
2
+ import { ComponentRef } from 'react';
3
+ import { CSSProperties } from 'react';
4
+ import { default as default_2 } from 'react';
5
+ import { Dispatch } from 'react';
6
+ import { ElementType } from 'react';
7
+ import { ForwardedRef } from 'react';
8
+ import { ForwardRefExoticComponent } from 'react';
9
+ import { Icon as Icon_2 } from '@phosphor-icons/react';
10
+ import { IconWeight } from '@phosphor-icons/react';
11
+ import { JSX } from 'react/jsx-runtime';
12
+ import { MouseEvent as MouseEvent_2 } from 'react';
13
+ import { PropsWithChildren } from 'react';
14
+ import { ReactNode } from 'react';
15
+ import { ReactPortal } from 'react';
16
+ import { RefAttributes } from 'react';
17
+ import { RefObject } from 'react';
18
+ import { SetStateAction } from 'react';
19
+
20
+ export declare const Accordion: {
21
+ <T extends readonly AccordionItem[]>({ items, onToggle, openItems, allowMultipleOpenItems, }: AccordionProps<T>): JSX.Element;
22
+ displayName: string;
23
+ };
24
+
25
+ export declare interface AccordionItem {
26
+ id: string;
27
+ title: string;
28
+ supportingText?: string;
29
+ children: ReactNode;
30
+ isOpen?: boolean;
31
+ disabled?: boolean;
32
+ }
33
+
34
+ export declare type AccordionItemId<T extends readonly AccordionItem[]> = T[number]['id'];
35
+
36
+ export declare interface AccordionProps<T extends readonly AccordionItem[] = readonly AccordionItem[]> {
37
+ /**
38
+ * The children of the Accordion.
39
+ */
40
+ items: AccordionItem[];
41
+ /**
42
+ * The open items of the Accordion. By default, all items are closed. <br />
43
+ * The ids must match the `id` of the item. <br />
44
+ * When allowMultipleOpenItems is false, this should be a single id or undefined. <br />
45
+ * When allowMultipleOpenItems is true, this can be an array of ids or undefined.
46
+ */
47
+ openItems?: AccordionItemId<T> | AccordionItemId<T>[];
48
+ /**
49
+ * Callback when the accordion header is clicked <br />
50
+ * If provided, this will override the default behavior and you need to manage the open items yourself.
51
+ */
52
+ onToggle?: (item: AccordionItem) => void;
53
+ /**
54
+ * Whether to allow multiple open items or not.
55
+ * @default false
56
+ */
57
+ allowMultipleOpenItems?: boolean;
58
+ }
59
+
60
+ export declare const ActionCard: {
61
+ ({ header, children, footer, isOpen, expandable, onExpandToggle, }: ActionCardProps): JSX.Element;
62
+ displayName: string;
63
+ };
64
+
65
+ export declare interface ActionCardProps {
66
+ /**
67
+ * Content rendered inside the card header area with a
68
+ * `surface-container-lowest` background. Wrapped in a horizontal Stack
69
+ * with standardised padding so the consumer only provides the inner nodes.
70
+ */
71
+ header?: ReactNode;
72
+ /** Card body content. */
73
+ children: ReactNode;
74
+ /**
75
+ * Content rendered inside the card footer area. Wrapped in a horizontal
76
+ * Stack with standardised padding so the consumer only provides the inner
77
+ * nodes (typically action buttons).
78
+ */
79
+ footer?: ReactNode;
80
+ /**
81
+ * Whether the ActionCard is expandable.
82
+ * @default false
83
+ */
84
+ expandable?: boolean;
85
+ /**
86
+ * Whether the ActionCard is open or closed.
87
+ * @default true
88
+ */
89
+ isOpen?: boolean;
90
+ /**
91
+ * Called when the header is clicked in expandable mode.
92
+ * Required when using `isOpen` (controlled) so the parent can update its state.
93
+ */
94
+ onExpandToggle?: () => void;
95
+ }
96
+
97
+ export declare interface ActionConfirmation {
98
+ /**
99
+ * Icon to swap to when confirmed (e.g. `'check'` for a copy action).
100
+ * When omitted, the original icon is kept and shown as filled instead.
101
+ */
102
+ icon?: CommonIconNames;
103
+ /**
104
+ * Confirmation text shown next to the action group (e.g. "Copied").
105
+ */
106
+ text?: string;
107
+ /**
108
+ * Duration in ms before the confirmation auto-reverts.
109
+ * Defaults to `3000`. Set to `0` for toggle actions that stay until toggled off.
110
+ * @default 3000
111
+ */
112
+ duration?: number;
113
+ }
114
+
115
+ declare const align: {
116
+ readonly LEFT: "left";
117
+ readonly CENTER: "center";
118
+ readonly RIGHT: "right";
119
+ };
120
+
121
+ export declare type AlignItems = 'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline';
122
+
123
+ /**
124
+ * Types of announcements that can be made to screen readers.
125
+ */
126
+ export declare type AnnouncementType = 'added' | 'removed' | 'cleared' | 'component-error' | 'count-changed';
127
+
128
+ export declare const Avatar: ({ size, type: typeProp, name, image, initialsAmount, variant, }: AvatarProps) => JSX.Element;
129
+
130
+ declare const AVATAR_SIZES: {
131
+ readonly SM: "sm";
132
+ readonly MD: "md";
133
+ readonly LG: "lg";
134
+ };
135
+
136
+ export declare const AvatarGroup: ({ children, maxLength, total }: AvatarGroupProps) => JSX.Element;
137
+
138
+ export declare interface AvatarGroupProps {
139
+ /**
140
+ * The children of the button.
141
+ */
142
+ children: ReactNode;
143
+ /**
144
+ * Maximum number of avatars to display before showing a count
145
+ */
146
+ maxLength?: number;
147
+ /**
148
+ * Total number of avatars in the group
149
+ */
150
+ total?: number;
151
+ }
152
+
153
+ export declare interface AvatarProps extends React.HTMLAttributes<HTMLDivElement> {
154
+ /**
155
+ * The size of the avatar.
156
+ *
157
+ * Accepts a single value or a responsive object keyed by viewport.
158
+ *
159
+ * @default 'md'
160
+ *
161
+ * @remarks
162
+ * The values `'small' | 'medium' | 'large'` are **deprecated** and kept for
163
+ * backwards compatibility. They are mapped to `'sm' | 'md' | 'lg'` and will
164
+ * be removed in v3.0.0.
165
+ */
166
+ size?: ResponsiveType<AvatarSize | AvatarSizeLegacy>;
167
+ /**
168
+ * The type of the avatar
169
+ */
170
+ type?: 'initials' | 'check' | 'avatar' | 'image' | 'zvoove';
171
+ /**
172
+ * The image of the avatar
173
+ */
174
+ image?: string;
175
+ /**
176
+ * The name of the avatar
177
+ */
178
+ name?: string;
179
+ /**
180
+ * The amount of initials of the avatar
181
+ */
182
+ initialsAmount?: 1 | 2;
183
+ /**
184
+ * The variant of the avatar
185
+ */
186
+ variant?: 'round' | 'square';
187
+ }
188
+
189
+ export declare type AvatarSize = (typeof AVATAR_SIZES)[keyof typeof AVATAR_SIZES];
190
+
191
+ /* Excluded from this release type: AvatarSizeLegacy */
192
+
193
+ declare type AxisVariant = 'X' | 'Y';
194
+
195
+ export declare type BackgroundColors = 'background' | 'outline' | 'outline-variant' | 'outline-low' | 'primary' | 'primary-hover' | 'primary-active' | 'secondary' | 'tertiary' | 'primary-container' | 'secondary-container' | 'tertiary-container' | 'tertiary-container-hover' | 'tertiary-container-active' | 'primary-fixed' | 'primary-fixed-dim' | 'secondary-fixed' | 'secondary-fixed-dim' | 'tertiary-fixed' | 'tertiary-fixed-dim' | 'surface' | 'surface-bright' | 'surface-dim' | 'surface-variant' | 'surface-container-lowest' | 'surface-container-low' | 'surface-container' | 'surface-container-high' | 'surface-container-highest' | 'error' | 'error-container' | 'inverse-surface' | 'inverse-on-surface' | 'inverse-primary' | 'scrim' | 'yellow' | 'dark-yellow' | 'yellow-container' | 'green' | 'dark-green' | 'green-container' | 'pink' | 'dark-pink' | 'pink-container' | 'steel-blue' | 'dark-steel-blue' | 'steel-blue-container' | 'container-neutral' | 'container-neutral-hover' | 'code-surface' | 'code-surface-variant';
196
+
197
+ export declare const Badge: ({ children, variant, content, dot, }: BadgeProps) => JSX.Element;
198
+
199
+ export declare interface BadgeProps {
200
+ /**
201
+ * The children of the button.
202
+ */
203
+ children: ReactNode;
204
+ /**
205
+ * The variant of the component
206
+ */
207
+ variant?: 'primary' | 'secondary';
208
+ /**
209
+ * The content of the badge. If undefined, the badge will be hidden.
210
+ */
211
+ content?: ReactNode;
212
+ /**
213
+ * The dot prop changes a badge into a small dot
214
+ */
215
+ dot?: boolean;
216
+ }
217
+
218
+ export declare const Breadcrumbs: <T extends default_2.ElementType = "a">({ items, linkComponent: LinkComponent, homeIcon, }: BreadcrumbsProps<T>) => JSX.Element;
219
+
220
+ export declare type BreadcrumbsItem<T extends React.ElementType = 'a'> = {
221
+ label: string;
222
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
223
+
224
+ export declare type BreadcrumbsProps<T extends React.ElementType = 'a'> = {
225
+ /**
226
+ * The items of the component. <br />
227
+ * The items are displayed in the order they are passed. <br />
228
+ * `type BreadcrumbsItem = { label: string; href: string; onItemClick?: () => void; }`
229
+ */
230
+ items: BreadcrumbsItem<T>[];
231
+ /**
232
+ * The component to render for the link
233
+ * @default 'a'
234
+ */
235
+ linkComponent?: T | 'a';
236
+ /**
237
+ * The icon name for the home (first) breadcrumb item
238
+ * @default 'home'
239
+ */
240
+ homeIcon?: CommonIconNames;
241
+ };
242
+
243
+ declare const BREAKPOINTS: {
244
+ readonly minimum: 0;
245
+ readonly mobile: 768;
246
+ readonly tablet: 1024;
247
+ readonly laptop: 1280;
248
+ readonly desktop: 1536;
249
+ readonly wide: 1920;
250
+ readonly ultrawide: 2560;
251
+ };
252
+
253
+ export declare const Button: {
254
+ <T extends React.ElementType = "button">({ children, variant, hideLabel, as, icon, linkComponent, size, isLoading, ...props }: ButtonProps<T> & {
255
+ ref?: ForwardedRef<T>;
256
+ }): JSX.Element;
257
+ displayName: string;
258
+ };
259
+
260
+ export declare type ButtonProps<T extends React.ElementType = 'button'> = UnionAs & {
261
+ /**
262
+ * The children of the button.
263
+ */
264
+ children?: ReactNode;
265
+ /**
266
+ * The size of the button.
267
+ */
268
+ size?: ResponsiveType<'sm' | 'md' | 'lg'>;
269
+ /**
270
+ * The icon of the button.
271
+ */
272
+ icon?: CommonIconNames | Omit<IconProps, 'size' | 'color'>;
273
+ /**
274
+ * Hide the label of the button. <br />
275
+ * Only works if `icon` is provided.
276
+ */
277
+ hideLabel?: ResponsiveType<boolean>;
278
+ /**
279
+ * Handle click events.
280
+ */
281
+ onClick?: (event: MouseEvent_2<HTMLElement>) => void;
282
+ /**
283
+ * The variant is used
284
+ * to change the visual communication.
285
+ */
286
+ variant?: ResponsiveType<'text' | 'textSecondary' | 'filled' | 'outlined' | 'elevated' | 'tonal' | 'linkPrimary' | 'linkSecondary' | 'positive' | 'negative'>;
287
+ /**
288
+ * The component to render the button as. <br />
289
+ * This is useful if you want to use a different component for the button like a `Link` component from **Next.js** or **React Router**.
290
+ */
291
+ linkComponent?: T;
292
+ /**
293
+ * The ref of the button.
294
+ */
295
+ ref?: ForwardedRef<T>;
296
+ /**
297
+ * Whether the button is loading.
298
+ */
299
+ isLoading?: boolean;
300
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
301
+
302
+ export declare type ButtonsTranslations = {
303
+ cancel?: string;
304
+ clear?: string;
305
+ ok?: string;
306
+ };
307
+
308
+ export declare const Card: {
309
+ <T extends React.ElementType = "div">({ children, header, headerBgColor, footer, footerBgColor, hideHeaderBorder, borderRadius, elevation, variant, padding, margin, className, overflow, bgColor, height, width, minHeight, maxHeight, minWidth, maxWidth, borderStyle, interactive, as, linkComponent, ...restProps }: CardProps<T> & {
310
+ ref?: ForwardedRef<ComponentRef<T>>;
311
+ }): JSX.Element;
312
+ displayName: string;
313
+ };
314
+
315
+ export declare type CardProps<T extends React.ElementType = 'div'> = UnionAs_2 & {
316
+ /**
317
+ * The content of the card.
318
+ */
319
+ children?: ReactNode;
320
+ /**
321
+ * Content rendered in the header area.
322
+ * When provided, a border-bottom separator is added automatically.
323
+ */
324
+ header?: ReactNode;
325
+ /**
326
+ * The style of the border of the card. <br />
327
+ * Only used when variant is 'outlined'.
328
+ * @default 'solid'
329
+ */
330
+ borderStyle?: 'solid' | 'dashed' | 'dotted';
331
+ /**
332
+ * Background color applied to the header area.
333
+ * Only used when `header` is provided.
334
+ */
335
+ headerBgColor?: BackgroundColors;
336
+ /**
337
+ * Whether to hide the border-bottom separator in the header area.
338
+ * @default false
339
+ */
340
+ hideHeaderBorder?: boolean;
341
+ /**
342
+ * Content rendered below the body.
343
+ * Receives no extra styling — the consumer controls its appearance.
344
+ */
345
+ footer?: ReactNode;
346
+ /**
347
+ * Background color applied to the footer area.
348
+ * Only used when `footer` is provided.
349
+ */
350
+ footerBgColor?: BackgroundColors;
351
+ /**
352
+ * @deprecated Use the `height`, `width`, `minHeight`, `maxHeight`, `minWidth`, `maxWidth` props instead.
353
+ */
354
+ className?: string;
355
+ /**
356
+ * The height of the card.
357
+ * @default 'auto'
358
+ */
359
+ height?: ResponsiveType<number | string>;
360
+ /**
361
+ * The width of the card.
362
+ * @default '100%'
363
+ */
364
+ width?: ResponsiveType<number | string>;
365
+ /**
366
+ * The min height of the card.
367
+ * @default 'auto'
368
+ */
369
+ minHeight?: ResponsiveType<number | string>;
370
+ /**
371
+ * The max height of the card.
372
+ * @default 'auto'
373
+ */
374
+ maxHeight?: ResponsiveType<number | string>;
375
+ /**
376
+ * The min width of the card.
377
+ * @default 'auto'
378
+ */
379
+ minWidth?: ResponsiveType<number | string>;
380
+ /**
381
+ * The max width of the card.
382
+ * @default 'auto'
383
+ */
384
+ maxWidth?: ResponsiveType<number | string>;
385
+ /**
386
+ * The border radius of the card.
387
+ */
388
+ borderRadius?: 'none' | 'sm' | 'md' | 'lg' | 'xl';
389
+ /**
390
+ * The padding of the card.
391
+ */
392
+ padding?: ResponsiveType<Padding>;
393
+ /**
394
+ * The margin of the card.
395
+ */
396
+ margin?: ResponsiveType<Margin>;
397
+ /**
398
+ * The elevation/shadow of the card.
399
+ */
400
+ elevation?: 0 | 1 | 2 | 3 | 4 | 5;
401
+ /**
402
+ * The variant of the card.
403
+ */
404
+ variant?: 'outlined' | 'filled';
405
+ /**
406
+ * The overflow of the card.
407
+ */
408
+ overflow?: ResponsiveType<Overflow>;
409
+ /**
410
+ * The background color of the card.
411
+ */
412
+ bgColor?: BackgroundColors;
413
+ /**
414
+ * When `true`, the card shows a hover background color at 80% opacity and
415
+ * a pointer cursor. Automatically enabled when `onClick`, `linkComponent`,
416
+ * or `as="a"` is set. Pass `false` to opt out.
417
+ */
418
+ interactive?: boolean;
419
+ /**
420
+ * Handle click events on the card.
421
+ */
422
+ onClick?: (event: MouseEvent_2<HTMLElement>) => void;
423
+ /**
424
+ * A custom component to render the card root as. Useful for router link
425
+ * components (e.g. Next.js `Link` or React Router `Link`).
426
+ * When provided, the `as` prop is ignored.
427
+ */
428
+ linkComponent?: T;
429
+ /**
430
+ * Ref forwarded to the root element.
431
+ */
432
+ ref?: ForwardedRef<ComponentRef<T>>;
433
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children' | 'className'>;
434
+
435
+ /**
436
+ * Event emitted when files are changed (added, removed, replaced, or cleared).
437
+ */
438
+ export declare interface ChangeEvent {
439
+ /**
440
+ * The type of change that occurred.
441
+ */
442
+ action: 'add' | 'remove' | 'replace' | 'clear';
443
+ /**
444
+ * Files that were added in this action.
445
+ * Present when action is 'add' or 'replace'.
446
+ */
447
+ addedFiles?: FileItem[];
448
+ /**
449
+ * Files that were removed in this action.
450
+ * Present when action is 'remove'.
451
+ */
452
+ removedFiles?: FileItem[];
453
+ /**
454
+ * The complete list of files after the change.
455
+ */
456
+ allFiles: FileItem[];
457
+ /**
458
+ * Component-level error if one occurred during the action.
459
+ */
460
+ componentError?: {
461
+ code: COMPONENT_ERROR;
462
+ message: string;
463
+ };
464
+ }
465
+
466
+ export declare const ChatBubble: ForwardRefExoticComponent<ChatBubbleProps & RefAttributes<HTMLDivElement>>;
467
+
468
+ export declare const ChatBubbleMedia: ForwardRefExoticComponent<ChatBubbleMediaProps & RefAttributes<HTMLElement>>;
469
+
470
+ export declare interface ChatBubbleMediaProps extends React.HTMLAttributes<HTMLElement> {
471
+ /** The media element (img, video, or iframe) to render. */
472
+ children: React.ReactNode;
473
+ /** Optional caption displayed below the media. */
474
+ caption?: string;
475
+ }
476
+
477
+ export declare interface ChatBubbleProps extends React.HTMLAttributes<HTMLDivElement> {
478
+ /**
479
+ * The variant determines alignment and styling of the bubble.
480
+ * - sender: right-aligned, primary blue background
481
+ * - receiver: left-aligned, light surface background
482
+ */
483
+ variant?: ChatBubbleVariant;
484
+ /**
485
+ * Visual state of the bubble.
486
+ * - default: renders children inside a styled bubble
487
+ * - thinking: receiver-only, shows italic label with animated dots
488
+ * - error: reserved for error state styling
489
+ * @default 'default'
490
+ */
491
+ state?: ChatBubbleState;
492
+ /**
493
+ * The message content to display in the bubble. Accepts any ReactNode —
494
+ * plain text, HTML via ContentBlock, custom components, media, tables, etc.
495
+ */
496
+ children?: React.ReactNode;
497
+ /**
498
+ * Phrases to cycle through while in the "thinking" state.
499
+ * Each phrase is shown with animated dots appended.
500
+ * @default ['Einen Moment bitte', 'Ich denke nach', 'Wird verarbeitet']
501
+ */
502
+ thinkingPhrases?: string[];
503
+ /**
504
+ * Props forwarded to the Avatar component.
505
+ * When not provided, defaults to `{ type: 'zvoove' }` for receiver
506
+ * and auto-detects type based on `image`/`name` for sender.
507
+ */
508
+ avatar?: AvatarProps;
509
+ /**
510
+ * Rich content rendered below the bubble without bubble styling — cards,
511
+ * tables, or structured data. When both `children` and `attachment` are set,
512
+ * the text appears inside a styled bubble and the attachment renders directly
513
+ * below, aligned with the bubble. When only `attachment` is set, it renders
514
+ * next to the avatar without a surrounding bubble.
515
+ */
516
+ attachment?: React.ReactNode;
517
+ /**
518
+ * Footer content rendered at the bottom of the ContentSlot, below the bubble
519
+ * and attachment. Typically used for `MessageActions`.
520
+ */
521
+ footer?: React.ReactNode;
522
+ }
523
+
524
+ export declare type ChatBubbleState = 'default' | 'thinking' | 'error';
525
+
526
+ export declare type ChatBubbleVariant = 'sender' | 'receiver';
527
+
528
+ export declare const Checkbox: ({ checked, name, id, disabled, error, indeterminate, value, label, onChange, }: CheckboxProps) => JSX.Element;
529
+
530
+ export declare interface CheckboxProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange'> {
531
+ /**
532
+ * Handle change events.
533
+ */
534
+ onChange?: ChangeEventHandler<HTMLInputElement>;
535
+ /**
536
+ * Handle the label of the checkbox.
537
+ */
538
+ label: ReactNode;
539
+ /**
540
+ * Handle the name of the checkbox.
541
+ */
542
+ name?: string;
543
+ /**
544
+ * Handle the id of the checkbox.
545
+ * @default auto-generated
546
+ */
547
+ id?: string;
548
+ /**
549
+ * Handle the value of the checkbox.
550
+ */
551
+ value?: string;
552
+ /**
553
+ * Handle if the checkbox is checked.
554
+ */
555
+ checked?: boolean;
556
+ /**
557
+ * Handle if the checkbox is disabled.
558
+ */
559
+ disabled?: boolean;
560
+ /**
561
+ * Handle if the checkbox has an error.
562
+ */
563
+ error?: boolean;
564
+ /**
565
+ * Handle if the checkbox has an indeterminate state.
566
+ */
567
+ indeterminate?: boolean;
568
+ }
569
+
570
+ export declare const Chip: default_2.ForwardRefExoticComponent<ChipProps & default_2.RefAttributes<HTMLButtonElement>>;
571
+
572
+ export declare type ChipProps = ChipPropsTypeIcon & {
573
+ /**
574
+ * The children of the button.
575
+ */
576
+ label: string;
577
+ /**
578
+ * The variant of the component
579
+ */
580
+ variant?: 'primary' | 'secondary' | 'pending' | 'confirmed' | 'rejected' | 'skipped';
581
+ /**
582
+ * The drop shadow of the component
583
+ */
584
+ elevated?: boolean;
585
+ /**
586
+ * Whether the component is readonly or not. <br />
587
+ * This is used for `choice` chips.
588
+ */
589
+ readonly?: boolean;
590
+ /**
591
+ * Whether the component is disabled or not.
592
+ */
593
+ disabled?: boolean;
594
+ /**
595
+ * The size of the component
596
+ */
597
+ size?: 'medium' | 'large';
598
+ /**
599
+ * The action to perform when the delete button is clicked.
600
+ * This is used only for `input` type chips.
601
+ */
602
+ onDelete?: () => void;
603
+ /**
604
+ * The action to perform when the chip is clicked.
605
+ * This is used only for `filter` and 'choice' type chips.
606
+ */
607
+ onToggleOpen?: () => void;
608
+ /**
609
+ * Whether to show the dropdown icon or not.
610
+ * This is used only for `filter` and 'choice' type chips.
611
+ * @default true
612
+ */
613
+ showDropdownIcon?: boolean;
614
+ /**
615
+ * The number of lines to truncate the text.
616
+ * @default undefined
617
+ */
618
+ truncate?: TypographyProps['truncate'];
619
+ };
620
+
621
+ declare type ChipPropsTypeIcon = {
622
+ /**
623
+ * The type of the component
624
+ */
625
+ type?: 'input' | 'filter' | 'assistive' | 'suggestion';
626
+ /**
627
+ * The icon to show on the left side of the button.
628
+ */
629
+ icon?: CommonIconNames;
630
+ } | {
631
+ type?: 'choice';
632
+ icon?: never;
633
+ };
634
+
635
+ export declare const CodeBlock: {
636
+ ({ code, filename, language, variant, ...props }: CodeBlockProps): JSX.Element;
637
+ displayName: string;
638
+ };
639
+
640
+ export declare interface CodeBlockProps extends React.HTMLAttributes<HTMLPreElement> {
641
+ /**
642
+ * The source code to display.
643
+ */
644
+ code: string;
645
+ /**
646
+ * Optional filename shown in the header bar (block variant only).
647
+ */
648
+ filename?: string;
649
+ /**
650
+ * Programming language for syntax highlighting (e.g. `"typescript"`,
651
+ * `"python"`, `"bash"`). When provided the code is tokenized and
652
+ * coloured via react-syntax-highlighter / Prism.
653
+ * @default 'text'
654
+ */
655
+ language?: string;
656
+ /**
657
+ * Display variant. In `auto` mode the component renders inline for
658
+ * single-line code without a filename, and as a full block otherwise.
659
+ * Use `inline` or `block` to force a specific rendering.
660
+ * @default 'auto'
661
+ */
662
+ variant?: 'auto' | 'block' | 'inline';
663
+ }
664
+
665
+ export declare type ColumnAlign = (typeof align)[keyof typeof align];
666
+
667
+ export declare type ColumnId<T extends readonly TableColumnProps[]> = T[number]['id'];
668
+
669
+ export declare type CommonIconNames = keyof typeof commonIconsMap;
670
+
671
+ export declare const commonIconsMap: {
672
+ readonly add: Icon_2;
673
+ readonly 'add-circle': Icon_2;
674
+ readonly 'add-file': Icon_2;
675
+ readonly agent: Icon_2;
676
+ readonly airplane: Icon_2;
677
+ readonly archive: Icon_2;
678
+ readonly 'arrow-back': Icon_2;
679
+ readonly 'arrow-bend': Icon_2;
680
+ readonly 'arrow-elbow-down-left': Icon_2;
681
+ readonly 'arrow-down': Icon_2;
682
+ readonly 'arrow-forward': Icon_2;
683
+ readonly 'arrow-left-right': Icon_2;
684
+ readonly 'arrow-up': Icon_2;
685
+ readonly article: Icon_2;
686
+ readonly automate: Icon_2;
687
+ readonly backspace: Icon_2;
688
+ readonly bank: Icon_2;
689
+ readonly bicycle: Icon_2;
690
+ readonly billing: Icon_2;
691
+ readonly binoculars: Icon_2;
692
+ readonly break: Icon_2;
693
+ readonly bus: Icon_2;
694
+ readonly calendar: Icon_2;
695
+ readonly 'calendar-blank': Icon_2;
696
+ readonly 'calendar-check': Icon_2;
697
+ readonly 'calendar-dot': Icon_2;
698
+ readonly 'calendar-x': Icon_2;
699
+ readonly camera: Icon_2;
700
+ readonly car: Icon_2;
701
+ readonly cart: Icon_2;
702
+ readonly 'cash-money': Icon_2;
703
+ readonly certificate: Icon_2;
704
+ readonly 'chat-bubble': Icon_2;
705
+ readonly 'chat-dots': Icon_2;
706
+ readonly 'chat-slash': Icon_2;
707
+ readonly chats: Icon_2;
708
+ readonly check: Icon_2;
709
+ readonly circle: Icon_2;
710
+ readonly 'check-circle': Icon_2;
711
+ readonly checkbox: Icon_2;
712
+ readonly 'checkbox-empty': Icon_2;
713
+ readonly 'checkbox-indefinitely': Icon_2;
714
+ readonly checks: Icon_2;
715
+ readonly 'chevron-down': Icon_2;
716
+ readonly 'chevron-left': Icon_2;
717
+ readonly 'chevron-right': Icon_2;
718
+ readonly 'chevron-up': Icon_2;
719
+ readonly 'circle-notch': Icon_2;
720
+ readonly close: Icon_2;
721
+ readonly 'close-circle': Icon_2;
722
+ readonly 'cloud-download': Icon_2;
723
+ readonly 'cloud-upload': Icon_2;
724
+ readonly 'clock-countdown': Icon_2;
725
+ readonly 'clock-person': Icon_2;
726
+ readonly command: Icon_2;
727
+ readonly columns: Icon_2;
728
+ readonly control: Icon_2;
729
+ readonly copy: Icon_2;
730
+ readonly 'currency-dollar': Icon_2;
731
+ readonly 'currency-dollar-circle': Icon_2;
732
+ readonly 'currency-gbp': Icon_2;
733
+ readonly 'dark-mode': Icon_2;
734
+ readonly deactivate: Icon_2;
735
+ readonly delete: Icon_2;
736
+ readonly 'diagram-view': Icon_2;
737
+ readonly download: Icon_2;
738
+ readonly drag: Icon_2;
739
+ readonly edit: Icon_2;
740
+ readonly error: Icon_2;
741
+ readonly 'exclamation-mark': Icon_2;
742
+ readonly expand: Icon_2;
743
+ readonly expenses: Icon_2;
744
+ readonly 'face-id': Icon_2;
745
+ readonly file: Icon_2;
746
+ readonly 'simple-file-archive': Icon_2;
747
+ readonly 'simple-file-audio': Icon_2;
748
+ readonly 'simple-file-c': Icon_2;
749
+ readonly 'simple-file-c-sharp': Icon_2;
750
+ readonly 'simple-file-code': Icon_2;
751
+ readonly 'simple-file-cpp': Icon_2;
752
+ readonly 'simple-file-css': Icon_2;
753
+ readonly 'simple-file-csv': Icon_2;
754
+ readonly 'simple-file-doc': Icon_2;
755
+ readonly 'simple-file-html': Icon_2;
756
+ readonly 'simple-file-image': Icon_2;
757
+ readonly 'simple-file-ini': Icon_2;
758
+ readonly 'simple-file-jpg': Icon_2;
759
+ readonly 'simple-file-js': Icon_2;
760
+ readonly 'simple-file-jsx': Icon_2;
761
+ readonly 'simple-file-md': Icon_2;
762
+ readonly 'simple-file-pdf': Icon_2;
763
+ readonly 'simple-file-png': Icon_2;
764
+ readonly 'simple-file-ppt': Icon_2;
765
+ readonly 'simple-file-py': Icon_2;
766
+ readonly 'simple-file-rs': Icon_2;
767
+ readonly 'simple-file-sql': Icon_2;
768
+ readonly 'simple-file-svg': Icon_2;
769
+ readonly 'simple-file-ts': Icon_2;
770
+ readonly 'simple-file-tsx': Icon_2;
771
+ readonly 'simple-file-text': Icon_2;
772
+ readonly 'simple-file-txt': Icon_2;
773
+ readonly 'simple-file-video': Icon_2;
774
+ readonly 'simple-file-vue': Icon_2;
775
+ readonly 'simple-file-xls': Icon_2;
776
+ readonly 'simple-file-zip': Icon_2;
777
+ readonly filter: Icon_2;
778
+ readonly filters: Icon_2;
779
+ readonly 'first-page': Icon_2;
780
+ readonly 'flag-de': ({ size }: {
781
+ size?: number;
782
+ }) => JSX.Element;
783
+ readonly 'flag-es': ({ size }: {
784
+ size?: number;
785
+ }) => JSX.Element;
786
+ readonly 'flag-fr': ({ size }: {
787
+ size?: number;
788
+ }) => JSX.Element;
789
+ readonly 'flag-gb': ({ size }: {
790
+ size?: number;
791
+ }) => JSX.Element;
792
+ readonly 'flag-nl': ({ size }: {
793
+ size?: number;
794
+ }) => JSX.Element;
795
+ readonly folder: Icon_2;
796
+ readonly 'folder-open': Icon_2;
797
+ readonly 'grid-view': Icon_2;
798
+ readonly 'hard-hat': Icon_2;
799
+ readonly 'head-circuit': Icon_2;
800
+ readonly help: Icon_2;
801
+ readonly hide: Icon_2;
802
+ readonly home: Icon_2;
803
+ readonly images: Icon_2;
804
+ readonly info: Icon_2;
805
+ readonly invoice: Icon_2;
806
+ readonly job: Icon_2;
807
+ readonly 'key-return': Icon_2;
808
+ readonly keyboard: Icon_2;
809
+ readonly knowledge: Icon_2;
810
+ readonly language: Icon_2;
811
+ readonly 'last-page': Icon_2;
812
+ readonly 'light-mode': Icon_2;
813
+ readonly 'list-view': Icon_2;
814
+ readonly location: Icon_2;
815
+ readonly 'location-pin': Icon_2;
816
+ readonly lock: Icon_2;
817
+ readonly 'lock-key': Icon_2;
818
+ readonly 'lock-key-open': Icon_2;
819
+ readonly menu: Icon_2;
820
+ readonly metadata: Icon_2;
821
+ readonly code: Icon_2;
822
+ readonly microphone: Icon_2;
823
+ readonly minus: Icon_2;
824
+ readonly 'more-horizontal': Icon_2;
825
+ readonly 'more-vertical': Icon_2;
826
+ readonly moped: Icon_2;
827
+ readonly 'navigation-arrow': Icon_2;
828
+ readonly notifications: Icon_2;
829
+ readonly note: Icon_2;
830
+ readonly numpad: Icon_2;
831
+ readonly option: Icon_2;
832
+ readonly 'open-in-new-tab': Icon_2;
833
+ readonly order: Icon_2;
834
+ readonly organization: Icon_2;
835
+ readonly pause: Icon_2;
836
+ readonly attachment: Icon_2;
837
+ readonly phone: Icon_2;
838
+ readonly pin: Icon_2;
839
+ readonly 'pin-simple': Icon_2;
840
+ readonly 'pin-simple-slash': Icon_2;
841
+ readonly 'pin-slash': Icon_2;
842
+ readonly 'piggy-bank': Icon_2;
843
+ readonly plant: Icon_2;
844
+ readonly printer: Icon_2;
845
+ readonly privacy: Icon_2;
846
+ readonly 'qr-code': Icon_2;
847
+ readonly refresh: Icon_2;
848
+ readonly remark: Icon_2;
849
+ readonly robot: Icon_2;
850
+ readonly save: Icon_2;
851
+ readonly search: Icon_2;
852
+ readonly 'search-plus': Icon_2;
853
+ readonly 'send-message': Icon_2;
854
+ readonly settings: Icon_2;
855
+ readonly 'setup-time': Icon_2;
856
+ readonly shapes: Icon_2;
857
+ readonly show: Icon_2;
858
+ readonly sidebar: Icon_2;
859
+ readonly signature: Icon_2;
860
+ readonly 'sign-out': Icon_2;
861
+ readonly 'skip-forward': Icon_2;
862
+ readonly smartphone: Icon_2;
863
+ readonly sparkle: Icon_2;
864
+ readonly star: Icon_2;
865
+ readonly start: Icon_2;
866
+ readonly stop: Icon_2;
867
+ readonly sick: Icon_2;
868
+ readonly table: Icon_2;
869
+ readonly 'thumb-up': Icon_2;
870
+ readonly 'thumb-down': Icon_2;
871
+ readonly taxi: Icon_2;
872
+ readonly 'text-align-center': Icon_2;
873
+ readonly 'text-align-justify': Icon_2;
874
+ readonly 'text-align-left': Icon_2;
875
+ readonly 'text-align-right': Icon_2;
876
+ readonly 'text-t': Icon_2;
877
+ readonly ticket: Icon_2;
878
+ readonly notches: Icon_2;
879
+ readonly time: Icon_2;
880
+ readonly timer: Icon_2;
881
+ readonly 'time-sheet-download': Icon_2;
882
+ readonly 'time-sheet-upload': Icon_2;
883
+ readonly train: Icon_2;
884
+ readonly translate: Icon_2;
885
+ readonly travel: Icon_2;
886
+ readonly unfold: Icon_2;
887
+ readonly user: Icon_2;
888
+ readonly upload: Icon_2;
889
+ readonly 'user-account': Icon_2;
890
+ readonly users: Icon_2;
891
+ readonly vacation: Icon_2;
892
+ readonly wallet: Icon_2;
893
+ readonly warning: Icon_2;
894
+ readonly wrench: Icon_2;
895
+ };
896
+
897
+ /**
898
+ * Error types that affect the component as a whole.
899
+ */
900
+ export declare enum COMPONENT_ERROR {
901
+ /** Total size of all files exceeds maxTotalSize. */
902
+ TOTAL_SIZE_EXCEEDED = "total-size-exceeded",
903
+ /** Number of files exceeds maxCount. */
904
+ MAX_COUNT_EXCEEDED = "max-count-exceeded",
905
+ /** Number of files is below minCount. */
906
+ MIN_COUNT_NOT_MET = "min-count-not-met",
907
+ /** A duplicate file was detected. */
908
+ DUPLICATE_FILE = "duplicate-file"
909
+ }
910
+
911
+ export declare const ContentBlock: {
912
+ ({ children }: ContentBlockProps): JSX.Element;
913
+ displayName: string;
914
+ };
915
+
916
+ export declare interface ContentBlockProps {
917
+ /**
918
+ * The children of the ContentBlock.
919
+ */
920
+ children: ReactNode;
921
+ }
922
+
923
+ export declare type CustomCommonIconNames = keyof typeof customCommonIconsMap;
924
+
925
+ /**
926
+ * Custom common icons — brand/product icons not from Phosphor.
927
+ * Unlike Phosphor icons, these accept a `color` prop to switch between
928
+ * their default duotone brand colors and a single inherited color.
929
+ */
930
+ export declare const customCommonIconsMap: {
931
+ readonly zvoove: ({ size, color }: ZvooveLogoProps) => JSX.Element;
932
+ readonly 'zvoove-one': ({ size, color }: {
933
+ size?: number;
934
+ color?: string;
935
+ }) => JSX.Element;
936
+ readonly 'zvoove-recruit': ({ size, color, }: {
937
+ size?: number;
938
+ color?: string;
939
+ }) => JSX.Element;
940
+ readonly 'zvoove-invoice-monitor': ({ size, color, }: {
941
+ size?: number;
942
+ color?: string;
943
+ }) => JSX.Element;
944
+ readonly 'zvoove-go': ({ size, color }: {
945
+ size?: number;
946
+ color?: string;
947
+ }) => JSX.Element;
948
+ readonly 'zvoove-intelligence': ({ size, color, }: {
949
+ size?: number;
950
+ color?: string;
951
+ }) => JSX.Element;
952
+ readonly 'zvoove-free': ({ size, color, }: {
953
+ size?: number;
954
+ color?: string;
955
+ }) => JSX.Element;
956
+ readonly 'zvoove-work-expert': ({ size, color, }: {
957
+ size?: number;
958
+ color?: string;
959
+ }) => JSX.Element;
960
+ readonly 'zvoove-elevate': ({ size, color, }: {
961
+ size?: number;
962
+ color?: string;
963
+ }) => JSX.Element;
964
+ readonly 'zvoove-cashlink': ({ size, color, }: {
965
+ size?: number;
966
+ color?: string;
967
+ }) => JSX.Element;
968
+ readonly 'zvoove-docs-ai': ({ size, color, }: {
969
+ size?: number;
970
+ color?: string;
971
+ }) => JSX.Element;
972
+ readonly 'cockpit-x': ({ size, color }: {
973
+ size?: number;
974
+ color?: string;
975
+ }) => JSX.Element;
976
+ };
977
+
978
+ declare interface CustomIconProps {
979
+ /**
980
+ * The type of the icon. <br />
981
+ * Only available for File Type Icons
982
+ */
983
+ type?: IconTypes;
984
+ }
985
+
986
+ export declare const DatePicker: (props: DatePickerProps) => JSX.Element;
987
+
988
+ export declare interface DatePickerProps extends Omit<TextFieldProps, 'onChange' | 'value' | 'clearable' | 'icon' | 'isFocused' | 'onIconClick' | 'iconPosition'> {
989
+ /**
990
+ * The label that will be displayed above the input. <br />
991
+ * It is required for accessibility purposes.
992
+ */
993
+ label: string;
994
+ /**
995
+ * The value of the date picker.
996
+ */
997
+ value?: string;
998
+ /**
999
+ * The function that will be called when the date picker value changes.
1000
+ */
1001
+ onChange?: (e: React.ChangeEvent<HTMLInputElement>, date?: Date) => void;
1002
+ /**
1003
+ * If true, the date picker will be open when the input is focused.
1004
+ */
1005
+ openOnFocus?: boolean;
1006
+ /**
1007
+ * The name of the date picker.
1008
+ */
1009
+ name: string;
1010
+ /**
1011
+ * The locale of the date picker.
1012
+ * @default de-DE
1013
+ */
1014
+ locale?: string;
1015
+ /**
1016
+ * The maximum date that can be selected. <br/>
1017
+ * format: YYYY-MM-DD <br/>
1018
+ * This will determine the end year range for the date picker.
1019
+ * @default 50 years from now
1020
+ */
1021
+ maxDate?: string;
1022
+ /**
1023
+ * The minimum date that can be selected. <br/>
1024
+ * format: YYYY-MM-DD <br/>
1025
+ * This will determine the start year range for the date picker.
1026
+ * @default 90 years ago
1027
+ */
1028
+ minDate?: string;
1029
+ /**
1030
+ * The translations of the buttons. <br/>
1031
+ * In case the locale is not supported you can set custom translations.
1032
+ * @default { cancel: 'Abbrechen ', clear: 'Löschen', ok: 'OK' }
1033
+ */
1034
+ buttonsTranslations?: ButtonsTranslations;
1035
+ /**
1036
+ * If true, the date picker will close automatically when a date is selected.
1037
+ * @default false
1038
+ */
1039
+ closeOnSelect?: boolean;
1040
+ /**
1041
+ * The placeholder of the date picker. <br/>
1042
+ * If not provided, the placeholder will be based on the locale (e.g. 'TT.MM.JJJJ' for 'de-DE').
1043
+ */
1044
+ placeholder?: string;
1045
+ }
1046
+
1047
+ export declare const DEFAULT_ANNOUNCEMENTS: {
1048
+ added: (count: number, total: number) => string;
1049
+ removed: (total: number) => string;
1050
+ cleared: () => string;
1051
+ 'component-error': (message: string) => string;
1052
+ 'count-changed': (total: number) => string;
1053
+ };
1054
+
1055
+ /**
1056
+ * Default icon for unknown file types
1057
+ */
1058
+ export declare const DEFAULT_FILE_ICON: FileIconNames;
1059
+
1060
+ export declare const DEFAULT_LABELS: UploaderLabels;
1061
+
1062
+ export declare type Density = 'default' | '-2' | '-4';
1063
+
1064
+ export declare const Dialog: ({ open, onClose, children, closeOnBackdropClick, closeOnEsc, padding, size, zIndex, }: DialogProps) => ReactPortal | null;
1065
+
1066
+ /**
1067
+ * Global manager for Dialog components to track open dialogs.
1068
+ * Maintains a stack order so nested/stacked dialogs can determine
1069
+ * which dialog is topmost (for focus trapping).
1070
+ */
1071
+ declare class DialogManager {
1072
+ private readonly dialogStack;
1073
+ private readonly closeCallbacks;
1074
+ /**
1075
+ * Register a Dialog as open with its close callback.
1076
+ * The dialog is pushed to the top of the stack.
1077
+ */
1078
+ registerOpenDialog(dialogId: string, closeCallback: () => void): void;
1079
+ /**
1080
+ * Unregister a Dialog as closed.
1081
+ * The dialog is removed from the stack.
1082
+ */
1083
+ unregisterOpenDialog(dialogId: string): void;
1084
+ /**
1085
+ * Close all other Dialogs except the specified one
1086
+ */
1087
+ closeOtherDialogs(excludeDialogId: string): void;
1088
+ /**
1089
+ * Check if the given dialog is the topmost (last opened) dialog
1090
+ */
1091
+ isTopDialog(dialogId: string): boolean;
1092
+ /**
1093
+ * Check if any Dialogs are currently open
1094
+ */
1095
+ hasOpenDialogs(): boolean;
1096
+ /**
1097
+ * Get all currently open Dialog IDs
1098
+ */
1099
+ getOpenDialogs(): string[];
1100
+ /**
1101
+ * Clear all registered Dialogs (useful for cleanup)
1102
+ */
1103
+ clear(): void;
1104
+ }
1105
+
1106
+ export declare const dialogManager: DialogManager;
1107
+
1108
+ export declare interface DialogProps {
1109
+ /**
1110
+ * Controls whether the dialog is open or closed.
1111
+ */
1112
+ open: boolean;
1113
+ /**
1114
+ * Callback function called when the dialog is closed.
1115
+ */
1116
+ onClose: () => void;
1117
+ /**
1118
+ * The main content of the dialog.
1119
+ */
1120
+ children: ReactNode;
1121
+ /**
1122
+ * Whether clicking the backdrop should close the dialog.
1123
+ */
1124
+ closeOnBackdropClick?: boolean;
1125
+ /**
1126
+ * Whether pressing the Escape key should close the dialog.
1127
+ */
1128
+ closeOnEsc?: boolean;
1129
+ /**
1130
+ * Whether to remove the default padding from the dialog content.
1131
+ * Useful for when the dialog has full width content/dividers.
1132
+ * @deprecated Use `padding` prop instead.
1133
+ */
1134
+ removePadding?: boolean;
1135
+ /**
1136
+ * The padding of the dialog content.
1137
+ */
1138
+ padding?: CardProps['padding'];
1139
+ /**
1140
+ * The size of the dialog.
1141
+ * @default none
1142
+ */
1143
+ size?: ResponsiveType<DialogSize>;
1144
+ /**
1145
+ * The z-index of the dialog.
1146
+ * @default 20
1147
+ */
1148
+ zIndex?: number;
1149
+ }
1150
+
1151
+ declare type DialogSize = 'sm' | 'md' | 'lg' | 'none' | 'fullscreen';
1152
+
1153
+ declare const direction: {
1154
+ readonly ASC: "asc";
1155
+ readonly DESC: "desc";
1156
+ readonly NONE: "none";
1157
+ };
1158
+
1159
+ export declare const Divider: ({ variant, color, }: DividerProps) => JSX.Element;
1160
+
1161
+ export declare interface DividerProps {
1162
+ /**
1163
+ * The variant to use.
1164
+ */
1165
+ variant?: 'fullWidth' | 'inset' | 'middle';
1166
+ /**
1167
+ * The color of the divider.
1168
+ * Accepts any background color token name.
1169
+ * @default 'outline-variant'
1170
+ */
1171
+ color?: BackgroundColors;
1172
+ }
1173
+
1174
+ export declare const Expandable: {
1175
+ <T extends React.ElementType = "div">({ children, isOpen, as: Component, ...props }: ExpandableProps<T>): JSX.Element;
1176
+ displayName: string;
1177
+ };
1178
+
1179
+ export declare type ExpandableProps<T extends React.ElementType = 'div'> = Omit<React.ComponentPropsWithoutRef<T>, 'as' | 'children'> & {
1180
+ /**
1181
+ * The children of the Expandable.
1182
+ */
1183
+ children: ReactNode;
1184
+ /**
1185
+ * Whether the Expandable is open or closed.
1186
+ */
1187
+ isOpen?: boolean;
1188
+ as?: 'div' | 'td' | 'tr' | 'th' | 'tbody' | 'thead' | 'tfoot' | 'section' | 'article' | 'main' | 'footer' | 'header' | 'aside' | 'nav' | 'form' | 'iframe' | 'picture' | 'video' | 'audio' | 'canvas' | 'embed' | 'object' | T;
1189
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
1190
+
1191
+ declare interface ExpandableRowConfig {
1192
+ id: string;
1193
+ render: React.ReactNode;
1194
+ }
1195
+
1196
+ /**
1197
+ * Recursively extracts the raw text content from a React node tree.
1198
+ * Useful for pulling the string out of `<pre><code>…</code></pre>` children.
1199
+ */
1200
+ export declare function extractText(node: ReactNode): string;
1201
+
1202
+ export declare type FeedbackType = 'positive' | 'negative' | null;
1203
+
1204
+ /**
1205
+ * Error types that can occur for individual files during validation.
1206
+ */
1207
+ export declare enum FILE_ERROR {
1208
+ /** File size exceeds the maxFileSize limit. */
1209
+ FILE_TOO_LARGE = "file-too-large",
1210
+ /** File type does not match the accepted types. */
1211
+ INVALID_TYPE = "invalid-type",
1212
+ /** File has zero bytes. */
1213
+ EMPTY_FILE = "empty-file",
1214
+ /** Adding this file would exceed the maxCount limit. */
1215
+ MAX_COUNT_EXCEEDED = "max-count-exceeded",
1216
+ /** File is a duplicate of an existing file. */
1217
+ DUPLICATE_FILE = "duplicate-file"
1218
+ }
1219
+
1220
+ /**
1221
+ * Status of a file in the upload process.
1222
+ */
1223
+ export declare enum FILE_STATUS {
1224
+ /** File is added but upload has not started. */
1225
+ IDLE = "idle",
1226
+ /** File is queued and waiting for upload. */
1227
+ PENDING = "pending",
1228
+ /** File upload is in progress. */
1229
+ UPLOADING = "uploading",
1230
+ /** File upload was canceled by user. */
1231
+ CANCELED = "canceled",
1232
+ /** File upload failed. */
1233
+ FAILED = "failed",
1234
+ /** File upload completed successfully. */
1235
+ SUCCESS = "success"
1236
+ }
1237
+
1238
+ /**
1239
+ * Maps file extensions to their corresponding icon names.
1240
+ * Use `getIconForFileExtension` to get an icon name from a file extension.
1241
+ */
1242
+ export declare const fileExtensionToIconMap: Record<string, FileIconNames>;
1243
+
1244
+ export declare type FileIconNames = keyof typeof fileIconsMap;
1245
+
1246
+ export declare const fileIconsMap: {
1247
+ readonly 'file-empty': ({ type }: CustomIconProps) => JSX.Element;
1248
+ readonly 'file-pdf': ({ type }: CustomIconProps) => JSX.Element;
1249
+ readonly 'file-folder': ({ type }: CustomIconProps) => JSX.Element;
1250
+ readonly 'file-image': ({ type }: CustomIconProps) => JSX.Element;
1251
+ readonly 'file-video': ({ type }: CustomIconProps) => JSX.Element;
1252
+ readonly 'file-video-2': ({ type }: CustomIconProps) => JSX.Element;
1253
+ readonly 'file-audio': ({ type }: CustomIconProps) => JSX.Element;
1254
+ readonly 'file-code': ({ type }: CustomIconProps) => JSX.Element;
1255
+ readonly 'file-document': ({ type }: CustomIconProps) => JSX.Element;
1256
+ readonly 'file-spreadsheet': ({ type }: CustomIconProps) => JSX.Element;
1257
+ readonly 'file-image-img': ({ type }: CustomIconProps) => JSX.Element;
1258
+ readonly 'file-image-jpg': ({ type }: CustomIconProps) => JSX.Element;
1259
+ readonly 'file-image-jpeg': ({ type }: CustomIconProps) => JSX.Element;
1260
+ readonly 'file-image-png': ({ type }: CustomIconProps) => JSX.Element;
1261
+ readonly 'file-image-webp': ({ type }: CustomIconProps) => JSX.Element;
1262
+ readonly 'file-image-tiff': ({ type }: CustomIconProps) => JSX.Element;
1263
+ readonly 'file-image-gif': ({ type }: CustomIconProps) => JSX.Element;
1264
+ readonly 'file-image-svg': ({ type }: CustomIconProps) => JSX.Element;
1265
+ readonly 'file-image-eps': ({ type }: CustomIconProps) => JSX.Element;
1266
+ readonly 'file-document-pdf': ({ type }: CustomIconProps) => JSX.Element;
1267
+ readonly 'file-document-doc': ({ type }: CustomIconProps) => JSX.Element;
1268
+ readonly 'file-document-docx': ({ type }: CustomIconProps) => JSX.Element;
1269
+ readonly 'file-document-txt': ({ type }: CustomIconProps) => JSX.Element;
1270
+ readonly 'file-document-csv': ({ type }: CustomIconProps) => JSX.Element;
1271
+ readonly 'file-document-xls': ({ type }: CustomIconProps) => JSX.Element;
1272
+ readonly 'file-document-xlsx': ({ type }: CustomIconProps) => JSX.Element;
1273
+ readonly 'file-document-ppt': ({ type }: CustomIconProps) => JSX.Element;
1274
+ readonly 'file-document-pptx': ({ type }: CustomIconProps) => JSX.Element;
1275
+ readonly 'file-design-fig': ({ type }: CustomIconProps) => JSX.Element;
1276
+ readonly 'file-design-ai': ({ type }: CustomIconProps) => JSX.Element;
1277
+ readonly 'file-design-psd': ({ type }: CustomIconProps) => JSX.Element;
1278
+ readonly 'file-design-indd': ({ type }: CustomIconProps) => JSX.Element;
1279
+ readonly 'file-design-aep': ({ type }: CustomIconProps) => JSX.Element;
1280
+ readonly 'file-media-mp3': ({ type }: CustomIconProps) => JSX.Element;
1281
+ readonly 'file-media-wav': ({ type }: CustomIconProps) => JSX.Element;
1282
+ readonly 'file-media-mp4': ({ type }: CustomIconProps) => JSX.Element;
1283
+ readonly 'file-media-mpeg': ({ type }: CustomIconProps) => JSX.Element;
1284
+ readonly 'file-media-avi': ({ type }: CustomIconProps) => JSX.Element;
1285
+ readonly 'file-media-mkv': ({ type }: CustomIconProps) => JSX.Element;
1286
+ readonly 'file-development-html': ({ type }: CustomIconProps) => JSX.Element;
1287
+ readonly 'file-development-css': ({ type }: CustomIconProps) => JSX.Element;
1288
+ readonly 'file-development-rss': ({ type }: CustomIconProps) => JSX.Element;
1289
+ readonly 'file-development-sql': ({ type }: CustomIconProps) => JSX.Element;
1290
+ readonly 'file-development-js': ({ type }: CustomIconProps) => JSX.Element;
1291
+ readonly 'file-development-json': ({ type }: CustomIconProps) => JSX.Element;
1292
+ readonly 'file-development-java': ({ type }: CustomIconProps) => JSX.Element;
1293
+ readonly 'file-development-xml': ({ type }: CustomIconProps) => JSX.Element;
1294
+ readonly 'file-development-exe': ({ type }: CustomIconProps) => JSX.Element;
1295
+ readonly 'file-development-dmg': ({ type }: CustomIconProps) => JSX.Element;
1296
+ readonly 'file-archive-zip': ({ type }: CustomIconProps) => JSX.Element;
1297
+ readonly 'file-archive-rar': ({ type }: CustomIconProps) => JSX.Element;
1298
+ };
1299
+
1300
+ /**
1301
+ * Additional information that can be attached to a file.
1302
+ */
1303
+ export declare interface FileInfo {
1304
+ /**
1305
+ * Additional text to display below the file name.
1306
+ * @example "PDF Document"
1307
+ */
1308
+ additionalInfo?: string;
1309
+ /**
1310
+ * Custom React node to render as the file label.
1311
+ * When provided, replaces the default file name display.
1312
+ */
1313
+ customLabel?: default_2.ReactNode;
1314
+ /**
1315
+ * Allow additional custom properties.
1316
+ */
1317
+ [key: string]: unknown;
1318
+ }
1319
+
1320
+ /**
1321
+ * Represents a file in the uploader with its metadata and state.
1322
+ */
1323
+ export declare interface FileItem {
1324
+ /**
1325
+ * Unique identifier for this file item.
1326
+ */
1327
+ id: string;
1328
+ /**
1329
+ * The actual File object.
1330
+ */
1331
+ file: File;
1332
+ /**
1333
+ * Additional information about the file.
1334
+ */
1335
+ info: FileInfo;
1336
+ /**
1337
+ * Current state of the file.
1338
+ */
1339
+ state: FileState;
1340
+ /**
1341
+ * How the file was added to the uploader.
1342
+ */
1343
+ source: FileSource;
1344
+ }
1345
+
1346
+ /**
1347
+ * Source from which a file was added to the uploader.
1348
+ */
1349
+ export declare type FileSource = 'picker' | 'drop';
1350
+
1351
+ /**
1352
+ * Current state of a file in the uploader.
1353
+ */
1354
+ export declare interface FileState {
1355
+ /**
1356
+ * Current status of the file.
1357
+ */
1358
+ status: FILE_STATUS;
1359
+ /**
1360
+ * Whether the file has a validation or upload error.
1361
+ */
1362
+ hasError: boolean;
1363
+ /**
1364
+ * The error type if the file has an error.
1365
+ */
1366
+ error?: FILE_ERROR;
1367
+ /**
1368
+ * Human-readable error message.
1369
+ */
1370
+ errorMessage?: string;
1371
+ /**
1372
+ * Upload progress percentage (0-100).
1373
+ * Only relevant when status is UPLOADING.
1374
+ */
1375
+ progress?: number;
1376
+ /**
1377
+ * Custom status message to display.
1378
+ * Overrides the default status text when provided.
1379
+ */
1380
+ statusMessage?: string;
1381
+ }
1382
+
1383
+ export declare type FlexDirection = 'row' | 'row-reverse' | 'column' | 'column-reverse';
1384
+
1385
+ export declare type FlexResponsiveStyles<Attr extends string, T extends string> = {
1386
+ [K in FlexResponsiveStylesKeys<Attr>]: Record<T, string>;
1387
+ };
1388
+
1389
+ export declare type FlexResponsiveStylesKeys<Attr extends string> = GenerateSimpleResponsiveStyleKeys<Attr>;
1390
+
1391
+ export declare type FlexWrap = 'nowrap' | 'wrap' | 'wrap-reverse';
1392
+
1393
+ export declare const FloatSearch: {
1394
+ <T extends React.ElementType = "button">({ open, onClose, items, onSearch, onSelect, value, placeholder, translations: translationsProp, zIndex, loading, linkComponent: ItemComponent, }: FloatSearchProps<T>): ReactPortal | null;
1395
+ displayName: string;
1396
+ };
1397
+
1398
+ export declare type FloatSearchItem<T extends React.ElementType = 'button'> = {
1399
+ /**
1400
+ * Unique identifier for the item.
1401
+ */
1402
+ id: string;
1403
+ /**
1404
+ * Display label shown in the result row.
1405
+ */
1406
+ label: string;
1407
+ /**
1408
+ * Type of the item — determines the icon rendered on the left.
1409
+ */
1410
+ type: 'chat' | 'project';
1411
+ /**
1412
+ * Secondary metadata shown right-aligned (e.g. "Heute", "24 Chats").
1413
+ */
1414
+ meta?: string;
1415
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children' | 'id' | 'type'>;
1416
+
1417
+ export declare type FloatSearchProps<T extends React.ElementType = 'button'> = {
1418
+ /**
1419
+ * Controls whether the search overlay is visible.
1420
+ */
1421
+ open: boolean;
1422
+ /**
1423
+ * Called when the overlay should close (backdrop click, Esc, or clear button).
1424
+ */
1425
+ onClose: () => void;
1426
+ /**
1427
+ * Items to display in the result list.
1428
+ */
1429
+ items?: FloatSearchItem<T>[];
1430
+ /**
1431
+ * Called whenever the search query changes.
1432
+ */
1433
+ onSearch?: (query: string) => void;
1434
+ /**
1435
+ * Called when the user confirms a result (Enter key or click).
1436
+ */
1437
+ onSelect?: (item: FloatSearchItem<T>) => void;
1438
+ /**
1439
+ * Controlled search query value. When provided, the input becomes controlled.
1440
+ */
1441
+ value?: string;
1442
+ /**
1443
+ * Placeholder text for the search input.
1444
+ * @default 'Chats und Projekte durchsuchen'
1445
+ * @deprecated Use `translations.placeholder` instead.
1446
+ */
1447
+ placeholder?: string;
1448
+ /**
1449
+ * Override translatable UI strings. All keys are optional — missing keys fall back to German defaults.
1450
+ */
1451
+ translations?: FloatSearchTranslations;
1452
+ /**
1453
+ * z-index of the overlay.
1454
+ * @default 20
1455
+ */
1456
+ zIndex?: number;
1457
+ /**
1458
+ * When `true`, displays skeleton placeholders instead of the result list.
1459
+ * Use this while fetching search results asynchronously.
1460
+ * @default false
1461
+ */
1462
+ loading?: boolean;
1463
+ /**
1464
+ * The component to render each result item as. <br />
1465
+ * This is useful if you want to use a different component like a `Link` component from **Next.js** or **React Router**.
1466
+ * @default 'button'
1467
+ */
1468
+ linkComponent?: T | 'button';
1469
+ };
1470
+
1471
+ export declare interface FloatSearchTranslations {
1472
+ /**
1473
+ * Placeholder text for the search input.
1474
+ * @default 'Chats und Projekte durchsuchen'
1475
+ */
1476
+ placeholder?: string;
1477
+ /**
1478
+ * Aria-label for the clear-query button.
1479
+ * @default 'Suche zurücksetzen'
1480
+ */
1481
+ clearAriaLabel?: string;
1482
+ /**
1483
+ * Aria-label for the close button.
1484
+ * @default 'Suche schließen'
1485
+ */
1486
+ closeAriaLabel?: string;
1487
+ /**
1488
+ * Text shown when no results match the query.
1489
+ * @default 'Keine Ergebnisse gefunden'
1490
+ */
1491
+ noResults?: string;
1492
+ /**
1493
+ * Footer hint label for arrow-key navigation.
1494
+ * @default 'navigieren'
1495
+ */
1496
+ navigate?: string;
1497
+ /**
1498
+ * Footer hint label for the Enter key action.
1499
+ * @default 'öffnen'
1500
+ */
1501
+ open?: string;
1502
+ /**
1503
+ * Footer hint label for the Escape key action.
1504
+ * @default 'schließen'
1505
+ */
1506
+ close?: string;
1507
+ }
1508
+
1509
+ export declare type ForegroundColors = 'primary' | 'secondary' | 'tertiary' | 'yellow' | 'green' | 'pink' | 'steel-blue' | 'dark-yellow' | 'dark-green' | 'dark-pink' | 'dark-steel-blue' | 'inverse-on-surface' | 'on-primary' | 'on-secondary' | 'on-tertiary' | 'on-primary-container' | 'on-secondary-container' | 'on-tertiary-container' | 'on-primary-fixed' | 'on-primary-fixed-variant' | 'on-secondary-fixed' | 'on-secondary-fixed-variant' | 'on-tertiary-fixed' | 'on-tertiary-fixed-variant' | 'on-surface' | 'on-surface-variant' | 'on-surface-variant-lowest' | 'on-error' | 'on-error-container' | 'on-yellow' | 'on-dark-yellow' | 'on-yellow-container' | 'on-green' | 'on-dark-green' | 'on-green-container' | 'on-pink' | 'on-dark-pink' | 'on-pink-container' | 'on-steel-blue' | 'on-dark-steel-blue' | 'on-steel-blue-container' | 'error' | 'on-scrim' | 'on-container-neutral' | 'code-on-surface';
1510
+
1511
+ export declare const FormLabel: ({ value, required, htmlFor, ...props }: FormLabelProps) => JSX.Element;
1512
+
1513
+ export declare interface FormLabelProps {
1514
+ /**
1515
+ * The content of the label.
1516
+ */
1517
+ value: string;
1518
+ /**
1519
+ * The ID of the input element that the label should be associated with.
1520
+ * If not provided, the label will not be associated with any input.
1521
+ */
1522
+ htmlFor?: string;
1523
+ /**
1524
+ * Whether the field is required
1525
+ */
1526
+ required?: boolean;
1527
+ }
1528
+
1529
+ export declare type Gap = SpacingKeys | {
1530
+ row?: SpacingKeys;
1531
+ column?: SpacingKeys;
1532
+ };
1533
+
1534
+ declare type GapAxisVariant = 'Row' | 'Column';
1535
+
1536
+ export declare type GapResponsiveStyles<Attr extends string> = {
1537
+ [K in GenerateGapResponsiveStyleKeys<Attr>]: Record<SpacingKeys, string>;
1538
+ };
1539
+
1540
+ declare type GenerateGapResponsiveStyleKeys<Attr extends string> = Attr | `${Attr}${ResponsiveBreakpoint}` | `${Attr}${GapAxisVariant}` | `${Attr}${GapAxisVariant}${ResponsiveBreakpoint}`;
1541
+
1542
+ export declare type GenerateResponsiveGenericStyleKeys<Attr extends string> = Attr | `${Attr}${ResponsiveBreakpoint}`;
1543
+
1544
+ declare type GenerateResponsiveStyleKeys<Attr extends string> = Attr | `${Attr}${ResponsiveBreakpoint}` | `${Attr}${AxisVariant}` | `${Attr}${SideVariant}` | `${Attr}${AxisVariant}${ResponsiveBreakpoint}` | `${Attr}${SideVariant}${ResponsiveBreakpoint}`;
1545
+
1546
+ declare type GenerateSimpleResponsiveStyleKeys<Attr extends string> = Attr | `${Attr}${ResponsiveBreakpoint}`;
1547
+
1548
+ export declare type GenericResponsiveKeys<T extends string> = {
1549
+ [key in Viewport]: Record<T, string>;
1550
+ };
1551
+
1552
+ /**
1553
+ * Determines the breakpoint based on window width.
1554
+ * Checks breakpoints in descending order (desktop to minimum).
1555
+ *
1556
+ * @param width - The window width in pixels
1557
+ * @returns The corresponding viewport breakpoint
1558
+ */
1559
+ export declare const getBreakpoint: (width: number) => Viewport;
1560
+
1561
+ export declare type GetGapPropsReturnType<Attr extends string> = {
1562
+ [K in GenerateGapResponsiveStyleKeys<Attr>]: SpacingKeys | undefined;
1563
+ };
1564
+
1565
+ export declare type GetGenericPropsReturnType<Attr extends string, T extends string> = {
1566
+ [K in GenerateSimpleResponsiveStyleKeys<Attr>]: T | undefined;
1567
+ };
1568
+
1569
+ /**
1570
+ * Gets the appropriate icon name for a file extension.
1571
+ * @param extension - The file extension (e.g., "pdf", "jpg", ".pdf")
1572
+ * @returns The corresponding icon name, or 'file-empty' if not found
1573
+ */
1574
+ export declare const getIconForFileExtension: (extension?: string) => FileIconNames;
1575
+
1576
+ export declare type GetSimpleSpacingPropsReturnType<Attr extends string> = {
1577
+ [K in GenerateSimpleResponsiveStyleKeys<Attr>]: SpacingKeys | undefined;
1578
+ };
1579
+
1580
+ export declare type GetSpacingPropsReturnType<Attr extends string> = {
1581
+ [K in GenerateResponsiveStyleKeys<Attr>]: SpacingKeys | undefined;
1582
+ };
1583
+
1584
+ export declare const Grid: GridComponent;
1585
+
1586
+ declare type GridComponent = React.ForwardRefExoticComponent<GridProps & React.RefAttributes<HTMLDivElement>> & {
1587
+ Item: React.ForwardRefExoticComponent<GridItemProps & React.RefAttributes<HTMLDivElement>>;
1588
+ };
1589
+
1590
+ declare interface GridItemProps extends React.HTMLAttributes<HTMLDivElement> {
1591
+ /**
1592
+ * The children of the component.
1593
+ */
1594
+ children: ReactNode;
1595
+ /**
1596
+ * The number of columns to span in the `Grid.Item`.
1597
+ */
1598
+ colSpan?: ResponsiveType<number>;
1599
+ /**
1600
+ * The number of rows to span in the `Grid.Item`.
1601
+ */
1602
+ rowSpan?: ResponsiveType<number>;
1603
+ }
1604
+
1605
+ export declare interface GridProps extends React.HTMLAttributes<HTMLDivElement> {
1606
+ /**
1607
+ * The children of the component.
1608
+ */
1609
+ children: ReactNode;
1610
+ /**
1611
+ * The height of the grid.
1612
+ * @default 'auto'
1613
+ */
1614
+ height?: ResponsiveType<number | string>;
1615
+ /**
1616
+ * The minimum height of the grid.
1617
+ * @default 'auto'
1618
+ */
1619
+ minHeight?: ResponsiveType<number | string>;
1620
+ /**
1621
+ * The maximum height of the grid.
1622
+ * @default 'auto'
1623
+ */
1624
+ maxHeight?: ResponsiveType<number | string>;
1625
+ /**
1626
+ * The width of the grid.
1627
+ * @default '100%'
1628
+ */
1629
+ width?: ResponsiveType<number | string>;
1630
+ /**
1631
+ * The minimum width of the grid.
1632
+ * @default 'auto'
1633
+ */
1634
+ minWidth?: ResponsiveType<number | string>;
1635
+ /**
1636
+ * The maximum width of the grid.
1637
+ * @default 'auto'
1638
+ */
1639
+ maxWidth?: ResponsiveType<number | string>;
1640
+ /**
1641
+ * The number of columns to display or the grid-template-columns property.
1642
+ * @default 1
1643
+ */
1644
+ columns?: ResponsiveType<number | string>;
1645
+ /**
1646
+ * The number of rows to display or the grid-template-rows property.
1647
+ * @default 1
1648
+ */
1649
+ rows?: ResponsiveType<number | string>;
1650
+ /**
1651
+ * The gap between grid items.
1652
+ *
1653
+ * Accepts either a single spacing key applied to both axes, or an object
1654
+ * with `row` / `column` keys to target each axis independently.
1655
+ * Fully responsive: any per-breakpoint value can itself be a spacing key
1656
+ * or a `{ row, column }` object.
1657
+ *
1658
+ * @example
1659
+ * gap="md"
1660
+ * gap={{ row: 'md', column: 'sm' }}
1661
+ * gap={{ minimum: 'sm', mobile: { row: 'md', column: 'lg' } }}
1662
+ *
1663
+ * @default 'none'
1664
+ */
1665
+ gap?: ResponsiveType<Gap>;
1666
+ /**
1667
+ * Define padding to the grid wrapper.
1668
+ * @default 'none'
1669
+ */
1670
+ padding?: ResponsiveType<Padding>;
1671
+ /**
1672
+ * Define margin to the grid wrapper.
1673
+ * @default 'none'
1674
+ */
1675
+ margin?: ResponsiveType<Margin>;
1676
+ }
1677
+
1678
+ export declare type HighlightStyle = {
1679
+ [key: string]: CSSProperties;
1680
+ };
1681
+
1682
+ export declare const Icon: ({ name, size, weight, color, type, featured, ...props }: IconProps) => JSX.Element;
1683
+
1684
+ declare const iconMap: {
1685
+ readonly zvoove: ({ size, color }: ZvooveLogoProps) => JSX.Element;
1686
+ readonly 'zvoove-one': ({ size, color }: {
1687
+ size?: number;
1688
+ color?: string;
1689
+ }) => JSX.Element;
1690
+ readonly 'zvoove-recruit': ({ size, color, }: {
1691
+ size?: number;
1692
+ color?: string;
1693
+ }) => JSX.Element;
1694
+ readonly 'zvoove-invoice-monitor': ({ size, color, }: {
1695
+ size?: number;
1696
+ color?: string;
1697
+ }) => JSX.Element;
1698
+ readonly 'zvoove-go': ({ size, color }: {
1699
+ size?: number;
1700
+ color?: string;
1701
+ }) => JSX.Element;
1702
+ readonly 'zvoove-intelligence': ({ size, color, }: {
1703
+ size?: number;
1704
+ color?: string;
1705
+ }) => JSX.Element;
1706
+ readonly 'zvoove-free': ({ size, color, }: {
1707
+ size?: number;
1708
+ color?: string;
1709
+ }) => JSX.Element;
1710
+ readonly 'zvoove-work-expert': ({ size, color, }: {
1711
+ size?: number;
1712
+ color?: string;
1713
+ }) => JSX.Element;
1714
+ readonly 'zvoove-elevate': ({ size, color, }: {
1715
+ size?: number;
1716
+ color?: string;
1717
+ }) => JSX.Element;
1718
+ readonly 'zvoove-cashlink': ({ size, color, }: {
1719
+ size?: number;
1720
+ color?: string;
1721
+ }) => JSX.Element;
1722
+ readonly 'zvoove-docs-ai': ({ size, color, }: {
1723
+ size?: number;
1724
+ color?: string;
1725
+ }) => JSX.Element;
1726
+ readonly 'cockpit-x': ({ size, color }: {
1727
+ size?: number;
1728
+ color?: string;
1729
+ }) => JSX.Element;
1730
+ readonly add: Icon_2;
1731
+ readonly 'add-circle': Icon_2;
1732
+ readonly 'add-file': Icon_2;
1733
+ readonly agent: Icon_2;
1734
+ readonly airplane: Icon_2;
1735
+ readonly archive: Icon_2;
1736
+ readonly 'arrow-back': Icon_2;
1737
+ readonly 'arrow-bend': Icon_2;
1738
+ readonly 'arrow-elbow-down-left': Icon_2;
1739
+ readonly 'arrow-down': Icon_2;
1740
+ readonly 'arrow-forward': Icon_2;
1741
+ readonly 'arrow-left-right': Icon_2;
1742
+ readonly 'arrow-up': Icon_2;
1743
+ readonly article: Icon_2;
1744
+ readonly automate: Icon_2;
1745
+ readonly backspace: Icon_2;
1746
+ readonly bank: Icon_2;
1747
+ readonly bicycle: Icon_2;
1748
+ readonly billing: Icon_2;
1749
+ readonly binoculars: Icon_2;
1750
+ readonly break: Icon_2;
1751
+ readonly bus: Icon_2;
1752
+ readonly calendar: Icon_2;
1753
+ readonly 'calendar-blank': Icon_2;
1754
+ readonly 'calendar-check': Icon_2;
1755
+ readonly 'calendar-dot': Icon_2;
1756
+ readonly 'calendar-x': Icon_2;
1757
+ readonly camera: Icon_2;
1758
+ readonly car: Icon_2;
1759
+ readonly cart: Icon_2;
1760
+ readonly 'cash-money': Icon_2;
1761
+ readonly certificate: Icon_2;
1762
+ readonly 'chat-bubble': Icon_2;
1763
+ readonly 'chat-dots': Icon_2;
1764
+ readonly 'chat-slash': Icon_2;
1765
+ readonly chats: Icon_2;
1766
+ readonly check: Icon_2;
1767
+ readonly circle: Icon_2;
1768
+ readonly 'check-circle': Icon_2;
1769
+ readonly checkbox: Icon_2;
1770
+ readonly 'checkbox-empty': Icon_2;
1771
+ readonly 'checkbox-indefinitely': Icon_2;
1772
+ readonly checks: Icon_2;
1773
+ readonly 'chevron-down': Icon_2;
1774
+ readonly 'chevron-left': Icon_2;
1775
+ readonly 'chevron-right': Icon_2;
1776
+ readonly 'chevron-up': Icon_2;
1777
+ readonly 'circle-notch': Icon_2;
1778
+ readonly close: Icon_2;
1779
+ readonly 'close-circle': Icon_2;
1780
+ readonly 'cloud-download': Icon_2;
1781
+ readonly 'cloud-upload': Icon_2;
1782
+ readonly 'clock-countdown': Icon_2;
1783
+ readonly 'clock-person': Icon_2;
1784
+ readonly command: Icon_2;
1785
+ readonly columns: Icon_2;
1786
+ readonly control: Icon_2;
1787
+ readonly copy: Icon_2;
1788
+ readonly 'currency-dollar': Icon_2;
1789
+ readonly 'currency-dollar-circle': Icon_2;
1790
+ readonly 'currency-gbp': Icon_2;
1791
+ readonly 'dark-mode': Icon_2;
1792
+ readonly deactivate: Icon_2;
1793
+ readonly delete: Icon_2;
1794
+ readonly 'diagram-view': Icon_2;
1795
+ readonly download: Icon_2;
1796
+ readonly drag: Icon_2;
1797
+ readonly edit: Icon_2;
1798
+ readonly error: Icon_2;
1799
+ readonly 'exclamation-mark': Icon_2;
1800
+ readonly expand: Icon_2;
1801
+ readonly expenses: Icon_2;
1802
+ readonly 'face-id': Icon_2;
1803
+ readonly file: Icon_2;
1804
+ readonly 'simple-file-archive': Icon_2;
1805
+ readonly 'simple-file-audio': Icon_2;
1806
+ readonly 'simple-file-c': Icon_2;
1807
+ readonly 'simple-file-c-sharp': Icon_2;
1808
+ readonly 'simple-file-code': Icon_2;
1809
+ readonly 'simple-file-cpp': Icon_2;
1810
+ readonly 'simple-file-css': Icon_2;
1811
+ readonly 'simple-file-csv': Icon_2;
1812
+ readonly 'simple-file-doc': Icon_2;
1813
+ readonly 'simple-file-html': Icon_2;
1814
+ readonly 'simple-file-image': Icon_2;
1815
+ readonly 'simple-file-ini': Icon_2;
1816
+ readonly 'simple-file-jpg': Icon_2;
1817
+ readonly 'simple-file-js': Icon_2;
1818
+ readonly 'simple-file-jsx': Icon_2;
1819
+ readonly 'simple-file-md': Icon_2;
1820
+ readonly 'simple-file-pdf': Icon_2;
1821
+ readonly 'simple-file-png': Icon_2;
1822
+ readonly 'simple-file-ppt': Icon_2;
1823
+ readonly 'simple-file-py': Icon_2;
1824
+ readonly 'simple-file-rs': Icon_2;
1825
+ readonly 'simple-file-sql': Icon_2;
1826
+ readonly 'simple-file-svg': Icon_2;
1827
+ readonly 'simple-file-ts': Icon_2;
1828
+ readonly 'simple-file-tsx': Icon_2;
1829
+ readonly 'simple-file-text': Icon_2;
1830
+ readonly 'simple-file-txt': Icon_2;
1831
+ readonly 'simple-file-video': Icon_2;
1832
+ readonly 'simple-file-vue': Icon_2;
1833
+ readonly 'simple-file-xls': Icon_2;
1834
+ readonly 'simple-file-zip': Icon_2;
1835
+ readonly filter: Icon_2;
1836
+ readonly filters: Icon_2;
1837
+ readonly 'first-page': Icon_2;
1838
+ readonly 'flag-de': ({ size }: {
1839
+ size?: number;
1840
+ }) => JSX.Element;
1841
+ readonly 'flag-es': ({ size }: {
1842
+ size?: number;
1843
+ }) => JSX.Element;
1844
+ readonly 'flag-fr': ({ size }: {
1845
+ size?: number;
1846
+ }) => JSX.Element;
1847
+ readonly 'flag-gb': ({ size }: {
1848
+ size?: number;
1849
+ }) => JSX.Element;
1850
+ readonly 'flag-nl': ({ size }: {
1851
+ size?: number;
1852
+ }) => JSX.Element;
1853
+ readonly folder: Icon_2;
1854
+ readonly 'folder-open': Icon_2;
1855
+ readonly 'grid-view': Icon_2;
1856
+ readonly 'hard-hat': Icon_2;
1857
+ readonly 'head-circuit': Icon_2;
1858
+ readonly help: Icon_2;
1859
+ readonly hide: Icon_2;
1860
+ readonly home: Icon_2;
1861
+ readonly images: Icon_2;
1862
+ readonly info: Icon_2;
1863
+ readonly invoice: Icon_2;
1864
+ readonly job: Icon_2;
1865
+ readonly 'key-return': Icon_2;
1866
+ readonly keyboard: Icon_2;
1867
+ readonly knowledge: Icon_2;
1868
+ readonly language: Icon_2;
1869
+ readonly 'last-page': Icon_2;
1870
+ readonly 'light-mode': Icon_2;
1871
+ readonly 'list-view': Icon_2;
1872
+ readonly location: Icon_2;
1873
+ readonly 'location-pin': Icon_2;
1874
+ readonly lock: Icon_2;
1875
+ readonly 'lock-key': Icon_2;
1876
+ readonly 'lock-key-open': Icon_2;
1877
+ readonly menu: Icon_2;
1878
+ readonly metadata: Icon_2;
1879
+ readonly code: Icon_2;
1880
+ readonly microphone: Icon_2;
1881
+ readonly minus: Icon_2;
1882
+ readonly 'more-horizontal': Icon_2;
1883
+ readonly 'more-vertical': Icon_2;
1884
+ readonly moped: Icon_2;
1885
+ readonly 'navigation-arrow': Icon_2;
1886
+ readonly notifications: Icon_2;
1887
+ readonly note: Icon_2;
1888
+ readonly numpad: Icon_2;
1889
+ readonly option: Icon_2;
1890
+ readonly 'open-in-new-tab': Icon_2;
1891
+ readonly order: Icon_2;
1892
+ readonly organization: Icon_2;
1893
+ readonly pause: Icon_2;
1894
+ readonly attachment: Icon_2;
1895
+ readonly phone: Icon_2;
1896
+ readonly pin: Icon_2;
1897
+ readonly 'pin-simple': Icon_2;
1898
+ readonly 'pin-simple-slash': Icon_2;
1899
+ readonly 'pin-slash': Icon_2;
1900
+ readonly 'piggy-bank': Icon_2;
1901
+ readonly plant: Icon_2;
1902
+ readonly printer: Icon_2;
1903
+ readonly privacy: Icon_2;
1904
+ readonly 'qr-code': Icon_2;
1905
+ readonly refresh: Icon_2;
1906
+ readonly remark: Icon_2;
1907
+ readonly robot: Icon_2;
1908
+ readonly save: Icon_2;
1909
+ readonly search: Icon_2;
1910
+ readonly 'search-plus': Icon_2;
1911
+ readonly 'send-message': Icon_2;
1912
+ readonly settings: Icon_2;
1913
+ readonly 'setup-time': Icon_2;
1914
+ readonly shapes: Icon_2;
1915
+ readonly show: Icon_2;
1916
+ readonly sidebar: Icon_2;
1917
+ readonly signature: Icon_2;
1918
+ readonly 'sign-out': Icon_2;
1919
+ readonly 'skip-forward': Icon_2;
1920
+ readonly smartphone: Icon_2;
1921
+ readonly sparkle: Icon_2;
1922
+ readonly star: Icon_2;
1923
+ readonly start: Icon_2;
1924
+ readonly stop: Icon_2;
1925
+ readonly sick: Icon_2;
1926
+ readonly table: Icon_2;
1927
+ readonly 'thumb-up': Icon_2;
1928
+ readonly 'thumb-down': Icon_2;
1929
+ readonly taxi: Icon_2;
1930
+ readonly 'text-align-center': Icon_2;
1931
+ readonly 'text-align-justify': Icon_2;
1932
+ readonly 'text-align-left': Icon_2;
1933
+ readonly 'text-align-right': Icon_2;
1934
+ readonly 'text-t': Icon_2;
1935
+ readonly ticket: Icon_2;
1936
+ readonly notches: Icon_2;
1937
+ readonly time: Icon_2;
1938
+ readonly timer: Icon_2;
1939
+ readonly 'time-sheet-download': Icon_2;
1940
+ readonly 'time-sheet-upload': Icon_2;
1941
+ readonly train: Icon_2;
1942
+ readonly translate: Icon_2;
1943
+ readonly travel: Icon_2;
1944
+ readonly unfold: Icon_2;
1945
+ readonly user: Icon_2;
1946
+ readonly upload: Icon_2;
1947
+ readonly 'user-account': Icon_2;
1948
+ readonly users: Icon_2;
1949
+ readonly vacation: Icon_2;
1950
+ readonly wallet: Icon_2;
1951
+ readonly warning: Icon_2;
1952
+ readonly wrench: Icon_2;
1953
+ readonly 'file-empty': ({ type }: CustomIconProps) => JSX.Element;
1954
+ readonly 'file-pdf': ({ type }: CustomIconProps) => JSX.Element;
1955
+ readonly 'file-folder': ({ type }: CustomIconProps) => JSX.Element;
1956
+ readonly 'file-image': ({ type }: CustomIconProps) => JSX.Element;
1957
+ readonly 'file-video': ({ type }: CustomIconProps) => JSX.Element;
1958
+ readonly 'file-video-2': ({ type }: CustomIconProps) => JSX.Element;
1959
+ readonly 'file-audio': ({ type }: CustomIconProps) => JSX.Element;
1960
+ readonly 'file-code': ({ type }: CustomIconProps) => JSX.Element;
1961
+ readonly 'file-document': ({ type }: CustomIconProps) => JSX.Element;
1962
+ readonly 'file-spreadsheet': ({ type }: CustomIconProps) => JSX.Element;
1963
+ readonly 'file-image-img': ({ type }: CustomIconProps) => JSX.Element;
1964
+ readonly 'file-image-jpg': ({ type }: CustomIconProps) => JSX.Element;
1965
+ readonly 'file-image-jpeg': ({ type }: CustomIconProps) => JSX.Element;
1966
+ readonly 'file-image-png': ({ type }: CustomIconProps) => JSX.Element;
1967
+ readonly 'file-image-webp': ({ type }: CustomIconProps) => JSX.Element;
1968
+ readonly 'file-image-tiff': ({ type }: CustomIconProps) => JSX.Element;
1969
+ readonly 'file-image-gif': ({ type }: CustomIconProps) => JSX.Element;
1970
+ readonly 'file-image-svg': ({ type }: CustomIconProps) => JSX.Element;
1971
+ readonly 'file-image-eps': ({ type }: CustomIconProps) => JSX.Element;
1972
+ readonly 'file-document-pdf': ({ type }: CustomIconProps) => JSX.Element;
1973
+ readonly 'file-document-doc': ({ type }: CustomIconProps) => JSX.Element;
1974
+ readonly 'file-document-docx': ({ type }: CustomIconProps) => JSX.Element;
1975
+ readonly 'file-document-txt': ({ type }: CustomIconProps) => JSX.Element;
1976
+ readonly 'file-document-csv': ({ type }: CustomIconProps) => JSX.Element;
1977
+ readonly 'file-document-xls': ({ type }: CustomIconProps) => JSX.Element;
1978
+ readonly 'file-document-xlsx': ({ type }: CustomIconProps) => JSX.Element;
1979
+ readonly 'file-document-ppt': ({ type }: CustomIconProps) => JSX.Element;
1980
+ readonly 'file-document-pptx': ({ type }: CustomIconProps) => JSX.Element;
1981
+ readonly 'file-design-fig': ({ type }: CustomIconProps) => JSX.Element;
1982
+ readonly 'file-design-ai': ({ type }: CustomIconProps) => JSX.Element;
1983
+ readonly 'file-design-psd': ({ type }: CustomIconProps) => JSX.Element;
1984
+ readonly 'file-design-indd': ({ type }: CustomIconProps) => JSX.Element;
1985
+ readonly 'file-design-aep': ({ type }: CustomIconProps) => JSX.Element;
1986
+ readonly 'file-media-mp3': ({ type }: CustomIconProps) => JSX.Element;
1987
+ readonly 'file-media-wav': ({ type }: CustomIconProps) => JSX.Element;
1988
+ readonly 'file-media-mp4': ({ type }: CustomIconProps) => JSX.Element;
1989
+ readonly 'file-media-mpeg': ({ type }: CustomIconProps) => JSX.Element;
1990
+ readonly 'file-media-avi': ({ type }: CustomIconProps) => JSX.Element;
1991
+ readonly 'file-media-mkv': ({ type }: CustomIconProps) => JSX.Element;
1992
+ readonly 'file-development-html': ({ type }: CustomIconProps) => JSX.Element;
1993
+ readonly 'file-development-css': ({ type }: CustomIconProps) => JSX.Element;
1994
+ readonly 'file-development-rss': ({ type }: CustomIconProps) => JSX.Element;
1995
+ readonly 'file-development-sql': ({ type }: CustomIconProps) => JSX.Element;
1996
+ readonly 'file-development-js': ({ type }: CustomIconProps) => JSX.Element;
1997
+ readonly 'file-development-json': ({ type }: CustomIconProps) => JSX.Element;
1998
+ readonly 'file-development-java': ({ type }: CustomIconProps) => JSX.Element;
1999
+ readonly 'file-development-xml': ({ type }: CustomIconProps) => JSX.Element;
2000
+ readonly 'file-development-exe': ({ type }: CustomIconProps) => JSX.Element;
2001
+ readonly 'file-development-dmg': ({ type }: CustomIconProps) => JSX.Element;
2002
+ readonly 'file-archive-zip': ({ type }: CustomIconProps) => JSX.Element;
2003
+ readonly 'file-archive-rar': ({ type }: CustomIconProps) => JSX.Element;
2004
+ };
2005
+
2006
+ export declare type IconNames = keyof typeof iconMap;
2007
+
2008
+ export declare interface IconProps extends CustomIconProps, React.HTMLAttributes<SVGElement> {
2009
+ /**
2010
+ * The name of the icon to display.
2011
+ */
2012
+ name: IconNames;
2013
+ /**
2014
+ * The size of the icon.
2015
+ * @default 'lg'
2016
+ */
2017
+ size?: IconSizes;
2018
+ /**
2019
+ * The weight of the icon.
2020
+ */
2021
+ weight?: IconWeight;
2022
+ /**
2023
+ * The color of the icon.
2024
+ */
2025
+ color?: ForegroundColors;
2026
+ /**
2027
+ * If true, the icon will be displayed in a featured style.
2028
+ */
2029
+ featured?: boolean;
2030
+ }
2031
+
2032
+ declare const iconSizeMap: {
2033
+ readonly '2xs': 12;
2034
+ readonly xs: 16;
2035
+ readonly sm: 18;
2036
+ readonly md: 20;
2037
+ readonly lg: 24;
2038
+ readonly xl: 32;
2039
+ readonly '2xl': 40;
2040
+ };
2041
+
2042
+ export declare type IconSizes = keyof typeof iconSizeMap;
2043
+
2044
+ declare type IconStates = {
2045
+ on: CommonIconNames;
2046
+ off: CommonIconNames;
2047
+ };
2048
+
2049
+ declare type IconTypes = keyof typeof iconTypes;
2050
+
2051
+ declare const iconTypes: {
2052
+ readonly default: "default";
2053
+ readonly solid: "solid";
2054
+ readonly gray: "gray";
2055
+ };
2056
+
2057
+ export declare const ImageVisualizer: {
2058
+ ({ src, alt, width, height, maxWidth, maxHeight, minWidth, minHeight, borderRadius, objectFit, }: ImageVisualizerProps): JSX.Element;
2059
+ displayName: string;
2060
+ };
2061
+
2062
+ export declare interface ImageVisualizerProps {
2063
+ /**
2064
+ * The source URL of the image.
2065
+ */
2066
+ src: string;
2067
+ /**
2068
+ * The alt text of the image.
2069
+ * @default ''
2070
+ */
2071
+ alt?: string;
2072
+ /**
2073
+ * The width of the image container.
2074
+ */
2075
+ width?: ResponsiveType<number | string>;
2076
+ /**
2077
+ * The height of the image container.
2078
+ */
2079
+ height?: ResponsiveType<number | string>;
2080
+ /**
2081
+ * The minimum width of the image container.
2082
+ */
2083
+ minWidth?: ResponsiveType<number | string>;
2084
+ /**
2085
+ * The minimum height of the image container.
2086
+ */
2087
+ minHeight?: ResponsiveType<number | string>;
2088
+ /**
2089
+ * The maximum width of the image container.
2090
+ */
2091
+ maxWidth?: ResponsiveType<number | string>;
2092
+ /**
2093
+ * The maximum height of the image container.
2094
+ */
2095
+ maxHeight?: ResponsiveType<number | string>;
2096
+ /**
2097
+ * The border radius of the image container.
2098
+ * @default 'sm'
2099
+ */
2100
+ borderRadius?: 'none' | 'sm' | 'md' | 'lg' | 'xl';
2101
+ /**
2102
+ * The CSS object-fit of the image inside the container.
2103
+ * @default 'cover'
2104
+ */
2105
+ objectFit?: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down';
2106
+ }
2107
+
2108
+ export declare const InfoBox: {
2109
+ ({ message, variant, icon, elevated, }: InfoBoxProps): JSX.Element;
2110
+ displayName: string;
2111
+ };
2112
+
2113
+ export declare interface InfoBoxProps {
2114
+ /**
2115
+ * The message to display in the InfoBox.
2116
+ */
2117
+ message: string;
2118
+ /**
2119
+ * The semantic variant of the InfoBox
2120
+ * @default 'default'
2121
+ */
2122
+ variant?: InfoBoxVariant;
2123
+ /**
2124
+ * Icon to display in the InfoBox. If not provided, uses the default icon for the variant.
2125
+ */
2126
+ icon?: CommonIconNames | Omit<IconProps, 'size' | 'color'>;
2127
+ /**
2128
+ * Whether to elevate the InfoBox.
2129
+ * @default true
2130
+ */
2131
+ elevated?: boolean;
2132
+ }
2133
+
2134
+ export declare type InfoBoxVariant = 'default' | 'positive' | 'warning' | 'error' | 'subtle' | 'neutral' | 'outlined';
2135
+
2136
+ /**
2137
+ * Detects **sectioned** `items` passed to `ListMenu`.
2138
+ *
2139
+ * **Sectioned** when the array is non-empty and the first entry looks like
2140
+ * `{ title?, items: ListMenuItem[] }`: it has an `items` array and does **not**
2141
+ * have a top-level `label` (every `ListMenuItem` has `label`). Any section may omit
2142
+ * `title` (e.g. the first group) — no header row is rendered.
2143
+ *
2144
+ * **Flat** when empty `[]` or when entries are normal rows. Do not mix shapes in one array.
2145
+ */
2146
+ export declare function isListMenuSections<T extends ElementType = 'a'>(items: ListMenuItem<T>[] | ListMenuSection<T>[]): items is ListMenuSection<T>[];
2147
+
2148
+ export declare type JustifyContent = 'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around' | 'space-evenly';
2149
+
2150
+ declare type LabelStates = {
2151
+ on: string;
2152
+ off: string;
2153
+ };
2154
+
2155
+ export declare const List: {
2156
+ <T extends default_2.ElementType = "div">({ items, activeItemId, showDividers, linkComponent: LinkComponent, }: ListProps<T>): JSX.Element;
2157
+ displayName: string;
2158
+ };
2159
+
2160
+ export declare type ListItem<T extends default_2.ElementType = 'div'> = {
2161
+ /**
2162
+ * The content of the list item.
2163
+ */
2164
+ content: ReactNode;
2165
+ /**
2166
+ * The id of the list item. This will be use as the key for the list item.
2167
+ */
2168
+ id: string;
2169
+ } & Omit<default_2.ComponentPropsWithoutRef<T>, 'children' | 'className' | 'content' | 'id'>;
2170
+
2171
+ export declare const ListMenu: {
2172
+ <T extends default_2.ElementType = "a">({ items, activeItem, open, variant, linkComponent: LinkComponent, onItemClick, }: ListMenuProps<T>): JSX.Element;
2173
+ displayName: string;
2174
+ };
2175
+
2176
+ export declare type ListMenuItem<T extends React.ElementType = 'a'> = {
2177
+ /**
2178
+ * The label of the menu item
2179
+ */
2180
+ label: string;
2181
+ /**
2182
+ * The id of the menu item
2183
+ */
2184
+ id: string;
2185
+ /**
2186
+ * The icon of the menu item
2187
+ */
2188
+ icon?: CommonIconNames | CustomCommonIconNames | React.ReactElement;
2189
+ /**
2190
+ * Extra content rendered at the end of the label area (e.g. a tag, badge, or action button)
2191
+ */
2192
+ endContent?: React.ReactNode;
2193
+ /**
2194
+ * When to show the end content
2195
+ * @default 'always'
2196
+ */
2197
+ endContentVisibility?: 'always' | 'hover';
2198
+ /**
2199
+ * Renders a spacer instead of a menu item.
2200
+ * @default false
2201
+ */
2202
+ isSpacer?: boolean;
2203
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
2204
+
2205
+ export declare type ListMenuProps<T extends React.ElementType = 'a'> = {
2206
+ /**
2207
+ * Either a flat list of menu items (default) **or** an array of sections
2208
+ * `{ title?, items }[]`. The two shapes are mutually exclusive — use one or the other.
2209
+ */
2210
+ items: ListMenuItem<T>[] | ListMenuSection<T>[];
2211
+ /**
2212
+ * The active item must match the id of the menu item
2213
+ */
2214
+ activeItem?: string;
2215
+ /**
2216
+ * Whether the menu is expanded (showing labels)
2217
+ * @default true
2218
+ */
2219
+ open?: boolean;
2220
+ /**
2221
+ * The visual variant of the menu
2222
+ * @default 'default'
2223
+ */
2224
+ variant?: ListMenuVariant;
2225
+ /**
2226
+ * The component to render for the link
2227
+ * @default 'a'
2228
+ */
2229
+ linkComponent?: T | 'a';
2230
+ /**
2231
+ * The callback to handle the item click
2232
+ */
2233
+ onItemClick?: (item: ListMenuItem<T>) => void;
2234
+ };
2235
+
2236
+ /**
2237
+ * One titled group of rows inside a sectioned `ListMenu`. Do not mix with flat
2238
+ * `ListMenuItem[]` in the same `items` array.
2239
+ */
2240
+ export declare type ListMenuSection<T extends React.ElementType = 'a'> = {
2241
+ /**
2242
+ * Optional section header (uppercase label styling; omitted when missing, empty, or whitespace-only).
2243
+ */
2244
+ title?: string;
2245
+ /**
2246
+ * Rows in this section; same shape as flat `ListMenu` items.
2247
+ */
2248
+ items: ListMenuItem<T>[];
2249
+ };
2250
+
2251
+ export declare type ListMenuVariant = 'default' | 'compact';
2252
+
2253
+ export declare interface ListProps<T extends default_2.ElementType = 'div'> {
2254
+ /**
2255
+ * The items of the List.
2256
+ */
2257
+ items: ListItem<T>[];
2258
+ /**
2259
+ * The active item id of the List.
2260
+ * If provided, the item will be highlighted.
2261
+ */
2262
+ activeItemId?: string;
2263
+ /**
2264
+ * Whether to show dividers between items.
2265
+ * @default true
2266
+ */
2267
+ showDividers?: boolean;
2268
+ /**
2269
+ * The component to render for each list item.
2270
+ * @default 'div'
2271
+ */
2272
+ linkComponent?: T | 'div';
2273
+ }
2274
+
2275
+ export declare type Margin = SpacingKeys | {
2276
+ top?: SpacingKeys;
2277
+ right?: SpacingKeys;
2278
+ bottom?: SpacingKeys;
2279
+ left?: SpacingKeys;
2280
+ x?: SpacingKeys;
2281
+ y?: SpacingKeys;
2282
+ };
2283
+
2284
+ /**
2285
+ * @deprecated Use `ListMenuItem` instead
2286
+ */
2287
+ export declare type MenuItem<T extends React.ElementType = 'a'> = ListMenuItem<T>;
2288
+
2289
+ export declare interface MessageAction {
2290
+ /**
2291
+ * The icon to display for this action.
2292
+ */
2293
+ icon: CommonIconNames;
2294
+ /**
2295
+ * Accessible label for the action (used as tooltip and aria-label).
2296
+ */
2297
+ label: string;
2298
+ /**
2299
+ * Callback fired when the action button is clicked.
2300
+ */
2301
+ onClick?: (event: MouseEvent_2<HTMLButtonElement>) => void;
2302
+ /**
2303
+ * Whether this action is currently in an active/toggled state.
2304
+ * @default false
2305
+ */
2306
+ active?: boolean;
2307
+ /**
2308
+ * Feedback group for mutual exclusion (e.g. thumbs up/down).
2309
+ * Actions sharing the same group are mutually exclusive — activating one deactivates the other.
2310
+ */
2311
+ feedbackType?: 'positive' | 'negative';
2312
+ /**
2313
+ * Confirmation behavior on click — animation, icon swap, and text.
2314
+ * Provides a consistent pattern for copy ("Copied"), feedback ("Thanks for your feedback"), etc.
2315
+ */
2316
+ confirmation?: ActionConfirmation;
2317
+ }
2318
+
2319
+ export declare const MessageActions: ForwardRefExoticComponent<MessageActionsProps & RefAttributes<HTMLDivElement>>;
2320
+
2321
+ export declare interface MessageActionsProps {
2322
+ /**
2323
+ * The layout variant matching the parent ChatBubble alignment.
2324
+ * - `receiver`: actions on the left, timestamp on the right
2325
+ * - `sender`: timestamp on the left, actions on the right
2326
+ * @default 'receiver'
2327
+ */
2328
+ variant?: MessageActionsVariant;
2329
+ /**
2330
+ * The timestamp text to display (e.g. "10:01").
2331
+ */
2332
+ timestamp?: string;
2333
+ /**
2334
+ * The action buttons to display.
2335
+ * Defaults to copy, thumb-up, thumb-down, and more-horizontal.
2336
+ */
2337
+ actions?: MessageAction[];
2338
+ /**
2339
+ * Menu items shown in the "More" action popup menu.
2340
+ * When provided, the last default action (more-horizontal) opens a PopUpMenu.
2341
+ */
2342
+ menuItems?: PopUpMenuItem[];
2343
+ /**
2344
+ * Callback fired when a feedback action (thumbs up/down) is selected.
2345
+ */
2346
+ onFeedback?: (feedback: FeedbackType) => void;
2347
+ /**
2348
+ * Additional CSS class name.
2349
+ */
2350
+ className?: string;
2351
+ }
2352
+
2353
+ export declare type MessageActionsVariant = 'sender' | 'receiver';
2354
+
2355
+ /**
2356
+ * One titled block of mid-section rows. Items are always rendered with **compact** `ListMenu` density;
2357
+ * this type only describes the data shape (same as root `midSections` on `SideNavigation`).
2358
+ */
2359
+ export declare type MidSection<T extends ElementType = 'a'> = {
2360
+ /**
2361
+ * The title of the section
2362
+ */
2363
+ title?: string;
2364
+ /**
2365
+ * Whether to show a divider above the section
2366
+ * @default true
2367
+ */
2368
+ showDivider?: boolean;
2369
+ /**
2370
+ * The list of items in the section
2371
+ */
2372
+ items: ListMenuItem<T>[];
2373
+ /**
2374
+ * Whether to hide the entire section when the menu is closed
2375
+ * @default false
2376
+ */
2377
+ hideOnMenuClosed?: boolean;
2378
+ /**
2379
+ * Highlights the section with a background color and rounded corners.
2380
+ * @default false
2381
+ */
2382
+ highlight?: boolean;
2383
+ /**
2384
+ * When set, the section collapses into this icon when the menu is closed (desktop only).
2385
+ * On hover, a PopUpMenu opens revealing the section items.
2386
+ */
2387
+ replaceWithIconOnClose?: CommonIconNames;
2388
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
2389
+
2390
+ export declare const MidSectionMenus: {
2391
+ <T extends ElementType = "a">({ sections, open, variant, activeItem, linkComponent: LinkComponent, onItemClick, }: MidSectionMenusProps<T>): JSX.Element | null;
2392
+ displayName: string;
2393
+ };
2394
+
2395
+ export declare type MidSectionMenusProps<T extends ElementType = 'a'> = {
2396
+ /**
2397
+ * Section definitions (same shape as `SideNavigation` `midSections`).
2398
+ */
2399
+ sections: MidSection<T>[];
2400
+ /**
2401
+ * Whether the parent navigation is expanded (labels visible).
2402
+ * @default true
2403
+ */
2404
+ open?: boolean;
2405
+ /**
2406
+ * Sidebar shell width mode: must match the parent `SideNavigation` `variant` so open/closed width
2407
+ * transitions on the section wrappers stay aligned (`default` vs `compact` rail widths).
2408
+ * Does **not** change list row density — inner `ListMenu` instances are always `compact`.
2409
+ * @default 'default'
2410
+ */
2411
+ variant?: ListMenuVariant;
2412
+ /**
2413
+ * Active item id for `ListMenu` highlighting.
2414
+ */
2415
+ activeItem?: string;
2416
+ /**
2417
+ * Link element for menu rows.
2418
+ */
2419
+ linkComponent?: T | 'a';
2420
+ /**
2421
+ * Called when a row is activated (same contract as `ListMenu` / `SideNavigation` root lists).
2422
+ */
2423
+ onItemClick?: (item: ListMenuItem<T>) => void;
2424
+ };
2425
+
2426
+ declare type NonNullable_2<T> = Exclude<T, null | undefined>;
2427
+ export { NonNullable_2 as NonNullable }
2428
+
2429
+ export declare type Overflow = OverflowBase | {
2430
+ y?: OverflowYOrX;
2431
+ x?: OverflowYOrX;
2432
+ };
2433
+
2434
+ export declare type OverflowBase = 'visible' | 'hidden' | 'scroll' | 'auto' | 'y-auto' | 'y-scroll' | 'x-auto' | 'x-scroll';
2435
+
2436
+ export declare type OverflowYOrX = 'auto' | 'scroll' | 'hidden' | 'visible';
2437
+
2438
+ export declare type Padding = SpacingKeys | {
2439
+ top?: SpacingKeys;
2440
+ right?: SpacingKeys;
2441
+ bottom?: SpacingKeys;
2442
+ left?: SpacingKeys;
2443
+ x?: SpacingKeys;
2444
+ y?: SpacingKeys;
2445
+ };
2446
+
2447
+ export declare const Pagination: ({ currentPage, totalPages, rowsPerPage, onPageChange, onRowsPerPageChange, disabled, rowsPerPageLabel, pageOfPagesLabel, }: PaginationProps) => JSX.Element;
2448
+
2449
+ export declare interface PaginationProps {
2450
+ /**
2451
+ * The text for the rows per page.
2452
+ * @default "Zeilen pro Seite"
2453
+ */
2454
+ rowsPerPageLabel?: string;
2455
+ /**
2456
+ * The text for the "of" in "1 of 10".
2457
+ * @default "von"
2458
+ */
2459
+ pageOfPagesLabel?: string;
2460
+ /**
2461
+ * The current page of the Pagination.
2462
+ */
2463
+ currentPage: number;
2464
+ /**
2465
+ * The total pages of the Pagination.
2466
+ */
2467
+ totalPages: number;
2468
+ /**
2469
+ * The rows per page of the Pagination.
2470
+ */
2471
+ rowsPerPage?: RowsPerPage;
2472
+ /**
2473
+ * The callback function to handle page change.
2474
+ */
2475
+ onPageChange: (page: number) => void;
2476
+ /**
2477
+ * The callback function to handle rows per page change.
2478
+ */
2479
+ onRowsPerPageChange?: (rowsPerPage: RowsPerPage) => void;
2480
+ /**
2481
+ * The disabled state of the Pagination.
2482
+ */
2483
+ disabled?: boolean;
2484
+ }
2485
+
2486
+ declare type Panel = {
2487
+ id: string;
2488
+ children: React.ReactNode;
2489
+ };
2490
+
2491
+ export declare const PopUpMenu: ({ children, placement, disabled, trigger, density, closeOnItemClick, items, onItemClick, selectedItem, selectable, open, onClose, closeOnClickOutside, closeOnEscape, toggleOnClick, queryHighlight, showSearch, searchPlaceholder, allowClearAll, allowSelectAll, selectAllLabel, clearAllLabel, noResultsFoundMessage, onClearAllOrSelectAllClick, searchMode, onSearchChange, isLoading, wrapperWidth, onScrollEnd, isLoadingMore, height, minHeight, maxHeight, ...props }: PopUpMenuProps) => JSX.Element;
2492
+
2493
+ export declare type PopUpMenuItem<T extends React.ElementType = 'button'> = UnionAs_3 & {
2494
+ /**
2495
+ * The id of the item
2496
+ * @required
2497
+ */
2498
+ id: string;
2499
+ /**
2500
+ * The label of the item
2501
+ * @required (ignored when isDivider is true)
2502
+ */
2503
+ label: string;
2504
+ /**
2505
+ * Whether the item is a visual divider
2506
+ * @default false
2507
+ */
2508
+ isDivider?: boolean;
2509
+ /**
2510
+ * Props passed to the Divider component
2511
+ * Only used when `isDivider` is true
2512
+ */
2513
+ dividerProps?: DividerProps;
2514
+ /**
2515
+ * Custom ReactNode to render instead of the label.
2516
+ * When set, the item becomes non-interactive (not clickable, not focusable).
2517
+ */
2518
+ customContent?: React.ReactNode;
2519
+ /**
2520
+ * Whether the menu should stay open when this item is clicked
2521
+ * @default false
2522
+ */
2523
+ keepOpen?: boolean;
2524
+ /**
2525
+ * The callback function that is called when the item is clicked
2526
+ */
2527
+ onClick?: () => void;
2528
+ /**
2529
+ * The icon of the item
2530
+ * @see {@link CommonIconNames} for available icons
2531
+ */
2532
+ icon?: CommonIconNames;
2533
+ /**
2534
+ * Whether the item is disabled
2535
+ * @default false
2536
+ */
2537
+ disabled?: boolean;
2538
+ /**
2539
+ * Sub-menu items displayed in a nested PopUpMenu when the item is hovered.
2540
+ * Opens to the right of the item (or left if no space).
2541
+ */
2542
+ subMenuItems?: PopUpMenuItem[];
2543
+ /**
2544
+ * The custom component to be used for the item <br />
2545
+ * `as` is ignored when `linkComponent` is set
2546
+ * @see {@link UnionAs}
2547
+ */
2548
+ linkComponent?: T;
2549
+ } & Omit<React.ComponentProps<T>, 'className' | 'ref' | 'role' | 'tabIndex' | 'onClick' | 'disabled'>;
2550
+
2551
+ export declare type PopUpMenuPlacement = 'top' | 'bottom' | 'left' | 'right' | 'bottom-left' | 'bottom-right' | 'top-left' | 'top-right' | 'left-top' | 'left-bottom' | 'right-top' | 'right-bottom';
2552
+
2553
+ export declare interface PopUpMenuProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'children' | 'className'> {
2554
+ /**
2555
+ * The trigger element that the context menu is attached to
2556
+ */
2557
+ children: React.ReactNode;
2558
+ /**
2559
+ * The items to be displayed in the context menu <br />
2560
+ * The Generic type `T` is type of the `linkComponent` prop. Default `T` is `button`. <br />
2561
+ * If you use the prop `as` the types of the the selected option are automatically inferred to that particular item
2562
+ * @see {@link PopUpMenuItem}
2563
+ * @example
2564
+ * ```ts
2565
+ * const items: PopUpMenuItem[] = [
2566
+ * {
2567
+ * id: 'delete',
2568
+ * label: 'Delete',
2569
+ * onClick: () => {
2570
+ * console.log('Deleted');
2571
+ * },
2572
+ * icon: 'delete',
2573
+ * },
2574
+ * ];
2575
+ * ```
2576
+ */
2577
+ items: PopUpMenuItem[];
2578
+ /**
2579
+ * The selected items in the context menu
2580
+ * @see {@link PopUpMenuSelectionType}
2581
+ */
2582
+ selectedItem?: PopUpMenuSelectionType;
2583
+ /**
2584
+ * The callback function that is called when the items are clicked
2585
+ * @see {@link PopUpMenuSelectionType}
2586
+ * @see {@link PopUpMenuItem}
2587
+ */
2588
+ onItemClick?: (item: PopUpMenuItem, selectedItem?: PopUpMenuSelectionType) => void;
2589
+ /**
2590
+ * The callback function that is called when the clear all or select all buttons are clicked
2591
+ * @see {@link PopUpMenuSelectionType}
2592
+ * @see {@link PopUpMenuItem}
2593
+ */
2594
+ onClearAllOrSelectAllClick?: (items: PopUpMenuItem[], selectedItems: PopUpMenuSelectionType) => void;
2595
+ /**
2596
+ * The position of the context menu relative to its trigger
2597
+ * @default 'bottom-left'
2598
+ */
2599
+ placement?: ResponsiveType<PopUpMenuPlacement>;
2600
+ /**
2601
+ * The trigger event that opens the context menu
2602
+ * @default click
2603
+ */
2604
+ trigger?: 'hover' | 'click' | 'right-click';
2605
+ /**
2606
+ * The density of the context menu
2607
+ * @default default
2608
+ */
2609
+ density?: 'default' | '-2' | '-4';
2610
+ /**
2611
+ * Whether the context menu should be selectable
2612
+ * @default none
2613
+ */
2614
+ selectable?: 'single' | 'multiple' | 'none';
2615
+ /**
2616
+ * Whether the context menu should be disabled
2617
+ * @default false
2618
+ */
2619
+ disabled?: boolean;
2620
+ /**
2621
+ * Whether the context menu should be closed when the user clicks outside of it
2622
+ * @default true
2623
+ */
2624
+ closeOnClickOutside?: boolean;
2625
+ /**
2626
+ * Whether the context menu should be closed when the user presses the escape key
2627
+ * @default true
2628
+ */
2629
+ closeOnEscape?: boolean;
2630
+ /**
2631
+ * Whether the context menu should be toggled when the user clicks on the trigger
2632
+ * @default true
2633
+ */
2634
+ toggleOnClick?: boolean;
2635
+ /**
2636
+ * Whether the context menu should be open
2637
+ * @default false
2638
+ */
2639
+ open?: boolean;
2640
+ /**
2641
+ * The callback function that is called when the context menu is opened
2642
+ */
2643
+ onOpen?: () => void;
2644
+ /**
2645
+ * The callback function that is called when the context menu is closed
2646
+ */
2647
+ onClose?: () => void;
2648
+ /**
2649
+ * The query to be used to filter the items by label or id
2650
+ */
2651
+ queryHighlight?: string;
2652
+ /**
2653
+ * Whether the context menu should be closed when the item is clicked
2654
+ * Default is `true` when the `selectable` prop is `none` or `single`
2655
+ * @default true
2656
+ */
2657
+ closeOnItemClick?: boolean;
2658
+ /**
2659
+ * Whether the context menu should show a search input
2660
+ * @default false
2661
+ */
2662
+ showSearch?: boolean;
2663
+ /**
2664
+ * The placeholder of the search input
2665
+ * @default 'Suchen'
2666
+ */
2667
+ searchPlaceholder?: string;
2668
+ /**
2669
+ * Whether the context menu should allow clearing all selected items
2670
+ * @default false
2671
+ */
2672
+ allowClearAll?: boolean;
2673
+ /**
2674
+ * The label of the clear all button
2675
+ * @default 'Alle löschen'
2676
+ */
2677
+ clearAllLabel?: string;
2678
+ /**
2679
+ * Whether the context menu should allow selecting all items
2680
+ * @default false
2681
+ */
2682
+ allowSelectAll?: boolean;
2683
+ /**
2684
+ * The label of the select all button
2685
+ * @default 'Alle auswählen'
2686
+ */
2687
+ selectAllLabel?: string;
2688
+ /**
2689
+ * The message of the no results found message
2690
+ * @default 'Keine Ergebnisse gefunden'
2691
+ */
2692
+ noResultsFoundMessage?: string;
2693
+ /**
2694
+ * The mode of the search
2695
+ * @default 'built-in'
2696
+ */
2697
+ searchMode?: 'built-in' | 'async';
2698
+ /**
2699
+ * The callback function that is called when the search query is changed <br />
2700
+ * This is only used when the `searchMode` prop is set to `async`
2701
+ */
2702
+ onSearchChange?: (searchQuery: string) => void;
2703
+ /**
2704
+ * Whether the context menu is loading
2705
+ * @default false
2706
+ */
2707
+ isLoading?: boolean;
2708
+ /**
2709
+ * The width of the wrapper div that contains the context menu,
2710
+ * this is useful if you need the wrapped element to be full width (like in a InputField for example)
2711
+ * @default 'fit'
2712
+ */
2713
+ wrapperWidth?: 'fit' | 'full';
2714
+ /**
2715
+ * The callback function that is called when the scroll end is reached
2716
+ */
2717
+ onScrollEnd?: () => void;
2718
+ /**
2719
+ * Whether the context menu is loading more items when the user scrolls to the bottom
2720
+ * @default false
2721
+ */
2722
+ isLoadingMore?: boolean;
2723
+ /**
2724
+ * The height of the popup menu content
2725
+ */
2726
+ height?: ResponsiveType<number | string>;
2727
+ /**
2728
+ * The min height of the popup menu content
2729
+ */
2730
+ minHeight?: ResponsiveType<number | string>;
2731
+ /**
2732
+ * The max height of the popup menu content
2733
+ */
2734
+ maxHeight?: ResponsiveType<number | string>;
2735
+ }
2736
+
2737
+ export declare type PopUpMenuSelectionType = string | string[] | undefined;
2738
+
2739
+ export declare const ProgressIndicator: ({ value, indeterminate, variant, size, foregroundColor, backgroundColor, }: ProgressIndicatorProps) => JSX.Element;
2740
+
2741
+ export declare interface ProgressIndicatorProps {
2742
+ /**
2743
+ * The percentage of the progress indicator
2744
+ * @default 0
2745
+ */
2746
+ value?: number;
2747
+ /**
2748
+ * Whether the progress indicator is indeterminate
2749
+ * @default false
2750
+ */
2751
+ indeterminate?: boolean;
2752
+ /**
2753
+ * The variant of the progress indicator
2754
+ * @default 'linear'
2755
+ */
2756
+ variant?: 'linear' | 'circular';
2757
+ /**
2758
+ * The size of the circular progress indicator. Only applies to the circular variant.
2759
+ * @default 'md'
2760
+ */
2761
+ size?: 'sm' | 'md';
2762
+ /**
2763
+ * Custom color for the progress fill (foreground). Accepts any valid CSS color value.
2764
+ */
2765
+ foregroundColor?: BackgroundColors;
2766
+ /**
2767
+ * Custom color for the progress track (background).
2768
+ */
2769
+ backgroundColor?: BackgroundColors;
2770
+ }
2771
+
2772
+ export declare const RadioButton: React.FC<RadioButtonProps>;
2773
+
2774
+ export declare interface RadioButtonProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange'> {
2775
+ /**
2776
+ * Handle change events.
2777
+ */
2778
+ onChange?: ChangeEventHandler<HTMLInputElement>;
2779
+ /**
2780
+ * Handle the label of the radio button.
2781
+ */
2782
+ label: ReactNode;
2783
+ /**
2784
+ * Handle the name of the radio button.
2785
+ */
2786
+ name?: string;
2787
+ /**
2788
+ * Handle the id of the radio button.
2789
+ * @default auto-generated
2790
+ */
2791
+ id?: string;
2792
+ /**
2793
+ * Handle the value of the radio button.
2794
+ */
2795
+ value?: string;
2796
+ /**
2797
+ * Handle if the radio button is checked.
2798
+ */
2799
+ checked?: boolean;
2800
+ /**
2801
+ * Handle if the radio button is disabled.
2802
+ */
2803
+ disabled?: boolean;
2804
+ }
2805
+
2806
+ export declare const RadioGroup: {
2807
+ ({ children, name, value, onChange, row, disabled, }: RadioGroupProps): default_2.DetailedReactHTMLElement<{
2808
+ className: string;
2809
+ role: "radiogroup";
2810
+ 'aria-labelledby': string;
2811
+ }, HTMLElement>;
2812
+ displayName: string;
2813
+ };
2814
+
2815
+ export declare interface RadioGroupProps extends React.HTMLAttributes<HTMLDivElement> {
2816
+ /**
2817
+ * The children of the radio group.
2818
+ */
2819
+ children: React.ReactNode;
2820
+ /**
2821
+ * The name of the radio group. This will be passed to the radio buttons.
2822
+ */
2823
+ name: string;
2824
+ /**
2825
+ * The value of the selected radio button.
2826
+ */
2827
+ value?: string;
2828
+ /**
2829
+ * Handle change events.
2830
+ */
2831
+ onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
2832
+ /**
2833
+ * Set the group to be displayed in a row
2834
+ */
2835
+ row?: boolean;
2836
+ /**
2837
+ * Set the group to be disabled
2838
+ */
2839
+ disabled?: boolean;
2840
+ }
2841
+
2842
+ declare type RefType<T extends Node = HTMLElement> = RefObject<T | null> | null | undefined;
2843
+
2844
+ /**
2845
+ * Represents a file that was rejected during validation.
2846
+ * These files are not added to the file list but shown in the rejection list.
2847
+ */
2848
+ export declare interface RejectedFile {
2849
+ /**
2850
+ * The actual File object that was rejected.
2851
+ */
2852
+ file: File;
2853
+ /**
2854
+ * The validation error that caused the rejection.
2855
+ */
2856
+ error: FILE_ERROR;
2857
+ /**
2858
+ * Human-readable error message.
2859
+ */
2860
+ errorMessage: string;
2861
+ }
2862
+
2863
+ declare type ResponsiveBreakpoint = 'SM' | 'MD' | 'LG' | 'XL' | '2XL' | '3XL' | '4XL';
2864
+
2865
+ export declare type ResponsiveGenericStyles<Attr extends string, T extends string = string> = {
2866
+ [K in GenerateResponsiveGenericStyleKeys<Attr>]: Record<T, string>;
2867
+ };
2868
+
2869
+ export declare type ResponsiveStyles<Attr extends string> = {
2870
+ [K in GenerateResponsiveStyleKeys<Attr>]: Record<SpacingKeys, string>;
2871
+ };
2872
+
2873
+ export declare type ResponsiveType<T> = T | {
2874
+ [key in Viewport]?: T;
2875
+ };
2876
+
2877
+ export declare type ResponsiveTypeFixed<T> = {
2878
+ [key in Viewport]: T;
2879
+ };
2880
+
2881
+ export declare type RowsPerPage = 10 | 20 | 50 | 100 | 200;
2882
+
2883
+ export declare const ScoreCard: ForwardRefExoticComponent<ScoreCardProps & RefAttributes<HTMLDivElement>>;
2884
+
2885
+ export declare interface ScoreCardProps {
2886
+ /**
2887
+ * Main KPI value displayed prominently (e.g. "0,00", "156", "92,3%").
2888
+ */
2889
+ value: string | number;
2890
+ /**
2891
+ * Secondary label below the value (e.g. "Parameter", "davon 12 in kritischem Status").
2892
+ */
2893
+ parameter?: string;
2894
+ /**
2895
+ * Icon shown to the left of the parameter text.
2896
+ */
2897
+ parameterIcon?: CommonIconNames;
2898
+ /**
2899
+ * Whether to show the parameter icon.
2900
+ * @default true
2901
+ */
2902
+ showIcon?: boolean;
2903
+ /**
2904
+ * Color variant controlling background and text colors.
2905
+ * @default 'neutral'
2906
+ */
2907
+ variant?: ScoreCardVariant;
2908
+ /**
2909
+ * Size variant controlling padding and typography scale.
2910
+ * @default 'large'
2911
+ */
2912
+ size?: ScoreCardSize;
2913
+ /**
2914
+ * Locale for number formatting (e.g. 'de-DE', 'en-US').
2915
+ * When omitted, uses the browser's default locale.
2916
+ */
2917
+ locale?: string;
2918
+ /**
2919
+ * Fully custom content — replaces the default value/parameter layout.
2920
+ */
2921
+ children?: ReactNode;
2922
+ }
2923
+
2924
+ export declare type ScoreCardSize = 'large' | 'medium' | 'small';
2925
+
2926
+ export declare type ScoreCardVariant = 'negative' | 'active' | 'positive' | 'neutral' | 'ghost';
2927
+
2928
+ export declare const SegmentButton: <T extends React.ElementType = "button", V = string>({ label, active, matchSiblings, icon, value, as, linkComponent, ...props }: SegmentButtonProps<T, V>) => JSX.Element;
2929
+
2930
+ export declare type SegmentButtonProps<T extends React.ElementType, V = string> = React.ComponentPropsWithoutRef<T> & {
2931
+ /**
2932
+ * The label of the button.
2933
+ */
2934
+ label?: string;
2935
+ /**
2936
+ * The icon of the button.
2937
+ */
2938
+ icon?: CommonIconNames;
2939
+ /**
2940
+ * Whether the button is active.
2941
+ */
2942
+ active?: boolean;
2943
+ /**
2944
+ * Whether the button should match width with sibling buttons. <br />
2945
+ * Only used in `SegmentGroup`.
2946
+ * @default false
2947
+ */
2948
+ matchSiblings?: boolean;
2949
+ /**
2950
+ * The onClick event handler.
2951
+ */
2952
+ onClick?: (value: V) => void;
2953
+ /**
2954
+ * The link component of the button.
2955
+ * @default 'button'
2956
+ */
2957
+ as?: 'a' | 'button';
2958
+ /**
2959
+ * The link component of the button.
2960
+ * @default 'button'
2961
+ */
2962
+ linkComponent?: T;
2963
+ /**
2964
+ * The value of the button.
2965
+ */
2966
+ value: V;
2967
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
2968
+
2969
+ export declare const SegmentGroup: <T extends default_2.ElementType = "button", V = string>({ children, stretch, onChange, multiSelect, activeButton, disabled, linkComponent, }: SegmentGroupProps<T, V>) => default_2.DetailedReactHTMLElement<{
2970
+ className: string;
2971
+ }, HTMLElement>;
2972
+
2973
+ export declare interface SegmentGroupProps<T extends React.ElementType = 'button', V = string> {
2974
+ /**
2975
+ * The children of the button.
2976
+ */
2977
+ children: React.ReactElement<SegmentButtonProps<T, V>> | React.ReactElement<SegmentButtonProps<T, V>>[];
2978
+ /**
2979
+ * Make the segment group stretch to fill the container.
2980
+ */
2981
+ stretch?: boolean;
2982
+ /**
2983
+ * The active button value. <br />
2984
+ * If `multiSelect` is `true`, this should be an array of values. <br />
2985
+ * `V | V[]`
2986
+ */
2987
+ activeButton?: SegmentValue<V>;
2988
+ /**
2989
+ * Whether to allow multiple selections.
2990
+ */
2991
+ multiSelect?: boolean;
2992
+ /**
2993
+ * Handle change events.
2994
+ */
2995
+ onChange?: (value: SegmentValue<V>) => void;
2996
+ /**
2997
+ * The custom link component. <br />
2998
+ * It will be passed to the all `SegmentButton` components.
2999
+ * @default 'button'
3000
+ */
3001
+ linkComponent?: T;
3002
+ /**
3003
+ * Whether the segment group is disabled.
3004
+ */
3005
+ disabled?: boolean;
3006
+ }
3007
+
3008
+ export declare type SegmentValue<T = string> = T | T[];
3009
+
3010
+ export declare const Select: ({ value, multiple, options, onChange, error, errorMessage, disabled, label, hideLabel, name, id, searchable, allowClearAll, allowSelectAll, selectAllLabel, clearAllLabel, noResultsFoundMessage, onScrollEnd, isLoadingMore, ...props }: SelectProps) => JSX.Element;
3011
+
3012
+ export declare type SelectOption = Omit<PopUpMenuItem, 'id' | 'onClick' | 'disabled' | 'linkComponent' | 'as'> & {
3013
+ /**
3014
+ * The value of the option
3015
+ * @required
3016
+ */
3017
+ value: string;
3018
+ };
3019
+
3020
+ export declare type SelectProps = Union & {
3021
+ /**
3022
+ * The options of the select.
3023
+ */
3024
+ options: SelectOption[];
3025
+ /**
3026
+ * The onChange event handler.
3027
+ */
3028
+ onChange?: React.ChangeEventHandler<HTMLSelectElement>;
3029
+ /**
3030
+ * Whether the select has a search input.
3031
+ */
3032
+ searchable?: boolean;
3033
+ /**
3034
+ * Whether the select has an error.
3035
+ */
3036
+ error?: boolean;
3037
+ /**
3038
+ * The error message of the select.
3039
+ */
3040
+ errorMessage?: string;
3041
+ /**
3042
+ * Whether the select is disabled.
3043
+ */
3044
+ disabled?: boolean;
3045
+ /**
3046
+ * The label of the select.
3047
+ */
3048
+ label?: string;
3049
+ /**
3050
+ * Whether to hide the label.
3051
+ */
3052
+ hideLabel?: boolean;
3053
+ /**
3054
+ * The name of the select.
3055
+ */
3056
+ name: string;
3057
+ /**
3058
+ * The id of the select.
3059
+ */
3060
+ id?: string;
3061
+ } & Pick<PopUpMenuProps, 'allowClearAll' | 'allowSelectAll' | 'selectAllLabel' | 'clearAllLabel' | 'noResultsFoundMessage' | 'onScrollEnd' | 'isLoadingMore'> & Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'>;
3062
+
3063
+ export declare const Sheet: {
3064
+ ({ open, onClose, children, title, subTitle, closeOnBackdropClick, closeOnEsc, padding, showHandle, size, placement, headerActions, footerActions, stickyFooter, stickyHeader, showCloseButton, showBackArrow, resizable, width, minWidth, maxWidth, onResizeEnd, }: SheetProps): ReactPortal | null;
3065
+ displayName: string;
3066
+ };
3067
+
3068
+ /**
3069
+ * Global manager for Sheet components to track open sheets
3070
+ */
3071
+ declare class SheetManager {
3072
+ private readonly openSheets;
3073
+ private readonly closeCallbacks;
3074
+ /**
3075
+ * Register a Sheet as open with its close callback
3076
+ * @param sheetId - Unique identifier for the Sheet
3077
+ * @param closeCallback - Function to close this specific Sheet
3078
+ */
3079
+ registerOpenSheet(sheetId: string, closeCallback: () => void): void;
3080
+ /**
3081
+ * Unregister a Sheet as closed
3082
+ * @param sheetId - Unique identifier for the Sheet
3083
+ */
3084
+ unregisterOpenSheet(sheetId: string): void;
3085
+ /**
3086
+ * Close all other Sheets except the specified one
3087
+ * @param excludeSheetId - Sheet ID to exclude from closing
3088
+ */
3089
+ closeOtherSheets(excludeSheetId: string): void;
3090
+ /**
3091
+ * Check if any Sheets are currently open
3092
+ */
3093
+ hasOpenSheets(): boolean;
3094
+ /**
3095
+ * Get all currently open Sheet IDs
3096
+ */
3097
+ getOpenSheets(): string[];
3098
+ /**
3099
+ * Clear all registered Sheets (useful for cleanup)
3100
+ */
3101
+ clear(): void;
3102
+ }
3103
+
3104
+ export declare const sheetManager: SheetManager;
3105
+
3106
+ export declare type SheetProps = UnionPlacement & {
3107
+ /**
3108
+ * Controls whether the sheet is open or closed.
3109
+ */
3110
+ open: boolean;
3111
+ /**
3112
+ * Callback function called when the sheet is closed.
3113
+ * @default undefined
3114
+ */
3115
+ onClose: () => void;
3116
+ /**
3117
+ * The main content of the sheet.
3118
+ */
3119
+ children: ReactNode;
3120
+ /**
3121
+ * The title of the sheet.
3122
+ * @default undefined
3123
+ */
3124
+ title?: string;
3125
+ /**
3126
+ * The subtitle of the sheet.
3127
+ * @default undefined
3128
+ */
3129
+ subTitle?: string;
3130
+ /**
3131
+ * Whether clicking the backdrop should close the sheet.
3132
+ * @default true
3133
+ */
3134
+ closeOnBackdropClick?: boolean;
3135
+ /**
3136
+ * Whether pressing the Escape key should close the sheet.
3137
+ * @default false
3138
+ */
3139
+ closeOnEsc?: boolean;
3140
+ /**
3141
+ * The padding of the sheet content.
3142
+ * @default 'lg'
3143
+ */
3144
+ padding?: SpacingKeys;
3145
+ /**
3146
+ * Whether to show the drag handle (typically shown on mobile).
3147
+ * @default true
3148
+ */
3149
+ showHandle?: boolean;
3150
+ /**
3151
+ * The size of the sheet (affects width on desktop).
3152
+ * On mobile, the sheet always takes full width - 40px.
3153
+ * @default none
3154
+ */
3155
+ size?: 'sm' | 'md' | 'lg';
3156
+ /**
3157
+ * The footer actions of the sheet.
3158
+ * @default undefined
3159
+ */
3160
+ footerActions?: ReactNode;
3161
+ /**
3162
+ * The header actions of the sheet.
3163
+ * @default undefined
3164
+ */
3165
+ headerActions?: ReactNode;
3166
+ /**
3167
+ * Whether to make the footer sticky of the sheet.
3168
+ * @default true
3169
+ */
3170
+ stickyFooter?: boolean;
3171
+ /**
3172
+ * Whether to make the header sticky of the sheet.
3173
+ * @default true
3174
+ */
3175
+ stickyHeader?: boolean;
3176
+ /**
3177
+ * Whether to show the close button in the header. <br />
3178
+ * onClose() will be called when the close button is clicked.
3179
+ * @default false
3180
+ */
3181
+ showCloseButton?: boolean;
3182
+ /**
3183
+ * Whether to show the back button in the header. <br />
3184
+ * onClose() will be called when the back button is clicked.
3185
+ * @default false
3186
+ */
3187
+ showBackArrow?: boolean;
3188
+ };
3189
+
3190
+ export declare const SideNavigation: <T extends ElementType = "a">({ menuItems, utilityItems, midSections, subMenus, userArea, hideUserAreaInMobile, hideToggleButton, addBorderToToggleButton, logo, open, variant, activeItem, onToggleOpen, onActiveItemChange, onItemClick, linkComponent: LinkComponent, }: SideNavigationProps<T>) => JSX.Element;
3191
+
3192
+ export declare type SideNavigationProps<T extends React.ElementType = 'a'> = {
3193
+ /**
3194
+ * Whether the navigation is expanded
3195
+ */
3196
+ open?: boolean;
3197
+ /**
3198
+ * The visual variant of the navigation
3199
+ * @default 'default'
3200
+ */
3201
+ variant?: ListMenuVariant;
3202
+ /**
3203
+ * Logo displayed in the top area (compact variant only).
3204
+ * Shows `icon` when collapsed, `icon + name` when expanded.
3205
+ * Both have zvoove defaults if omitted.
3206
+ */
3207
+ logo?: {
3208
+ /**
3209
+ * Small logo icon shown when the sidebar is collapsed.
3210
+ */
3211
+ icon?: ReactNode;
3212
+ /**
3213
+ * Full logo name shown next to the icon when expanded.
3214
+ */
3215
+ name?: ReactNode;
3216
+ /**
3217
+ * When `true`, the icon is hidden while the sidebar is expanded so that only the name is visible.
3218
+ * When the sidebar collapses the icon reappears as the sole identifier.
3219
+ * @default false
3220
+ */
3221
+ hideIconWhenOpen?: boolean;
3222
+ };
3223
+ /**
3224
+ * The list of menu items
3225
+ */
3226
+ menuItems: ListMenuItem<T>[];
3227
+ /**
3228
+ * The list of utility items to stay at the bottom of the menu
3229
+ */
3230
+ utilityItems?: ListMenuItem<T>[];
3231
+ /**
3232
+ * Sections between the root main list and utility items, with collapse/expand behavior when the sidebar
3233
+ * closes (see `replaceWithIconOnClose`). Only the **root** column uses this prop; any lists inside a
3234
+ * slide-in panel belong in that layer’s `content`.
3235
+ */
3236
+ midSections?: MidSection<T>[];
3237
+ /**
3238
+ * Slide-in panels: `parentId` matches a root `menuItems` id; `content` is the custom body (back row is built-in).
3239
+ */
3240
+ subMenus?: SubMenuLayer[];
3241
+ /**
3242
+ * User area rendered at the bottom of the navigation
3243
+ */
3244
+ userArea?: UserAreaProps;
3245
+ /**
3246
+ * Hide the user area on mobile (useful when it's shown elsewhere, e.g. in a top bar).
3247
+ * @default true
3248
+ */
3249
+ hideUserAreaInMobile?: boolean;
3250
+ /**
3251
+ * When `true`, the built-in expand/collapse control in the header row is not rendered.
3252
+ * Use a `utilityItems` entry with `onClick` (and controlled `open` / `onToggleOpen`) instead.
3253
+ * @default false
3254
+ */
3255
+ hideToggleButton?: boolean;
3256
+ /**
3257
+ * When `true`, a border top, right and bottom are added to the toggle button. <br />
3258
+ * This is useful when the SideNavigation is used next to a Card with outlined variant as a content container.
3259
+ * @default false
3260
+ */
3261
+ addBorderToToggleButton?: boolean;
3262
+ /**
3263
+ * Active id for **root** `menuItems` / `utilityItems`. To open a sub panel from the shell, pass either the
3264
+ * layer’s `parentId` (e.g. `'zain'`) or an opaque dotted string `'<parentId>.<segment>'` where only the
3265
+ * part before the first `.` is read to choose the panel; the rest is for your app / `content` only.
3266
+ */
3267
+ activeItem?: string;
3268
+ /**
3269
+ * The component to render for the link
3270
+ */
3271
+ linkComponent?: T | 'a';
3272
+ /**
3273
+ * The callback to handle the open/close state
3274
+ */
3275
+ onToggleOpen?: (open: boolean) => void;
3276
+ /**
3277
+ * Fired after a root `menuItems` / `utilityItems` click with the suggested `activeItem` id, or with the
3278
+ * sub-panel `parentId` when opening a layer. Not called for `__back__` or `target="_blank"`. Clicks inside
3279
+ * `subMenus[].content` are not observed here.
3280
+ */
3281
+ onActiveItemChange?: (activeItem: string) => void;
3282
+ /**
3283
+ * The callback to handle the item click
3284
+ */
3285
+ onItemClick?: (item: ListMenuItem) => void;
3286
+ };
3287
+
3288
+ /**
3289
+ * @deprecated Use `ListMenuVariant` instead
3290
+ */
3291
+ export declare type SideNavigationVariant = ListMenuVariant;
3292
+
3293
+ declare type SideVariant = 'Top' | 'Bottom' | 'Left' | 'Right';
3294
+
3295
+ export declare type SimpleResponsiveStyles<Attr extends string> = {
3296
+ [K in GenerateSimpleResponsiveStyleKeys<Attr>]: Record<SpacingKeys, string>;
3297
+ };
3298
+
3299
+ export declare const Skeleton: ForwardRefExoticComponent<SkeletonProps & RefAttributes<HTMLDivElement>>;
3300
+
3301
+ export declare interface SkeletonProps extends React.HTMLAttributes<HTMLDivElement> {
3302
+ /**
3303
+ * The animation type of the skeleton.
3304
+ * @default 'pulse'
3305
+ */
3306
+ animation?: 'pulse' | 'wave' | false;
3307
+ /**
3308
+ * The width of the skeleton.
3309
+ */
3310
+ width?: number | string;
3311
+ /**
3312
+ * The height of the skeleton.
3313
+ */
3314
+ height?: number | string;
3315
+ /**
3316
+ * The border radius of the skeleton.
3317
+ * @default 'xs'
3318
+ */
3319
+ borderRadius?: 'xs' | 'sm' | 'md' | 'lg' | 'full';
3320
+ }
3321
+
3322
+ /**
3323
+ * Snackbar component for displaying snackbar notifications
3324
+ * Must be used within a SnackbarProvider
3325
+ *
3326
+ * @example
3327
+ * ```tsx
3328
+ * import { SnackbarProvider, Snackbar, useSnackbar } from '@components';
3329
+ *
3330
+ * function App() {
3331
+ * return (
3332
+ * <SnackbarProvider>
3333
+ * <Snackbar />
3334
+ * <YourApp />
3335
+ * </SnackbarProvider>
3336
+ * );
3337
+ * }
3338
+ *
3339
+ * function YourComponent() {
3340
+ * const { snackbar, success, error } = useSnackbar();
3341
+ *
3342
+ * return (
3343
+ * <button onClick={() => success('Operation completed!')}>
3344
+ * Click me
3345
+ * </button>
3346
+ * );
3347
+ * }
3348
+ * ```
3349
+ */
3350
+ export declare const Snackbar: default_2.FC<SnackbarProps>;
3351
+
3352
+ export declare interface SnackbarItem {
3353
+ /**
3354
+ * Unique identifier for the snackbar
3355
+ */
3356
+ id: string;
3357
+ /**
3358
+ * Content of the snackbar
3359
+ */
3360
+ children: string;
3361
+ /**
3362
+ * Timestamp when the snackbar was created
3363
+ */
3364
+ createdAt: number;
3365
+ /**
3366
+ * Semantic variant of the snackbar
3367
+ */
3368
+ variant: SnackbarVariant;
3369
+ /**
3370
+ * Placement of the snackbar on screen
3371
+ */
3372
+ placement: SnackbarPlacement;
3373
+ /**
3374
+ * Whether to show the close button
3375
+ */
3376
+ showCloseButton: boolean;
3377
+ /**
3378
+ * Icon to display in the snackbar
3379
+ */
3380
+ icon?: CommonIconNames | Omit<IconProps, 'size' | 'color'>;
3381
+ /**
3382
+ * Label for the action button
3383
+ */
3384
+ actionLabel?: string;
3385
+ /**
3386
+ * Action to perform when the action button is clicked
3387
+ */
3388
+ onAction?: (id: string) => void;
3389
+ /**
3390
+ * Callback when close button is clicked
3391
+ */
3392
+ onClose?: (id: string) => void;
3393
+ /**
3394
+ * Duration in milliseconds before auto-dismissing (0 = no auto-dismiss)
3395
+ */
3396
+ duration: number;
3397
+ /**
3398
+ * Whether the snackbar is currently being removed
3399
+ */
3400
+ isRemoving?: boolean;
3401
+ }
3402
+
3403
+ export declare interface SnackbarOptions {
3404
+ /**
3405
+ * The semantic variant of the Snackbar
3406
+ */
3407
+ variant?: SnackbarVariant;
3408
+ /**
3409
+ * Placement of the snackbar on screen
3410
+ * @default 'top-right'
3411
+ */
3412
+ placement?: SnackbarPlacement;
3413
+ /**
3414
+ * Whether to show the close button
3415
+ */
3416
+ showCloseButton?: boolean;
3417
+ /**
3418
+ * Icon to display in the Snackbar
3419
+ */
3420
+ icon?: CommonIconNames | Omit<IconProps, 'size' | 'color'>;
3421
+ /**
3422
+ * Label for the action button
3423
+ */
3424
+ actionLabel?: string;
3425
+ /**
3426
+ * Action to perform when the action button is clicked
3427
+ */
3428
+ onAction?: (id: string) => void;
3429
+ /**
3430
+ * Callback when close button is clicked
3431
+ */
3432
+ onClose?: (id: string) => void;
3433
+ /**
3434
+ * Duration in milliseconds before auto-dismissing (0 = no auto-dismiss)
3435
+ */
3436
+ duration?: number;
3437
+ /**
3438
+ * Custom ID for the snackbar
3439
+ */
3440
+ id?: string;
3441
+ }
3442
+
3443
+ export declare type SnackbarPlacement = 'top-left' | 'top-center' | 'top-right' | 'bottom-left' | 'bottom-center' | 'bottom-right';
3444
+
3445
+ export declare type SnackbarProps = Record<string, never>;
3446
+
3447
+ export declare const SnackbarProvider: default_2.FC<SnackbarProviderProps>;
3448
+
3449
+ declare interface SnackbarProviderProps {
3450
+ children: default_2.ReactNode;
3451
+ maxSnackbars?: number;
3452
+ defaultDuration?: number;
3453
+ }
3454
+
3455
+ export declare type SnackbarVariant = 'default' | 'positive' | 'warning' | 'error' | 'subtle';
3456
+
3457
+ export declare type SpacingKeys = 'none' | 'xs2' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xl2' | 'xl3' | 'xl4' | 'xl5' | 'xl6' | 'xl7';
3458
+
3459
+ export declare const Stack: ForwardRefExoticComponent<StackProps & RefAttributes<HTMLSpanElement>>;
3460
+
3461
+ export declare interface StackProps extends React.HTMLAttributes<HTMLDivElement> {
3462
+ /**
3463
+ * The children of the button.
3464
+ */
3465
+ children: ReactNode;
3466
+ /**
3467
+ * Define gap between elements.
3468
+ *
3469
+ * Accepts either a single spacing key applied to both axes, or an object
3470
+ * with `row` / `column` keys to target each axis independently.
3471
+ * Fully responsive: any per-breakpoint value can itself be a spacing key
3472
+ * or a `{ row, column }` object.
3473
+ *
3474
+ * @example
3475
+ * gap="md"
3476
+ * gap={{ row: 'sm', column: 'md' }}
3477
+ * gap={{ minimum: 'sm', mobile: { row: 'md', column: 'lg' } }}
3478
+ */
3479
+ gap?: ResponsiveType<Gap>;
3480
+ /**
3481
+ * Define the direction of the stack
3482
+ */
3483
+ direction?: ResponsiveType<FlexDirection>;
3484
+ /**
3485
+ * Define how to justify the content
3486
+ * All CSS properties from `justify-content` are accepted
3487
+ */
3488
+ justify?: ResponsiveType<JustifyContent>;
3489
+ /**
3490
+ * Define how to align the items
3491
+ * All CSS properties from `align-items` are accepted
3492
+ * @default 'baseline'
3493
+ */
3494
+ align?: ResponsiveType<AlignItems>;
3495
+ /**
3496
+ * Define how to align the items
3497
+ * All CSS properties from `flex-wrap` are accepted
3498
+ */
3499
+ wrap?: ResponsiveType<FlexWrap>;
3500
+ /**
3501
+ * Define padding to the stack wrapper.
3502
+ */
3503
+ padding?: ResponsiveType<Padding>;
3504
+ /**
3505
+ * Define margin to the stack wrapper.
3506
+ */
3507
+ margin?: ResponsiveType<Margin>;
3508
+ /**
3509
+ * @deprecated Use the `height`, `width`, `minHeight`, `maxHeight`, `minWidth`, `maxWidth` props instead.
3510
+ */
3511
+ className?: string;
3512
+ /**
3513
+ * The height of the stack.
3514
+ * @default 'auto'
3515
+ */
3516
+ height?: ResponsiveType<number | string>;
3517
+ /**
3518
+ * The width of the stack.
3519
+ * @default '100%'
3520
+ */
3521
+ width?: ResponsiveType<number | string>;
3522
+ /**
3523
+ * The min height of the stack.
3524
+ * @default 'auto'
3525
+ */
3526
+ minHeight?: ResponsiveType<number | string>;
3527
+ /**
3528
+ * The max height of the stack.
3529
+ * @default 'auto'
3530
+ */
3531
+ maxHeight?: ResponsiveType<number | string>;
3532
+ /**
3533
+ * The min width of the stack.
3534
+ * @default 'auto'
3535
+ */
3536
+ minWidth?: ResponsiveType<number | string>;
3537
+ /**
3538
+ * The max width of the stack.
3539
+ * @default 'auto'
3540
+ */
3541
+ maxWidth?: ResponsiveType<number | string>;
3542
+ }
3543
+
3544
+ /**
3545
+ * Slide-in panel for a root `menuItems` entry. The shell renders only the back row and spacer; pass any
3546
+ * content (e.g. one or more `ListMenu`s from a micro-frontend) as `content`. Selection and `activeItem`
3547
+ * for that UI live outside `SideNavigation`.
3548
+ */
3549
+ export declare type SubMenuLayer = {
3550
+ /**
3551
+ * Must match the `id` of the root `menuItems` entry that opens this panel.
3552
+ */
3553
+ parentId: string;
3554
+ /**
3555
+ * Custom body below the back row (often `ListMenu` or composed layout from a remote module).
3556
+ */
3557
+ content: ReactNode;
3558
+ /**
3559
+ * Label for the control that returns to the main menu.
3560
+ * @default 'Hauptmenü'
3561
+ */
3562
+ backLabel?: string;
3563
+ };
3564
+
3565
+ export declare const Switch: default_2.ForwardRefExoticComponent<SwitchProps & default_2.RefAttributes<HTMLInputElement>>;
3566
+
3567
+ export declare interface SwitchProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange'> {
3568
+ /**
3569
+ * Whether the switch is checked.
3570
+ */
3571
+ checked?: boolean;
3572
+ /**
3573
+ * Whether the switch is disabled.
3574
+ */
3575
+ disabled?: boolean;
3576
+ /**
3577
+ * Handle change events.
3578
+ */
3579
+ onChange?: React.ChangeEventHandler<HTMLInputElement>;
3580
+ /**
3581
+ * Whether to show icons on the switch.
3582
+ */
3583
+ withIcons?: boolean | IconStates;
3584
+ /**
3585
+ * The labels for the switch.
3586
+ */
3587
+ label?: string | LabelStates;
3588
+ /**
3589
+ * The placement of the label.
3590
+ * @default 'left'
3591
+ */
3592
+ labelPlacement?: 'left' | 'right';
3593
+ /**
3594
+ * How the switch and label are aligned horizontally.
3595
+ */
3596
+ justify?: JustifyContent;
3597
+ /**
3598
+ * The value of the switch.
3599
+ */
3600
+ value?: string;
3601
+ /**
3602
+ * The name of the switch.
3603
+ */
3604
+ name?: string;
3605
+ /**
3606
+ * The id of the switch.
3607
+ * @default auto-generated
3608
+ */
3609
+ id?: string;
3610
+ }
3611
+
3612
+ declare type TabItem<T extends React.ElementType = 'button'> = {
3613
+ label: string;
3614
+ icon?: CommonIconNames;
3615
+ iconPosition?: 'left' | 'top';
3616
+ hideLabel?: boolean;
3617
+ hasActivity?: boolean;
3618
+ id: string;
3619
+ } & Omit<React.ComponentPropsWithoutRef<T>, 'children'>;
3620
+
3621
+ export declare const Table: {
3622
+ <T extends readonly TableColumnProps[]>({ data, columns, title, subtitle, actions, filters, footer, orderBy, onOrderByChange, emptyState, hiddenColumns, loading, expandedRows, headerBackgroundColor, }: TableProps<T>): JSX.Element;
3623
+ displayName: string;
3624
+ };
3625
+
3626
+ export declare type TableColumnDirection = (typeof direction)[keyof typeof direction];
3627
+
3628
+ export declare interface TableColumnProps extends React.HTMLAttributes<HTMLTableColElement> {
3629
+ /**
3630
+ * The children of the Table.
3631
+ */
3632
+ label: React.ReactNode;
3633
+ /**
3634
+ * The id of the Table column.
3635
+ */
3636
+ id: string;
3637
+ /**
3638
+ * The alignment of the Table column.
3639
+ */
3640
+ align?: ColumnAlign;
3641
+ /**
3642
+ * The width of the Table column.
3643
+ */
3644
+ width?: string;
3645
+ /**
3646
+ * The minimum width of the Table column.
3647
+ */
3648
+ minWidth?: string;
3649
+ /**
3650
+ * If true, the column is orderable.
3651
+ */
3652
+ orderable?: boolean;
3653
+ }
3654
+
3655
+ export declare interface TableProps<T extends readonly TableColumnProps[] = readonly TableColumnProps[]> extends React.HTMLAttributes<HTMLTableElement> {
3656
+ /**
3657
+ * The title of the Table.
3658
+ */
3659
+ title?: string;
3660
+ /**
3661
+ * The subtitle of the Table.
3662
+ */
3663
+ subtitle?: string;
3664
+ /**
3665
+ * The action of the Table.
3666
+ */
3667
+ actions?: React.ReactNode;
3668
+ /**
3669
+ * The filters of the Table.
3670
+ */
3671
+ filters?: React.ReactNode;
3672
+ /**
3673
+ * The data rows of the Table.
3674
+ */
3675
+ data: TableRowData<T>[];
3676
+ /**
3677
+ * The loading state of the Table.
3678
+ */
3679
+ loading?: boolean;
3680
+ /**
3681
+ * The columns of the Table.
3682
+ */
3683
+ columns: T;
3684
+ /**
3685
+ * The hidden columns of the Table.
3686
+ */
3687
+ hiddenColumns?: ColumnId<T>[];
3688
+ /**
3689
+ * The expanded rows of the Table.
3690
+ */
3691
+ expandedRows?: string[];
3692
+ /**
3693
+ * The order by of the Table.
3694
+ */
3695
+ orderBy?: {
3696
+ column: ColumnId<T>;
3697
+ direction: TableColumnDirection;
3698
+ };
3699
+ /**
3700
+ * Callback function to handle order by change.
3701
+ */
3702
+ onOrderByChange?: ({ columnId, direction, }: {
3703
+ columnId: ColumnId<T>;
3704
+ direction: TableColumnDirection;
3705
+ }) => void;
3706
+ /**
3707
+ * The empty state of the Table.
3708
+ * @default 'Keine Daten gefunden'
3709
+ */
3710
+ emptyState?: React.ReactNode;
3711
+ /**
3712
+ * The footer of the Table.
3713
+ */
3714
+ footer?: React.ReactNode;
3715
+ /**
3716
+ * The background color of the table header.
3717
+ * @default false
3718
+ */
3719
+ headerBackgroundColor?: boolean;
3720
+ }
3721
+
3722
+ export declare type TableRowData<T extends readonly TableColumnProps[]> = {
3723
+ [K in ColumnId<T>]: React.ReactNode;
3724
+ } & {
3725
+ expandableRow?: ExpandableRowConfig;
3726
+ };
3727
+
3728
+ export declare const Tabs: {
3729
+ <T extends React.ElementType = "button">({ items, activeItem, onChange, hideBorder, itemsAlignment, isSticky, panels, linkComponent: LinkComponent, }: TabsProps<T>): JSX.Element;
3730
+ displayName: string;
3731
+ };
3732
+
3733
+ export declare interface TabsProps<T extends React.ElementType = 'button'> {
3734
+ /**
3735
+ * The items to display in the tabs.
3736
+ */
3737
+ items: TabItem<T>[];
3738
+ /**
3739
+ * Whether the tabs are sticky.
3740
+ */
3741
+ isSticky?: boolean;
3742
+ /**
3743
+ * The panels to display in the tabs.
3744
+ */
3745
+ panels?: Panel[];
3746
+ /**
3747
+ * The active item in the tabs.
3748
+ */
3749
+ activeItem: string;
3750
+ /**
3751
+ * The callback function to handle the change of the active item.
3752
+ */
3753
+ onChange?: (item: TabItem<T>) => void;
3754
+ /**
3755
+ * Whether to hide the border of the tabs.
3756
+ */
3757
+ hideBorder?: boolean;
3758
+ /**
3759
+ * The link component to use for the tabs.
3760
+ */
3761
+ linkComponent?: T | 'button' | 'a';
3762
+ /**
3763
+ * The alignment of the tabs.
3764
+ */
3765
+ itemsAlignment?: 'left' | 'center' | 'right' | 'between' | 'around' | 'evenly';
3766
+ }
3767
+
3768
+ export declare const Tag: ForwardRefExoticComponent<TagProps & RefAttributes<HTMLSpanElement>>;
3769
+
3770
+ export declare interface TagProps extends React.HTMLAttributes<HTMLSpanElement> {
3771
+ /**
3772
+ * The label of the tag.
3773
+ */
3774
+ label: string;
3775
+ /**
3776
+ * The variant of the tag
3777
+ */
3778
+ variant?: 'solid' | 'outlined' | 'ghost';
3779
+ /**
3780
+ * The color of the tag
3781
+ */
3782
+ color?: 'green' | 'yellow' | 'pink' | 'steel-blue' | 'error' | 'primary' | 'neutral';
3783
+ /**
3784
+ * The tone of the tag `color` <br />
3785
+ * Only works with `variant` set to `solid`
3786
+ */
3787
+ tone?: 'dark' | 'light';
3788
+ /**
3789
+ * The size of the tag.
3790
+ *
3791
+ * Accepts a single value or a responsive object keyed by viewport.
3792
+ *
3793
+ * @default 'md'
3794
+ *
3795
+ * @remarks
3796
+ * The values `'small' | 'medium' | 'large'` are **deprecated** and kept for
3797
+ * backwards compatibility. They are mapped to `'sm' | 'md' | 'lg'` and will
3798
+ * be removed in v3.0.0.
3799
+ */
3800
+ size?: ResponsiveType<TagSize | TagSizeLegacy>;
3801
+ /**
3802
+ * The icon of the tag
3803
+ */
3804
+ icon?: CommonIconNames;
3805
+ }
3806
+
3807
+ export declare type TagSize = 'sm' | 'md' | 'lg';
3808
+
3809
+ /* Excluded from this release type: TagSizeLegacy */
3810
+
3811
+ export declare const Textarea: ForwardRefExoticComponent<TextareaProps & RefAttributes<HTMLTextAreaElement>>;
3812
+
3813
+ export declare interface TextareaProps extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'className' | 'style'> {
3814
+ /**
3815
+ * If true, the textarea will display an error state.
3816
+ */
3817
+ error?: boolean;
3818
+ /**
3819
+ * The value of the textarea.
3820
+ */
3821
+ value?: string;
3822
+ /**
3823
+ * The error message to display below the textarea.
3824
+ */
3825
+ errorMessage?: string;
3826
+ /**
3827
+ * The maximum length of the textarea.
3828
+ */
3829
+ maxLength?: number;
3830
+ /**
3831
+ * The border radius of the textarea.
3832
+ * @default 'sm'
3833
+ */
3834
+ borderRadius?: 'none' | 'sm' | 'md' | 'lg' | 'xl';
3835
+ /**
3836
+ * Content rendered above the textarea input, separated by a subtle border.
3837
+ * Use to display contextual items such as attached files (e.g. `<Chip type="input" />`).
3838
+ */
3839
+ header?: React.ReactNode;
3840
+ /**
3841
+ * The actions to display below the textarea.
3842
+ */
3843
+ actions?: React.ReactNode;
3844
+ }
3845
+
3846
+ export declare const TextField: ForwardRefExoticComponent<TextFieldProps & RefAttributes<HTMLInputElement>>;
3847
+
3848
+ export declare interface TextFieldProps extends React.InputHTMLAttributes<HTMLInputElement> {
3849
+ /**
3850
+ * The label that will be displayed above the input. <br />
3851
+ * It is required for accessibility purposes.
3852
+ */
3853
+ label: string;
3854
+ /**
3855
+ * When true, the input applies the error style. <br />
3856
+ * Will also display the error message is any is provided.
3857
+ */
3858
+ error?: boolean;
3859
+ /**
3860
+ * The error message that will be displayed below the input. <br />
3861
+ * It is only displayed when the error prop is true.
3862
+ */
3863
+ errorMessage?: string;
3864
+ /**
3865
+ * The value of the input. <br />
3866
+ */
3867
+ value?: string;
3868
+ /**
3869
+ * The placeholder that will be displayed inside the input. <br />
3870
+ * If the label is visible, it will be shown in its active state.
3871
+ */
3872
+ placeholder?: string;
3873
+ /**
3874
+ * The density of the input will control the size of the input.
3875
+ */
3876
+ density?: ResponsiveType<Density>;
3877
+ /**
3878
+ * If true the label will be hidden. <br />
3879
+ * This will apply only visually, the label will still be present in the DOM for accessibility purposes.
3880
+ */
3881
+ hideLabel?: boolean;
3882
+ /**
3883
+ * Make the input disabled.
3884
+ */
3885
+ disabled?: boolean;
3886
+ /**
3887
+ * Make the input focused in a controlled way.
3888
+ */
3889
+ isFocused?: boolean;
3890
+ /**
3891
+ * Make the input clearable. <br />
3892
+ * When true, a clear button will be displayed on the right side of the input. <br />
3893
+ * When there's a icon placed on the right side of the input, the clear button will be hidden. <br />
3894
+ * Important: only works with controlled inputs.
3895
+ */
3896
+ clearable?: boolean;
3897
+ /**
3898
+ * The icon that will be displayed on the left side of the input.
3899
+ */
3900
+ icon?: CommonIconNames;
3901
+ /**
3902
+ * The action that will be triggered when the icon is clicked.
3903
+ */
3904
+ onIconClick?: () => void;
3905
+ /**
3906
+ * This prop controls the position of the icon.
3907
+ */
3908
+ iconPosition?: 'left' | 'right';
3909
+ /**
3910
+ * Callback function that will be called when the input changes.
3911
+ */
3912
+ onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void;
3913
+ }
3914
+
3915
+ export declare const Tooltip: ({ children, content, placement, disabled, }: TooltipProps) => JSX.Element;
3916
+
3917
+ export declare interface TooltipProps {
3918
+ /**
3919
+ * The trigger element that the tooltip is attached to
3920
+ */
3921
+ children: React.ReactNode;
3922
+ /**
3923
+ * The content to be displayed in the tooltip
3924
+ */
3925
+ content: React.ReactNode;
3926
+ /**
3927
+ * The position of the tooltip relative to its trigger
3928
+ */
3929
+ placement?: 'top' | 'bottom' | 'left' | 'right';
3930
+ /**
3931
+ * Whether the tooltip should be disabled
3932
+ */
3933
+ disabled?: boolean;
3934
+ /**
3935
+ * Whether the tooltip should be open
3936
+ */
3937
+ isOpen?: boolean;
3938
+ }
3939
+
3940
+ export declare const TopBar: ({ leftBottomContent, subtitle, leftTopContent, rightTopContent, rightBottomContent, density, }: TopBarProps) => JSX.Element;
3941
+
3942
+ export declare interface TopBarProps {
3943
+ /**
3944
+ * The content to be displayed in the left top section.
3945
+ */
3946
+ leftTopContent?: ReactNode;
3947
+ /**
3948
+ * The content to be displayed in the right top section.
3949
+ */
3950
+ rightTopContent?: ReactNode;
3951
+ /**
3952
+ * The content to be displayed in the left bottom section.
3953
+ */
3954
+ leftBottomContent?: string | ReactNode;
3955
+ /**
3956
+ * The content to be displayed in the right bottom section.
3957
+ */
3958
+ rightBottomContent?: ReactNode;
3959
+ /**
3960
+ * The subtitle to be displayed bellow the bottom section.
3961
+ */
3962
+ subtitle?: string;
3963
+ /**
3964
+ * The density of the top bar. It can be used to adjust the spacing and font sizes.
3965
+ */
3966
+ density?: 'default' | '-2' | '-4';
3967
+ }
3968
+
3969
+ export declare const Typography: ({ children, variant, size, as: AsComponent, color, textAlign, truncate, textTransform, hyphenate, wrap, ...props }: TypographyProps) => JSX.Element;
3970
+
3971
+ declare type TypographyElements = 'p' | 'span' | 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
3972
+
3973
+ export declare type TypographyProps<T extends TypographyElements = 'p'> = Omit<React.ComponentPropsWithoutRef<T>, 'as' | 'children'> & {
3974
+ /**
3975
+ * The children of the typography.
3976
+ */
3977
+ children: React.ReactNode;
3978
+ /**
3979
+ * The variant is used
3980
+ */
3981
+ variant?: 'display' | 'body' | 'title' | 'headline' | 'label';
3982
+ /**
3983
+ * The size of the typography.
3984
+ *
3985
+ * Accepts a single value or a responsive object keyed by viewport.
3986
+ *
3987
+ * @default 'md'
3988
+ *
3989
+ * @remarks
3990
+ * The values `'small' | 'medium' | 'large'` are **deprecated** and kept for
3991
+ * backwards compatibility. They are mapped to `'sm' | 'md' | 'lg'` and will
3992
+ * be removed in v3.0.0.
3993
+ */
3994
+ size?: ResponsiveType<TypographySize | TypographySizeLegacy>;
3995
+ /**
3996
+ * The html element of the typography. The TS type of the chosen element will be extended so you the component will accept all the props of the chosen element.
3997
+ */
3998
+ as?: 'p' | 'span' | 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';
3999
+ /**
4000
+ * The text alignment of the typography.
4001
+ */
4002
+ textAlign?: 'left' | 'center' | 'right';
4003
+ /**
4004
+ * CSS text-transform property
4005
+ */
4006
+ textTransform?: 'uppercase' | 'lowercase' | 'capitalize';
4007
+ /**
4008
+ * The color of the typography.
4009
+ */
4010
+ color?: ForegroundColors;
4011
+ /**
4012
+ * If true, the text will be hyphenated based on the `lang` attribute of the parent element.
4013
+ * @default true
4014
+ */
4015
+ hyphenate?: boolean;
4016
+ /**
4017
+ * Sets a specific amount of lines to show based on it's container.
4018
+ * The text that doesn't fit the container will be hidden and replaced by ellipsis
4019
+ */
4020
+ truncate?: number;
4021
+ /**
4022
+ * If true, the text will be wrapped.
4023
+ */
4024
+ wrap?: boolean;
4025
+ };
4026
+
4027
+ export declare type TypographySize = 'sm' | 'md' | 'lg';
4028
+
4029
+ /* Excluded from this release type: TypographySizeLegacy */
4030
+
4031
+ declare type Union = {
4032
+ /**
4033
+ * Whether the select is multiple.
4034
+ */
4035
+ multiple?: true;
4036
+ /**
4037
+ * The value of the select.
4038
+ */
4039
+ value?: string[];
4040
+ } | {
4041
+ /**
4042
+ * Whether the select is multiple.
4043
+ */
4044
+ multiple?: false;
4045
+ /**
4046
+ * The value of the select.
4047
+ */
4048
+ value?: string;
4049
+ };
4050
+
4051
+ declare type UnionAs = ({
4052
+ /**
4053
+ * The component to render the button as.
4054
+ * @default button
4055
+ */
4056
+ as?: 'a';
4057
+ } & Omit<React.ComponentProps<'a'>, 'className'>) | ({
4058
+ as?: 'button';
4059
+ } & Omit<React.ComponentProps<'button'>, 'className'>) | ({
4060
+ as?: 'span';
4061
+ } & Omit<React.ComponentProps<'span'>, 'className'>);
4062
+
4063
+ declare type UnionAs_2 = ({
4064
+ /**
4065
+ * Render the card root as a specific HTML element.
4066
+ * @default 'div'
4067
+ */
4068
+ as?: 'a';
4069
+ } & Omit<React.ComponentProps<'a'>, 'className'>) | ({
4070
+ as?: 'div';
4071
+ } & Omit<React.ComponentProps<'div'>, 'className'>);
4072
+
4073
+ declare type UnionAs_3 = ({
4074
+ /**
4075
+ * The component to render the button as.
4076
+ * @default button
4077
+ */
4078
+ as?: 'a';
4079
+ } & Omit<React.ComponentProps<'a'>, 'className' | 'ref' | 'role' | 'tabIndex' | 'onClick' | 'disabled'>) | ({
4080
+ /**
4081
+ * The component to render the button as.
4082
+ * @default button
4083
+ */
4084
+ as?: 'button';
4085
+ } & Omit<React.ComponentProps<'button'>, 'className' | 'type' | 'onClick' | 'disabled' | 'ref' | 'role' | 'tabIndex'>);
4086
+
4087
+ declare type UnionPlacement = {
4088
+ /**
4089
+ * The placement of the sheet.
4090
+ * - 'bottom': Slides up from bottom, centered horizontally
4091
+ * - 'right': Slides in from right, full screen on mobile, max-width 570px on desktop
4092
+ * @default 'bottom'
4093
+ */
4094
+ placement?: 'bottom';
4095
+ /**
4096
+ * Whether to make the sheet resizable. <br />
4097
+ * only available for right placement.
4098
+ * @default never
4099
+ */
4100
+ resizable?: never;
4101
+ /**
4102
+ * Custom width for the sheet in pixels. <br />
4103
+ * only available for right placement.
4104
+ * @default never
4105
+ */
4106
+ width?: never;
4107
+ /**
4108
+ * Minimum width for the sheet in pixels. <br />
4109
+ * only available for right placement.
4110
+ * @default never
4111
+ */
4112
+ minWidth?: never;
4113
+ /**
4114
+ * Maximum width for the sheet in pixels. <br />
4115
+ * only available for right placement.
4116
+ * @default never
4117
+ */
4118
+ maxWidth?: never;
4119
+ /**
4120
+ * Callback function called when the sheet resize finishes. <br />
4121
+ * only available for right placement.
4122
+ * @default never
4123
+ */
4124
+ onResizeEnd?: never;
4125
+ } | {
4126
+ /**
4127
+ * The placement of the sheet.
4128
+ * - 'bottom': Slides up from bottom, centered horizontally
4129
+ * - 'right': Slides in from right, full screen on mobile, max-width 570px on desktop
4130
+ * @default 'bottom'
4131
+ */
4132
+ placement?: 'right';
4133
+ /**
4134
+ * Whether to make the sheet resizable. <br />
4135
+ * Only available for right placement on desktop (768px/mobile breakpoint and above). <br />
4136
+ * On mobile, the sheet always takes 100% width and is not resizable.
4137
+ * @default false
4138
+ */
4139
+ resizable?: boolean;
4140
+ /**
4141
+ * Custom width for the sheet. <br />
4142
+ * Accepts a number (pixels) or string (e.g., "50%", "30rem"). <br />
4143
+ * Will not go below the minimum width (default 570px or custom minWidth). <br />
4144
+ * Only available for right placement on desktop (768px/mobile breakpoint and above). <br />
4145
+ * On mobile, the sheet always takes 100% width.
4146
+ * @default undefined
4147
+ */
4148
+ width?: number | string;
4149
+ /**
4150
+ * Minimum width for the sheet. <br />
4151
+ * Accepts a number (pixels) or string (e.g., "50%", "30rem"). <br />
4152
+ * Note: The absolute minimum of 570px is always enforced, regardless of this setting. <br />
4153
+ * Only available for right placement on desktop (768px/mobile breakpoint and above).
4154
+ * @default 570
4155
+ */
4156
+ minWidth?: number | string;
4157
+ /**
4158
+ * Maximum width for the sheet. <br />
4159
+ * Accepts a number (pixels) or string (e.g., "80%", "50rem"). <br />
4160
+ * Only available for right placement on desktop (768px/mobile breakpoint and above).
4161
+ * @default undefined
4162
+ */
4163
+ maxWidth?: number | string;
4164
+ /**
4165
+ * Callback function called when the sheet resize finishes. <br />
4166
+ * Provides the new width in pixels. <br />
4167
+ * Only available for right placement on desktop (768px/mobile breakpoint and above).
4168
+ * @param width - The new width of the sheet in pixels
4169
+ * @default undefined
4170
+ */
4171
+ onResizeEnd?: (width: number) => void;
4172
+ };
4173
+
4174
+ export declare const Uploader: ForwardRefExoticComponent<UploaderProps & RefAttributes<UploaderRef>>;
4175
+
4176
+ /**
4177
+ * Context value provided by the Uploader component.
4178
+ * Contains all state and methods needed by child components.
4179
+ */
4180
+ export declare interface UploaderContextValue {
4181
+ /**
4182
+ * Current list of files in the uploader.
4183
+ */
4184
+ files: FileItem[];
4185
+ /**
4186
+ * Whether files are currently being processed.
4187
+ */
4188
+ isProcessing: boolean;
4189
+ /**
4190
+ * Current component-level error, if any.
4191
+ */
4192
+ componentError: {
4193
+ code: COMPONENT_ERROR;
4194
+ message: string;
4195
+ } | null;
4196
+ /**
4197
+ * List of files that were rejected during validation.
4198
+ */
4199
+ rejectedFiles: RejectedFile[];
4200
+ /**
4201
+ * Whether files are being dragged over the drop zone.
4202
+ */
4203
+ isDragging: boolean;
4204
+ /**
4205
+ * Current screen reader announcement text.
4206
+ */
4207
+ announcement: string;
4208
+ /**
4209
+ * Whether the uploader is disabled.
4210
+ */
4211
+ disabled?: boolean;
4212
+ /**
4213
+ * Whether files can be deleted from the list.
4214
+ */
4215
+ canDeleteFile?: boolean;
4216
+ /**
4217
+ * Accepted file types string.
4218
+ */
4219
+ accept?: string;
4220
+ /**
4221
+ * Whether multiple files can be selected.
4222
+ */
4223
+ multiple?: boolean;
4224
+ /**
4225
+ * Localized label strings.
4226
+ */
4227
+ labels: typeof DEFAULT_LABELS;
4228
+ /**
4229
+ * HTML name attribute for the input.
4230
+ */
4231
+ name?: string;
4232
+ /**
4233
+ * Whether the input is required.
4234
+ */
4235
+ required?: boolean;
4236
+ /**
4237
+ * HTML id attribute for the input.
4238
+ */
4239
+ id?: string;
4240
+ /**
4241
+ * Form ID the input belongs to.
4242
+ */
4243
+ form?: string;
4244
+ /**
4245
+ * ID of element labelling the uploader.
4246
+ */
4247
+ ariaLabelledby?: string;
4248
+ /**
4249
+ * ID of element describing the uploader.
4250
+ */
4251
+ ariaDescribedby?: string;
4252
+ /**
4253
+ * ID of the error message element.
4254
+ */
4255
+ errorMessageId?: string;
4256
+ /**
4257
+ * Adds files to the uploader.
4258
+ */
4259
+ addFiles: (files: FileItem[]) => void;
4260
+ /**
4261
+ * Removes a file by ID.
4262
+ */
4263
+ removeFile: (id: string) => void;
4264
+ /**
4265
+ * Replaces all files with new files.
4266
+ */
4267
+ replaceFiles: (files: FileItem[]) => void;
4268
+ /**
4269
+ * Removes all files.
4270
+ */
4271
+ clearAll: () => void;
4272
+ /**
4273
+ * Updates the state of a specific file.
4274
+ */
4275
+ updateFileState: (id: string, state: Partial<FileState>) => void;
4276
+ /**
4277
+ * Sets the processing state.
4278
+ */
4279
+ setProcessing: (isProcessing: boolean, processingId?: string | null) => void;
4280
+ /**
4281
+ * Sets a component-level error.
4282
+ */
4283
+ setComponentError: (error: {
4284
+ code: COMPONENT_ERROR;
4285
+ message: string;
4286
+ } | null) => void;
4287
+ /**
4288
+ * Clears all rejected files from the rejection list.
4289
+ */
4290
+ clearRejectedFiles: () => void;
4291
+ /**
4292
+ * Makes a screen reader announcement.
4293
+ */
4294
+ announce: (type: AnnouncementType, data: Record<string, unknown>) => void;
4295
+ /**
4296
+ * Ref to the hidden file input element.
4297
+ */
4298
+ inputRef: default_2.RefObject<HTMLInputElement | null>;
4299
+ /**
4300
+ * Opens the native file picker.
4301
+ */
4302
+ openPicker: () => void;
4303
+ /**
4304
+ * Handles file input change events.
4305
+ */
4306
+ handleInputChange: (event: default_2.ChangeEvent<HTMLInputElement>) => void;
4307
+ /**
4308
+ * Handles file input invalid events.
4309
+ */
4310
+ handleInputInvalid: (event: default_2.FormEvent<HTMLInputElement>) => void;
4311
+ /**
4312
+ * Event handlers for drag and drop functionality.
4313
+ */
4314
+ dragHandlers: {
4315
+ onDragEnter: (event: default_2.DragEvent) => void;
4316
+ onDragOver: (event: default_2.DragEvent) => void;
4317
+ onDragLeave: (event: default_2.DragEvent) => void;
4318
+ onDrop: (event: default_2.DragEvent) => void;
4319
+ };
4320
+ /**
4321
+ * Custom function to generate file error messages.
4322
+ */
4323
+ getFileErrorMessage?: (error: FILE_ERROR, file: File) => string;
4324
+ /**
4325
+ * Custom function to generate component error messages.
4326
+ */
4327
+ getComponentErrorMessage?: (error: COMPONENT_ERROR, data: Record<string, unknown>) => string;
4328
+ /**
4329
+ * Custom function to generate announcements.
4330
+ */
4331
+ getAnnouncement?: (type: AnnouncementType, data: Record<string, unknown>) => string;
4332
+ /**
4333
+ * Callback when upload is cancelled.
4334
+ */
4335
+ onCancel?: (id: string) => void;
4336
+ /**
4337
+ * Callback when failed upload should be retried.
4338
+ */
4339
+ onRetry?: (id: string) => void;
4340
+ /**
4341
+ * Additional input props to spread on the native input element.
4342
+ */
4343
+ inputProps?: Omit<default_2.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'onInvalid' | 'className' | 'value' | 'type' | 'accept' | 'multiple' | 'name' | 'required' | 'id' | 'form' | 'disabled'>;
4344
+ }
4345
+
4346
+ /**
4347
+ * Labels configuration for the Uploader component.
4348
+ * All fields are required when defining the full labels object.
4349
+ * Use Partial<UploaderLabels> for optional overrides.
4350
+ */
4351
+ export declare type UploaderLabels = {
4352
+ /** Text displayed in the drop zone. */
4353
+ dropZoneText: string;
4354
+ /** Text for the browse link. */
4355
+ browseText: string;
4356
+ /** Text shown when dragging files over the drop zone. */
4357
+ dragOverText: string;
4358
+ /** Text shown while processing files. */
4359
+ processingText: string;
4360
+ /** Accessible label for the drop zone. */
4361
+ ariaLabel: string;
4362
+ /** Accessible label for the file list. */
4363
+ fileListLabel: string;
4364
+ /** Text shown when upload is canceled. */
4365
+ canceledText: string;
4366
+ /** Text shown when upload fails. */
4367
+ failedText: string;
4368
+ /** Text for cancel button. */
4369
+ cancelButtonText: string;
4370
+ /** Accessible label function for cancel button. */
4371
+ cancelButtonLabel: (fileName: string) => string;
4372
+ /** Text for retry button. */
4373
+ retryButtonText: string;
4374
+ /** Accessible label function for retry button. */
4375
+ retryButtonLabel: (fileName: string) => string;
4376
+ /** Accessible label function for remove button. */
4377
+ removeButtonLabel: (fileName: string) => string;
4378
+ /** Function returning upload progress text. */
4379
+ uploadingText: (progress: number) => string;
4380
+ /** Text shown while finalizing upload. */
4381
+ finalizingUploadText: string;
4382
+ /** Function to pluralize "file(s)" text. */
4383
+ pluralizeFiles: (count: number) => string;
4384
+ /** Text for dismiss all rejections button. */
4385
+ dismissAllRejectionsText: string;
4386
+ /** Header text for the rejection list. */
4387
+ rejectionListHeaderText: string;
4388
+ /** Function returning show more files text. */
4389
+ showMoreFilesText: (count: number) => string;
4390
+ /** Text to show less files. */
4391
+ showLessFilesText: string;
4392
+ /** Function returning max count exceeded error message with limit. */
4393
+ maxCountExceededWithLimitText: (maxCount: number) => string;
4394
+ /** Text for "added" in announcements. */
4395
+ addedText: string;
4396
+ /** Text for "total" in announcements. */
4397
+ totalText: string;
4398
+ /** Text for "selected" in announcements. */
4399
+ selectedText: string;
4400
+ /** Text for file removed announcement. */
4401
+ fileRemovedText: string;
4402
+ /** Text for all files removed announcement. */
4403
+ allFilesRemovedText: string;
4404
+ /** Error message for required field. */
4405
+ requiredErrorMessage: string;
4406
+ /** Error messages for file-level validation errors. Allows overriding individual messages. */
4407
+ fileErrorMessages: Partial<Record<FILE_ERROR, string>>;
4408
+ /** Error messages for component-level validation errors. Allows overriding individual messages. */
4409
+ componentErrorMessages: Partial<Record<COMPONENT_ERROR, string>>;
4410
+ };
4411
+
4412
+ export declare interface UploaderProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'onInvalid' | 'className' | 'value' | 'type' | 'accept' | 'multiple' | 'name' | 'required' | 'id' | 'form' | 'disabled'> {
4413
+ /**
4414
+ * Accepted file types (MIME types or file extensions).
4415
+ * Uses the same format as the HTML input accept attribute.
4416
+ * @example "image/*,.pdf,.doc,.docx"
4417
+ */
4418
+ accept?: string;
4419
+ /**
4420
+ * Whether multiple files can be selected at once.
4421
+ * @default true
4422
+ */
4423
+ multiple?: boolean;
4424
+ /**
4425
+ * Whether the uploader is disabled.
4426
+ * When disabled, files cannot be added or removed.
4427
+ * @default false
4428
+ */
4429
+ disabled?: boolean;
4430
+ /**
4431
+ * Whether individual files can be deleted from the list.
4432
+ * When false, the delete button is hidden on file items.
4433
+ */
4434
+ canDeleteFile?: boolean;
4435
+ /**
4436
+ * Determines how new files are handled when selected.
4437
+ * - 'append': New files are added to the existing list
4438
+ * - 'replace': New files replace the existing list
4439
+ * @default 'append'
4440
+ */
4441
+ selectionMode?: 'append' | 'replace';
4442
+ /**
4443
+ * Maximum allowed size for a single file in bytes.
4444
+ * Files exceeding this limit will be marked as invalid.
4445
+ */
4446
+ maxFileSize?: number;
4447
+ /**
4448
+ * Maximum allowed total size of all files combined in bytes.
4449
+ * Exceeding this limit triggers a component-level error.
4450
+ */
4451
+ maxTotalSize?: number;
4452
+ /**
4453
+ * Maximum number of files allowed.
4454
+ * Exceeding this limit triggers a component-level error.
4455
+ */
4456
+ maxCount?: number;
4457
+ /**
4458
+ * Minimum number of files required.
4459
+ * Having fewer files triggers a component-level error.
4460
+ */
4461
+ minCount?: number;
4462
+ /**
4463
+ * Controlled value - the list of files.
4464
+ * When provided, the component operates in controlled mode.
4465
+ */
4466
+ value?: FileItem[];
4467
+ /**
4468
+ * Callback fired when files are added, removed, replaced, or cleared.
4469
+ * Required when using controlled mode (value prop).
4470
+ */
4471
+ onChange?: (event: ChangeEvent) => void;
4472
+ /**
4473
+ * Callback fired after file validation is complete.
4474
+ * Provides validation results for each file and any component-level errors.
4475
+ */
4476
+ onValidation?: (event: ValidationEvent) => void;
4477
+ /**
4478
+ * Callback fired when a file upload is cancelled.
4479
+ * Receives the file ID that was cancelled.
4480
+ */
4481
+ onCancel?: (id: string) => void;
4482
+ /**
4483
+ * Callback fired when a failed upload should be retried.
4484
+ * Receives the file ID that should be retried.
4485
+ */
4486
+ onRetry?: (id: string) => void;
4487
+ /**
4488
+ * Custom labels for various UI elements.
4489
+ * Allows localization and customization of text content.
4490
+ */
4491
+ labels?: Partial<UploaderLabels>;
4492
+ /**
4493
+ * Custom function to generate error messages for file-level errors.
4494
+ * @param error - The error type
4495
+ * @param file - The file that caused the error
4496
+ * @returns Custom error message
4497
+ */
4498
+ getFileErrorMessage?: (error: FILE_ERROR, file: File) => string;
4499
+ /**
4500
+ * Custom function to generate error messages for component-level errors.
4501
+ * @param error - The error type
4502
+ * @param data - Additional data about the error (e.g., maxCount, totalSize)
4503
+ * @returns Custom error message
4504
+ */
4505
+ getComponentErrorMessage?: (error: COMPONENT_ERROR, data: Record<string, unknown>) => string;
4506
+ /**
4507
+ * Custom function to generate announcement messages for screen readers.
4508
+ * @param type - The type of announcement
4509
+ * @param data - Additional data about the action
4510
+ * @returns Custom announcement message
4511
+ */
4512
+ getAnnouncement?: (type: AnnouncementType, data: Record<string, unknown>) => string;
4513
+ /**
4514
+ * HTML name attribute for the file input.
4515
+ * Used for form submission.
4516
+ */
4517
+ name?: string;
4518
+ /**
4519
+ * Whether the file input is required.
4520
+ * Used for form validation.
4521
+ */
4522
+ required?: boolean;
4523
+ /**
4524
+ * HTML id attribute for the file input.
4525
+ */
4526
+ id?: string;
4527
+ /**
4528
+ * Associates the input with a specific form element.
4529
+ */
4530
+ form?: string;
4531
+ /**
4532
+ * ID of an element that labels the uploader.
4533
+ * Used for accessibility.
4534
+ */
4535
+ ariaLabelledby?: string;
4536
+ /**
4537
+ * ID of an element that describes the uploader.
4538
+ * Used for accessibility.
4539
+ */
4540
+ ariaDescribedby?: string;
4541
+ /**
4542
+ * Custom content to render instead of the default FileList.
4543
+ * When provided, showFileList is ignored.
4544
+ */
4545
+ children?: React.ReactNode;
4546
+ /**
4547
+ * Whether to show the default file list below the drop zone.
4548
+ * @default true
4549
+ */
4550
+ showFileList?: boolean;
4551
+ }
4552
+
4553
+ /**
4554
+ * Provider component that supplies the Uploader context to child components.
4555
+ */
4556
+ export declare const UploaderProvider: ({ value, children, }: UploaderProviderProps) => default_2.JSX.Element;
4557
+
4558
+ /**
4559
+ * Props for the UploaderProvider component.
4560
+ */
4561
+ export declare interface UploaderProviderProps extends PropsWithChildren {
4562
+ /**
4563
+ * The context value to provide.
4564
+ */
4565
+ value: UploaderContextValue;
4566
+ }
4567
+
4568
+ /**
4569
+ * Ref handle for the Uploader component.
4570
+ * Provides imperative methods to control the uploader.
4571
+ */
4572
+ export declare interface UploaderRef {
4573
+ /**
4574
+ * Focuses the file input element.
4575
+ */
4576
+ focus: () => void;
4577
+ /**
4578
+ * Opens the file picker dialog.
4579
+ */
4580
+ click: () => void;
4581
+ /**
4582
+ * Removes all files from the uploader.
4583
+ * Only works in uncontrolled mode.
4584
+ */
4585
+ clearAll: () => void;
4586
+ /**
4587
+ * Updates the state of a specific file.
4588
+ * Only works in uncontrolled mode.
4589
+ * @param id - The ID of the file to update
4590
+ * @param state - Partial state to merge with existing state
4591
+ */
4592
+ updateFileState: (id: string, state: Partial<FileState>) => void;
4593
+ /**
4594
+ * Removes a specific file from the uploader.
4595
+ * Only works in uncontrolled mode.
4596
+ * @param id - The ID of the file to remove
4597
+ */
4598
+ removeFile: (id: string) => void;
4599
+ }
4600
+
4601
+ /**
4602
+ * Custom hook that tracks the current breakpoint based on window width.
4603
+ * Returns an object with the current breakpoint and utility functions for comparison.
4604
+ *
4605
+ * @param enabled - Whether to set up resize event listeners. Defaults to true.
4606
+ * Set to false to prevent unnecessary listeners when breakpoint tracking is not needed.
4607
+ * @returns An object containing the current breakpoint and comparison utilities
4608
+ *
4609
+ * @example
4610
+ * ```tsx
4611
+ * const { currentBreakpoint, isBiggerThan, isSmallerThan, isBetween } = useBreakpoint();
4612
+ *
4613
+ * // Check current breakpoint
4614
+ * console.log(currentBreakpoint); // 'tablet'
4615
+ *
4616
+ * // Check if viewport is bigger than mobile
4617
+ * if (isBiggerThan('mobile')) {
4618
+ * // Render desktop layout
4619
+ * }
4620
+ *
4621
+ * // Check if viewport is smaller than laptop
4622
+ * if (isSmallerThan('laptop')) {
4623
+ * // Render mobile layout
4624
+ * }
4625
+ *
4626
+ * // Check if viewport is between tablet and laptop (inclusive)
4627
+ * if (isBetween('tablet', 'laptop')) {
4628
+ * // Render medium layout
4629
+ * }
4630
+ * ```
4631
+ */
4632
+ export declare const useBreakpoint: (enabled?: boolean) => UseBreakpointReturn;
4633
+
4634
+ export declare interface UseBreakpointReturn {
4635
+ /** The current viewport breakpoint */
4636
+ currentBreakpoint: Viewport;
4637
+ /** Returns true if the current breakpoint is larger than the specified breakpoint */
4638
+ isBiggerThan: (breakpoint: Viewport) => boolean;
4639
+ /** Returns true if the current breakpoint is smaller than the specified breakpoint */
4640
+ isSmallerThan: (breakpoint: Viewport) => boolean;
4641
+ /** Returns true if the current breakpoint is between the two specified breakpoints (inclusive) */
4642
+ isBetween: (minBreakpoint: Viewport, maxBreakpoint: Viewport) => boolean;
4643
+ }
4644
+
4645
+ export declare const useClickOutside: <T extends Node = HTMLElement>(refs: RefType<T> | RefType<T>[] | RefType<Node>[], callback: () => void, isOpen?: boolean) => void;
4646
+
4647
+ export declare const UserArea: ForwardRefExoticComponent<UserAreaProps & RefAttributes<HTMLDivElement>>;
4648
+
4649
+ export declare interface UserAreaProps {
4650
+ /**
4651
+ * The user's display name
4652
+ */
4653
+ name: string;
4654
+ /**
4655
+ * Optional subtitle (e.g. role, company)
4656
+ */
4657
+ subtitle?: string;
4658
+ /**
4659
+ * The avatar of the user (see AvatarProps)
4660
+ */
4661
+ avatar: AvatarProps;
4662
+ /**
4663
+ * Whether to display in compact mode (small avatar)
4664
+ * @default false
4665
+ */
4666
+ compact?: boolean;
4667
+ /**
4668
+ * Whether to show the user info text (name and subtitle)
4669
+ * @default true
4670
+ */
4671
+ showInfo?: boolean;
4672
+ /**
4673
+ * Position of the info text relative to the avatar
4674
+ * @default 'right'
4675
+ */
4676
+ infoPosition?: 'left' | 'right';
4677
+ /**
4678
+ * Menu items displayed in a PopUpMenu when the user area is clicked
4679
+ */
4680
+ menuItems?: PopUpMenuItem[];
4681
+ /**
4682
+ * Callback when a menu item is clicked
4683
+ */
4684
+ onItemClick?: (item: PopUpMenuItem) => void;
4685
+ /**
4686
+ * The max height of the popup menu
4687
+ * @default '80dvh'
4688
+ */
4689
+ menuMaxHeight?: ResponsiveType<number | string>;
4690
+ /**
4691
+ * The placement of the popup menu
4692
+ * @default 'top-left'
4693
+ */
4694
+ menuPlacement?: ResponsiveType<PopUpMenuPlacement>;
4695
+ }
4696
+
4697
+ export declare const useSheetAnimation: (open: boolean) => {
4698
+ mounted: boolean;
4699
+ show: boolean;
4700
+ setShow: Dispatch<SetStateAction<boolean>>;
4701
+ };
4702
+
4703
+ /**
4704
+ * Custom hook to handle Sheet closing logic
4705
+ *
4706
+ * Centralizes the close animation pattern:
4707
+ * 1. Hide the sheet (trigger exit animation)
4708
+ * 2. Wait for animation to complete (500ms)
4709
+ * 3. Call onClose callback (unmount)
4710
+ */
4711
+ export declare const useSheetClose: ({ setShow, onClose, closeOnBackdropClick, }: UseSheetCloseProps) => UseSheetCloseReturn;
4712
+
4713
+ declare interface UseSheetCloseProps {
4714
+ setShow: Dispatch<SetStateAction<boolean>>;
4715
+ onClose: () => void;
4716
+ closeOnBackdropClick: boolean;
4717
+ }
4718
+
4719
+ declare interface UseSheetCloseReturn {
4720
+ handleSwipeDismiss: () => void;
4721
+ handleBackdropClick: () => void;
4722
+ }
4723
+
4724
+ export declare const useSheetEscape: (onClose: () => void, closeOnEsc: boolean) => void;
4725
+
4726
+ export declare const useSheetFocus: (sheetRef: React.RefObject<HTMLDivElement | null>, mounted: boolean) => void;
4727
+
4728
+ /**
4729
+ * Custom hook to register/unregister sheet with the global SheetManager
4730
+ *
4731
+ * Ensures proper lifecycle management of sheets in the manager,
4732
+ * allowing for global sheet coordination (e.g., closing all sheets)
4733
+ */
4734
+ export declare const useSheetRegistration: ({ sheetId, mounted, open, onClose, }: UseSheetRegistrationProps) => void;
4735
+
4736
+ declare interface UseSheetRegistrationProps {
4737
+ sheetId: string;
4738
+ mounted: boolean;
4739
+ open: boolean;
4740
+ onClose: () => void;
4741
+ }
4742
+
4743
+ export declare const useSheetResize: ({ sheetRef, handleRef, enabled, minWidth: customMinWidth, maxWidth: customMaxWidth, onResizeEnd, }: UseSheetResizeProps) => void;
4744
+
4745
+ declare interface UseSheetResizeProps {
4746
+ sheetRef: React.RefObject<HTMLDivElement | null>;
4747
+ handleRef: React.RefObject<HTMLDivElement | null>;
4748
+ enabled: boolean;
4749
+ minWidth?: number | string;
4750
+ maxWidth?: number | string;
4751
+ onResizeEnd?: (width: number) => void;
4752
+ }
4753
+
4754
+ /**
4755
+ * Custom hook to track scroll position and overflow state for Sheet component
4756
+ *
4757
+ * Monitors:
4758
+ * - Whether content is scrolled from top (for header border)
4759
+ * - Whether scrolled to bottom (for footer border)
4760
+ * - Whether content overflows container (for conditional styling)
4761
+ */
4762
+ export declare const useSheetScrollTracking: ({ scrollableContentRef, sheetRef, contentRef, mounted, }: UseSheetScrollTrackingProps) => UseSheetScrollTrackingReturn;
4763
+
4764
+ declare interface UseSheetScrollTrackingProps {
4765
+ scrollableContentRef: React.RefObject<HTMLDivElement | null>;
4766
+ sheetRef: React.RefObject<HTMLDivElement | null>;
4767
+ contentRef: React.RefObject<HTMLDivElement | null>;
4768
+ mounted: boolean;
4769
+ }
4770
+
4771
+ declare interface UseSheetScrollTrackingReturn {
4772
+ isScrolled: boolean;
4773
+ isAtBottom: boolean;
4774
+ hasOverflow: boolean;
4775
+ }
4776
+
4777
+ export declare const useSheetSwipe: ({ sheetRef, onDismiss, enabled, placement, }: UseSheetSwipeProps) => void;
4778
+
4779
+ declare interface UseSheetSwipeProps {
4780
+ sheetRef: React.RefObject<HTMLDivElement | null>;
4781
+ onDismiss: () => void;
4782
+ enabled: boolean;
4783
+ placement?: 'bottom' | 'right';
4784
+ }
4785
+
4786
+ /**
4787
+ * Custom hook to manage Sheet width constraints and validation
4788
+ *
4789
+ * Features:
4790
+ * - Applies custom width for right-placed sheets on desktop
4791
+ * - Enforces absolute minimum width (570px)
4792
+ * - Validates against min/max width constraints
4793
+ * - Ensures width doesn't exceed screen width
4794
+ * - Provides helpful console warnings for constraint violations
4795
+ */
4796
+ export declare const useSheetWidth: ({ sheetRef, placement, width, minWidth, maxWidth, mounted, }: UseSheetWidthProps) => void;
4797
+
4798
+ declare interface UseSheetWidthProps {
4799
+ sheetRef: React.RefObject<HTMLDivElement | null>;
4800
+ placement: 'bottom' | 'right';
4801
+ width?: number | string;
4802
+ minWidth?: number | string;
4803
+ maxWidth?: number | string;
4804
+ mounted: boolean;
4805
+ }
4806
+
4807
+ /**
4808
+ * Hook to interact with the Snackbar system
4809
+ * Must be used within a SnackbarProvider
4810
+ */
4811
+ export declare const useSnackbar: () => UseSnackbarReturn;
4812
+
4813
+ export declare interface UseSnackbarReturn {
4814
+ /**
4815
+ * Show a snackbar message
4816
+ */
4817
+ snackbar: (message: SnackbarItem['children'], options?: SnackbarOptions) => SnackbarItem['id'];
4818
+ /**
4819
+ * Dismiss a specific snackbar by ID
4820
+ */
4821
+ dismiss: (id: string) => void;
4822
+ /**
4823
+ * Dismiss all snackbars
4824
+ */
4825
+ dismissAll: () => void;
4826
+ }
4827
+
4828
+ /**
4829
+ * Event emitted after file validation is complete.
4830
+ */
4831
+ export declare interface ValidationEvent {
4832
+ /**
4833
+ * Whether all files passed validation with no component errors.
4834
+ */
4835
+ isValid: boolean;
4836
+ /**
4837
+ * Validation results for each file.
4838
+ */
4839
+ fileResults: Array<{
4840
+ /** ID of the file. Optional for rejected files that are not added to the file list. */
4841
+ id?: string;
4842
+ /** Whether the file has a validation error. */
4843
+ hasError: boolean;
4844
+ /** The error type if validation failed. */
4845
+ error?: FILE_ERROR;
4846
+ /** Human-readable error message. */
4847
+ errorMessage?: string;
4848
+ }>;
4849
+ /**
4850
+ * Component-level errors that occurred during validation.
4851
+ */
4852
+ componentErrors?: Array<{
4853
+ code: COMPONENT_ERROR;
4854
+ message: string;
4855
+ }>;
4856
+ }
4857
+
4858
+ export declare type Viewport = keyof typeof BREAKPOINTS;
4859
+
4860
+ export declare const ZvooveBrand: {
4861
+ ({ product, iconStyle, size, hideIcon, hideName, hideTagline, tagline: taglineProp, iconSize: iconSizeProp, nameHeight: nameHeightProp, taglineSize: taglineSizeProp, }: ZvooveBrandProps): JSX.Element;
4862
+ displayName: string;
4863
+ };
4864
+
4865
+ /**
4866
+ * Visual style of the logomark.
4867
+ * - `duotone`: brand colors in light mode, switches to the themed flat
4868
+ * variant in dark mode so the logomark always follows the surface tone.
4869
+ * - `flat`: a single-color version using the surface foreground token,
4870
+ * themed in both light and dark mode.
4871
+ */
4872
+ export declare type ZvooveBrandIconStyle = 'duotone' | 'flat';
4873
+
4874
+ export declare interface ZvooveBrandProps {
4875
+ /**
4876
+ * The zvoove product to display. Drives both the logomark and the tagline.
4877
+ * @default 'default'
4878
+ */
4879
+ product?: ZvooveProduct;
4880
+ /**
4881
+ * Visual style of the logomark.
4882
+ * @default 'duotone'
4883
+ */
4884
+ iconStyle?: ZvooveBrandIconStyle;
4885
+ /**
4886
+ * Overall size of the brand lock-up. Sets sensible defaults for the
4887
+ * logomark, wordmark and tagline while keeping the Figma design ratios.
4888
+ * Individual `iconSize`, `nameHeight` and `taglineSize` props can
4889
+ * override the values picked from the size.
4890
+ * @default 'md'
4891
+ */
4892
+ size?: ZvooveBrandSize;
4893
+ /**
4894
+ * Hide the logomark.
4895
+ * @default false
4896
+ */
4897
+ hideIcon?: boolean;
4898
+ /**
4899
+ * Hide the "zvoove" wordmark.
4900
+ * @default false
4901
+ */
4902
+ hideName?: boolean;
4903
+ /**
4904
+ * Hide the product tagline (e.g. "One", "Recruit").
4905
+ * Has no effect when `product="default"` since the default brand has no tagline.
4906
+ * @default false
4907
+ */
4908
+ hideTagline?: boolean;
4909
+ /**
4910
+ * Override the product tagline with a custom string. Falls back to the
4911
+ * tagline derived from `product` when omitted. Useful for sub-products,
4912
+ * environment labels (e.g. "Beta", "Staging") or fully custom branding.
4913
+ * Has no effect when `hideTagline` is `true`.
4914
+ */
4915
+ tagline?: string;
4916
+ /**
4917
+ * Override the logomark size in pixels. Falls back to the value derived
4918
+ * from `size`.
4919
+ */
4920
+ iconSize?: number;
4921
+ /**
4922
+ * Override the "zvoove" wordmark height in pixels. Falls back to the
4923
+ * value derived from `size`.
4924
+ */
4925
+ nameHeight?: number;
4926
+ /**
4927
+ * Override the product tagline font size in pixels. Falls back to the
4928
+ * value derived from `size`.
4929
+ */
4930
+ taglineSize?: number;
4931
+ }
4932
+
4933
+ /**
4934
+ * Overall size of the brand lock-up. Each tier scales the logomark,
4935
+ * wordmark and tagline together while keeping the design ratios.
4936
+ * `md` matches the Figma baseline (icon 32px, wordmark 13px, tagline 24px).
4937
+ */
4938
+ export declare type ZvooveBrandSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';
4939
+
4940
+ declare interface ZvooveLogoProps {
4941
+ size?: number;
4942
+ color?: string;
4943
+ }
4944
+
4945
+ /**
4946
+ * The zvoove product whose brand identity to display.
4947
+ * Determines the logomark and the tagline text (e.g. "One", "Recruit").
4948
+ */
4949
+ export declare type ZvooveProduct = 'default' | 'one' | 'recruit' | 'invoice-monitor' | 'go' | 'insights' | 'work-expert' | 'elevate' | 'cashlink' | 'docs-ai';
4950
+
4951
+ export { }