@mezzanine-ui/react 0.16.0 → 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 (454) hide show
  1. package/Accordion/AccordionControlContext.js +1 -0
  2. package/Accordion/AccordionDetails.js +1 -0
  3. package/Accordion/AccordionSummary.js +10 -10
  4. package/Accordion/index.d.ts +6 -3
  5. package/Alert/index.d.ts +3 -2
  6. package/AlertBanner/AlertBanner.d.ts +93 -0
  7. package/AlertBanner/AlertBanner.js +154 -0
  8. package/AlertBanner/index.d.ts +2 -0
  9. package/AlertBanner/index.js +1 -0
  10. package/Anchor/Anchor.js +1 -1
  11. package/Anchor/index.d.ts +2 -1
  12. package/AppBar/index.d.ts +8 -4
  13. package/{Overlay/Overlay.d.ts → Backdrop/Backdrop.d.ts} +12 -16
  14. package/Backdrop/Backdrop.js +40 -0
  15. package/Backdrop/index.d.ts +2 -0
  16. package/Backdrop/index.js +1 -0
  17. package/Badge/Badge.d.ts +20 -14
  18. package/Badge/Badge.js +14 -16
  19. package/Badge/BadgeContainer.d.ts +1 -1
  20. package/Badge/BadgeContainer.js +1 -1
  21. package/Badge/index.d.ts +3 -2
  22. package/Badge/typings.d.ts +48 -0
  23. package/Breadcrumb/Breadcrumb.d.ts +6 -0
  24. package/Breadcrumb/Breadcrumb.js +25 -0
  25. package/Breadcrumb/BreadcrumbItem.d.ts +4 -0
  26. package/Breadcrumb/BreadcrumbItem.js +45 -0
  27. package/Breadcrumb/index.d.ts +2 -0
  28. package/Breadcrumb/index.js +1 -0
  29. package/Breadcrumb/typings.d.ts +70 -0
  30. package/Button/Button.js +24 -19
  31. package/Button/ButtonGroup.d.ts +6 -28
  32. package/Button/ButtonGroup.js +7 -16
  33. package/Button/index.d.ts +4 -10
  34. package/Button/index.js +2 -3
  35. package/Button/typings.d.ts +11 -26
  36. package/Calendar/Calendar.d.ts +31 -2
  37. package/Calendar/Calendar.js +74 -19
  38. package/Calendar/CalendarCell.d.ts +4 -0
  39. package/Calendar/CalendarCell.js +3 -3
  40. package/Calendar/CalendarConfigProviderDayjs.d.ts +21 -0
  41. package/Calendar/CalendarConfigProviderDayjs.js +15 -0
  42. package/Calendar/CalendarConfigProviderLuxon.d.ts +21 -0
  43. package/Calendar/CalendarConfigProviderLuxon.js +15 -0
  44. package/Calendar/CalendarConfigProviderMoment.d.ts +21 -0
  45. package/Calendar/CalendarConfigProviderMoment.js +15 -0
  46. package/Calendar/CalendarContext.d.ts +14 -7
  47. package/Calendar/CalendarContext.js +8 -13
  48. package/Calendar/CalendarControls.d.ts +16 -0
  49. package/Calendar/CalendarControls.js +3 -7
  50. package/Calendar/CalendarDayOfWeek.js +4 -3
  51. package/Calendar/CalendarDays.d.ts +9 -1
  52. package/Calendar/CalendarDays.js +63 -38
  53. package/Calendar/CalendarFooterActions.d.ts +13 -0
  54. package/Calendar/CalendarFooterActions.js +14 -0
  55. package/Calendar/CalendarFooterControl.d.ts +16 -0
  56. package/Calendar/CalendarFooterControl.js +14 -0
  57. package/Calendar/CalendarHalfYears.d.ts +39 -0
  58. package/Calendar/CalendarHalfYears.js +62 -0
  59. package/Calendar/CalendarMonths.js +16 -4
  60. package/Calendar/CalendarQuarters.d.ts +37 -0
  61. package/Calendar/CalendarQuarters.js +64 -0
  62. package/Calendar/CalendarQuickSelect.d.ts +21 -0
  63. package/Calendar/CalendarQuickSelect.js +15 -0
  64. package/Calendar/CalendarWeeks.d.ts +1 -1
  65. package/Calendar/CalendarWeeks.js +89 -44
  66. package/Calendar/CalendarYears.js +13 -3
  67. package/Calendar/RangeCalendar.d.ts +59 -0
  68. package/Calendar/RangeCalendar.js +232 -0
  69. package/Calendar/index.d.ts +33 -10
  70. package/Calendar/index.js +7 -0
  71. package/Calendar/useCalendarControlModifiers.d.ts +4 -4
  72. package/Calendar/useCalendarControlModifiers.js +40 -8
  73. package/Calendar/useCalendarControls.d.ts +2 -0
  74. package/Calendar/useCalendarControls.js +19 -2
  75. package/Calendar/useCalendarModeStack.js +1 -0
  76. package/Calendar/useRangeCalendarControls.d.ts +18 -0
  77. package/Calendar/useRangeCalendarControls.js +115 -0
  78. package/Card/CardActions.js +1 -1
  79. package/Card/index.d.ts +4 -2
  80. package/Checkbox/CheckAll.d.ts +16 -6
  81. package/Checkbox/CheckAll.js +40 -26
  82. package/Checkbox/Checkbox.d.ts +100 -22
  83. package/Checkbox/Checkbox.js +73 -16
  84. package/Checkbox/CheckboxGroup.d.ts +100 -18
  85. package/Checkbox/CheckboxGroup.js +169 -24
  86. package/Checkbox/CheckboxGroupContext.d.ts +0 -2
  87. package/Checkbox/CheckboxGroupContext.js +1 -0
  88. package/Checkbox/index.d.ts +16 -4
  89. package/Checkbox/index.js +6 -2
  90. package/Checkbox/typings.d.ts +37 -0
  91. package/ClearActions/ClearActions.d.ts +41 -0
  92. package/ClearActions/ClearActions.js +23 -0
  93. package/ClearActions/index.d.ts +3 -0
  94. package/ClearActions/index.js +5 -0
  95. package/ConfirmActions/ConfirmActions.d.ts +2 -1
  96. package/ConfirmActions/index.d.ts +2 -1
  97. package/DatePicker/DatePicker.d.ts +12 -1
  98. package/DatePicker/DatePicker.js +41 -9
  99. package/DatePicker/DatePickerCalendar.d.ts +2 -5
  100. package/DatePicker/DatePickerCalendar.js +37 -37
  101. package/DatePicker/index.d.ts +4 -2
  102. package/DateRangePicker/DateRangePicker.d.ts +18 -2
  103. package/DateRangePicker/DateRangePicker.js +143 -100
  104. package/DateRangePicker/DateRangePickerCalendar.d.ts +13 -9
  105. package/DateRangePicker/DateRangePickerCalendar.js +7 -94
  106. package/DateRangePicker/index.d.ts +6 -3
  107. package/DateRangePicker/useDateRangeCalendarControls.js +11 -6
  108. package/DateRangePicker/useDateRangePickerValue.d.ts +38 -15
  109. package/DateRangePicker/useDateRangePickerValue.js +142 -63
  110. package/DateTimePicker/DateTimePicker.d.ts +31 -10
  111. package/DateTimePicker/DateTimePicker.js +179 -94
  112. package/DateTimePicker/index.d.ts +2 -2
  113. package/DateTimePicker/index.js +0 -1
  114. package/Drawer/Drawer.js +2 -2
  115. package/Drawer/index.d.ts +2 -1
  116. package/Dropdown/Dropdown.js +12 -22
  117. package/Dropdown/index.d.ts +2 -1
  118. package/Empty/Empty.d.ts +1 -16
  119. package/Empty/Empty.js +36 -7
  120. package/Empty/icons/EmptyMainInitialDataIcon.d.ts +4 -0
  121. package/Empty/icons/EmptyMainInitialDataIcon.js +9 -0
  122. package/Empty/icons/EmptyMainResultIcon.d.ts +4 -0
  123. package/Empty/icons/EmptyMainResultIcon.js +9 -0
  124. package/Empty/icons/EmptyMainSystemIcon.d.ts +4 -0
  125. package/Empty/icons/EmptyMainSystemIcon.js +9 -0
  126. package/Empty/index.d.ts +2 -1
  127. package/Empty/typings.d.ts +52 -0
  128. package/Form/FormControlContext.js +1 -0
  129. package/Form/FormHintText.d.ts +18 -0
  130. package/Form/FormHintText.js +17 -0
  131. package/Form/FormLabel.js +1 -0
  132. package/Form/index.d.ts +9 -5
  133. package/Form/index.js +1 -1
  134. package/Form/useAutoCompleteValueControl.js +2 -0
  135. package/Form/useCheckboxControlValue.js +0 -1
  136. package/Form/useSelectValueControl.js +2 -0
  137. package/InlineMessage/InlineMessage.d.ts +33 -0
  138. package/InlineMessage/InlineMessage.js +42 -0
  139. package/InlineMessage/InlineMessageGroup.d.ts +24 -0
  140. package/InlineMessage/InlineMessageGroup.js +21 -0
  141. package/InlineMessage/index.d.ts +4 -0
  142. package/InlineMessage/index.js +2 -0
  143. package/Input/ActionButton/ActionButton.d.ts +26 -0
  144. package/Input/ActionButton/ActionButton.js +14 -0
  145. package/Input/ActionButton/index.d.ts +2 -0
  146. package/Input/ActionButton/index.js +1 -0
  147. package/Input/Input.d.ts +147 -42
  148. package/Input/Input.js +195 -27
  149. package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.d.ts +31 -0
  150. package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.js +18 -0
  151. package/Input/PasswordStrengthIndicator/index.d.ts +2 -0
  152. package/Input/PasswordStrengthIndicator/index.js +1 -0
  153. package/Input/SelectButton/SelectButton.d.ts +20 -0
  154. package/Input/SelectButton/SelectButton.js +21 -0
  155. package/Input/SelectButton/index.d.ts +2 -0
  156. package/Input/SelectButton/index.js +1 -0
  157. package/Input/SpinnerButton/SpinnerButton.d.ts +19 -0
  158. package/Input/SpinnerButton/SpinnerButton.js +14 -0
  159. package/Input/SpinnerButton/index.d.ts +2 -0
  160. package/Input/SpinnerButton/index.js +1 -0
  161. package/Input/index.d.ts +3 -2
  162. package/Menu/Menu.js +1 -0
  163. package/Menu/index.d.ts +8 -4
  164. package/Message/Message.d.ts +6 -4
  165. package/Message/Message.js +86 -9
  166. package/Message/MessageTimerController.d.ts +14 -0
  167. package/Message/MessageTimerController.js +27 -0
  168. package/Message/index.d.ts +3 -2
  169. package/Modal/Modal.js +2 -2
  170. package/Modal/ModalActions.js +1 -0
  171. package/Modal/ModalControl.js +1 -0
  172. package/Modal/ModalHeader.js +1 -0
  173. package/Modal/index.d.ts +10 -5
  174. package/Modal/useModalContainer.d.ts +1 -1
  175. package/Modal/useModalContainer.js +2 -4
  176. package/Navigation/Navigation.js +37 -34
  177. package/Navigation/NavigationContext.js +1 -0
  178. package/Navigation/NavigationItem.js +1 -0
  179. package/Navigation/NavigationSubMenu.js +16 -26
  180. package/Navigation/index.d.ts +8 -4
  181. package/Notification/Notification.js +0 -1
  182. package/Notification/index.d.ts +3 -2
  183. package/Notifier/NotifierManager.d.ts +15 -2
  184. package/Notifier/NotifierManager.js +60 -18
  185. package/Notifier/createNotifier.d.ts +9 -0
  186. package/Notifier/createNotifier.js +3 -2
  187. package/Notifier/typings.d.ts +3 -1
  188. package/OverflowTooltip/OverflowCounterTag.d.ts +12 -0
  189. package/OverflowTooltip/OverflowCounterTag.js +48 -0
  190. package/OverflowTooltip/OverflowTooltip.d.ts +34 -0
  191. package/OverflowTooltip/OverflowTooltip.js +53 -0
  192. package/OverflowTooltip/index.d.ts +2 -0
  193. package/OverflowTooltip/index.js +2 -0
  194. package/PageFooter/PageFooter.d.ts +73 -8
  195. package/PageFooter/PageFooter.js +34 -3
  196. package/PageFooter/index.d.ts +2 -1
  197. package/PageHeader/PageHeader.d.ts +36 -0
  198. package/PageHeader/PageHeader.js +65 -0
  199. package/PageHeader/index.d.ts +2 -0
  200. package/PageHeader/index.js +1 -0
  201. package/PageToolbar/PageToolbar.d.ts +67 -0
  202. package/PageToolbar/PageToolbar.js +114 -0
  203. package/PageToolbar/index.d.ts +2 -0
  204. package/PageToolbar/index.js +1 -0
  205. package/Pagination/Pagination.d.ts +23 -29
  206. package/Pagination/Pagination.js +3 -4
  207. package/Pagination/PaginationItem.d.ts +1 -1
  208. package/Pagination/PaginationItem.js +6 -3
  209. package/Pagination/PaginationJumper.d.ts +7 -9
  210. package/Pagination/PaginationJumper.js +3 -5
  211. package/Pagination/PaginationPageSize.d.ts +8 -11
  212. package/Pagination/PaginationPageSize.js +5 -4
  213. package/Pagination/index.d.ts +8 -4
  214. package/Pagination/usePagination.d.ts +3 -1
  215. package/Pagination/usePagination.js +30 -21
  216. package/Picker/FormattedInput.d.ts +17 -0
  217. package/Picker/FormattedInput.js +74 -0
  218. package/Picker/MaskFormat.d.ts +39 -0
  219. package/Picker/MaskFormat.js +94 -0
  220. package/Picker/PickerTrigger.d.ts +13 -3
  221. package/Picker/PickerTrigger.js +17 -2
  222. package/Picker/PickerTriggerWithSeparator.d.ts +124 -0
  223. package/Picker/PickerTriggerWithSeparator.js +80 -0
  224. package/Picker/RangePickerTrigger.d.ts +55 -4
  225. package/Picker/RangePickerTrigger.js +65 -7
  226. package/Picker/formatUtils.d.ts +34 -0
  227. package/Picker/formatUtils.js +124 -0
  228. package/Picker/index.d.ts +17 -6
  229. package/Picker/index.js +4 -1
  230. package/Picker/useDateInputFormatter.d.ts +52 -0
  231. package/Picker/useDateInputFormatter.js +382 -0
  232. package/Picker/usePickerValue.d.ts +1 -2
  233. package/Picker/usePickerValue.js +8 -13
  234. package/Popconfirm/Popconfirm.js +1 -1
  235. package/Popconfirm/index.d.ts +2 -1
  236. package/Popover/Popover.js +4 -8
  237. package/Popover/index.d.ts +2 -1
  238. package/Popper/Popper.d.ts +15 -10
  239. package/Popper/Popper.js +88 -17
  240. package/Popper/index.d.ts +2 -1
  241. package/Portal/Portal.d.ts +13 -5
  242. package/Portal/Portal.js +25 -10
  243. package/Portal/index.d.ts +4 -1
  244. package/Portal/index.js +1 -0
  245. package/Portal/portalRegistry.d.ts +17 -0
  246. package/Portal/portalRegistry.js +92 -0
  247. package/Progress/Progress.d.ts +23 -30
  248. package/Progress/Progress.js +71 -21
  249. package/Progress/index.d.ts +3 -2
  250. package/Provider/ConfigProvider.d.ts +1 -0
  251. package/Provider/ConfigProvider.js +1 -0
  252. package/Provider/context.js +1 -0
  253. package/Radio/Radio.d.ts +1 -1
  254. package/Radio/Radio.js +2 -1
  255. package/Radio/RadioGroup.d.ts +1 -1
  256. package/Radio/RadioGroup.js +1 -1
  257. package/Radio/RadioGroupContext.js +1 -0
  258. package/Radio/index.d.ts +4 -2
  259. package/ResultState/ResultState.d.ts +52 -0
  260. package/ResultState/ResultState.js +24 -0
  261. package/ResultState/index.d.ts +2 -0
  262. package/ResultState/index.js +1 -0
  263. package/Select/AutoComplete.d.ts +1 -1
  264. package/Select/AutoComplete.js +2 -1
  265. package/Select/Option.js +1 -0
  266. package/Select/Select.d.ts +1 -1
  267. package/Select/Select.js +2 -1
  268. package/Select/SelectControlContext.js +1 -0
  269. package/Select/SelectTrigger.d.ts +1 -87
  270. package/Select/SelectTrigger.js +26 -21
  271. package/Select/SelectTriggerTags.d.ts +1 -1
  272. package/Select/SelectTriggerTags.js +47 -18
  273. package/Select/TreeSelect.d.ts +1 -1
  274. package/Select/TreeSelect.js +2 -1
  275. package/Select/index.d.ts +14 -7
  276. package/Select/typings.d.ts +99 -0
  277. package/Select/useSelectTriggerTags.d.ts +15 -8
  278. package/Select/useSelectTriggerTags.js +83 -44
  279. package/Selection/Selection.d.ts +98 -0
  280. package/Selection/Selection.js +46 -0
  281. package/Selection/index.d.ts +12 -0
  282. package/Selection/index.js +5 -0
  283. package/Skeleton/Skeleton.d.ts +10 -3
  284. package/Skeleton/Skeleton.js +12 -4
  285. package/Skeleton/index.d.ts +2 -1
  286. package/Slider/Slider.d.ts +44 -7
  287. package/Slider/Slider.js +17 -13
  288. package/Slider/index.d.ts +5 -3
  289. package/Spin/Spin.d.ts +39 -0
  290. package/{Loading/Loading.js → Spin/Spin.js} +9 -9
  291. package/Spin/index.d.ts +2 -0
  292. package/Spin/index.js +1 -0
  293. package/Stepper/Step.d.ts +1 -35
  294. package/Stepper/Step.js +43 -8
  295. package/Stepper/Stepper.d.ts +1 -14
  296. package/Stepper/Stepper.js +49 -15
  297. package/Stepper/index.d.ts +5 -2
  298. package/Stepper/index.js +1 -0
  299. package/Stepper/typings.d.ts +77 -0
  300. package/Stepper/useStepDistance.d.ts +10 -0
  301. package/Stepper/useStepDistance.js +81 -0
  302. package/Stepper/useStepper.d.ts +21 -0
  303. package/Stepper/useStepper.js +26 -0
  304. package/Table/Table.js +2 -2
  305. package/Table/TableBody.js +3 -2
  306. package/Table/TableBodyRow.js +1 -0
  307. package/Table/TableContext.js +1 -0
  308. package/Table/TableExpandedTable.js +1 -0
  309. package/Table/TableHeader.js +1 -0
  310. package/Table/editable/TableEditRenderWrapper.js +1 -0
  311. package/Table/expandable/TableExpandable.js +1 -1
  312. package/Table/index.d.ts +7 -4
  313. package/Table/pagination/TablePagination.js +1 -0
  314. package/Table/pagination/useTablePagination.js +1 -0
  315. package/Table/refresh/TableRefresh.js +3 -1
  316. package/Table/rowSelection/TableRowSelection.js +3 -2
  317. package/Table/sorting/TableSortingIcon.js +2 -1
  318. package/Table/sorting/useTableSorting.js +1 -0
  319. package/Table/useTableFetchMore.js +1 -1
  320. package/Table/useTableScroll.d.ts +4 -8
  321. package/Table/useTableScroll.js +9 -7
  322. package/Tabs/TabPane.js +1 -0
  323. package/Tabs/Tabs.js +9 -4
  324. package/Tabs/index.d.ts +6 -3
  325. package/Tabs/useTabsOverflow.js +4 -3
  326. package/Tag/Tag.d.ts +2 -25
  327. package/Tag/Tag.js +23 -13
  328. package/Tag/TagGroup.d.ts +12 -0
  329. package/Tag/TagGroup.js +41 -0
  330. package/Tag/index.d.ts +2 -1
  331. package/Tag/typings.d.ts +78 -0
  332. package/TextField/TextField.d.ts +78 -19
  333. package/TextField/TextField.js +58 -22
  334. package/TextField/index.d.ts +2 -1
  335. package/Textarea/Textarea.d.ts +19 -51
  336. package/Textarea/Textarea.js +13 -19
  337. package/Textarea/index.d.ts +2 -2
  338. package/TimePanel/TimePanel.d.ts +1 -22
  339. package/TimePanel/TimePanel.js +31 -26
  340. package/TimePanel/TimePanelAction.d.ts +2 -8
  341. package/TimePanel/TimePanelAction.js +2 -2
  342. package/TimePanel/TimePanelColumn.d.ts +0 -13
  343. package/TimePanel/TimePanelColumn.js +9 -11
  344. package/TimePanel/index.d.ts +6 -3
  345. package/TimePicker/TimePicker.d.ts +10 -1
  346. package/TimePicker/TimePicker.js +86 -35
  347. package/TimePicker/TimePickerPanel.d.ts +1 -2
  348. package/TimePicker/TimePickerPanel.js +2 -2
  349. package/TimePicker/index.d.ts +4 -2
  350. package/Toggle/Toggle.d.ts +46 -0
  351. package/Toggle/Toggle.js +29 -0
  352. package/Toggle/index.d.ts +3 -0
  353. package/Toggle/index.js +1 -0
  354. package/Tooltip/Tooltip.d.ts +13 -2
  355. package/Tooltip/Tooltip.js +56 -10
  356. package/Tooltip/index.d.ts +2 -1
  357. package/Tooltip/useDelayMouseEnterLeave.d.ts +1 -2
  358. package/Tooltip/useDelayMouseEnterLeave.js +10 -13
  359. package/Transition/Collapse.d.ts +2 -0
  360. package/Transition/Collapse.js +5 -6
  361. package/Transition/Fade.js +4 -4
  362. package/Transition/Rotate.d.ts +42 -0
  363. package/Transition/Rotate.js +30 -0
  364. package/Transition/Scale.d.ts +13 -0
  365. package/Transition/{Grow.js → Scale.js} +19 -16
  366. package/Transition/Slide.d.ts +7 -0
  367. package/Transition/{Zoom.js → Slide.js} +14 -12
  368. package/Transition/SlideFade.d.ts +3 -0
  369. package/Transition/SlideFade.js +5 -4
  370. package/Transition/Transition.d.ts +2 -2
  371. package/Transition/Translate.d.ts +14 -0
  372. package/Transition/Translate.js +94 -0
  373. package/Transition/index.d.ts +16 -6
  374. package/Transition/index.js +4 -2
  375. package/Transition/useAutoTransitionDuration.d.ts +1 -1
  376. package/Transition/useAutoTransitionDuration.js +3 -3
  377. package/Transition/useSetNodeTransition.js +0 -2
  378. package/Tree/TreeNode.js +7 -6
  379. package/Tree/index.d.ts +10 -5
  380. package/Typography/Typography.d.ts +6 -9
  381. package/Typography/Typography.js +7 -9
  382. package/Typography/index.d.ts +2 -5
  383. package/Upload/Upload.d.ts +175 -0
  384. package/Upload/Upload.js +279 -0
  385. package/Upload/UploadItem.d.ts +82 -0
  386. package/Upload/UploadItem.js +118 -0
  387. package/Upload/UploadPictureCard.d.ts +110 -0
  388. package/Upload/UploadPictureCard.js +101 -0
  389. package/Upload/Uploader.d.ts +161 -0
  390. package/Upload/Uploader.js +120 -0
  391. package/Upload/index.d.ts +8 -6
  392. package/Upload/index.js +4 -5
  393. package/Upload/upload-utils.d.ts +41 -0
  394. package/Upload/upload-utils.js +65 -0
  395. package/_internal/InputCheck/index.d.ts +4 -2
  396. package/_internal/InputTriggerPopper/InputTriggerPopper.js +15 -25
  397. package/_internal/InputTriggerPopper/index.d.ts +2 -1
  398. package/_internal/SlideFadeOverlay/SlideFadeOverlay.d.ts +2 -2
  399. package/_internal/SlideFadeOverlay/SlideFadeOverlay.js +4 -27
  400. package/_internal/SlideFadeOverlay/index.d.ts +2 -1
  401. package/_internal/SlideFadeOverlay/useTopStack.js +1 -0
  402. package/dayjs.d.ts +21 -0
  403. package/dayjs.js +2 -0
  404. package/hooks/useComposeRefs.js +1 -1
  405. package/hooks/useLastCallback.js +3 -1
  406. package/hooks/useScrollLock.d.ts +28 -0
  407. package/hooks/useScrollLock.js +134 -0
  408. package/index.d.ts +126 -58
  409. package/index.js +93 -80
  410. package/luxon.d.ts +21 -0
  411. package/luxon.js +2 -0
  412. package/moment.d.ts +21 -0
  413. package/moment.js +2 -0
  414. package/package.json +13 -17
  415. package/utils/composeRefs.js +0 -1
  416. package/utils/get-css-variable-value.d.ts +1 -0
  417. package/utils/get-css-variable-value.js +9 -0
  418. package/Button/IconButton.d.ts +0 -21
  419. package/Button/IconButton.js +0 -13
  420. package/DateTimePicker/DateTimePickerPanel.d.ts +0 -28
  421. package/DateTimePicker/DateTimePickerPanel.js +0 -49
  422. package/Form/FormMessage.d.ts +0 -7
  423. package/Form/FormMessage.js +0 -18
  424. package/Form/useInputWithTagsModeValue.js +0 -86
  425. package/Loading/Loading.d.ts +0 -33
  426. package/Loading/index.d.ts +0 -1
  427. package/Loading/index.js +0 -1
  428. package/Overlay/Overlay.js +0 -31
  429. package/Overlay/index.d.ts +0 -1
  430. package/Overlay/index.js +0 -1
  431. package/Picker/useRangePickerValue.d.ts +0 -23
  432. package/Picker/useRangePickerValue.js +0 -99
  433. package/Switch/Switch.d.ts +0 -43
  434. package/Switch/Switch.js +0 -28
  435. package/Switch/index.d.ts +0 -2
  436. package/Switch/index.js +0 -1
  437. package/Transition/Grow.d.ts +0 -12
  438. package/Transition/Zoom.d.ts +0 -7
  439. package/Upload/UploadButton.d.ts +0 -9
  440. package/Upload/UploadButton.js +0 -23
  441. package/Upload/UploadInput.d.ts +0 -20
  442. package/Upload/UploadInput.js +0 -24
  443. package/Upload/UploadPicture.d.ts +0 -49
  444. package/Upload/UploadPicture.js +0 -51
  445. package/Upload/UploadPictureBlock.d.ts +0 -20
  446. package/Upload/UploadPictureBlock.js +0 -81
  447. package/Upload/UploadPictureWall.d.ts +0 -81
  448. package/Upload/UploadPictureWall.js +0 -168
  449. package/Upload/UploadPictureWallItem.d.ts +0 -15
  450. package/Upload/UploadPictureWallItem.js +0 -18
  451. package/Upload/UploadResult.d.ts +0 -35
  452. package/Upload/UploadResult.js +0 -29
  453. package/utils/scroll-lock.d.ts +0 -2
  454. package/utils/scroll-lock.js +0 -24
