@mezzanine-ui/react 0.16.0 → 1.0.0-beta.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 (547) 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 +53 -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 +75 -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.d.ts +47 -6
  115. package/Drawer/Drawer.js +36 -11
  116. package/Drawer/index.d.ts +2 -1
  117. package/Dropdown/Dropdown.js +12 -22
  118. package/Dropdown/index.d.ts +2 -1
  119. package/Empty/Empty.d.ts +1 -16
  120. package/Empty/Empty.js +59 -7
  121. package/Empty/icons/EmptyMainInitialDataIcon.d.ts +4 -0
  122. package/Empty/icons/EmptyMainInitialDataIcon.js +9 -0
  123. package/Empty/icons/EmptyMainResultIcon.d.ts +4 -0
  124. package/Empty/icons/EmptyMainResultIcon.js +9 -0
  125. package/Empty/icons/EmptyMainSystemIcon.d.ts +4 -0
  126. package/Empty/icons/EmptyMainSystemIcon.js +9 -0
  127. package/Empty/index.d.ts +2 -1
  128. package/Empty/typings.d.ts +61 -0
  129. package/Form/FormControlContext.js +1 -0
  130. package/Form/FormHintText.d.ts +18 -0
  131. package/Form/FormHintText.js +17 -0
  132. package/Form/FormLabel.js +1 -0
  133. package/Form/index.d.ts +9 -5
  134. package/Form/index.js +1 -1
  135. package/Form/useAutoCompleteValueControl.js +2 -0
  136. package/Form/useCheckboxControlValue.js +0 -1
  137. package/Form/useSelectValueControl.js +2 -0
  138. package/InlineMessage/InlineMessage.d.ts +33 -0
  139. package/InlineMessage/InlineMessage.js +42 -0
  140. package/InlineMessage/InlineMessageGroup.d.ts +24 -0
  141. package/InlineMessage/InlineMessageGroup.js +21 -0
  142. package/InlineMessage/index.d.ts +4 -0
  143. package/InlineMessage/index.js +2 -0
  144. package/Input/ActionButton/ActionButton.d.ts +26 -0
  145. package/Input/ActionButton/ActionButton.js +14 -0
  146. package/Input/ActionButton/index.d.ts +2 -0
  147. package/Input/ActionButton/index.js +1 -0
  148. package/Input/Input.d.ts +147 -42
  149. package/Input/Input.js +195 -27
  150. package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.d.ts +31 -0
  151. package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.js +18 -0
  152. package/Input/PasswordStrengthIndicator/index.d.ts +2 -0
  153. package/Input/PasswordStrengthIndicator/index.js +1 -0
  154. package/Input/SelectButton/SelectButton.d.ts +20 -0
  155. package/Input/SelectButton/SelectButton.js +21 -0
  156. package/Input/SelectButton/index.d.ts +2 -0
  157. package/Input/SelectButton/index.js +1 -0
  158. package/Input/SpinnerButton/SpinnerButton.d.ts +19 -0
  159. package/Input/SpinnerButton/SpinnerButton.js +14 -0
  160. package/Input/SpinnerButton/index.d.ts +2 -0
  161. package/Input/SpinnerButton/index.js +1 -0
  162. package/Input/index.d.ts +3 -2
  163. package/Menu/Menu.js +1 -0
  164. package/Menu/index.d.ts +8 -4
  165. package/Message/Message.d.ts +6 -4
  166. package/Message/Message.js +86 -9
  167. package/Message/MessageTimerController.d.ts +14 -0
  168. package/Message/MessageTimerController.js +27 -0
  169. package/Message/index.d.ts +3 -2
  170. package/Modal/Modal.js +2 -2
  171. package/Modal/ModalActions.js +1 -0
  172. package/Modal/ModalControl.js +1 -0
  173. package/Modal/ModalHeader.js +1 -0
  174. package/Modal/index.d.ts +10 -5
  175. package/Modal/useModalContainer.d.ts +1 -1
  176. package/Modal/useModalContainer.js +2 -4
  177. package/Navigation/Navigation.js +37 -34
  178. package/Navigation/NavigationContext.js +1 -0
  179. package/Navigation/NavigationItem.js +1 -0
  180. package/Navigation/NavigationSubMenu.js +16 -26
  181. package/Navigation/index.d.ts +8 -4
  182. package/Notification/Notification.js +0 -1
  183. package/Notification/index.d.ts +3 -2
  184. package/Notifier/NotifierManager.d.ts +15 -2
  185. package/Notifier/NotifierManager.js +60 -18
  186. package/Notifier/createNotifier.d.ts +9 -0
  187. package/Notifier/createNotifier.js +3 -2
  188. package/Notifier/typings.d.ts +3 -1
  189. package/OverflowTooltip/OverflowCounterTag.d.ts +12 -0
  190. package/OverflowTooltip/OverflowCounterTag.js +48 -0
  191. package/OverflowTooltip/OverflowTooltip.d.ts +34 -0
  192. package/OverflowTooltip/OverflowTooltip.js +53 -0
  193. package/OverflowTooltip/index.d.ts +2 -0
  194. package/OverflowTooltip/index.js +2 -0
  195. package/PageFooter/PageFooter.d.ts +73 -8
  196. package/PageFooter/PageFooter.js +34 -3
  197. package/PageFooter/index.d.ts +2 -1
  198. package/PageHeader/PageHeader.d.ts +40 -0
  199. package/PageHeader/PageHeader.js +70 -0
  200. package/PageHeader/index.d.ts +2 -0
  201. package/PageHeader/index.js +1 -0
  202. package/PageToolbar/PageToolbar.d.ts +114 -0
  203. package/PageToolbar/PageToolbar.js +23 -0
  204. package/PageToolbar/index.d.ts +2 -0
  205. package/PageToolbar/index.js +1 -0
  206. package/PageToolbar/utils.d.ts +23 -0
  207. package/PageToolbar/utils.js +165 -0
  208. package/Pagination/Pagination.d.ts +23 -29
  209. package/Pagination/Pagination.js +3 -4
  210. package/Pagination/PaginationItem.d.ts +1 -1
  211. package/Pagination/PaginationItem.js +4 -3
  212. package/Pagination/PaginationJumper.d.ts +7 -9
  213. package/Pagination/PaginationJumper.js +3 -5
  214. package/Pagination/PaginationPageSize.d.ts +8 -11
  215. package/Pagination/PaginationPageSize.js +5 -4
  216. package/Pagination/index.d.ts +8 -4
  217. package/Pagination/usePagination.d.ts +3 -1
  218. package/Pagination/usePagination.js +12 -21
  219. package/Picker/FormattedInput.d.ts +17 -0
  220. package/Picker/FormattedInput.js +74 -0
  221. package/Picker/MaskFormat.d.ts +39 -0
  222. package/Picker/MaskFormat.js +94 -0
  223. package/Picker/PickerTrigger.d.ts +13 -3
  224. package/Picker/PickerTrigger.js +17 -2
  225. package/Picker/PickerTriggerWithSeparator.d.ts +124 -0
  226. package/Picker/PickerTriggerWithSeparator.js +80 -0
  227. package/Picker/RangePickerTrigger.d.ts +55 -4
  228. package/Picker/RangePickerTrigger.js +65 -7
  229. package/Picker/formatUtils.d.ts +34 -0
  230. package/Picker/formatUtils.js +124 -0
  231. package/Picker/index.d.ts +17 -6
  232. package/Picker/index.js +4 -1
  233. package/Picker/useDateInputFormatter.d.ts +52 -0
  234. package/Picker/useDateInputFormatter.js +382 -0
  235. package/Picker/usePickerValue.d.ts +1 -2
  236. package/Picker/usePickerValue.js +8 -13
  237. package/Popconfirm/Popconfirm.js +1 -1
  238. package/Popconfirm/index.d.ts +2 -1
  239. package/Popover/Popover.js +4 -8
  240. package/Popover/index.d.ts +2 -1
  241. package/Popper/Popper.d.ts +15 -10
  242. package/Popper/Popper.js +88 -17
  243. package/Popper/index.d.ts +2 -1
  244. package/Portal/Portal.d.ts +13 -5
  245. package/Portal/Portal.js +25 -10
  246. package/Portal/index.d.ts +4 -1
  247. package/Portal/index.js +1 -0
  248. package/Portal/portalRegistry.d.ts +17 -0
  249. package/Portal/portalRegistry.js +92 -0
  250. package/Progress/Progress.d.ts +23 -30
  251. package/Progress/Progress.js +71 -21
  252. package/Progress/index.d.ts +3 -2
  253. package/Provider/ConfigProvider.d.ts +1 -0
  254. package/Provider/ConfigProvider.js +1 -0
  255. package/Provider/context.js +1 -0
  256. package/Radio/Radio.d.ts +37 -4
  257. package/Radio/Radio.js +23 -12
  258. package/Radio/RadioGroup.d.ts +37 -8
  259. package/Radio/RadioGroup.js +6 -5
  260. package/Radio/RadioGroupContext.d.ts +2 -1
  261. package/Radio/RadioGroupContext.js +1 -0
  262. package/Radio/index.d.ts +5 -3
  263. package/ResultState/ResultState.d.ts +52 -0
  264. package/ResultState/ResultState.js +24 -0
  265. package/ResultState/index.d.ts +2 -0
  266. package/ResultState/index.js +1 -0
  267. package/Select/AutoComplete.d.ts +1 -1
  268. package/Select/AutoComplete.js +2 -1
  269. package/Select/Option.js +1 -0
  270. package/Select/Select.d.ts +1 -1
  271. package/Select/Select.js +2 -1
  272. package/Select/SelectControlContext.js +1 -0
  273. package/Select/SelectTrigger.d.ts +1 -87
  274. package/Select/SelectTrigger.js +26 -21
  275. package/Select/SelectTriggerTags.d.ts +1 -1
  276. package/Select/SelectTriggerTags.js +47 -18
  277. package/Select/TreeSelect.d.ts +1 -1
  278. package/Select/TreeSelect.js +2 -1
  279. package/Select/index.d.ts +14 -7
  280. package/Select/typings.d.ts +99 -0
  281. package/Select/useSelectTriggerTags.d.ts +15 -8
  282. package/Select/useSelectTriggerTags.js +83 -44
  283. package/Selection/Selection.d.ts +98 -0
  284. package/Selection/Selection.js +46 -0
  285. package/Selection/index.d.ts +12 -0
  286. package/Selection/index.js +5 -0
  287. package/Skeleton/Skeleton.d.ts +10 -3
  288. package/Skeleton/Skeleton.js +12 -4
  289. package/Skeleton/index.d.ts +2 -1
  290. package/Slider/Slider.d.ts +44 -7
  291. package/Slider/Slider.js +17 -13
  292. package/Slider/index.d.ts +5 -3
  293. package/Spin/Spin.d.ts +39 -0
  294. package/{Loading/Loading.js → Spin/Spin.js} +9 -9
  295. package/Spin/index.d.ts +2 -0
  296. package/Spin/index.js +1 -0
  297. package/Stepper/Step.d.ts +1 -35
  298. package/Stepper/Step.js +43 -8
  299. package/Stepper/Stepper.d.ts +1 -14
  300. package/Stepper/Stepper.js +49 -15
  301. package/Stepper/index.d.ts +5 -2
  302. package/Stepper/index.js +1 -0
  303. package/Stepper/typings.d.ts +77 -0
  304. package/Stepper/useStepDistance.d.ts +10 -0
  305. package/Stepper/useStepDistance.js +81 -0
  306. package/Stepper/useStepper.d.ts +21 -0
  307. package/Stepper/useStepper.js +26 -0
  308. package/Tab/Tab.d.ts +32 -0
  309. package/Tab/Tab.js +57 -0
  310. package/Tab/TabItem.d.ts +27 -0
  311. package/Tab/TabItem.js +18 -0
  312. package/Tab/index.d.ts +4 -0
  313. package/Tab/index.js +2 -0
  314. package/Table/Table.d.ts +75 -94
  315. package/Table/Table.js +216 -161
  316. package/Table/TableContext.d.ts +114 -51
  317. package/Table/TableContext.js +22 -3
  318. package/Table/components/TableBody.d.ts +5 -0
  319. package/Table/components/TableBody.js +102 -0
  320. package/Table/components/TableCell.d.ts +17 -0
  321. package/Table/components/TableCell.js +74 -0
  322. package/Table/components/TableColGroup.d.ts +4 -0
  323. package/Table/components/TableColGroup.js +206 -0
  324. package/Table/components/TableDragHandleCell.d.ts +9 -0
  325. package/Table/components/TableDragHandleCell.js +37 -0
  326. package/Table/components/TableExpandCell.d.ts +11 -0
  327. package/Table/components/TableExpandCell.js +44 -0
  328. package/Table/components/TableExpandedRow.d.ts +9 -0
  329. package/Table/components/TableExpandedRow.js +46 -0
  330. package/Table/components/TableHeader.d.ts +4 -0
  331. package/Table/components/TableHeader.js +125 -0
  332. package/Table/components/TablePagination.d.ts +3 -0
  333. package/Table/components/TablePagination.js +11 -0
  334. package/Table/components/TableResizeHandle.d.ts +13 -0
  335. package/Table/components/TableResizeHandle.js +115 -0
  336. package/Table/components/TableRow.d.ts +12 -0
  337. package/Table/components/TableRow.js +126 -0
  338. package/Table/components/TableSelectionCell.d.ts +13 -0
  339. package/Table/components/TableSelectionCell.js +35 -0
  340. package/Table/components/index.d.ts +10 -0
  341. package/Table/components/index.js +10 -0
  342. package/Table/hooks/index.d.ts +9 -0
  343. package/Table/hooks/index.js +8 -0
  344. package/Table/hooks/typings.d.ts +14 -0
  345. package/Table/hooks/useTableColumns.d.ts +8 -0
  346. package/Table/hooks/useTableColumns.js +91 -0
  347. package/Table/hooks/useTableDataSource.d.ts +57 -0
  348. package/Table/hooks/useTableDataSource.js +183 -0
  349. package/Table/hooks/useTableExpansion.d.ts +7 -0
  350. package/Table/hooks/useTableExpansion.js +52 -0
  351. package/Table/hooks/useTableFixedOffsets.d.ts +29 -0
  352. package/Table/hooks/useTableFixedOffsets.js +241 -0
  353. package/Table/hooks/useTableScroll.d.ts +12 -0
  354. package/Table/hooks/useTableScroll.js +58 -0
  355. package/Table/hooks/useTableSelection.d.ts +7 -0
  356. package/Table/hooks/useTableSelection.js +94 -0
  357. package/Table/hooks/useTableSorting.d.ts +6 -0
  358. package/Table/hooks/useTableSorting.js +32 -0
  359. package/Table/hooks/useTableVirtualization.d.ts +22 -0
  360. package/Table/hooks/useTableVirtualization.js +115 -0
  361. package/Table/index.d.ts +7 -7
  362. package/Table/index.js +22 -6
  363. package/Table/utils/index.d.ts +2 -0
  364. package/Table/utils/index.js +1 -0
  365. package/Table/utils/useTableRowSelection.d.ts +18 -0
  366. package/Table/utils/useTableRowSelection.js +63 -0
  367. package/Tag/Tag.d.ts +2 -25
  368. package/Tag/Tag.js +23 -13
  369. package/Tag/TagGroup.d.ts +12 -0
  370. package/Tag/TagGroup.js +41 -0
  371. package/Tag/index.d.ts +2 -1
  372. package/Tag/typings.d.ts +78 -0
  373. package/TextField/TextField.d.ts +78 -19
  374. package/TextField/TextField.js +58 -22
  375. package/TextField/index.d.ts +2 -1
  376. package/Textarea/Textarea.d.ts +19 -51
  377. package/Textarea/Textarea.js +13 -19
  378. package/Textarea/index.d.ts +2 -2
  379. package/TimePanel/TimePanel.d.ts +1 -22
  380. package/TimePanel/TimePanel.js +31 -26
  381. package/TimePanel/TimePanelAction.d.ts +2 -8
  382. package/TimePanel/TimePanelAction.js +2 -2
  383. package/TimePanel/TimePanelColumn.d.ts +0 -13
  384. package/TimePanel/TimePanelColumn.js +9 -11
  385. package/TimePanel/index.d.ts +6 -3
  386. package/TimePicker/TimePicker.d.ts +10 -1
  387. package/TimePicker/TimePicker.js +86 -35
  388. package/TimePicker/TimePickerPanel.d.ts +1 -2
  389. package/TimePicker/TimePickerPanel.js +2 -2
  390. package/TimePicker/index.d.ts +4 -2
  391. package/Toggle/Toggle.d.ts +46 -0
  392. package/Toggle/Toggle.js +29 -0
  393. package/Toggle/index.d.ts +3 -0
  394. package/Toggle/index.js +1 -0
  395. package/Tooltip/Tooltip.d.ts +13 -2
  396. package/Tooltip/Tooltip.js +56 -10
  397. package/Tooltip/index.d.ts +2 -1
  398. package/Tooltip/useDelayMouseEnterLeave.d.ts +1 -2
  399. package/Tooltip/useDelayMouseEnterLeave.js +10 -13
  400. package/Transition/Collapse.d.ts +2 -0
  401. package/Transition/Collapse.js +5 -6
  402. package/Transition/Fade.js +4 -4
  403. package/Transition/Rotate.d.ts +42 -0
  404. package/Transition/Rotate.js +30 -0
  405. package/Transition/Scale.d.ts +13 -0
  406. package/Transition/{Grow.js → Scale.js} +19 -16
  407. package/Transition/Slide.d.ts +7 -0
  408. package/Transition/{Zoom.js → Slide.js} +14 -12
  409. package/Transition/SlideFade.d.ts +3 -0
  410. package/Transition/SlideFade.js +5 -4
  411. package/Transition/Transition.d.ts +2 -2
  412. package/Transition/Translate.d.ts +14 -0
  413. package/Transition/Translate.js +94 -0
  414. package/Transition/index.d.ts +16 -6
  415. package/Transition/index.js +4 -2
  416. package/Transition/useAutoTransitionDuration.d.ts +1 -1
  417. package/Transition/useAutoTransitionDuration.js +3 -3
  418. package/Transition/useSetNodeTransition.js +0 -2
  419. package/Tree/TreeNode.js +7 -6
  420. package/Tree/index.d.ts +10 -5
  421. package/Typography/Typography.d.ts +6 -9
  422. package/Typography/Typography.js +7 -9
  423. package/Typography/index.d.ts +2 -5
  424. package/Upload/Upload.d.ts +175 -0
  425. package/Upload/Upload.js +279 -0
  426. package/Upload/UploadItem.d.ts +82 -0
  427. package/Upload/UploadItem.js +118 -0
  428. package/Upload/UploadPictureCard.d.ts +110 -0
  429. package/Upload/UploadPictureCard.js +101 -0
  430. package/Upload/Uploader.d.ts +161 -0
  431. package/Upload/Uploader.js +120 -0
  432. package/Upload/index.d.ts +8 -6
  433. package/Upload/index.js +4 -5
  434. package/Upload/upload-utils.d.ts +41 -0
  435. package/Upload/upload-utils.js +65 -0
  436. package/_internal/InputCheck/InputCheck.d.ts +15 -1
  437. package/_internal/InputCheck/InputCheck.js +6 -2
  438. package/_internal/InputCheck/InputCheckGroup.d.ts +11 -1
  439. package/_internal/InputCheck/InputCheckGroup.js +4 -2
  440. package/_internal/InputCheck/index.d.ts +4 -2
  441. package/_internal/InputTriggerPopper/InputTriggerPopper.js +15 -25
  442. package/_internal/InputTriggerPopper/index.d.ts +2 -1
  443. package/_internal/SlideFadeOverlay/SlideFadeOverlay.d.ts +3 -3
  444. package/_internal/SlideFadeOverlay/SlideFadeOverlay.js +5 -28
  445. package/_internal/SlideFadeOverlay/index.d.ts +2 -1
  446. package/_internal/SlideFadeOverlay/useTopStack.js +1 -0
  447. package/dayjs.d.ts +21 -0
  448. package/dayjs.js +2 -0
  449. package/hooks/useComposeRefs.js +1 -1
  450. package/hooks/useLastCallback.js +3 -1
  451. package/hooks/useScrollLock.d.ts +28 -0
  452. package/hooks/useScrollLock.js +134 -0
  453. package/index.d.ts +128 -58
  454. package/index.js +90 -80
  455. package/luxon.d.ts +21 -0
  456. package/luxon.js +2 -0
  457. package/moment.d.ts +21 -0
  458. package/moment.js +2 -0
  459. package/package.json +14 -17
  460. package/utils/composeRefs.js +0 -1
  461. package/utils/flatten-children.d.ts +12 -0
  462. package/utils/flatten-children.js +37 -0
  463. package/utils/get-css-variable-value.d.ts +2 -0
  464. package/utils/get-css-variable-value.js +12 -0
  465. package/Button/IconButton.d.ts +0 -21
  466. package/Button/IconButton.js +0 -13
  467. package/DateTimePicker/DateTimePickerPanel.d.ts +0 -28
  468. package/DateTimePicker/DateTimePickerPanel.js +0 -49
  469. package/Form/FormMessage.d.ts +0 -7
  470. package/Form/FormMessage.js +0 -18
  471. package/Form/useInputWithTagsModeValue.js +0 -86
  472. package/Loading/Loading.d.ts +0 -33
  473. package/Loading/index.d.ts +0 -1
  474. package/Loading/index.js +0 -1
  475. package/Overlay/Overlay.js +0 -31
  476. package/Overlay/index.d.ts +0 -1
  477. package/Overlay/index.js +0 -1
  478. package/Picker/useRangePickerValue.d.ts +0 -23
  479. package/Picker/useRangePickerValue.js +0 -99
  480. package/Switch/Switch.d.ts +0 -43
  481. package/Switch/Switch.js +0 -28
  482. package/Switch/index.d.ts +0 -2
  483. package/Switch/index.js +0 -1
  484. package/Table/TableBody.d.ts +0 -10
  485. package/Table/TableBody.js +0 -30
  486. package/Table/TableBodyRow.d.ts +0 -11
  487. package/Table/TableBodyRow.js +0 -64
  488. package/Table/TableCell.d.ts +0 -19
  489. package/Table/TableCell.js +0 -24
  490. package/Table/TableExpandedTable.d.ts +0 -11
  491. package/Table/TableExpandedTable.js +0 -28
  492. package/Table/TableHeader.d.ts +0 -3
  493. package/Table/TableHeader.js +0 -35
  494. package/Table/draggable/useTableDraggable.d.ts +0 -14
  495. package/Table/draggable/useTableDraggable.js +0 -64
  496. package/Table/editable/TableEditRenderWrapper.d.ts +0 -7
  497. package/Table/editable/TableEditRenderWrapper.js +0 -15
  498. package/Table/expandable/TableExpandable.d.ts +0 -27
  499. package/Table/expandable/TableExpandable.js +0 -24
  500. package/Table/pagination/TablePagination.d.ts +0 -10
  501. package/Table/pagination/TablePagination.js +0 -25
  502. package/Table/pagination/useTablePagination.d.ts +0 -8
  503. package/Table/pagination/useTablePagination.js +0 -29
  504. package/Table/refresh/TableRefresh.d.ts +0 -10
  505. package/Table/refresh/TableRefresh.js +0 -20
  506. package/Table/rowSelection/TableRowSelection.d.ts +0 -18
  507. package/Table/rowSelection/TableRowSelection.js +0 -92
  508. package/Table/rowSelection/useTableRowSelection.d.ts +0 -6
  509. package/Table/rowSelection/useTableRowSelection.js +0 -53
  510. package/Table/sorting/TableSortingIcon.d.ts +0 -10
  511. package/Table/sorting/TableSortingIcon.js +0 -32
  512. package/Table/sorting/useTableSorting.d.ts +0 -11
  513. package/Table/sorting/useTableSorting.js +0 -120
  514. package/Table/useTableFetchMore.d.ts +0 -10
  515. package/Table/useTableFetchMore.js +0 -50
  516. package/Table/useTableLoading.d.ts +0 -5
  517. package/Table/useTableLoading.js +0 -19
  518. package/Table/useTableScroll.d.ts +0 -596
  519. package/Table/useTableScroll.js +0 -294
  520. package/Tabs/Tab.d.ts +0 -18
  521. package/Tabs/Tab.js +0 -16
  522. package/Tabs/TabPane.d.ts +0 -14
  523. package/Tabs/TabPane.js +0 -18
  524. package/Tabs/Tabs.d.ts +0 -39
  525. package/Tabs/Tabs.js +0 -47
  526. package/Tabs/index.d.ts +0 -3
  527. package/Tabs/index.js +0 -3
  528. package/Tabs/useTabsOverflow.d.ts +0 -8
  529. package/Tabs/useTabsOverflow.js +0 -61
  530. package/Transition/Grow.d.ts +0 -12
  531. package/Transition/Zoom.d.ts +0 -7
  532. package/Upload/UploadButton.d.ts +0 -9
  533. package/Upload/UploadButton.js +0 -23
  534. package/Upload/UploadInput.d.ts +0 -20
  535. package/Upload/UploadInput.js +0 -24
  536. package/Upload/UploadPicture.d.ts +0 -49
  537. package/Upload/UploadPicture.js +0 -51
  538. package/Upload/UploadPictureBlock.d.ts +0 -20
  539. package/Upload/UploadPictureBlock.js +0 -81
  540. package/Upload/UploadPictureWall.d.ts +0 -81
  541. package/Upload/UploadPictureWall.js +0 -168
  542. package/Upload/UploadPictureWallItem.d.ts +0 -15
  543. package/Upload/UploadPictureWallItem.js +0 -18
  544. package/Upload/UploadResult.d.ts +0 -35
  545. package/Upload/UploadResult.js +0 -29
  546. package/utils/scroll-lock.d.ts +0 -2
  547. package/utils/scroll-lock.js +0 -24
