@mezzanine-ui/react 0.15.3 → 1.0.0-alpha.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 (490) hide show
  1. package/Accordion/Accordion.js +1 -2
  2. package/Accordion/AccordionControlContext.js +1 -0
  3. package/Accordion/AccordionDetails.js +2 -2
  4. package/Accordion/AccordionSummary.d.ts +1 -1
  5. package/Accordion/AccordionSummary.js +11 -12
  6. package/Accordion/index.d.ts +6 -3
  7. package/Alert/Alert.js +1 -2
  8. package/Alert/index.d.ts +3 -2
  9. package/AlertBanner/AlertBanner.d.ts +93 -0
  10. package/AlertBanner/AlertBanner.js +154 -0
  11. package/AlertBanner/index.d.ts +2 -0
  12. package/AlertBanner/index.js +1 -0
  13. package/Anchor/Anchor.js +2 -3
  14. package/Anchor/index.d.ts +2 -1
  15. package/AppBar/AppBar.js +1 -2
  16. package/AppBar/AppBarBrand.js +1 -2
  17. package/AppBar/AppBarMain.js +1 -2
  18. package/AppBar/AppBarSupport.js +1 -2
  19. package/AppBar/index.d.ts +8 -4
  20. package/{Overlay/Overlay.d.ts → Backdrop/Backdrop.d.ts} +12 -16
  21. package/Backdrop/Backdrop.js +40 -0
  22. package/Backdrop/index.d.ts +2 -0
  23. package/Backdrop/index.js +1 -0
  24. package/Badge/Badge.d.ts +20 -14
  25. package/Badge/Badge.js +15 -18
  26. package/Badge/BadgeContainer.d.ts +1 -1
  27. package/Badge/BadgeContainer.js +2 -3
  28. package/Badge/index.d.ts +3 -2
  29. package/Badge/typings.d.ts +48 -0
  30. package/Breadcrumb/Breadcrumb.d.ts +6 -0
  31. package/Breadcrumb/Breadcrumb.js +25 -0
  32. package/Breadcrumb/BreadcrumbItem.d.ts +4 -0
  33. package/Breadcrumb/BreadcrumbItem.js +45 -0
  34. package/Breadcrumb/index.d.ts +2 -0
  35. package/Breadcrumb/index.js +1 -0
  36. package/Breadcrumb/typings.d.ts +70 -0
  37. package/Button/Button.js +24 -19
  38. package/Button/ButtonGroup.d.ts +6 -28
  39. package/Button/ButtonGroup.js +8 -18
  40. package/Button/index.d.ts +6 -12
  41. package/Button/index.js +2 -3
  42. package/Button/typings.d.ts +11 -26
  43. package/Calendar/Calendar.d.ts +31 -2
  44. package/Calendar/Calendar.js +75 -21
  45. package/Calendar/CalendarCell.d.ts +4 -0
  46. package/Calendar/CalendarCell.js +3 -3
  47. package/Calendar/CalendarConfigProviderDayjs.d.ts +21 -0
  48. package/Calendar/CalendarConfigProviderDayjs.js +15 -0
  49. package/Calendar/CalendarConfigProviderLuxon.d.ts +21 -0
  50. package/Calendar/CalendarConfigProviderLuxon.js +15 -0
  51. package/Calendar/CalendarConfigProviderMoment.d.ts +21 -0
  52. package/Calendar/CalendarConfigProviderMoment.js +15 -0
  53. package/Calendar/CalendarContext.d.ts +14 -7
  54. package/Calendar/CalendarContext.js +8 -13
  55. package/Calendar/CalendarControls.d.ts +16 -0
  56. package/Calendar/CalendarControls.js +3 -7
  57. package/Calendar/CalendarDayOfWeek.js +4 -3
  58. package/Calendar/CalendarDays.d.ts +9 -1
  59. package/Calendar/CalendarDays.js +63 -38
  60. package/Calendar/CalendarFooterActions.d.ts +13 -0
  61. package/Calendar/CalendarFooterActions.js +14 -0
  62. package/Calendar/CalendarFooterControl.d.ts +16 -0
  63. package/Calendar/CalendarFooterControl.js +14 -0
  64. package/Calendar/CalendarHalfYears.d.ts +39 -0
  65. package/Calendar/CalendarHalfYears.js +62 -0
  66. package/Calendar/CalendarMonths.js +17 -5
  67. package/Calendar/CalendarQuarters.d.ts +37 -0
  68. package/Calendar/CalendarQuarters.js +64 -0
  69. package/Calendar/CalendarQuickSelect.d.ts +21 -0
  70. package/Calendar/CalendarQuickSelect.js +15 -0
  71. package/Calendar/CalendarWeeks.d.ts +1 -1
  72. package/Calendar/CalendarWeeks.js +89 -44
  73. package/Calendar/CalendarYears.js +14 -4
  74. package/Calendar/RangeCalendar.d.ts +59 -0
  75. package/Calendar/RangeCalendar.js +232 -0
  76. package/Calendar/index.d.ts +33 -10
  77. package/Calendar/index.js +7 -0
  78. package/Calendar/useCalendarControlModifiers.d.ts +4 -4
  79. package/Calendar/useCalendarControlModifiers.js +40 -8
  80. package/Calendar/useCalendarControls.d.ts +2 -0
  81. package/Calendar/useCalendarControls.js +19 -2
  82. package/Calendar/useCalendarModeStack.js +1 -0
  83. package/Calendar/useRangeCalendarControls.d.ts +18 -0
  84. package/Calendar/useRangeCalendarControls.js +115 -0
  85. package/Card/Card.js +1 -2
  86. package/Card/CardActions.js +2 -3
  87. package/Card/index.d.ts +4 -2
  88. package/Checkbox/CheckAll.d.ts +16 -6
  89. package/Checkbox/CheckAll.js +41 -28
  90. package/Checkbox/Checkbox.d.ts +100 -22
  91. package/Checkbox/Checkbox.js +74 -18
  92. package/Checkbox/CheckboxGroup.d.ts +100 -18
  93. package/Checkbox/CheckboxGroup.js +169 -25
  94. package/Checkbox/CheckboxGroupContext.d.ts +0 -2
  95. package/Checkbox/CheckboxGroupContext.js +1 -0
  96. package/Checkbox/index.d.ts +16 -4
  97. package/Checkbox/index.js +6 -2
  98. package/Checkbox/typings.d.ts +37 -0
  99. package/ClearActions/ClearActions.d.ts +41 -0
  100. package/ClearActions/ClearActions.js +23 -0
  101. package/ClearActions/index.d.ts +3 -0
  102. package/ClearActions/index.js +5 -0
  103. package/ConfirmActions/ConfirmActions.d.ts +2 -1
  104. package/ConfirmActions/ConfirmActions.js +1 -2
  105. package/ConfirmActions/index.d.ts +2 -1
  106. package/DatePicker/DatePicker.d.ts +12 -1
  107. package/DatePicker/DatePicker.js +42 -11
  108. package/DatePicker/DatePickerCalendar.d.ts +3 -6
  109. package/DatePicker/DatePickerCalendar.js +38 -39
  110. package/DatePicker/index.d.ts +4 -2
  111. package/DateRangePicker/DateRangePicker.d.ts +18 -2
  112. package/DateRangePicker/DateRangePicker.js +144 -102
  113. package/DateRangePicker/DateRangePickerCalendar.d.ts +13 -9
  114. package/DateRangePicker/DateRangePickerCalendar.js +8 -96
  115. package/DateRangePicker/index.d.ts +6 -3
  116. package/DateRangePicker/useDateRangeCalendarControls.js +11 -6
  117. package/DateRangePicker/useDateRangePickerValue.d.ts +38 -15
  118. package/DateRangePicker/useDateRangePickerValue.js +142 -63
  119. package/DateTimePicker/DateTimePicker.d.ts +31 -10
  120. package/DateTimePicker/DateTimePicker.js +180 -96
  121. package/DateTimePicker/index.d.ts +2 -2
  122. package/DateTimePicker/index.js +0 -1
  123. package/Drawer/Drawer.js +3 -4
  124. package/Drawer/index.d.ts +2 -1
  125. package/Dropdown/Dropdown.js +13 -24
  126. package/Dropdown/index.d.ts +2 -1
  127. package/Empty/Empty.d.ts +1 -16
  128. package/Empty/Empty.js +37 -9
  129. package/Empty/icons/EmptyMainInitialDataIcon.d.ts +4 -0
  130. package/Empty/icons/EmptyMainInitialDataIcon.js +9 -0
  131. package/Empty/icons/EmptyMainResultIcon.d.ts +4 -0
  132. package/Empty/icons/EmptyMainResultIcon.js +9 -0
  133. package/Empty/icons/EmptyMainSystemIcon.d.ts +4 -0
  134. package/Empty/icons/EmptyMainSystemIcon.js +9 -0
  135. package/Empty/index.d.ts +2 -1
  136. package/Empty/typings.d.ts +52 -0
  137. package/Form/FormControlContext.js +1 -0
  138. package/Form/FormField.js +1 -2
  139. package/Form/FormHintText.d.ts +18 -0
  140. package/Form/FormHintText.js +17 -0
  141. package/Form/FormLabel.js +2 -2
  142. package/Form/index.d.ts +9 -5
  143. package/Form/index.js +1 -1
  144. package/Form/useAutoCompleteValueControl.js +2 -0
  145. package/Form/useCheckboxControlValue.js +0 -1
  146. package/Form/useInputWithClearControlValue.d.ts +1 -1
  147. package/Form/useInputWithTagsModeValue.d.ts +1 -1
  148. package/Form/useSelectValueControl.js +2 -0
  149. package/Icon/Icon.js +1 -2
  150. package/InlineMessage/InlineMessage.d.ts +33 -0
  151. package/InlineMessage/InlineMessage.js +42 -0
  152. package/InlineMessage/InlineMessageGroup.d.ts +24 -0
  153. package/InlineMessage/InlineMessageGroup.js +21 -0
  154. package/InlineMessage/index.d.ts +4 -0
  155. package/InlineMessage/index.js +2 -0
  156. package/Input/ActionButton/ActionButton.d.ts +26 -0
  157. package/Input/ActionButton/ActionButton.js +14 -0
  158. package/Input/ActionButton/index.d.ts +2 -0
  159. package/Input/ActionButton/index.js +1 -0
  160. package/Input/Input.d.ts +147 -42
  161. package/Input/Input.js +196 -31
  162. package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.d.ts +31 -0
  163. package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.js +18 -0
  164. package/Input/PasswordStrengthIndicator/index.d.ts +2 -0
  165. package/Input/PasswordStrengthIndicator/index.js +1 -0
  166. package/Input/SelectButton/SelectButton.d.ts +20 -0
  167. package/Input/SelectButton/SelectButton.js +21 -0
  168. package/Input/SelectButton/index.d.ts +2 -0
  169. package/Input/SelectButton/index.js +1 -0
  170. package/Input/SpinnerButton/SpinnerButton.d.ts +19 -0
  171. package/Input/SpinnerButton/SpinnerButton.js +14 -0
  172. package/Input/SpinnerButton/index.d.ts +2 -0
  173. package/Input/SpinnerButton/index.js +1 -0
  174. package/Input/index.d.ts +3 -2
  175. package/Menu/Menu.js +2 -2
  176. package/Menu/MenuDivider.js +1 -2
  177. package/Menu/MenuItem.js +1 -2
  178. package/Menu/MenuItemGroup.js +1 -2
  179. package/Menu/index.d.ts +8 -4
  180. package/Message/Message.d.ts +6 -4
  181. package/Message/Message.js +87 -11
  182. package/Message/MessageTimerController.d.ts +14 -0
  183. package/Message/MessageTimerController.js +27 -0
  184. package/Message/index.d.ts +3 -2
  185. package/Modal/Modal.js +3 -4
  186. package/Modal/ModalActions.js +2 -2
  187. package/Modal/ModalBody.js +1 -2
  188. package/Modal/ModalControl.js +1 -0
  189. package/Modal/ModalFooter.js +1 -2
  190. package/Modal/ModalHeader.js +3 -3
  191. package/Modal/index.d.ts +10 -5
  192. package/Modal/useModalContainer.d.ts +1 -1
  193. package/Modal/useModalContainer.js +2 -4
  194. package/Navigation/Navigation.js +38 -36
  195. package/Navigation/NavigationContext.js +1 -0
  196. package/Navigation/NavigationItem.js +2 -2
  197. package/Navigation/NavigationSubMenu.js +17 -28
  198. package/Navigation/index.d.ts +8 -4
  199. package/Notification/Notification.js +1 -3
  200. package/Notification/index.d.ts +3 -2
  201. package/Notifier/NotifierManager.d.ts +16 -3
  202. package/Notifier/NotifierManager.js +60 -18
  203. package/Notifier/createNotifier.d.ts +9 -0
  204. package/Notifier/createNotifier.js +3 -2
  205. package/Notifier/typings.d.ts +3 -1
  206. package/OverflowTooltip/OverflowCounterTag.d.ts +12 -0
  207. package/OverflowTooltip/OverflowCounterTag.js +48 -0
  208. package/OverflowTooltip/OverflowTooltip.d.ts +34 -0
  209. package/OverflowTooltip/OverflowTooltip.js +53 -0
  210. package/OverflowTooltip/index.d.ts +2 -0
  211. package/OverflowTooltip/index.js +2 -0
  212. package/PageFooter/PageFooter.d.ts +73 -8
  213. package/PageFooter/PageFooter.js +35 -5
  214. package/PageFooter/index.d.ts +2 -1
  215. package/PageHeader/PageHeader.d.ts +36 -0
  216. package/PageHeader/PageHeader.js +65 -0
  217. package/PageHeader/index.d.ts +2 -0
  218. package/PageHeader/index.js +1 -0
  219. package/PageToolbar/PageToolbar.d.ts +67 -0
  220. package/PageToolbar/PageToolbar.js +114 -0
  221. package/PageToolbar/index.d.ts +2 -0
  222. package/PageToolbar/index.js +1 -0
  223. package/Pagination/Pagination.d.ts +23 -29
  224. package/Pagination/Pagination.js +4 -6
  225. package/Pagination/PaginationItem.d.ts +1 -1
  226. package/Pagination/PaginationItem.js +7 -5
  227. package/Pagination/PaginationJumper.d.ts +7 -9
  228. package/Pagination/PaginationJumper.js +4 -7
  229. package/Pagination/PaginationPageSize.d.ts +8 -11
  230. package/Pagination/PaginationPageSize.js +6 -6
  231. package/Pagination/index.d.ts +8 -4
  232. package/Pagination/usePagination.d.ts +3 -1
  233. package/Pagination/usePagination.js +30 -21
  234. package/Picker/FormattedInput.d.ts +17 -0
  235. package/Picker/FormattedInput.js +74 -0
  236. package/Picker/MaskFormat.d.ts +39 -0
  237. package/Picker/MaskFormat.js +94 -0
  238. package/Picker/PickerTrigger.d.ts +14 -4
  239. package/Picker/PickerTrigger.js +18 -4
  240. package/Picker/PickerTriggerWithSeparator.d.ts +124 -0
  241. package/Picker/PickerTriggerWithSeparator.js +80 -0
  242. package/Picker/RangePickerTrigger.d.ts +57 -6
  243. package/Picker/RangePickerTrigger.js +66 -9
  244. package/Picker/formatUtils.d.ts +34 -0
  245. package/Picker/formatUtils.js +124 -0
  246. package/Picker/index.d.ts +17 -6
  247. package/Picker/index.js +4 -1
  248. package/Picker/useDateInputFormatter.d.ts +52 -0
  249. package/Picker/useDateInputFormatter.js +382 -0
  250. package/Picker/usePickerDocumentEventClose.d.ts +3 -3
  251. package/Picker/usePickerValue.d.ts +2 -3
  252. package/Picker/usePickerValue.js +8 -13
  253. package/Picker/useTabKeyClose.d.ts +1 -1
  254. package/Popconfirm/Popconfirm.js +3 -4
  255. package/Popconfirm/index.d.ts +2 -1
  256. package/Popover/Popover.js +5 -10
  257. package/Popover/index.d.ts +2 -1
  258. package/Popper/Popper.d.ts +15 -10
  259. package/Popper/Popper.js +89 -19
  260. package/Popper/index.d.ts +2 -1
  261. package/Portal/Portal.d.ts +13 -5
  262. package/Portal/Portal.js +26 -12
  263. package/Portal/index.d.ts +4 -1
  264. package/Portal/index.js +1 -0
  265. package/Portal/portalRegistry.d.ts +17 -0
  266. package/Portal/portalRegistry.js +92 -0
  267. package/Progress/Progress.d.ts +23 -30
  268. package/Progress/Progress.js +72 -23
  269. package/Progress/index.d.ts +3 -2
  270. package/Provider/ConfigProvider.d.ts +2 -1
  271. package/Provider/ConfigProvider.js +1 -0
  272. package/Provider/context.js +1 -0
  273. package/Radio/Radio.d.ts +1 -1
  274. package/Radio/Radio.js +3 -3
  275. package/Radio/RadioGroup.d.ts +1 -1
  276. package/Radio/RadioGroup.js +2 -3
  277. package/Radio/RadioGroupContext.js +1 -0
  278. package/Radio/index.d.ts +4 -2
  279. package/ResultState/ResultState.d.ts +52 -0
  280. package/ResultState/ResultState.js +24 -0
  281. package/ResultState/index.d.ts +2 -0
  282. package/ResultState/index.js +1 -0
  283. package/Select/AutoComplete.d.ts +3 -3
  284. package/Select/AutoComplete.js +6 -13
  285. package/Select/Option.js +2 -2
  286. package/Select/Select.d.ts +1 -1
  287. package/Select/Select.js +3 -3
  288. package/Select/SelectControlContext.js +1 -0
  289. package/Select/SelectTrigger.d.ts +1 -87
  290. package/Select/SelectTrigger.js +27 -23
  291. package/Select/SelectTriggerTags.d.ts +1 -1
  292. package/Select/SelectTriggerTags.js +48 -20
  293. package/Select/TreeSelect.d.ts +1 -1
  294. package/Select/TreeSelect.js +3 -3
  295. package/Select/index.d.ts +14 -7
  296. package/Select/typings.d.ts +99 -0
  297. package/Select/useSelectTriggerTags.d.ts +15 -8
  298. package/Select/useSelectTriggerTags.js +79 -43
  299. package/Selection/Selection.d.ts +98 -0
  300. package/Selection/Selection.js +46 -0
  301. package/Selection/index.d.ts +12 -0
  302. package/Selection/index.js +5 -0
  303. package/Skeleton/Skeleton.d.ts +10 -3
  304. package/Skeleton/Skeleton.js +13 -6
  305. package/Skeleton/index.d.ts +2 -1
  306. package/Slider/Slider.d.ts +44 -7
  307. package/Slider/Slider.js +18 -15
  308. package/Slider/index.d.ts +5 -3
  309. package/Slider/useSlider.d.ts +1 -1
  310. package/Slider/useSlider.js +1 -1
  311. package/Spin/Spin.d.ts +39 -0
  312. package/{Loading/Loading.js → Spin/Spin.js} +9 -10
  313. package/Spin/index.d.ts +2 -0
  314. package/Spin/index.js +1 -0
  315. package/Stepper/Step.d.ts +1 -35
  316. package/Stepper/Step.js +44 -10
  317. package/Stepper/Stepper.d.ts +1 -14
  318. package/Stepper/Stepper.js +50 -17
  319. package/Stepper/index.d.ts +5 -2
  320. package/Stepper/index.js +1 -0
  321. package/Stepper/typings.d.ts +77 -0
  322. package/Stepper/useStepDistance.d.ts +10 -0
  323. package/Stepper/useStepDistance.js +81 -0
  324. package/Stepper/useStepper.d.ts +21 -0
  325. package/Stepper/useStepper.js +26 -0
  326. package/Table/Table.d.ts +1 -1
  327. package/Table/Table.js +3 -4
  328. package/Table/TableBody.js +3 -2
  329. package/Table/TableBodyRow.js +1 -0
  330. package/Table/TableCell.js +1 -2
  331. package/Table/TableContext.js +1 -0
  332. package/Table/TableExpandedTable.js +1 -0
  333. package/Table/TableHeader.js +1 -0
  334. package/Table/draggable/useTableDraggable.d.ts +1 -1
  335. package/Table/editable/TableEditRenderWrapper.js +1 -0
  336. package/Table/expandable/TableExpandable.js +1 -1
  337. package/Table/index.d.ts +7 -4
  338. package/Table/pagination/TablePagination.d.ts +1 -1
  339. package/Table/pagination/TablePagination.js +1 -0
  340. package/Table/pagination/useTablePagination.d.ts +1 -1
  341. package/Table/pagination/useTablePagination.js +1 -0
  342. package/Table/refresh/TableRefresh.js +4 -3
  343. package/Table/rowSelection/TableRowSelection.js +3 -2
  344. package/Table/sorting/TableSortingIcon.js +2 -1
  345. package/Table/sorting/useTableSorting.js +1 -0
  346. package/Table/useTableFetchMore.js +1 -1
  347. package/Table/useTableScroll.d.ts +44 -14
  348. package/Table/useTableScroll.js +10 -8
  349. package/Tabs/Tab.js +1 -2
  350. package/Tabs/TabPane.js +2 -2
  351. package/Tabs/Tabs.js +10 -6
  352. package/Tabs/index.d.ts +6 -3
  353. package/Tabs/useTabsOverflow.d.ts +1 -1
  354. package/Tabs/useTabsOverflow.js +4 -3
  355. package/Tag/Tag.d.ts +2 -25
  356. package/Tag/Tag.js +24 -15
  357. package/Tag/TagGroup.d.ts +12 -0
  358. package/Tag/TagGroup.js +41 -0
  359. package/Tag/index.d.ts +2 -1
  360. package/Tag/typings.d.ts +78 -0
  361. package/TextField/TextField.d.ts +78 -20
  362. package/TextField/TextField.js +59 -24
  363. package/TextField/index.d.ts +2 -1
  364. package/Textarea/Textarea.d.ts +19 -51
  365. package/Textarea/Textarea.js +14 -21
  366. package/Textarea/index.d.ts +2 -2
  367. package/TimePanel/TimePanel.d.ts +1 -22
  368. package/TimePanel/TimePanel.js +32 -28
  369. package/TimePanel/TimePanelAction.d.ts +2 -8
  370. package/TimePanel/TimePanelAction.js +3 -4
  371. package/TimePanel/TimePanelColumn.d.ts +0 -13
  372. package/TimePanel/TimePanelColumn.js +10 -13
  373. package/TimePanel/index.d.ts +6 -3
  374. package/TimePicker/TimePicker.d.ts +10 -1
  375. package/TimePicker/TimePicker.js +87 -37
  376. package/TimePicker/TimePickerPanel.d.ts +1 -2
  377. package/TimePicker/TimePickerPanel.js +3 -4
  378. package/TimePicker/index.d.ts +4 -2
  379. package/Toggle/Toggle.d.ts +46 -0
  380. package/Toggle/Toggle.js +29 -0
  381. package/Toggle/index.d.ts +3 -0
  382. package/Toggle/index.js +1 -0
  383. package/Tooltip/Tooltip.d.ts +14 -3
  384. package/Tooltip/Tooltip.js +53 -18
  385. package/Tooltip/index.d.ts +2 -1
  386. package/Tooltip/useDelayMouseEnterLeave.d.ts +1 -2
  387. package/Tooltip/useDelayMouseEnterLeave.js +10 -13
  388. package/Transition/Collapse.d.ts +2 -0
  389. package/Transition/Collapse.js +7 -12
  390. package/Transition/Fade.js +5 -6
  391. package/Transition/Rotate.d.ts +42 -0
  392. package/Transition/Rotate.js +30 -0
  393. package/Transition/Scale.d.ts +13 -0
  394. package/Transition/{Grow.js → Scale.js} +19 -17
  395. package/Transition/Slide.d.ts +7 -0
  396. package/Transition/{Zoom.js → Slide.js} +14 -13
  397. package/Transition/SlideFade.d.ts +3 -0
  398. package/Transition/SlideFade.js +6 -6
  399. package/Transition/Transition.d.ts +3 -3
  400. package/Transition/Translate.d.ts +14 -0
  401. package/Transition/Translate.js +94 -0
  402. package/Transition/index.d.ts +16 -6
  403. package/Transition/index.js +4 -2
  404. package/Transition/useAutoTransitionDuration.d.ts +1 -1
  405. package/Transition/useAutoTransitionDuration.js +3 -3
  406. package/Transition/useSetNodeTransition.js +0 -2
  407. package/Tree/Tree.js +1 -2
  408. package/Tree/TreeNode.js +8 -8
  409. package/Tree/TreeNodeList.js +1 -2
  410. package/Tree/index.d.ts +10 -5
  411. package/Tree/typings.d.ts +2 -2
  412. package/Typography/Typography.d.ts +6 -9
  413. package/Typography/Typography.js +7 -9
  414. package/Typography/index.d.ts +4 -7
  415. package/Upload/Upload.d.ts +175 -0
  416. package/Upload/Upload.js +279 -0
  417. package/Upload/UploadItem.d.ts +82 -0
  418. package/Upload/UploadItem.js +118 -0
  419. package/Upload/UploadPictureCard.d.ts +110 -0
  420. package/Upload/UploadPictureCard.js +101 -0
  421. package/Upload/Uploader.d.ts +161 -0
  422. package/Upload/Uploader.js +120 -0
  423. package/Upload/index.d.ts +8 -6
  424. package/Upload/index.js +4 -5
  425. package/Upload/upload-utils.d.ts +41 -0
  426. package/Upload/upload-utils.js +65 -0
  427. package/_internal/InputCheck/InputCheck.js +1 -2
  428. package/_internal/InputCheck/InputCheckGroup.js +1 -2
  429. package/_internal/InputCheck/index.d.ts +4 -2
  430. package/_internal/InputTriggerPopper/InputTriggerPopper.js +16 -27
  431. package/_internal/InputTriggerPopper/index.d.ts +2 -1
  432. package/_internal/SlideFadeOverlay/SlideFadeOverlay.d.ts +2 -2
  433. package/_internal/SlideFadeOverlay/SlideFadeOverlay.js +5 -29
  434. package/_internal/SlideFadeOverlay/index.d.ts +2 -1
  435. package/_internal/SlideFadeOverlay/useTopStack.js +1 -0
  436. package/dayjs.d.ts +21 -0
  437. package/dayjs.js +2 -0
  438. package/hooks/useClickAway.d.ts +1 -1
  439. package/hooks/useComposeRefs.js +1 -1
  440. package/hooks/useLastCallback.js +3 -1
  441. package/hooks/useScrollLock.d.ts +28 -0
  442. package/hooks/useScrollLock.js +134 -0
  443. package/index.d.ts +126 -58
  444. package/index.js +103 -90
  445. package/luxon.d.ts +21 -0
  446. package/luxon.js +2 -0
  447. package/moment.d.ts +21 -0
  448. package/moment.js +2 -0
  449. package/package.json +16 -20
  450. package/utils/composeRefs.js +0 -1
  451. package/utils/get-css-variable-value.d.ts +1 -0
  452. package/utils/get-css-variable-value.js +9 -0
  453. package/utils/jsx-types.d.ts +1 -1
  454. package/Button/IconButton.d.ts +0 -21
  455. package/Button/IconButton.js +0 -13
  456. package/DateTimePicker/DateTimePickerPanel.d.ts +0 -28
  457. package/DateTimePicker/DateTimePickerPanel.js +0 -50
  458. package/Form/FormMessage.d.ts +0 -7
  459. package/Form/FormMessage.js +0 -19
  460. package/Form/useInputWithTagsModeValue.js +0 -86
  461. package/Loading/Loading.d.ts +0 -33
  462. package/Loading/index.d.ts +0 -1
  463. package/Loading/index.js +0 -1
  464. package/Overlay/Overlay.js +0 -32
  465. package/Overlay/index.d.ts +0 -1
  466. package/Overlay/index.js +0 -1
  467. package/Picker/useRangePickerValue.d.ts +0 -23
  468. package/Picker/useRangePickerValue.js +0 -99
  469. package/Switch/Switch.d.ts +0 -43
  470. package/Switch/Switch.js +0 -29
  471. package/Switch/index.d.ts +0 -2
  472. package/Switch/index.js +0 -1
  473. package/Transition/Grow.d.ts +0 -12
  474. package/Transition/Zoom.d.ts +0 -7
  475. package/Upload/UploadButton.d.ts +0 -9
  476. package/Upload/UploadButton.js +0 -24
  477. package/Upload/UploadInput.d.ts +0 -20
  478. package/Upload/UploadInput.js +0 -24
  479. package/Upload/UploadPicture.d.ts +0 -49
  480. package/Upload/UploadPicture.js +0 -52
  481. package/Upload/UploadPictureBlock.d.ts +0 -20
  482. package/Upload/UploadPictureBlock.js +0 -82
  483. package/Upload/UploadPictureWall.d.ts +0 -81
  484. package/Upload/UploadPictureWall.js +0 -169
  485. package/Upload/UploadPictureWallItem.d.ts +0 -15
  486. package/Upload/UploadPictureWallItem.js +0 -18
  487. package/Upload/UploadResult.d.ts +0 -35
  488. package/Upload/UploadResult.js +0 -30
  489. package/utils/scroll-lock.d.ts +0 -2
  490. package/utils/scroll-lock.js +0 -24