@@ -1,35 +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
91
 
35
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
  */
@@ -1,38 +1,183 @@
1
- import { jsx } from 'react/jsx-runtime';
2
- import { forwardRef, useMemo, createElement } from 'react';
1
+ 'use client';
2
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
3
+ import { checkboxGroupClasses } from '@mezzanine-ui/core/checkbox';
4
+ import { forwardRef, useId, useMemo, useCallback, useEffect, Children, isValidElement } from 'react';
3
5
  import { useControlValueState } from '../Form/useControlValueState.js';
4
- import { CheckboxGroupContext } from './CheckboxGroupContext.js';
5
6
  import Checkbox from './Checkbox.js';
6
- import InputCheckGroup from '../_internal/InputCheck/InputCheckGroup.js';
7
+ import { CheckboxGroupContext } from './CheckboxGroupContext.js';
8
+ import cx from 'clsx';
7
9
 
8
- const renderOption = ({ label: children, ...option }) => (createElement(Checkbox, { ...option, key: option.value }, children));
10
+ function assignCheckboxGroupValuesToEvent(event, values, name) {
11
+ const target = event.target;
12
+ target.values = values;
13
+ if (name) {
14
+ target.name = name;
15
+ }
16
+ return event;
17
+ }
18
+ const equalityFn = (a, b) => {
19
+ if (a.length !== b.length)
20
+ return false;
21
+ const sortedA = [...a].sort();
22
+ const sortedB = [...b].sort();
23
+ return sortedA.every((val, idx) => val === sortedB[idx]);
24
+ };
9
25
  /**
10
26
  * The react component for `mezzanine` checkbox group.
11
27
  */