@@ -1,5 +1,6 @@
1
+ 'use client';
1
2
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
- import { getYearRange, calendarYearModuler, calendarClasses } from '@mezzanine-ui/core/calendar';
3
+ import { getYearRange, calendarYearModuler, calendarQuarterYearsCount, calendarHalfYearYearsCount, calendarClasses } from '@mezzanine-ui/core/calendar';
3
4
  import castArray from 'lodash/castArray';
4
5
  import { forwardRef } from 'react';
5
6
  import { useCalendarContext } from './CalendarContext.js';
@@ -8,6 +9,10 @@ import CalendarDays from './CalendarDays.js';
8
9
  import CalendarMonths from './CalendarMonths.js';
9
10
  import CalendarWeeks from './CalendarWeeks.js';
10
11
  import CalendarYears from './CalendarYears.js';
12
+ import CalendarQuarters from './CalendarQuarters.js';
13
+ import CalendarHalfYears from './CalendarHalfYears.js';
14
+ import CalendarFooterControl from './CalendarFooterControl.js';
15
+ import CalendarQuickSelect from './CalendarQuickSelect.js';
11
16
  import cx from 'clsx';
12
17
 
13
18
  /**
@@ -16,45 +21,95 @@ import cx from 'clsx';
16
21
  * You may use the handlers provided by `useCalendarControls` hook or your own customizd methods.
17
22
  */