@@ -1,37 +1,50 @@
1
+ 'use client';
1
2
  import { jsxs, jsx } from 'react/jsx-runtime';
2
- import { forwardRef, Children, useMemo } from 'react';
3
- import { checkboxClasses } from '@mezzanine-ui/core/checkbox';
3
+ import { forwardRef, useId, useMemo } from 'react';
4
4
  import Checkbox from './Checkbox.js';
5
- import cx from 'clsx';
5
+ import { assignCheckboxGroupValuesToEvent } from './CheckboxGroup.js';
6
6
 
7
7
  /**
8
8
  * The react component for `mezzanine` check all.
9
- * Only support controlled.
9
+ * Wraps a CheckboxGroup and provides a "check all" checkbox that controls all checkboxes in the group.
10
10
  */
11
11
  const CheckAll = forwardRef(function CheckAll(props, ref) {
12
- const { children, className, label, ...rest } = props;
13
- const checkboxGroup = children && Children.only(children);
14
- const { disabled, name, onChange, options, size, value } = (checkboxGroup === null || checkboxGroup === void 0 ? void 0 : checkboxGroup.props) || {};
15
- const enabledOptions = useMemo(() => options === null || options === void 0 ? void 0 : options.filter((option) => !option.disabled), [options]);
16
- let allChecked = false;
17
- let indeterminate = false;
18
- if (enabledOptions && value) {
19
- allChecked = enabledOptions.length === value.length;
20
- indeterminate = enabledOptions.length > value.length && value.length > 0;
21
- }
22
- return (jsxs("div", { ...rest, ref: ref, className: cx(checkboxClasses.all, className), children: [jsx("div", { children: jsx(Checkbox, { checked: allChecked, disabled: disabled, indeterminate: indeterminate, inputProps: {
23
- name,
24
- }, onChange: (event) => {
25
- if (onChange) {
26
- if (!event.target.checked) {
27
- onChange([], event);
28
- }
29
- else if (enabledOptions) {
30
- onChange(enabledOptions.map((option) => option.value), event);
31
- }
32
- }
33
- }, size: size, children: label }) }), children] }));
12
+ const { children, disabled = false, label = 'Check All', } = props;
13
+ // Generate unique id for the check all checkbox
14
+ // This is important for accessibility
15
+ const checkAllId = useId();
16
+ const checkboxGroupProps = children.props;
17
+ const { options = [], value = [], onChange } = checkboxGroupProps;
18
+ // Calculate checked and indeterminate states
19
+ const { checked, indeterminate } = useMemo(() => {
20
+ const enabledOptions = options.filter((opt) => !opt.disabled);
21
+ const enabledValues = enabledOptions.map((opt) => opt.value);
22
+ const selectedEnabledValues = value.filter((v) => enabledValues.includes(v));
23
+ if (selectedEnabledValues.length === 0) {
24
+ return { checked: false, indeterminate: false };
25
+ }
26
+ if (selectedEnabledValues.length === enabledValues.length) {
27
+ return { checked: true, indeterminate: false };
28
+ }
29
+ return { checked: false, indeterminate: true };
30
+ }, [options, value]);
31
+ const handleCheckAllChange = (event) => {
32
+ var _a;
33
+ if (!onChange)
34
+ return;
35
+ const isChecked = event.target.checked;
36
+ const enabledOptions = options.filter((opt) => !opt.disabled);
37
+ const enabledValues = enabledOptions.map((opt) => opt.value);
38
+ const disabledOptions = options.filter((opt) => opt.disabled);
39
+ const disabledValues = disabledOptions.map((opt) => opt.value);
40
+ const selectedDisabledValues = value.filter((v) => disabledValues.includes(v));
41
+ const newValue = isChecked
42
+ ? [...enabledValues, ...selectedDisabledValues]
43
+ : selectedDisabledValues;
44
+ const syntheticEvent = assignCheckboxGroupValuesToEvent(event, newValue, (_a = checkboxGroupProps.name) !== null && _a !== void 0 ? _a : '');
45
+ onChange(syntheticEvent);
46
+ };
47
+ return (jsxs("div", { ref: ref, children: [jsx(Checkbox, { checked: checked, disabled: disabled, indeterminate: indeterminate, inputProps: { id: checkAllId }, label: label, name: checkboxGroupProps.name || checkAllId, onChange: handleCheckAllChange }), children] }));
34
48
  });