12
28
  const CheckboxGroup = forwardRef(function CheckboxGroup(props, ref) {
13
- const { children: childrenProp, defaultValue = [], disabled, name, options = [], onChange, size, value: valueProp, ...rest } = props;
29
+ var _a, _b, _c, _d, _e;
30
+ const { children: childrenProp, className, defaultValue, disabled, layout = 'horizontal', level, mode, name, options, onChange: onChangeProp, role = 'group', value: valueProp, ...rest } = props;
31
+ const generatedName = useId();
32
+ const resolvedName = name !== null && name !== void 0 ? name : generatedName;
33
+ const normalizedOptions = useMemo(() => options !== null && options !== void 0 ? options : [], [options]);
14
34
  const [value, setValue] = useControlValueState({
15
- defaultValue,
35
+ defaultValue: defaultValue !== null && defaultValue !== void 0 ? defaultValue : [],
36
+ equalityFn,
16
37
  value: valueProp,
17
38
  });
39
+ const handleChange = useCallback((event) => {
40
+ const checkboxValue = event.target.value;
41
+ const isChecked = event.target.checked;
42
+ const currentValue = value || [];
43
+ const newValue = isChecked
44
+ ? [...currentValue, checkboxValue]
45
+ : currentValue.filter((v) => v !== checkboxValue);
46
+ setValue(newValue);
47
+ if (onChangeProp) {
48
+ const syntheticEvent = assignCheckboxGroupValuesToEvent(event, newValue, resolvedName);
49
+ onChangeProp(syntheticEvent);
50
+ }
51
+ }, [onChangeProp, resolvedName, setValue, value]);
18
52
  const context = useMemo(() => ({
19
53
  disabled,
20
- name,
21
- onChange(event) {
22
- const { checked, value: targetValue } = event.target;
23
- const newValue = checked
24
- ? [...value, targetValue]
25
- : value.filter((v) => v !== targetValue);
26
- setValue(newValue);
27
- if (onChange) {
28
- onChange(newValue, event);
29
- }
30
- },
31
- size,
32
- value,
33
- }), [disabled, name, value, size, onChange, setValue]);
34
- const children = childrenProp || options.map(renderOption);
35
- return (jsx(CheckboxGroupContext.Provider, { value: context, children: jsx(InputCheckGroup, { ...rest, ref: ref, children: children }) }));
54
+ name: resolvedName,
55
+ onChange: handleChange,
56
+ value: value || [],
57
+ }), [disabled, resolvedName, handleChange, value]);
58
+ const hasChildrenInput = typeof childrenProp !== 'undefined';
59
+ const hasOptionsInput = Array.isArray(options);
60
+ // Validate input props and warn about missing props
61
+ useEffect(() => {
62
+ if (hasChildrenInput && hasOptionsInput) {
63
+ console.error('CheckboxGroup: Please provide either `children` or `options`, but not both.');
64
+ }
65
+ else if (!hasChildrenInput && !hasOptionsInput) {
66
+ console.error('CheckboxGroup: Please provide one of `children` or `options`.');
67
+ }
68
+ // Warn if name is not provided (important for react-hook-form integration)
69
+ if (!name) {
70
+ console.warn('CheckboxGroup: The `name` prop is recommended, especially when integrating with react-hook-form. ' +
71
+ 'All checkboxes in the group should share the same `name` attribute.');
72
+ }
73
+ // Validate that all children have value prop
74
+ if (hasChildrenInput) {
75
+ Children.forEach(childrenProp, (child, index) => {
76
+ if (isValidElement(child) && child.type === Checkbox) {
77
+ const checkboxProps = child.props;
78
+ if (!checkboxProps.value) {
79
+ console.warn(`CheckboxGroup: Each Checkbox child should have a \`value\` prop. ` +
80
+ `Checkbox at index ${index} is missing the \`value\` prop.`);
81
+ }
82
+ }
83
+ });
84
+ }
85
+ }, [hasChildrenInput, hasOptionsInput, name, childrenProp]);
86
+ // Validate that all children are Checkbox components
87
+ useEffect(() => {
88
+ if (hasChildrenInput) {
89
+ Children.forEach(childrenProp, (child) => {
90
+ var _a;
91
+ if (isValidElement(child) && child.type !== Checkbox) {
92
+ console.warn('CheckboxGroup: When using ReactNode (children) input, only Checkbox components are supported. ' +
93
+ `Found unsupported component: ${typeof child.type === 'string' ? child.type : ((_a = child.type) === null || _a === void 0 ? void 0 : _a.name) || 'Unknown'}`);
94
+ }
95
+ });
96
+ }
97
+ }, [hasChildrenInput, childrenProp]);
98
+ // Render priority: ReactNode (children) first, then options
99
+ // If using ReactNode, only Checkbox components are supported, other components are not supported
100
+ const children = useMemo(() => {
101
+ // Render ReactNode (children) if provided
102
+ if (hasChildrenInput) {
103
+ return childrenProp;
104
+ }
105
+ if (hasOptionsInput && normalizedOptions.length > 0) {
106
+ return normalizedOptions.map(({ label, value: optionValue, disabled: optionDisabled, id: optionId, inputProps: optionInputProps, inputRef: optionInputRef, ...optionRest }) => {
107
+ // Generate unique id if not provided
108
+ // Format: {name}-{value} or fallback to checkbox-{value}
109
+ const generatedId = resolvedName
110
+ ? `${resolvedName}-${optionValue}`
111
+ : `checkbox-${optionValue}`;
112
+ const finalId = optionId !== null && optionId !== void 0 ? optionId : generatedId;
113
+ return (jsx(Checkbox, { disabled: optionDisabled !== null && optionDisabled !== void 0 ? optionDisabled : disabled, id: finalId, inputProps: optionInputProps, inputRef: optionInputRef, label: typeof label === 'string' ? label : String(label), mode: mode, value: optionValue, ...optionRest }, optionValue));
114
+ });
115
+ }
116
+ return null;
117
+ }, [
118
+ childrenProp,
119
+ disabled,
120
+ hasChildrenInput,
121
+ hasOptionsInput,
122
+ mode,
123
+ normalizedOptions,
124
+ resolvedName,
125
+ ]);
126
+ const isLevelActive = (_a = level === null || level === void 0 ? void 0 : level.active) !== null && _a !== void 0 ? _a : false;
127
+ const isChipMode = mode === 'chip';
128
+ const isHorizontalLayout = layout === 'horizontal';
129
+ const shouldRenderLevelInsideContent = isLevelActive && isChipMode;
130
+ const ariaOrientation = isLevelActive ? 'vertical' : layout;
131
+ const canRenderLevelControl = isLevelActive && normalizedOptions.length > 0;
132
+ useEffect(() => {
133
+ if (isLevelActive && !hasOptionsInput) {
134
+ console.warn('CheckboxGroup: `level.active=true` currently supports only the `options` input approach.');
135
+ }
136
+ }, [hasOptionsInput, isLevelActive]);
137
+ const { levelChecked, levelIndeterminate } = useMemo(() => {
138
+ if (!canRenderLevelControl) {
139
+ return { levelChecked: false, levelIndeterminate: false };
140
+ }
141
+ const enabledOptions = normalizedOptions.filter((opt) => !opt.disabled);
142
+ const enabledValues = enabledOptions.map((opt) => opt.value);
143
+ const selectedEnabledValues = (value || []).filter((v) => enabledValues.includes(v));
144
+ if (selectedEnabledValues.length === 0) {
145
+ return { levelChecked: false, levelIndeterminate: false };
146
+ }
147
+ if (selectedEnabledValues.length === enabledValues.length) {
148
+ return { levelChecked: true, levelIndeterminate: false };
149
+ }
150
+ return { levelChecked: false, levelIndeterminate: true };
151
+ }, [canRenderLevelControl, normalizedOptions, value]);
152
+ const handleLevelControlChange = useCallback((event) => {
153
+ if (!canRenderLevelControl) {
154
+ return;
155
+ }
156
+ // Use custom onChange if provided
157
+ if (level === null || level === void 0 ? void 0 : level.onChange) {
158
+ level.onChange(event);
159
+ return;
160
+ }
161
+ // Default behavior: select/deselect all
162
+ const isChecked = event.target.checked;
163
+ const currentValue = value || [];
164
+ const enabledOptions = normalizedOptions.filter((opt) => !opt.disabled);
165
+ const enabledValues = enabledOptions.map((opt) => opt.value);
166
+ const disabledOptions = normalizedOptions.filter((opt) => opt.disabled);
167
+ const disabledValues = disabledOptions.map((opt) => opt.value);
168
+ const selectedDisabledValues = currentValue.filter((v) => disabledValues.includes(v));
169
+ const newValue = isChecked
170
+ ? [...enabledValues, ...selectedDisabledValues]
171
+ : selectedDisabledValues;
172
+ setValue(newValue);
173
+ if (onChangeProp) {
174
+ const syntheticEvent = assignCheckboxGroupValuesToEvent(event, newValue, resolvedName);
175
+ onChangeProp(syntheticEvent);
176
+ }
177
+ }, [canRenderLevelControl, level, onChangeProp, normalizedOptions, resolvedName, setValue, value]);
178
+ return (jsxs("div", { ...rest, ref: ref, "aria-orientation": ariaOrientation, className: cx(checkboxGroupClasses.host, {
179
+ [checkboxGroupClasses.nested]: isLevelActive,
180
+ }, className), role: role, children: [canRenderLevelControl && !shouldRenderLevelInsideContent && (jsx(Checkbox, { checked: levelChecked, disabled: disabled || (level === null || level === void 0 ? void 0 : level.disabled), id: `${resolvedName}-level-control`, indeterminate: levelIndeterminate, label: (_b = level === null || level === void 0 ? void 0 : level.label) !== null && _b !== void 0 ? _b : '', mode: (_c = level === null || level === void 0 ? void 0 : level.mode) !== null && _c !== void 0 ? _c : 'main', name: `${resolvedName}-level-control`, onChange: handleLevelControlChange })), jsxs("div", { className: cx(checkboxGroupClasses.contentWrapper, checkboxGroupClasses.layout(layout), mode && checkboxGroupClasses.mode(mode)), children: [canRenderLevelControl && shouldRenderLevelInsideContent && (jsxs(Fragment, { children: [jsx(Checkbox, { checked: levelChecked, disabled: disabled || (level === null || level === void 0 ? void 0 : level.disabled), id: `${resolvedName}-level-control`, indeterminate: levelIndeterminate, label: (_d = level === null || level === void 0 ? void 0 : level.label) !== null && _d !== void 0 ? _d : '', mode: (_e = level === null || level === void 0 ? void 0 : level.mode) !== null && _e !== void 0 ? _e : 'main', name: `${resolvedName}-level-control`, onChange: handleLevelControlChange }), isHorizontalLayout && jsx("i", { className: checkboxGroupClasses.levelControlSeparator })] })), jsx(CheckboxGroupContext.Provider, { value: context, children: children })] })] }));
36
181
  });