18
23
  const Calendar = forwardRef(function Calendar(props, ref) {
19
- const { displayMonthLocale: displayMonthLocaleFromConfig, getMonth, getMonthShortName, getYear, } = useCalendarContext();
20
- const { calendarDaysProps, calendarMonthsProps, calendarWeeksProps, calendarYearsProps, className, disabledMonthSwitch, disableOnNext, disableOnPrev, disabledYearSwitch, displayMonthLocale = displayMonthLocaleFromConfig, displayWeekDayLocale, isDateDisabled, isDateInRange, isMonthDisabled, isMonthInRange, isWeekDisabled, isWeekInRange, isYearDisabled, isYearInRange, mode = 'day', onChange, onDateHover, onMonthControlClick, onMonthHover, onNext, onPrev, onWeekHover, onYearControlClick, onYearHover, referenceDate, value: valueProp, ...restCalendarProps } = props;
24
+ const { locale, getNow, getMonth, getMonthShortName, getYear, getCurrentWeekFirstDate, getCurrentMonthFirstDate, getCurrentYearFirstDate, getCurrentQuarterFirstDate, getCurrentHalfYearFirstDate, setHour, setMinute, setSecond, setMillisecond, } = useCalendarContext();
25
+ const { renderAnnotations, calendarDaysProps, calendarMonthsProps, calendarWeeksProps, calendarYearsProps, calendarQuartersProps, calendarHalfYearsProps, className, disabledFooterControl = false, disabledMonthSwitch, disableOnNext, disableOnPrev, disableOnDoubleNext, disableOnDoublePrev, disabledYearSwitch, displayMonthLocale = locale, displayWeekDayLocale = locale, isDateDisabled, isDateInRange, isMonthDisabled, isMonthInRange, isWeekDisabled, isWeekInRange, isYearDisabled, isYearInRange, isQuarterDisabled, isQuarterInRange, isHalfYearDisabled, isHalfYearInRange, mode = 'day', onChange, onDateHover, onMonthControlClick, onMonthHover, onNext, onDoubleNext, onPrev, onDoublePrev, onWeekHover, onYearControlClick, onYearHover, onQuarterHover, onHalfYearHover, quickSelect, referenceDate, value: valueProp, ...restCalendarProps } = props;
21
26
  const value = valueProp ? castArray(valueProp) : undefined;
22
27
  /** Compute which calendar to use */
23
28
  let displayCalendar;
29
+ let displayFooterControl;
24
30
  if (mode === 'day') {
25
- displayCalendar = (jsx(CalendarDays, { ...calendarDaysProps, isYearDisabled: isYearDisabled, isMonthDisabled: isMonthDisabled, isDateDisabled: isDateDisabled, isDateInRange: isDateInRange, onClick: onChange, onDateHover: onDateHover, referenceDate: referenceDate, displayWeekDayLocale: displayWeekDayLocale, value: value }));
31
+ displayCalendar = (jsx(CalendarDays, { ...calendarDaysProps, renderAnnotations: renderAnnotations, isYearDisabled: isYearDisabled, isMonthDisabled: isMonthDisabled, isDateDisabled: isDateDisabled, isDateInRange: isDateInRange, onClick: onChange, onDateHover: onDateHover, referenceDate: referenceDate, displayWeekDayLocale: displayWeekDayLocale, value: value }));
32
+ if (!disabledFooterControl) {
33
+ displayFooterControl = (jsx(CalendarFooterControl, { onClick: () => onChange === null || onChange === void 0 ? void 0 : onChange(setMillisecond(setSecond(setMinute(setHour(getNow(), 0), 0), 0), 0)), children: "Today" }));
34
+ }
26
35
  }
27
36
  else if (mode === 'week') {
28
37
  displayCalendar = (jsx(CalendarWeeks, { ...calendarWeeksProps, isYearDisabled: isYearDisabled, isMonthDisabled: isMonthDisabled, isWeekDisabled: isWeekDisabled, isWeekInRange: isWeekInRange, onClick: onChange, onWeekHover: onWeekHover, referenceDate: referenceDate, displayWeekDayLocale: displayWeekDayLocale, value: value }));
38
+ if (!disabledFooterControl) {
39
+ displayFooterControl = (jsx(CalendarFooterControl, { onClick: () => onChange === null || onChange === void 0 ? void 0 : onChange(getCurrentWeekFirstDate(getNow(), displayWeekDayLocale)), children: "This week" }));
40
+ }
29
41
  }
30
42
  else if (mode === 'month') {
31
43
  displayCalendar = (jsx(CalendarMonths, { ...calendarMonthsProps, isYearDisabled: isYearDisabled, isMonthDisabled: isMonthDisabled, isMonthInRange: isMonthInRange, onClick: onChange, onMonthHover: onMonthHover, referenceDate: referenceDate, value: value }));
44
+ if (!disabledFooterControl) {
45
+ displayFooterControl = (jsx(CalendarFooterControl, { onClick: () => onChange === null || onChange === void 0 ? void 0 : onChange(getCurrentMonthFirstDate(getNow())), children: "This month" }));
46
+ }
32
47
  }
33
48
  else if (mode === 'year') {
34
49
  displayCalendar = (jsx(CalendarYears, { ...calendarYearsProps, isYearDisabled: isYearDisabled, isYearInRange: isYearInRange, onClick: onChange, onYearHover: onYearHover, referenceDate: referenceDate, value: value }));
50
+ if (!disabledFooterControl) {
51
+ displayFooterControl = (jsx(CalendarFooterControl, { onClick: () => onChange === null || onChange === void 0 ? void 0 : onChange(getCurrentYearFirstDate(getNow())), children: "This year" }));
52
+ }
53
+ }
54
+ else if (mode === 'quarter') {
55
+ displayCalendar = (jsx(CalendarQuarters, { ...calendarQuartersProps, isQuarterDisabled: isQuarterDisabled, isQuarterInRange: isQuarterInRange, onClick: onChange, onQuarterHover: onQuarterHover, referenceDate: referenceDate, value: value }));
56
+ if (!disabledFooterControl) {
57
+ displayFooterControl = (jsx(CalendarFooterControl, { onClick: () => onChange === null || onChange === void 0 ? void 0 : onChange(getCurrentQuarterFirstDate(getNow())), children: "This quarter" }));
58
+ }
59
+ }
60
+ else if (mode === 'half-year') {
61
+ displayCalendar = (jsx(CalendarHalfYears, { ...calendarHalfYearsProps, isHalfYearDisabled: isHalfYearDisabled, isHalfYearInRange: isHalfYearInRange, onClick: onChange, onHalfYearHover: onHalfYearHover, referenceDate: referenceDate, value: value }));
62
+ if (!disabledFooterControl) {
63
+ displayFooterControl = (jsx(CalendarFooterControl, { onClick: () => onChange === null || onChange === void 0 ? void 0 : onChange(getCurrentHalfYearFirstDate(getNow())), children: "This half year" }));
64
+ }
35
65
  }
36
66
  /** Compute controls outcome */
37
- const [start, end] = getYearRange(getYear(referenceDate), calendarYearModuler);
38
- const displayYearRange = `${start} - ${end}`;
39
67
  let controls;
40
68
  if (mode === 'day' || mode === 'week') {
41
- controls = (jsxs(Fragment, { children: [jsx("button", { type: "button", className: cx(calendarClasses.button, calendarClasses.controlsButton, disabledMonthSwitch && calendarClasses.buttonDisabled), disabled: disabledMonthSwitch, "aria-disabled": disabledMonthSwitch, onClick: onMonthControlClick, children: getMonthShortName(getMonth(referenceDate), displayMonthLocale) }), jsx("button", { type: "button", className: cx(calendarClasses.button, calendarClasses.controlsButton, disabledYearSwitch && calendarClasses.buttonDisabled), disabled: disabledYearSwitch, "aria-disabled": disabledYearSwitch, onClick: onYearControlClick, children: getYear(referenceDate) })] }));
69
+ const displayMonth = getMonthShortName(getMonth(referenceDate), displayMonthLocale);
70
+ const displayYear = getYear(referenceDate);
71
+ controls = (jsxs(Fragment, { children: [jsx("button", { type: "button", disabled: disabledMonthSwitch, "aria-disabled": disabledMonthSwitch, "aria-label": `Select month, currently ${displayMonth}`, onClick: onMonthControlClick, children: displayMonth }), jsx("button", { type: "button", disabled: disabledYearSwitch, "aria-disabled": disabledYearSwitch, "aria-label": `Select year, currently ${displayYear}`, onClick: onYearControlClick, children: displayYear })] }));
42
72
  }
43
73
  else if (mode === 'month') {
44
- controls = (jsx("button", { type: "button", className: cx(calendarClasses.button, calendarClasses.controlsButton, disabledYearSwitch && calendarClasses.buttonDisabled), disabled: disabledYearSwitch, "aria-disabled": disabledYearSwitch, onClick: onYearControlClick, children: getYear(referenceDate) }));
74
+ const displayYear = getYear(referenceDate);
75
+ controls = (jsx("button", { type: "button", disabled: disabledYearSwitch, "aria-disabled": disabledYearSwitch, "aria-label": `Select year, currently ${displayYear}`, onClick: onYearControlClick, children: displayYear }));
45
76
  }
46
77
  else if (mode === 'year') {
47
- controls = (jsx("button", { type: "button", className: cx(calendarClasses.button, calendarClasses.controlsButton, calendarClasses.buttonDisabled), disabled: true, "aria-disabled": true, children: displayYearRange }));
48
- }
49
- return (jsxs("div", { ...restCalendarProps, ref: ref, className: cx(calendarClasses.host, className), children: [jsx(CalendarControls, { disableOnNext: disableOnNext, disableOnPrev: disableOnPrev, onNext: onNext
50
- ? () => {
51
- onNext(mode);
52
- }
53
- : undefined, onPrev: onPrev
54
- ? () => {
55
- onPrev(mode);
56
- }
57
- : undefined, children: controls }), displayCalendar] }));
78
+ const [start, end] = getYearRange(getYear(referenceDate), calendarYearModuler);
79
+ const displayYearRange = `${start} - ${end}`;
80
+ controls = (jsx("button", { type: "button", disabled: true, "aria-disabled": true, "aria-label": `Year range ${displayYearRange}`, children: displayYearRange }));
81
+ }
82
+ else if (mode === 'quarter') {
83
+ const [start, end] = getYearRange(getYear(referenceDate), calendarQuarterYearsCount);
84
+ const displayQuarterYearRange = `${start} - ${end}`;
85
+ controls = (jsx("button", { type: "button", disabled: true, "aria-disabled": true, "aria-label": `Quarter year range ${displayQuarterYearRange}`, children: displayQuarterYearRange }));
86
+ }
87
+ else if (mode === 'half-year') {
88
+ const [start, end] = getYearRange(getYear(referenceDate), calendarHalfYearYearsCount);
89
+ const displayHalfYearYearRange = `${start} - ${end}`;
90
+ controls = (jsx("button", { type: "button", disabled: true, "aria-disabled": true, "aria-label": `Half-year range ${displayHalfYearYearRange}`, children: displayHalfYearYearRange }));
91
+ }
92
+ return (jsxs("div", { ...restCalendarProps, ref: ref, role: "application", "aria-label": `Calendar, ${mode} view`, className: cx(calendarClasses.host, calendarClasses.mode(mode), className), children: [quickSelect && (jsx(CalendarQuickSelect, { activeId: quickSelect.activeId, options: quickSelect.options })), jsxs("div", { className: calendarClasses.mainWithFooter, children: [jsxs("div", { className: calendarClasses.main, children: [jsx(CalendarControls, { disableOnNext: disableOnNext, disableOnPrev: disableOnPrev, disableOnDoubleNext: disableOnDoubleNext, disableOnDoublePrev: disableOnDoublePrev, onDoubleNext: onDoubleNext
93
+ ? () => {
94
+ onDoubleNext(mode);
95
+ }
96
+ : undefined, onNext:
97
+ // Only day and week modes have single next/prev (for month navigation)
98
+ onNext && (mode === 'day' || mode === 'week')
99
+ ? () => {
100
+ onNext(mode);
101
+ }
102
+ : undefined, onDoublePrev: onDoublePrev
103
+ ? () => {
104
+ onDoublePrev(mode);
105
+ }
106
+ : undefined, onPrev:
107
+ // Only day and week modes have single next/prev (for month navigation)
108
+ onPrev && (mode === 'day' || mode === 'week')
109
+ ? () => {
110
+ onPrev(mode);
111
+ }
112
+ : undefined, children: controls }), displayCalendar] }), displayFooterControl] })] }));
58
113
  });