35
- var CheckAll$1 = CheckAll;
36
49
 
37
- export { CheckAll$1 as default };
50
+ export { CheckAll as default };
@@ -1,41 +1,119 @@
1
- import { ChangeEventHandler } from 'react';
2
- import { CheckboxSize } from '@mezzanine-ui/core/checkbox';
3
- import { InputCheckProps } from '../_internal/InputCheck';
1
+ import { ChangeEventHandler, Ref } from 'react';
2
+ import { BaseInputProps } from '../Input';
4
3
  import { NativeElementPropsWithoutKeyAndRef } from '../utils/jsx-types';
5
- export interface CheckboxProps extends Omit<InputCheckProps, 'control' | 'htmlFor'> {
4
+ import { CheckboxPropsBase } from './typings';
5
+ type CheckboxInputElementProps = Omit<NativeElementPropsWithoutKeyAndRef<'input'>, 'checked' | 'defaultChecked' | 'disabled' | 'onChange' | 'placeholder' | 'type' | 'value' | `aria-${'disabled' | 'checked'}`> & {
6
6
  /**
7
- * Whether the checkbox is checked.
7
+ * The id attribute can be provided via inputProps, but it's recommended to use the `id` prop directly.
8
+ * If both are provided, the `id` prop takes precedence.
8
9
  */
9
- checked?: boolean;
10
+ id?: string;
10
11
  /**
11
- * Whether the checkbox is checked by default.
12
- * @default false
12
+ * The name attribute can be provided via inputProps, but it's recommended to use the `name` prop directly.
13
+ * If both are provided, the `name` prop takes precedence.
13
14
  */
14
- defaultChecked?: boolean;
15
+ name?: string;
16
+ };
17
+ export interface CheckboxProps extends Omit<NativeElementPropsWithoutKeyAndRef<'label'>, 'onChange'>, CheckboxPropsBase {
15
18
  /**
16
- * If true, it means its children checkboxes have at least one unchecked.
17
- * @default false
19
+ * Whether to show an editable input when checkbox is checked.
20
+ * When `true`, an Input component will be displayed after the checkbox when checked.
21
+ * If `editableInput` is not provided, default values will be used (name, id, placeholder).
22
+ *
23
+ * @example Simple usage
24
+ * ```tsx
25
+ * <Checkbox
26
+ * label="其他"
27
+ * withEditInput
28
+ * value={otherValue}
29
+ * onChange={(e) => setOtherValue(e.target.value)}
30
+ * />
31
+ * ```
32
+ *
33
+ * @example With custom editableInput
34
+ * ```tsx
35
+ * <Checkbox
36
+ * label="其他"
37
+ * withEditInput
38
+ * editableInput={{
39
+ * placeholder: "請輸入其他選項",
40
+ * name: "otherOption",
41
+ * value: otherValue,
42
+ * onChange: (e) => setOtherValue(e.target.value),
43
+ * }}
44
+ * />
45
+ * ```
46
+ *
47
+ * @example With react-hook-form
48
+ * ```tsx
49
+ * const { register, watch } = useForm();
50
+ * const isOtherChecked = watch('options.other');
51
+ *
52
+ * <Checkbox
53
+ * label="其他"
54
+ * {...register('options.other')}
55
+ * withEditInput
56
+ * editableInput={{
57
+ * ...register('otherOption', { required: isOtherChecked }),
58
+ * placeholder: "請輸入其他選項",
59
+ * }}
60
+ * />
61
+ * ```
62
+ */
63
+ withEditInput?: boolean;
64
+ /**
65
+ * Configuration for editable input that appears when checkbox is checked.
66
+ * When `withEditInput` is `true` and this prop is not provided, default values will be used.
67
+ *
68
+ * Default values when not provided:
69
+ * - `name`: `{checkboxName}_input` or `{checkboxId}_input`
70
+ * - `id`: `{checkboxId}_input`
71
+ * - `placeholder`: "Please enter..."
72
+ */
73
+ editableInput?: Omit<BaseInputProps, 'variant'>;
74
+ /**
75
+ * The id of input element.
18
76
  */
19
- indeterminate?: boolean;
77
+ id?: string;
20
78
  /**
21
79
  * Since at Mezzanine we use a host element to wrap our input, most derived props will be passed to the host element.
22
- * If you need direct control to the input element, use this prop to provide to it.
80
+ * If you need direct control to the input element, use this prop to provide to it.
81
+ */
82
+ inputProps?: CheckboxInputElementProps;
83
+ /**
84
+ * The react ref passed to input element.
23
85
  *
24
- * Noticed that if you pass in an id within this prop,
25
- * the rendered label element will have `htmlFor` sync with passed in id.
86
+ * @important When using with react-hook-form's `register`, pass the ref through this prop:
87
+ * ```tsx
88
+ * const { register } = useForm();
89
+ * <Checkbox inputRef={register('fieldName').ref} name="fieldName" />
90
+ * ```
91
+ *
92
+ * For CheckboxGroup, use `Controller` instead of `register` for better array value handling.
26
93
  */
27
- inputProps?: Omit<NativeElementPropsWithoutKeyAndRef<'input'>, 'checked' | 'defaultChecked' | 'disabled' | 'onChange' | 'placeholder' | 'readOnly' | 'required' | 'type' | 'value' | `aria-${'disabled' | 'checked'}`>;
94
+ inputRef?: Ref<HTMLInputElement>;
28
95
  /**
29
- * The change event handler of input in checkbox.
96
+ * The name attribute of the input element.
97
+ *
98
+ * @important When using with react-hook-form or inside a CheckboxGroup, this prop is recommended.
99
+ * For CheckboxGroup, all checkboxes should share the same `name` attribute.
100
+ *
101
+ * When using with react-hook-form's `register`, ensure this matches the field name:
102
+ * ```tsx
103
+ * const { register } = useForm();
104
+ * <Checkbox {...register('fieldName')} inputRef={register('fieldName').ref} />
105
+ * ```
30
106
  */
31
- onChange?: ChangeEventHandler<HTMLInputElement>;
107
+ name?: string;
32
108
  /**
33
- * The size of checkbox.
34
- * @default 'medium'
109
+ * Invoked by input change event.
35
110
  */
36
- size?: CheckboxSize;
111
+ onChange?: ChangeEventHandler<HTMLInputElement>;
37
112
  /**
38
- * The value of input in checkbox.
113
+ * The value of checkbox. Used when checkbox is inside a CheckboxGroup.
114
+ *
115
+ * @important This prop is required when checkbox is inside a CheckboxGroup.
116
+ * It is also recommended when integrating with react-hook-form.
39
117
  */
40
118
  value?: string;
41
119
  }
@@ -1,36 +1,92 @@
1
- import { jsx } from 'react/jsx-runtime';
2
- import { forwardRef, useContext } from 'react';
1
+ 'use client';
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { forwardRef, useContext, useId, useEffect, useMemo, useRef } from 'react';
3
4
  import { checkboxClasses } from '@mezzanine-ui/core/checkbox';
5
+ import { CheckedIcon } from '@mezzanine-ui/icons';
4
6
  import { useCheckboxControlValue } from '../Form/useCheckboxControlValue.js';
7
+ import Typography from '../Typography/Typography.js';
8
+ import { composeRefs } from '../utils/composeRefs.js';
5
9
  import { CheckboxGroupContext } from './CheckboxGroupContext.js';
6
- import { MezzanineConfig } from '../Provider/context.js';
7
- import { FormControlContext } from '../Form/FormControlContext.js';
8
- import InputCheck from '../_internal/InputCheck/InputCheck.js';
10
+ import Icon from '../Icon/Icon.js';
11
+ import Input from '../Input/Input.js';
9
12
  import cx from 'clsx';
10
13
 
11
14
  /**
12
15
  * The react component for `mezzanine` checkbox.
13
16
  */
14
17
  const Checkbox = forwardRef(function Checkbox(props, ref) {
15
- const { size: globalSize } = useContext(MezzanineConfig);
16
- const { disabled: disabledFromFormControl, severity } = useContext(FormControlContext) || {};
17
18
  const checkboxGroup = useContext(CheckboxGroupContext);
18
- const { disabled: disabledFromGroup, name: nameFromGroup, size: sizeFromGroup, } = checkboxGroup || {};
19
- const { checked: checkedProp, children, defaultChecked, disabled = (disabledFromGroup !== null && disabledFromGroup !== void 0 ? disabledFromGroup : disabledFromFormControl) || false, error = severity === 'error' || false, indeterminate: indeterminateProp = false, onChange: onChangeProp, size = sizeFromGroup || globalSize, value, inputProps, ...rest } = props;
20
- const { id: inputId, name = nameFromGroup, ...restInputProps } = inputProps || {};
19
+ const { disabled: disabledFromGroup, name: nameFromGroup, } = checkboxGroup || {};
20
+ const { checked: checkedProp, className, defaultChecked, description, disabled = disabledFromGroup, editableInput, id, indeterminate = false, inputProps, inputRef: inputRefProp, label, mode = 'main', name = nameFromGroup, onChange: onChangeProp, value, withEditInput = false, ...rest } = props;
21
+ const { name: nameFromInputProps, ...restInputProps } = inputProps || {};
22
+ // Generate unique id if not provided
23
+ const generatedId = useId();
24
+ const finalInputId = id !== null && id !== void 0 ? id : generatedId;
25
+ if (checkboxGroup && value == null) {
26
+ throw new Error('Checkbox: `value` is required when the checkbox is used inside a CheckboxGroup.');
27
+ }
21
28
  const [checked, onChange] = useCheckboxControlValue({
22
- checkboxGroup,
23
29
  checked: checkedProp,
24
30
  defaultChecked,
25
31
  onChange: onChangeProp,
32
+ checkboxGroup,
26
33
  value,
27
34
  });
28
- const indeterminate = !checked && indeterminateProp;
29
- return (jsx(InputCheck, { ...rest, ref: ref, control: jsx("span", { className: cx(checkboxClasses.host, {
30
- [checkboxClasses.checked]: checked,
31
- [checkboxClasses.indeterminate]: indeterminate,
32
- }), children: jsx("input", { ...restInputProps, "aria-checked": indeterminate ? 'mixed' : checked, "aria-disabled": disabled, checked: checked, disabled: disabled, id: inputId, onChange: onChange, name: name, type: "checkbox", value: value }) }), disabled: disabled, error: error, htmlFor: inputId, size: size, children: children }));
35
+ // Warn when checkbox is standalone and missing a name (helpful for form libs)
36
+ useEffect(() => {
37
+ if (!checkboxGroup && !name && !nameFromInputProps && label) {
38
+ console.warn('Checkbox: The `name` prop is recommended when integrating with react-hook-form. ' +
39
+ `Checkbox with label "${label}" is missing the \`name\` prop.`);
40
+ }
41
+ }, [checkboxGroup, name, nameFromInputProps, label]);
42
+ const isChecked = checked && !indeterminate;
43
+ const isIndeterminate = indeterminate;
44
+ const resolvedName = useMemo(() => {
45
+ if (name)
46
+ return name;
47
+ if (nameFromInputProps)
48
+ return nameFromInputProps;
49
+ return finalInputId;
50
+ }, [finalInputId, name, nameFromInputProps]);
51
+ const labelColor = useMemo(() => {
52
+ if (mode === 'chip' && disabled) {
53
+ return 'text-neutral-light';
54
+ }
55
+ return 'text-neutral-solid';
56
+ }, [mode, disabled]);
57
+ const inputElementRef = useRef(null);
58
+ const composedInputRef = useMemo(() => composeRefs([inputRefProp, inputElementRef]), [inputRefProp]);
59
+ useEffect(() => {
60
+ if (inputElementRef.current) {
61
+ inputElementRef.current.indeterminate = isIndeterminate;
62
+ }
63
+ }, [isIndeterminate]);
64
+ const editableInputRef = useRef(null);
65
+ // Generate default editable input config when withEditInput is true but editableInput is not provided
66
+ const defaultEditableInput = useMemo(() => {
67
+ if (!withEditInput)
68
+ return undefined;
69
+ if (editableInput) {
70
+ return editableInput;
71
+ }
72
+ // Default values when editableInput is not provided
73
+ const defaultName = resolvedName ? `${resolvedName}_input` : `${finalInputId}_input`;
74
+ const defaultId = `${finalInputId}_input`;
75
+ return {
76
+ id: defaultId,
77
+ name: defaultName,
78
+ placeholder: 'Please enter...',
79
+ };
80
+ }, [withEditInput, editableInput, resolvedName, finalInputId]);
81
+ const shouldShowEditableInput = withEditInput && defaultEditableInput;
82
+ return (jsxs("div", { className: cx(checkboxClasses.host, className, {
83
+ [checkboxClasses.checked]: isChecked,
84
+ [checkboxClasses.indeterminate]: isIndeterminate,
85
+ [checkboxClasses.disabled]: disabled,
86
+ }, checkboxClasses.mode(mode)), children: [jsxs("label", { ref: ref, ...rest, className: checkboxClasses.labelContainer, children: [jsx("div", { className: checkboxClasses.inputContainer, children: jsxs("div", { className: checkboxClasses.inputContent, children: [jsx("input", { ...restInputProps, "aria-checked": isIndeterminate ? 'mixed' : checked, "aria-disabled": disabled, checked: isChecked, className: checkboxClasses.input, disabled: disabled, id: finalInputId, name: resolvedName, onChange: onChange, ref: composedInputRef, type: "checkbox", value: value }), mode === 'chip' && isChecked && (jsx(Icon, { "aria-hidden": "true", className: checkboxClasses.icon, color: "brand", icon: CheckedIcon, size: 16 })), mode !== 'chip' && isChecked && (jsx(Icon, { "aria-hidden": "true", className: checkboxClasses.icon, color: "fixed-light", icon: CheckedIcon, size: 7 })), mode !== 'chip' && isIndeterminate && (jsx("span", { "aria-hidden": "true", className: checkboxClasses.indeterminateLine }))] }) }), (label || description) && (jsxs("span", { className: checkboxClasses.textContainer, children: [label && (jsx(Typography, { className: checkboxClasses.label, color: labelColor, variant: "label-primary", children: label })), description && mode !== 'chip' && !shouldShowEditableInput && (jsx(Typography, { className: checkboxClasses.description, color: "text-neutral", variant: "caption", children: description }))] }))] }), shouldShowEditableInput && defaultEditableInput && mode !== 'chip' && !indeterminate && (jsx("div", { className: checkboxClasses.editableInputContainer, children: jsx(Input, { ...defaultEditableInput, ...((!isChecked || disabled) && defaultEditableInput.disabled !== true ? { disabled: true } : {}), inputRef: composeRefs([
87
+ defaultEditableInput.inputRef,
88
+ editableInputRef,
89
+ ]), variant: "base" }) }))] }));
33
90
  });
34
- var Checkbox$1 = Checkbox;
35
91
 
36
- export { Checkbox$1 as default };
92
+ export { Checkbox as default };
@@ -1,11 +1,56 @@
1
- import { CheckboxGroupOption, CheckboxSize } from '@mezzanine-ui/core/checkbox';
2
- import { ChangeEvent, ReactNode } from 'react';
3
- import { InputCheckGroupProps } from '../_internal/InputCheck';
4
- export interface CheckboxGroupProps extends Omit<InputCheckGroupProps, 'defaultValue' | 'onChange'> {
1
+ import { CheckboxGroupLayout, CheckboxGroupOption, CheckboxMode } from '@mezzanine-ui/core/checkbox';
2
+ import { ChangeEvent, ChangeEventHandler, ComponentProps, ReactNode } from 'react';
3
+ import { NativeElementPropsWithoutKeyAndRef } from '../utils/jsx-types';
4
+ import Checkbox from './Checkbox';
5
+ export interface CheckboxGroupChangeEventTarget extends HTMLInputElement {
6
+ values: string[];
7
+ }
8
+ export type CheckboxGroupChangeEvent = ChangeEvent<HTMLInputElement> & {
9
+ target: CheckboxGroupChangeEventTarget;
10
+ };
11
+ export declare function assignCheckboxGroupValuesToEvent(event: ChangeEvent<HTMLInputElement>, values: string[], name: string): CheckboxGroupChangeEvent;
12
+ type CheckboxGroupOptionInput = CheckboxGroupOption & Omit<ComponentProps<typeof Checkbox>, 'checked' | 'mode' | 'children' | 'defaultChecked' | 'indeterminate' | 'inputProps' | 'inputRef' | 'name' | 'onChange' | 'ref' | 'value'> & {
13
+ /**
14
+ * The id of input element.
15
+ * If not provided, will be auto-generated as `{name}-{value}`.
16
+ */
17
+ id?: string;
18
+ /**
19
+ * The react ref passed to input element.
20
+ */
21
+ inputRef?: ComponentProps<typeof Checkbox>['inputRef'];
22
+ /**
23
+ * Additional props for the input element.
24
+ */
25
+ inputProps?: ComponentProps<typeof Checkbox>['inputProps'];
26
+ };
27
+ export interface CheckboxGroupLevelConfig {
5
28
  /**
6
- * The checkboxes in radio group.
29
+ * Whether the level control is active.
7
30
  */
8
- children?: ReactNode;
31
+ active: boolean;
32
+ /**
33
+ * Whether the level control checkbox is disabled.
34
+ * @default false
35
+ */
36
+ disabled?: boolean;
37
+ /**
38
+ * The label displayed for the level control checkbox.
39
+ * @default 'Select all'
40
+ */
41
+ label?: string;
42
+ /**
43
+ * The mode of level control checkbox.
44
+ * @default 'main'
45
+ */
46
+ mode?: CheckboxMode;
47
+ /**
48
+ * Custom onChange handler for the level control.
49
+ * If not provided, the default behavior (select/deselect all) will be used.
50
+ */
51
+ onChange?: ChangeEventHandler<HTMLInputElement>;
52
+ }
53
+ interface CheckboxGroupBaseProps extends NativeElementPropsWithoutKeyAndRef<'div'> {
9
54
  /**
10
55
  * The default value of checkbox group.
11
56
  */
@@ -16,30 +61,67 @@ export interface CheckboxGroupProps extends Omit<InputCheckGroupProps, 'defaultV
16
61
  */
17
62
  disabled?: boolean;
18
63
  /**
19
- * The name of checkbox group.
20
- * Control the name of checkboxes in group if name not passed to checkbox.
64
+ * The level control configuration.
65
+ * When provided, a "select all" checkbox will be rendered above the group.
21
66
  */
22
- name?: string;
67
+ level?: CheckboxGroupLevelConfig;
23
68
  /**
24
- * The onChange of checkbox group.
25
- * Will be passed to each checkboxes but composing both instead of overriding.
69
+ * The layout of checkbox group.
70
+ * @default 'horizontal'
71
+ */
72
+ layout?: CheckboxGroupLayout;
73
+ /**
74
+ * The mode of checkboxes in the group.
75
+ * Control the mode of checkboxes in group if mode not passed to checkbox.
26
76
  */
27
- onChange?: (value: string[], event: ChangeEvent<HTMLInputElement>) => void;
77
+ mode?: CheckboxMode;
28
78
  /**
29
- * The options of checkbox group.
30
- * Will be ignored if children passed.
79
+ * The name of checkbox group.
80
+ * Control the name of checkboxes in group if name not passed to checkbox.
81
+ *
82
+ * @important When integrating with react-hook-form, this prop is highly recommended.
83
+ * All checkboxes in the group will share the same `name` attribute, which is required
84
+ * for react-hook-form to correctly collect the selected values as an array.
85
+ *
86
+ * @example Using with react-hook-form's Controller:
87
+ * ```tsx
88
+ * const { control } = useForm();
89
+ * <Controller
90
+ * name="interests"
91
+ * control={control}
92
+ * render={({ field }) => (
93
+ * <CheckboxGroup
94
+ * name="interests"
95
+ * value={field.value || []}
96
+ * onChange={(e) => field.onChange(e.target.values)}
97
+ * >
98
+ * <Checkbox value="reading" label="Reading" />
99
+ * <Checkbox value="coding" label="Coding" />
100
+ * </CheckboxGroup>
101
+ * )}
102
+ * />
103
+ * ```
31
104
  */
32
- options?: CheckboxGroupOption[];
105
+ name?: string;
33
106
  /**
34
- * The size of checkbox group.
35
- * Control the size of checkboxes in group if size not passed to checkbox.
107
+ * The onChange of checkbox group.
108
+ * Provides the latest `values` array via `event.target.values`.
36
109
  */
37
- size?: CheckboxSize;
110
+ onChange?: (event: CheckboxGroupChangeEvent) => void;
38
111
  /**
39
112
  * The value of checkbox group.
40
113
  */
41
114
  value?: string[];
42
115
  }
116
+ interface CheckboxGroupOptionsInputProps extends CheckboxGroupBaseProps {
117
+ children?: never;
118
+ options: CheckboxGroupOptionInput[];
119
+ }
120
+ interface CheckboxGroupChildrenInputProps extends CheckboxGroupBaseProps {
121
+ children: ReactNode;
122
+ options?: never;
123
+ }
124
+ export type CheckboxGroupProps = CheckboxGroupOptionsInputProps | CheckboxGroupChildrenInputProps;
43
125
  /**
44
126
  * The react component for `mezzanine` checkbox group.
45
127
  */