37
182
 
38
- export { CheckboxGroup as default };
183
+ export { assignCheckboxGroupValuesToEvent, CheckboxGroup as default };
@@ -1,8 +1,6 @@
1
- import { CheckboxSize } from '@mezzanine-ui/core/checkbox';
2
1
  import { CheckboxGroupControlContextValue } from '../Form/useCheckboxControlValue';
3
2
  export interface CheckboxGroupContextValue extends CheckboxGroupControlContextValue {
4
3
  disabled?: boolean;
5
4
  name?: string;
6
- size?: CheckboxSize;
7
5
  }
8
6
  export declare const CheckboxGroupContext: import("react").Context<CheckboxGroupContextValue | undefined>;
@@ -1,3 +1,4 @@
1
+ 'use client';
1
2
  import { createContext } from 'react';
2
3
 
3
4
  const CheckboxGroupContext = createContext(undefined);
@@ -1,4 +1,16 @@
1
- export type { CheckboxSize, CheckboxGroupOrientation, CheckboxGroupOption, } from '@mezzanine-ui/core/checkbox';
2
- export { CheckboxProps, default } from './Checkbox';
3
- export { CheckboxGroupProps, default as CheckboxGroup } from './CheckboxGroup';
4
- export { CheckAllProps, default as CheckAll } from './CheckAll';
1
+ import { PropsWithoutRef, ReactElement, RefAttributes } from 'react';
2
+ import { CheckboxProps } from './Checkbox';
3
+ export type { CheckboxGroupLayout, CheckboxGroupOption, } from '@mezzanine-ui/core/checkbox';
4
+ export { default as CheckAll } from './CheckAll';
5
+ export type { CheckAllProps } from './CheckAll';
6
+ export { default as CheckboxGroup } from './CheckboxGroup';
7
+ export type { CheckboxGroupChangeEvent, CheckboxGroupChangeEventTarget, CheckboxGroupLevelConfig, CheckboxGroupProps, } from './CheckboxGroup';
8
+ export type { CheckboxProps } from './Checkbox';
9
+ export type { CheckboxComponent, CheckboxPropsBase } from './typings';
10
+ /**
11
+ * @remark
12
+ * Add type alias here for parsable to react docgen typescript.
13
+ */
14
+ type GenericCheckbox = (props: PropsWithoutRef<CheckboxProps> & RefAttributes<HTMLLabelElement>) => ReactElement<any>;
15
+ declare const _default: GenericCheckbox;
16
+ export default _default;
package/Checkbox/index.js CHANGED
@@ -1,3 +1,7 @@
1
- export { default } from './Checkbox.js';
2
- export { default as CheckboxGroup } from './CheckboxGroup.js';
1
+ import Checkbox from './Checkbox.js';
3
2
  export { default as CheckAll } from './CheckAll.js';