59
114
 
60
115
  export { Calendar as default };
@@ -12,6 +12,10 @@ export interface CalendarCellProps extends NativeElementPropsWithoutKeyAndRef<'d
12
12
  * Apply today styles if true.
13
13
  */
14
14
  today?: boolean;
15
+ /**
16
+ * The role attribute for accessibility
17
+ */
18
+ role?: string;
15
19
  }
16
20
  /**
17
21
  * The react component for `mezzanine` calendar cell.
@@ -7,11 +7,11 @@ import cx from 'clsx';
7
7
  * You may use it to compose your own calendar.
8
8
  */
9
9
  function CalendarCell(props) {
10
- const { active, children, className, disabled, onClick, today, ...restCalendarCellProps } = props;
11
- return (jsx("div", { className: cx(calendarClasses.cell, {
10
+ const { active, children, className, disabled, today, role, ...restCalendarCellProps } = props;
11
+ return (jsx("div", { role: role, className: cx(calendarClasses.cell, {
12
+ [calendarClasses.cellToday]: today,
12
13
  [calendarClasses.cellActive]: active,
13
14
  [calendarClasses.cellDisabled]: disabled,
14
- [calendarClasses.cellToday]: today,
15
15
  }, className), ...restCalendarCellProps, children: jsx("span", { className: calendarClasses.cellInner, children: children }) }));
16
16
  }
17
17
 
@@ -0,0 +1,21 @@
1
+ import { ReactNode } from 'react';
2
+ import { CalendarLocaleValue } from '@mezzanine-ui/core/calendar';
3
+ export type CalendarConfigProviderDayjsProps = {
4
+ children?: ReactNode;
5
+ defaultDateFormat?: string;
6
+ defaultTimeFormat?: string;
7
+ /**
8
+ * The unified locale for all calendar display and value processing.
9
+ * This determines the first day of week, month names, weekday names, etc.
10
+ * Use CalendarLocale enum for type-safe locale values.
11
+ * @example CalendarLocale.EN_US, CalendarLocale.ZH_TW, CalendarLocale.DE_DE
12
+ * @default CalendarLocale.EN_US
13
+ */
14
+ locale?: CalendarLocaleValue;
15
+ };
16
+ /**
17
+ * Pre-configured CalendarConfigProvider with Dayjs methods.
18
+ * Use this component in Next.js App Router to avoid Server/Client Component boundary issues.
19
+ */
20
+ export declare function CalendarConfigProviderDayjs(props: CalendarConfigProviderDayjsProps): import("react/jsx-runtime").JSX.Element;
21
+ export default CalendarConfigProviderDayjs;
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import CalendarMethodsDayjs from '@mezzanine-ui/core/calendarMethodsDayjs';
4
+ import CalendarConfigProvider from './CalendarContext.js';
5
+
6
+ /**
7
+ * Pre-configured CalendarConfigProvider with Dayjs methods.
8
+ * Use this component in Next.js App Router to avoid Server/Client Component boundary issues.
9
+ */
10
+ function CalendarConfigProviderDayjs(props) {
11
+ const { children, defaultDateFormat, defaultTimeFormat, locale } = props;
12
+ return (jsx(CalendarConfigProvider, { defaultDateFormat: defaultDateFormat, defaultTimeFormat: defaultTimeFormat, locale: locale, methods: CalendarMethodsDayjs, children: children }));
13
+ }
14
+
15
+ export { CalendarConfigProviderDayjs, CalendarConfigProviderDayjs as default };
@@ -0,0 +1,21 @@
1
+ import { ReactNode } from 'react';
2
+ import { CalendarLocaleValue } from '@mezzanine-ui/core/calendar';
3
+ export type CalendarConfigProviderLuxonProps = {
4
+ children?: ReactNode;
5
+ defaultDateFormat?: string;
6
+ defaultTimeFormat?: string;
7
+ /**
8
+ * The unified locale for all calendar display and value processing.
9
+ * This determines the first day of week, month names, weekday names, etc.
10
+ * Use CalendarLocale enum for type-safe locale values.
11
+ * @example CalendarLocale.EN_US, CalendarLocale.ZH_TW, CalendarLocale.DE_DE
12
+ * @default CalendarLocale.EN_US
13
+ */
14
+ locale?: CalendarLocaleValue;
15
+ };
16
+ /**
17
+ * Pre-configured CalendarConfigProvider with Luxon methods.
18
+ * Use this component in Next.js App Router to avoid Server/Client Component boundary issues.
19
+ */
20
+ export declare function CalendarConfigProviderLuxon(props: CalendarConfigProviderLuxonProps): import("react/jsx-runtime").JSX.Element;
21
+ export default CalendarConfigProviderLuxon;
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import CalendarMethodsLuxon from '@mezzanine-ui/core/calendarMethodsLuxon';
4
+ import CalendarConfigProvider from './CalendarContext.js';
5
+
6
+ /**
7
+ * Pre-configured CalendarConfigProvider with Luxon methods.
8
+ * Use this component in Next.js App Router to avoid Server/Client Component boundary issues.
9
+ */
10
+ function CalendarConfigProviderLuxon(props) {
11
+ const { children, defaultDateFormat, defaultTimeFormat, locale } = props;
12
+ return (jsx(CalendarConfigProvider, { defaultDateFormat: defaultDateFormat, defaultTimeFormat: defaultTimeFormat, locale: locale, methods: CalendarMethodsLuxon, children: children }));
13
+ }
14
+
15
+ export { CalendarConfigProviderLuxon, CalendarConfigProviderLuxon as default };
@@ -0,0 +1,21 @@
1
+ import { ReactNode } from 'react';
2
+ import { CalendarLocaleValue } from '@mezzanine-ui/core/calendar';
3
+ export type CalendarConfigProviderMomentProps = {
4
+ children?: ReactNode;
5
+ defaultDateFormat?: string;
6
+ defaultTimeFormat?: string;
7
+ /**
8
+ * The unified locale for all calendar display and value processing.
9
+ * This determines the first day of week, month names, weekday names, etc.
10
+ * Use CalendarLocale enum for type-safe locale values.
11
+ * @example CalendarLocale.EN_US, CalendarLocale.ZH_TW, CalendarLocale.DE_DE
12
+ * @default CalendarLocale.EN_US
13
+ */
14
+ locale?: CalendarLocaleValue;
15
+ };
16
+ /**
17
+ * Pre-configured CalendarConfigProvider with Moment methods.
18
+ * Use this component in Next.js App Router to avoid Server/Client Component boundary issues.
19
+ */
20
+ export declare function CalendarConfigProviderMoment(props: CalendarConfigProviderMomentProps): import("react/jsx-runtime").JSX.Element;
21
+ export default CalendarConfigProviderMoment;
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import CalendarMethodsMoment from '@mezzanine-ui/core/calendarMethodsMoment';
4
+ import CalendarConfigProvider from './CalendarContext.js';
5
+
6
+ /**
7
+ * Pre-configured CalendarConfigProvider with Moment methods.
8
+ * Use this component in Next.js App Router to avoid Server/Client Component boundary issues.
9
+ */
10
+ function CalendarConfigProviderMoment(props) {
11
+ const { children, defaultDateFormat, defaultTimeFormat, locale } = props;
12
+ return (jsx(CalendarConfigProvider, { defaultDateFormat: defaultDateFormat, defaultTimeFormat: defaultTimeFormat, locale: locale, methods: CalendarMethodsMoment, children: children }));
13
+ }
14
+
15
+ export { CalendarConfigProviderMoment, CalendarConfigProviderMoment as default };
@@ -1,21 +1,28 @@
1
1
  import { ReactNode } from 'react';
2
- import { CalendarMethods } from '@mezzanine-ui/core/calendar';
2
+ import { CalendarLocale, CalendarLocaleValue, CalendarMethods } from '@mezzanine-ui/core/calendar';
3
3
  export interface CalendarConfigs extends CalendarMethods {
4
4
  defaultDateFormat: string;
5
5
  defaultTimeFormat: string;
6
- displayMonthLocale: string;
7
- displayWeekDayLocale: string;
8
- valueLocale: string;
6
+ /**
7
+ * The unified locale for all calendar display and value processing.
8
+ */
9
+ locale: string;
9
10
  }
10
11
  export type CalendarConfigProviderProps = {
11
12
  children?: ReactNode;
12
13
  defaultDateFormat?: string;
13
14
  defaultTimeFormat?: string;
14
- displayMonthLocale?: string;
15
- displayWeekDayLocale?: string;
15
+ /**
16
+ * The unified locale for all calendar display and value processing.
17
+ * This determines the first day of week, month names, weekday names, etc.
18
+ * Use CalendarLocale enum for type-safe locale values.
19
+ * @example CalendarLocale.EN_US, CalendarLocale.ZH_TW, CalendarLocale.DE_DE
20
+ * @default CalendarLocale.EN_US
21
+ */
22
+ locale?: CalendarLocaleValue;
16
23
  methods: CalendarMethods;
17
- valueLocale?: string;
18
24
  };
25
+ export { CalendarLocale };
19
26
  export declare const CalendarContext: import("react").Context<CalendarConfigs | undefined>;
20
27
  export declare function useCalendarContext(): CalendarConfigs;
21
28
  declare function CalendarConfigProvider(props: CalendarConfigProviderProps): import("react/jsx-runtime").JSX.Element;
@@ -1,5 +1,8 @@
1
+ 'use client';
1
2
  import { jsx } from 'react/jsx-runtime';
2
- import { createContext, useContext, useMemo } from 'react';
3
+ import { createContext, useMemo, useContext } from 'react';
4
+ import { CalendarLocale, normalizeLocale } from '@mezzanine-ui/core/calendar';
5
+ export { CalendarLocale } from '@mezzanine-ui/core/calendar';
3
6
 
4
7
  const CalendarContext = createContext(undefined);
5
8
  function useCalendarContext() {
@@ -12,22 +15,14 @@ function useCalendarContext() {
12
15
  return configs;
13
16
  }
14
17
  function CalendarConfigProvider(props) {
15
- const { children, defaultDateFormat = 'YYYY-MM-DD', defaultTimeFormat = 'HH:mm:ss', displayMonthLocale = 'en-us', displayWeekDayLocale = 'en-us', methods, valueLocale = 'en-us', } = props;
18
+ const { children, defaultDateFormat = 'YYYY-MM-DD', defaultTimeFormat = 'HH:mm:ss', locale = CalendarLocale.EN_US, methods, } = props;
19
+ const resolvedLocale = normalizeLocale(locale);
16
20
  const context = useMemo(() => ({
17
21
  ...methods,
18
22
  defaultDateFormat,
19
23
  defaultTimeFormat,
20
- displayMonthLocale,
21
- displayWeekDayLocale,
22
- valueLocale,
23
- }), [
24
- methods,
25
- defaultDateFormat,
26
- defaultTimeFormat,
27
- displayMonthLocale,
28
- displayWeekDayLocale,
29
- valueLocale,
30
- ]);
24
+ locale: resolvedLocale,
25
+ }), [methods, defaultDateFormat, defaultTimeFormat, resolvedLocale]);
31
26
  return (jsx(CalendarContext.Provider, { value: context, children: children }));
32
27
  }
33
28
 
@@ -4,18 +4,34 @@ export interface CalendarControlsProps extends Omit<NativeElementPropsWithoutKey
4
4
  * Disable the next controller if true.
5
5
  */
6
6
  disableOnNext?: boolean;
7
+ /**
8
+ * Disable the double next controller if true.
9
+ */
10
+ disableOnDoubleNext?: boolean;
7
11
  /**
8
12
  * Disable the prev controller if true.
9
13
  */
10
14
  disableOnPrev?: boolean;
15
+ /**
16
+ * Disable the double prev controller if true.
17
+ */
18
+ disableOnDoublePrev?: boolean;
11
19
  /**
12
20
  * Click handler for next controller.
13
21
  */
14
22
  onNext?: VoidFunction;
23
+ /**
24
+ * Click handler for double next controller.
25
+ */
26
+ onDoubleNext?: VoidFunction;
15
27
  /**
16
28
  * Click handler for prev controller.
17
29
  */
18
30
  onPrev?: VoidFunction;
31
+ /**
32
+ * Click handler for double prev controller.
33
+ */
34
+ onDoublePrev?: VoidFunction;
19
35
  }
20
36
  /**
21
37
  * The react component for `mezzanine` calendar controls.
@@ -1,6 +1,6 @@
1
1
  import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { calendarClasses } from '@mezzanine-ui/core/calendar';
3
- import { ChevronLeftIcon, ChevronRightIcon } from '@mezzanine-ui/icons';
3
+ import { DoubleChevronLeftIcon, ChevronLeftIcon, ChevronRightIcon, DoubleChevronRightIcon } from '@mezzanine-ui/icons';
4
4
  import Icon from '../Icon/Icon.js';
5
5
  import cx from 'clsx';
6
6
 
@@ -9,12 +9,8 @@ import cx from 'clsx';
9
9
  * You may use it to compose your own calendar.
10
10
  */
11
11
  function CalendarControls(props) {
12
- const { children, className, disableOnNext, disableOnPrev, onNext, onPrev, ...restElementProps } = props;
13
- return (jsxs("div", { ...restElementProps, className: cx(calendarClasses.controls, className), children: [onPrev && (jsx("button", { type: "button", "aria-disabled": disableOnPrev, disabled: disableOnPrev, onClick: onPrev, className: cx(calendarClasses.button, calendarClasses.controlsIconButton, calendarClasses.controlsPrev, {
14
- [calendarClasses.buttonDisabled]: disableOnPrev,
15
- }), children: jsx(Icon, { icon: ChevronLeftIcon }) })), children, onNext && (jsx("button", { type: "button", "aria-disabled": disableOnNext, disabled: disableOnNext, onClick: onNext, className: cx(calendarClasses.button, calendarClasses.controlsIconButton, calendarClasses.controlsNext, {
16
- [calendarClasses.buttonDisabled]: disableOnNext,
17
- }), children: jsx(Icon, { icon: ChevronRightIcon }) }))] }));
12
+ const { children, className, disableOnNext, disableOnDoubleNext, disableOnPrev, disableOnDoublePrev, onPrev, onNext, onDoubleNext, onDoublePrev, ...restElementProps } = props;
13
+ return (jsxs("div", { ...restElementProps, className: cx(calendarClasses.controls, className), children: [jsxs("div", { className: cx(calendarClasses.controlsActions), children: [onDoublePrev && (jsx("button", { type: "button", "aria-disabled": disableOnDoublePrev, disabled: disableOnDoublePrev, onClick: onDoublePrev, "aria-label": "Go to previous year", title: "Previous Year", className: cx(calendarClasses.controlsButton), children: jsx(Icon, { icon: DoubleChevronLeftIcon, "aria-hidden": "true" }) })), onPrev && (jsx("button", { type: "button", "aria-disabled": disableOnPrev, disabled: disableOnPrev, onClick: onPrev, "aria-label": "Go to previous month", title: "Previous Month", className: cx(calendarClasses.controlsButton), children: jsx(Icon, { icon: ChevronLeftIcon, "aria-hidden": "true" }) }))] }), jsx("div", { className: cx(calendarClasses.controlsMain), children: children }), jsxs("div", { className: cx(calendarClasses.controlsActions), children: [onNext && (jsx("button", { type: "button", "aria-disabled": disableOnNext, disabled: disableOnNext, onClick: onNext, "aria-label": "Go to next month", title: "Next Month", className: cx(calendarClasses.controlsButton), children: jsx(Icon, { icon: ChevronRightIcon, "aria-hidden": "true" }) })), onDoubleNext && (jsx("button", { type: "button", "aria-disabled": disableOnDoubleNext, disabled: disableOnDoubleNext, onClick: onDoubleNext, "aria-label": "Go to next year", title: "Next Year", className: cx(calendarClasses.controlsButton), children: jsx(Icon, { icon: DoubleChevronRightIcon, "aria-hidden": "true" }) }))] })] }));
18
14
  }
19
15
 
20
16
  export { CalendarControls as default };
@@ -1,3 +1,4 @@
1
+ 'use client';
1
2
  import { jsx } from 'react/jsx-runtime';
2
3
  import { calendarClasses } from '@mezzanine-ui/core/calendar';
3
4
  import CalendarCell from './CalendarCell.js';
@@ -9,10 +10,10 @@ import cx from 'clsx';
9
10
  * You may use it to compose your own calendar.
10
11
  */
11
12
  function CalendarDayOfWeek(props) {
12
- const { getWeekDayNames, displayWeekDayLocale: displayWeekDayLocaleFromConfig, } = useCalendarContext();
13
- const { displayWeekDayLocale = displayWeekDayLocaleFromConfig, className, ...restRowProps } = props;
13
+ const { getWeekDayNames, locale } = useCalendarContext();
14
+ const { displayWeekDayLocale = locale, className, ...restRowProps } = props;
14
15
  const weekDayNames = getWeekDayNames(displayWeekDayLocale);
15
- return (jsx("div", { className: cx(calendarClasses.row, className), ...restRowProps, children: weekDayNames.map((name) => (jsx(CalendarCell, { children: name }, `CALENDAR_DAY_OF_WEEK/${name}`))) }));
16
+ return (jsx("div", { className: cx(calendarClasses.row, className), role: "row", "aria-label": "Days of the week", ...restRowProps, children: weekDayNames.map((name, idx) => (jsx(CalendarCell, { role: "columnheader", children: name }, `CALENDAR_DAY_OF_WEEK/${name}-${idx}`))) }));
16
17
  }
17
18
 
18
19
  export { CalendarDayOfWeek as default };
@@ -3,6 +3,7 @@ import { NativeElementPropsWithoutKeyAndRef } from '../utils/jsx-types';
3
3
  import { CalendarDayOfWeekProps } from './CalendarDayOfWeek';
4
4
  import type { CalendarYearsProps } from './CalendarYears';
5
5
  import type { CalendarMonthsProps } from './CalendarMonths';
6
+ import { TypographyColor } from '../Typography';
6
7
  export interface CalendarDaysProps extends Pick<CalendarDayOfWeekProps, 'displayWeekDayLocale'>, Pick<CalendarYearsProps, 'isYearDisabled'>, Pick<CalendarMonthsProps, 'isMonthDisabled'>, Omit<NativeElementPropsWithoutKeyAndRef<'div'>, 'onClick' | 'children'> {
7
8
  /**
8
9
  * Provide if you have a custom disabling logic. The method takes the date object as its parameter.
@@ -22,7 +23,14 @@ export interface CalendarDaysProps extends Pick<CalendarDayOfWeekProps, 'display
22
23
  */
23
24
  onDateHover?: (date: DateType) => void;
24
25
  /**
25
- * The refernce date for getting the month of the calendar.
26
+ * The extra annotations for specific dates.
27
+ */
28
+ renderAnnotations?: (date: DateType) => {
29
+ value: string;
30
+ color?: TypographyColor;
31
+ };
32
+ /**
33
+ * The reference date for getting the month of the calendar.
26
34
  */
27
35
  referenceDate: DateType;
28
36
  /**
@@ -1,9 +1,11 @@
1
- import { jsxs, jsx } from 'react/jsx-runtime';
1
+ 'use client';
2
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
3
  import { calendarClasses } from '@mezzanine-ui/core/calendar';
3
4
  import { useMemo } from 'react';
4
5
  import CalendarCell from './CalendarCell.js';
5
6
  import CalendarDayOfWeek from './CalendarDayOfWeek.js';
6
7
  import { useCalendarContext } from './CalendarContext.js';
8
+ import Typography from '../Typography/Typography.js';
7
9
  import cx from 'clsx';
8
10
 
9
11
  /**
@@ -12,43 +14,66 @@ import cx from 'clsx';
12
14
  * You may use it to compose your own calendar.
13
15
  */
14
16
  function CalendarDays(props) {
15
- const { displayWeekDayLocale: displayWeekDayLocaleFromConfig, getCalendarGrid, getDate, getMonth, getNow, isDateIncluded, isSameDate, setDate, setMonth, } = useCalendarContext();
16
- const { className, displayWeekDayLocale = displayWeekDayLocaleFromConfig, isYearDisabled, isMonthDisabled, isDateDisabled, isDateInRange, onClick: onClickProp, onDateHover, referenceDate, value, ...rest } = props;
17
- const daysGrid = useMemo(() => getCalendarGrid(referenceDate), [getCalendarGrid, referenceDate]);
18
- return (jsxs("div", { ...rest, className: cx(calendarClasses.board, className), children: [jsx(CalendarDayOfWeek, { displayWeekDayLocale: displayWeekDayLocale }), daysGrid.map((week, index) => (jsx("div", { className: calendarClasses.row, children: week.map((dateNum) => {
19
- const isPrevMonth = index === 0 && dateNum > 7;
20
- const isNextMonth = index > 3 && dateNum <= 14;
21
- const thisMonth = getMonth(referenceDate);
22
- // eslint-disable-next-line no-nested-ternary
23
- const month = isPrevMonth
24
- ? thisMonth - 1
25
- : isNextMonth
26
- ? thisMonth + 1
27
- : thisMonth;
28
- const date = setDate(setMonth(referenceDate, month), dateNum);
29
- const disabled = (isYearDisabled === null || isYearDisabled === void 0 ? void 0 : isYearDisabled(date)) ||
30
- (isMonthDisabled === null || isMonthDisabled === void 0 ? void 0 : isMonthDisabled(date)) ||
31
- (isDateDisabled === null || isDateDisabled === void 0 ? void 0 : isDateDisabled(date)) ||
32
- false;
33
- const inactive = !disabled && (isPrevMonth || isNextMonth);
34
- const inRange = !inactive && isDateInRange && isDateInRange(date);
35
- const active = !disabled && !inactive && value && isDateIncluded(date, value);
36
- const onMouseEnter = onDateHover
37
- ? () => {
38
- onDateHover(date);
39
- }
40
- : undefined;
41
- const onClick = onClickProp
42
- ? () => {
43
- onClickProp(date);
44
- }
45
- : undefined;
46
- return (jsx(CalendarCell, { today: isSameDate(date, getNow()), active: active, disabled: isPrevMonth || isNextMonth, children: jsx("button", { type: "button", "aria-disabled": disabled, disabled: disabled, onMouseEnter: onMouseEnter, className: cx(calendarClasses.button, {
47
- [calendarClasses.buttonInRange]: inRange,
48
- [calendarClasses.buttonActive]: active,
49
- [calendarClasses.buttonDisabled]: disabled,
50
- }), onClick: onClick, children: dateNum }) }, `${getMonth(date)}/${getDate(date)}`));
51
- }) }, `CALENDAR_DAYS/WEEK_OF/${index}`)))] }));
17
+ const { locale, getCalendarGrid, getDate, getMonth, getNow, isDateIncluded, isSameDate, setDate, setMonth, setHour, setMinute, setSecond, setMillisecond, } = useCalendarContext();
18
+ const { className, displayWeekDayLocale = locale, isYearDisabled, isMonthDisabled, isDateDisabled, isDateInRange, onClick: onClickProp, onDateHover, renderAnnotations, referenceDate, value, ...rest } = props;
19
+ const daysGrid = useMemo(() => getCalendarGrid(referenceDate, displayWeekDayLocale), [getCalendarGrid, displayWeekDayLocale, referenceDate]);
20
+ return (jsx("div", { ...rest, className: cx(calendarClasses.board, className), children: jsxs("div", { className: calendarClasses.daysGrid, children: [jsx(CalendarDayOfWeek, { displayWeekDayLocale: displayWeekDayLocale }), daysGrid.map((week, index) => (jsx("div", { className: calendarClasses.row, children: week.map((dateNum) => {
21
+ const isPrevMonth = index === 0 && dateNum > 7;
22
+ const isNextMonth = index > 3 && dateNum <= 14;
23
+ const thisMonth = getMonth(referenceDate);
24
+ const month = isPrevMonth
25
+ ? thisMonth - 1
26
+ : isNextMonth
27
+ ? thisMonth + 1
28
+ : thisMonth;
29
+ const date = setMillisecond(setSecond(setMinute(setHour(setDate(setMonth(referenceDate, month), dateNum), 0), 0), 0), 0);
30
+ const disabled = (isYearDisabled === null || isYearDisabled === void 0 ? void 0 : isYearDisabled(date)) ||
31
+ (isMonthDisabled === null || isMonthDisabled === void 0 ? void 0 : isMonthDisabled(date)) ||
32
+ (isDateDisabled === null || isDateDisabled === void 0 ? void 0 : isDateDisabled(date)) ||
33
+ false;
34
+ const inactive = !disabled && (isPrevMonth || isNextMonth);
35
+ const inRange = !inactive && isDateInRange && isDateInRange(date);
36
+ const active = !disabled && !inactive && value && isDateIncluded(date, value);
37
+ const onMouseEnter = onDateHover
38
+ ? () => {
39
+ onDateHover(date);
40
+ }
41
+ : undefined;
42
+ const onClick = onClickProp
43
+ ? () => {
44
+ onClickProp(date);
45
+ }
46
+ : undefined;
47
+ // Accessible date label for screen readers
48
+ const dateObj = new Date(date);
49
+ const dayName = dateObj.toLocaleDateString(displayWeekDayLocale, {
50
+ weekday: 'long',
51
+ });
52
+ const monthName = dateObj.toLocaleDateString(displayWeekDayLocale, { month: 'long' });
53
+ const year = dateObj.getFullYear();
54
+ const day = dateObj.getDate();
55
+ const isToday = isSameDate(date, getNow());
56
+ const ariaLabel = [
57
+ `${dayName}, ${monthName} ${day}, ${year}`,
58
+ isToday && 'Today',
59
+ active && 'Selected',
60
+ disabled && 'Not available',
61
+ inactive && 'Outside current month',
62
+ ]
63
+ .filter(Boolean)
64
+ .join(', ');
65
+ return (jsx(CalendarCell, { today: isSameDate(date, getNow()), active: active, disabled: isPrevMonth || isNextMonth, children: jsxs("button", { type: "button", "aria-disabled": disabled, disabled: disabled, "aria-label": ariaLabel, "aria-pressed": active, "aria-current": isToday ? 'date' : undefined, onMouseEnter: onMouseEnter, className: cx(calendarClasses.button, {
66
+ [calendarClasses.buttonInRange]: inRange,
67
+ [calendarClasses.buttonActive]: active,
68
+ [calendarClasses.buttonDisabled]: disabled,
69
+ }), onClick: onClick, children: [dateNum, typeof renderAnnotations === 'function'
70
+ ? (() => {
71
+ var _a, _b;
72
+ const annotation = renderAnnotations(date);
73
+ return (jsx(Typography, { variant: "annotation", color: (_a = annotation === null || annotation === void 0 ? void 0 : annotation.color) !== null && _a !== void 0 ? _a : 'text-neutral', children: (_b = annotation === null || annotation === void 0 ? void 0 : annotation.value) !== null && _b !== void 0 ? _b : '' }));
74
+ })()
75
+ : null] }) }, `${getMonth(date)}/${getDate(date)}`));
76
+ }) }, `CALENDAR_DAYS/WEEK_OF/${index}`)))] }) }));
52
77
  }
53
78
 
54
79
  export { CalendarDays as default };
@@ -0,0 +1,13 @@
1
+ import { NativeElementPropsWithoutKeyAndRef } from '../utils/jsx-types';
2
+ import { ButtonProps } from '../Button';
3
+ export interface CalendarFooterActionsProps extends Omit<NativeElementPropsWithoutKeyAndRef<'div'>, 'onClick'> {
4
+ actions: {
5
+ secondaryButtonProps: ButtonProps;
6
+ primaryButtonProps: ButtonProps;
7
+ };
8
+ }
9
+ /**
10
+ * The react component for `mezzanine` calendar footer actions.
11
+ */
12
+ declare function CalendarFooterActions(props: CalendarFooterActionsProps): import("react/jsx-runtime").JSX.Element;
13
+ export default CalendarFooterActions;
@@ -0,0 +1,14 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { calendarClasses } from '@mezzanine-ui/core/calendar';
3
+ import Button from '../Button/Button.js';
4
+ import cx from 'clsx';
5
+
6
+ /**
7
+ * The react component for `mezzanine` calendar footer actions.
8
+ */
9
+ function CalendarFooterActions(props) {
10
+ const { actions, className, ...restElementProps } = props;
11
+ return (jsxs("div", { ...restElementProps, className: cx(calendarClasses.footerActions, className), children: [jsx(Button, { variant: "base-tertiary", size: "minor", ...actions.secondaryButtonProps }), jsx(Button, { variant: "base-primary", size: "minor", ...actions.primaryButtonProps })] }));
12
+ }
13
+
14
+ export { CalendarFooterActions as default };