3
+ export { default as CheckboxGroup } from './CheckboxGroup.js';
4
+
5
+
6
+
7
+ export { Checkbox as default };
@@ -0,0 +1,37 @@
1
+ import { CheckboxMode } from '@mezzanine-ui/core/checkbox';
2
+ import { JSXElementConstructor } from 'react';
3
+ export type CheckboxComponent = 'label' | JSXElementConstructor<any>;
4
+ export interface CheckboxPropsBase {
5
+ /**
6
+ * Whether the checkbox is checked.
7
+ */
8
+ checked?: boolean;
9
+ /**
10
+ * Whether the checkbox is checked by default.
11
+ * Only used for uncontrolled.
12
+ */
13
+ defaultChecked?: boolean;
14
+ /**
15
+ * The description text displayed below the label.
16
+ */
17
+ description?: string;
18
+ /**
19
+ * Whether the checkbox is disabled.
20
+ * @default false
21
+ */
22
+ disabled?: boolean;
23
+ /**
24
+ * Whether the checkbox is in indeterminate state.
25
+ * @default false
26
+ */
27
+ indeterminate?: boolean;
28
+ /**
29
+ * The label text displayed beside the checkbox.
30
+ */
31
+ label?: string;
32
+ /**
33
+ * The mode of checkbox.
34
+ * @default 'main'
35
+ */
36
+ mode?: CheckboxMode;
37
+ }
@@ -0,0 +1,41 @@
1
+ import { ClearActionsEmbeddedVariant, ClearActionsStandardVariant } from '@mezzanine-ui/core/clear-actions';
2
+ import { NativeElementPropsWithoutKeyAndRef } from '../utils/jsx-types';
3
+ type ClearActionsCommonProps = Omit<NativeElementPropsWithoutKeyAndRef<'button'>, 'onClick' | 'type'> & {
4
+ /**
5
+ * Called when user clicks or activates the button (via mouse or keyboard).
6
+ */
7
+ onClick?: React.MouseEventHandler<HTMLButtonElement>;
8
+ };
9
+ type ClearActionsStandardProps = ClearActionsCommonProps & {
10
+ /**
11
+ * Clear Actions Contextual type.
12
+ * @default 'standard'
13
+ */
14
+ type?: 'standard';
15
+ /**
16
+ * Visual variant for standard type.
17
+ */
18
+ variant?: ClearActionsStandardVariant;
19
+ };
20
+ type ClearActionsEmbeddedProps = ClearActionsCommonProps & {
21
+ /**
22
+ * Clear Actions Contextual type.
23
+ */
24
+ type: 'embedded';
25
+ /**
26
+ * Visual variant for embedded type.
27
+ */
28
+ variant?: ClearActionsEmbeddedVariant;
29
+ };
30
+ type ClearActionsClearableProps = ClearActionsCommonProps & {
31
+ /**
32
+ * Clear Actions Contextual type.
33
+ */
34
+ type: 'clearable';
35
+ };
36
+ export type ClearActionsProps = ClearActionsEmbeddedProps | ClearActionsStandardProps | ClearActionsClearableProps;
37
+ /**
38
+ * Mezzanine clear actions button.
39
+ */
40
+ declare const ClearActions: import("react").ForwardRefExoticComponent<ClearActionsProps & import("react").RefAttributes<HTMLButtonElement>>;
41
+ export default ClearActions;
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { forwardRef } from 'react';
4
+ import { DangerousFilledIcon, CloseIcon } from '@mezzanine-ui/icons';
5
+ import { clearActionsClasses } from '@mezzanine-ui/core/clear-actions';
6
+ import Icon from '../Icon/Icon.js';
7
+ import cx from 'clsx';
8
+
9
+ /**
10
+ * Mezzanine clear actions button.
11
+ */
12
+ const ClearActions = forwardRef(function ClearActions(props, ref) {
13
+ const { className, onClick, type = 'standard', ...rest } = props;
14
+ const variant = 'variant' in props ? props.variant : undefined;
15
+ const resolvedVariant = type === 'clearable'
16
+ ? 'default'
17
+ : variant !== null && variant !== void 0 ? variant : (type === 'standard' ? 'base' : 'contrast');
18
+ return (jsx("button", { ...rest, ref: ref, "aria-label": "Close", className: cx(clearActionsClasses.host, clearActionsClasses.type(type), clearActionsClasses.variant(resolvedVariant), className), onClick: onClick, type: "button", children: type === 'clearable'
19
+ ? jsx(Icon, { className: clearActionsClasses.icon, icon: DangerousFilledIcon })
20
+ : jsx(Icon, { className: clearActionsClasses.icon, icon: CloseIcon }) }));
21
+ });
22
+
23
+ export { ClearActions as default };
@@ -0,0 +1,3 @@
1
+ import ClearActions from './ClearActions';
2
+ export type { ClearActionsProps } from './ClearActions';
3
+ export default ClearActions;
@@ -0,0 +1,5 @@
1
+ import ClearActions from './ClearActions.js';
2
+
3
+
4
+
5
+ export { ClearActions as default };
@@ -1,5 +1,6 @@
1
1
  import { ReactNode } from 'react';
2
- import { ButtonGroupProps, ButtonProps } from '../Button';
2
+ import { ButtonProps } from '../Button/Button';
3
+ import { ButtonGroupProps } from '../Button/ButtonGroup';
3
4
  export interface ConfirmActionsProps extends Omit<ButtonGroupProps, 'children'> {
4
5
  /**
5
6
  * Other props of cancel button.
@@ -1 +1,2 @@
1
- export { ConfirmActionsProps, default } from './ConfirmActions';
1
+ export { default } from './ConfirmActions';
2
+ export type { ConfirmActionsProps } from './ConfirmActions';