@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.
- package/Accordion/AccordionControlContext.js +1 -0
- package/Accordion/AccordionDetails.js +1 -0
- package/Accordion/AccordionSummary.js +10 -10
- package/Accordion/index.d.ts +6 -3
- package/Alert/index.d.ts +3 -2
- package/AlertBanner/AlertBanner.d.ts +93 -0
- package/AlertBanner/AlertBanner.js +154 -0
- package/AlertBanner/index.d.ts +2 -0
- package/AlertBanner/index.js +1 -0
- package/Anchor/Anchor.js +1 -1
- package/Anchor/index.d.ts +2 -1
- package/AppBar/index.d.ts +8 -4
- package/{Overlay/Overlay.d.ts → Backdrop/Backdrop.d.ts} +12 -16
- package/Backdrop/Backdrop.js +40 -0
- package/Backdrop/index.d.ts +2 -0
- package/Backdrop/index.js +1 -0
- package/Badge/Badge.d.ts +20 -14
- package/Badge/Badge.js +14 -16
- package/Badge/BadgeContainer.d.ts +1 -1
- package/Badge/BadgeContainer.js +1 -1
- package/Badge/index.d.ts +3 -2
- package/Badge/typings.d.ts +48 -0
- package/Breadcrumb/Breadcrumb.d.ts +6 -0
- package/Breadcrumb/Breadcrumb.js +53 -0
- package/Breadcrumb/BreadcrumbItem.d.ts +4 -0
- package/Breadcrumb/BreadcrumbItem.js +45 -0
- package/Breadcrumb/index.d.ts +2 -0
- package/Breadcrumb/index.js +1 -0
- package/Breadcrumb/typings.d.ts +75 -0
- package/Button/Button.js +24 -19
- package/Button/ButtonGroup.d.ts +6 -28
- package/Button/ButtonGroup.js +7 -16
- package/Button/index.d.ts +4 -10
- package/Button/index.js +2 -3
- package/Button/typings.d.ts +11 -26
- package/Calendar/Calendar.d.ts +31 -2
- package/Calendar/Calendar.js +74 -19
- package/Calendar/CalendarCell.d.ts +4 -0
- package/Calendar/CalendarCell.js +3 -3
- package/Calendar/CalendarConfigProviderDayjs.d.ts +21 -0
- package/Calendar/CalendarConfigProviderDayjs.js +15 -0
- package/Calendar/CalendarConfigProviderLuxon.d.ts +21 -0
- package/Calendar/CalendarConfigProviderLuxon.js +15 -0
- package/Calendar/CalendarConfigProviderMoment.d.ts +21 -0
- package/Calendar/CalendarConfigProviderMoment.js +15 -0
- package/Calendar/CalendarContext.d.ts +14 -7
- package/Calendar/CalendarContext.js +8 -13
- package/Calendar/CalendarControls.d.ts +16 -0
- package/Calendar/CalendarControls.js +3 -7
- package/Calendar/CalendarDayOfWeek.js +4 -3
- package/Calendar/CalendarDays.d.ts +9 -1
- package/Calendar/CalendarDays.js +63 -38
- package/Calendar/CalendarFooterActions.d.ts +13 -0
- package/Calendar/CalendarFooterActions.js +14 -0
- package/Calendar/CalendarFooterControl.d.ts +16 -0
- package/Calendar/CalendarFooterControl.js +14 -0
- package/Calendar/CalendarHalfYears.d.ts +39 -0
- package/Calendar/CalendarHalfYears.js +62 -0
- package/Calendar/CalendarMonths.js +16 -4
- package/Calendar/CalendarQuarters.d.ts +37 -0
- package/Calendar/CalendarQuarters.js +64 -0
- package/Calendar/CalendarQuickSelect.d.ts +21 -0
- package/Calendar/CalendarQuickSelect.js +15 -0
- package/Calendar/CalendarWeeks.d.ts +1 -1
- package/Calendar/CalendarWeeks.js +89 -44
- package/Calendar/CalendarYears.js +13 -3
- package/Calendar/RangeCalendar.d.ts +59 -0
- package/Calendar/RangeCalendar.js +232 -0
- package/Calendar/index.d.ts +33 -10
- package/Calendar/index.js +7 -0
- package/Calendar/useCalendarControlModifiers.d.ts +4 -4
- package/Calendar/useCalendarControlModifiers.js +40 -8
- package/Calendar/useCalendarControls.d.ts +2 -0
- package/Calendar/useCalendarControls.js +19 -2
- package/Calendar/useCalendarModeStack.js +1 -0
- package/Calendar/useRangeCalendarControls.d.ts +18 -0
- package/Calendar/useRangeCalendarControls.js +115 -0
- package/Card/CardActions.js +1 -1
- package/Card/index.d.ts +4 -2
- package/Checkbox/CheckAll.d.ts +16 -6
- package/Checkbox/CheckAll.js +40 -26
- package/Checkbox/Checkbox.d.ts +100 -22
- package/Checkbox/Checkbox.js +73 -16
- package/Checkbox/CheckboxGroup.d.ts +100 -18
- package/Checkbox/CheckboxGroup.js +169 -24
- package/Checkbox/CheckboxGroupContext.d.ts +0 -2
- package/Checkbox/CheckboxGroupContext.js +1 -0
- package/Checkbox/index.d.ts +16 -4
- package/Checkbox/index.js +6 -2
- package/Checkbox/typings.d.ts +37 -0
- package/ClearActions/ClearActions.d.ts +41 -0
- package/ClearActions/ClearActions.js +23 -0
- package/ClearActions/index.d.ts +3 -0
- package/ClearActions/index.js +5 -0
- package/ConfirmActions/ConfirmActions.d.ts +2 -1
- package/ConfirmActions/index.d.ts +2 -1
- package/DatePicker/DatePicker.d.ts +12 -1
- package/DatePicker/DatePicker.js +41 -9
- package/DatePicker/DatePickerCalendar.d.ts +2 -5
- package/DatePicker/DatePickerCalendar.js +37 -37
- package/DatePicker/index.d.ts +4 -2
- package/DateRangePicker/DateRangePicker.d.ts +18 -2
- package/DateRangePicker/DateRangePicker.js +143 -100
- package/DateRangePicker/DateRangePickerCalendar.d.ts +13 -9
- package/DateRangePicker/DateRangePickerCalendar.js +7 -94
- package/DateRangePicker/index.d.ts +6 -3
- package/DateRangePicker/useDateRangeCalendarControls.js +11 -6
- package/DateRangePicker/useDateRangePickerValue.d.ts +38 -15
- package/DateRangePicker/useDateRangePickerValue.js +142 -63
- package/DateTimePicker/DateTimePicker.d.ts +31 -10
- package/DateTimePicker/DateTimePicker.js +179 -94
- package/DateTimePicker/index.d.ts +2 -2
- package/DateTimePicker/index.js +0 -1
- package/Drawer/Drawer.d.ts +47 -6
- package/Drawer/Drawer.js +36 -11
- package/Drawer/index.d.ts +2 -1
- package/Dropdown/Dropdown.js +12 -22
- package/Dropdown/index.d.ts +2 -1
- package/Empty/Empty.d.ts +1 -16
- package/Empty/Empty.js +59 -7
- package/Empty/icons/EmptyMainInitialDataIcon.d.ts +4 -0
- package/Empty/icons/EmptyMainInitialDataIcon.js +9 -0
- package/Empty/icons/EmptyMainResultIcon.d.ts +4 -0
- package/Empty/icons/EmptyMainResultIcon.js +9 -0
- package/Empty/icons/EmptyMainSystemIcon.d.ts +4 -0
- package/Empty/icons/EmptyMainSystemIcon.js +9 -0
- package/Empty/index.d.ts +2 -1
- package/Empty/typings.d.ts +61 -0
- package/Form/FormControlContext.js +1 -0
- package/Form/FormHintText.d.ts +18 -0
- package/Form/FormHintText.js +17 -0
- package/Form/FormLabel.js +1 -0
- package/Form/index.d.ts +9 -5
- package/Form/index.js +1 -1
- package/Form/useAutoCompleteValueControl.js +2 -0
- package/Form/useCheckboxControlValue.js +0 -1
- package/Form/useSelectValueControl.js +2 -0
- package/InlineMessage/InlineMessage.d.ts +33 -0
- package/InlineMessage/InlineMessage.js +42 -0
- package/InlineMessage/InlineMessageGroup.d.ts +24 -0
- package/InlineMessage/InlineMessageGroup.js +21 -0
- package/InlineMessage/index.d.ts +4 -0
- package/InlineMessage/index.js +2 -0
- package/Input/ActionButton/ActionButton.d.ts +26 -0
- package/Input/ActionButton/ActionButton.js +14 -0
- package/Input/ActionButton/index.d.ts +2 -0
- package/Input/ActionButton/index.js +1 -0
- package/Input/Input.d.ts +147 -42
- package/Input/Input.js +195 -27
- package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.d.ts +31 -0
- package/Input/PasswordStrengthIndicator/PasswordStrengthIndicator.js +18 -0
- package/Input/PasswordStrengthIndicator/index.d.ts +2 -0
- package/Input/PasswordStrengthIndicator/index.js +1 -0
- package/Input/SelectButton/SelectButton.d.ts +20 -0
- package/Input/SelectButton/SelectButton.js +21 -0
- package/Input/SelectButton/index.d.ts +2 -0
- package/Input/SelectButton/index.js +1 -0
- package/Input/SpinnerButton/SpinnerButton.d.ts +19 -0
- package/Input/SpinnerButton/SpinnerButton.js +14 -0
- package/Input/SpinnerButton/index.d.ts +2 -0
- package/Input/SpinnerButton/index.js +1 -0
- package/Input/index.d.ts +3 -2
- package/Menu/Menu.js +1 -0
- package/Menu/index.d.ts +8 -4
- package/Message/Message.d.ts +6 -4
- package/Message/Message.js +86 -9
- package/Message/MessageTimerController.d.ts +14 -0
- package/Message/MessageTimerController.js +27 -0
- package/Message/index.d.ts +3 -2
- package/Modal/Modal.js +2 -2
- package/Modal/ModalActions.js +1 -0
- package/Modal/ModalControl.js +1 -0
- package/Modal/ModalHeader.js +1 -0
- package/Modal/index.d.ts +10 -5
- package/Modal/useModalContainer.d.ts +1 -1
- package/Modal/useModalContainer.js +2 -4
- package/Navigation/Navigation.js +37 -34
- package/Navigation/NavigationContext.js +1 -0
- package/Navigation/NavigationItem.js +1 -0
- package/Navigation/NavigationSubMenu.js +16 -26
- package/Navigation/index.d.ts +8 -4
- package/Notification/Notification.js +0 -1
- package/Notification/index.d.ts +3 -2
- package/Notifier/NotifierManager.d.ts +15 -2
- package/Notifier/NotifierManager.js +60 -18
- package/Notifier/createNotifier.d.ts +9 -0
- package/Notifier/createNotifier.js +3 -2
- package/Notifier/typings.d.ts +3 -1
- package/OverflowTooltip/OverflowCounterTag.d.ts +12 -0
- package/OverflowTooltip/OverflowCounterTag.js +48 -0
- package/OverflowTooltip/OverflowTooltip.d.ts +34 -0
- package/OverflowTooltip/OverflowTooltip.js +53 -0
- package/OverflowTooltip/index.d.ts +2 -0
- package/OverflowTooltip/index.js +2 -0
- package/PageFooter/PageFooter.d.ts +73 -8
- package/PageFooter/PageFooter.js +34 -3
- package/PageFooter/index.d.ts +2 -1
- package/PageHeader/PageHeader.d.ts +40 -0
- package/PageHeader/PageHeader.js +70 -0
- package/PageHeader/index.d.ts +2 -0
- package/PageHeader/index.js +1 -0
- package/PageToolbar/PageToolbar.d.ts +114 -0
- package/PageToolbar/PageToolbar.js +23 -0
- package/PageToolbar/index.d.ts +2 -0
- package/PageToolbar/index.js +1 -0
- package/PageToolbar/utils.d.ts +23 -0
- package/PageToolbar/utils.js +165 -0
- package/Pagination/Pagination.d.ts +23 -29
- package/Pagination/Pagination.js +3 -4
- package/Pagination/PaginationItem.d.ts +1 -1
- package/Pagination/PaginationItem.js +4 -3
- package/Pagination/PaginationJumper.d.ts +7 -9
- package/Pagination/PaginationJumper.js +3 -5
- package/Pagination/PaginationPageSize.d.ts +8 -11
- package/Pagination/PaginationPageSize.js +5 -4
- package/Pagination/index.d.ts +8 -4
- package/Pagination/usePagination.d.ts +3 -1
- package/Pagination/usePagination.js +12 -21
- package/Picker/FormattedInput.d.ts +17 -0
- package/Picker/FormattedInput.js +74 -0
- package/Picker/MaskFormat.d.ts +39 -0
- package/Picker/MaskFormat.js +94 -0
- package/Picker/PickerTrigger.d.ts +13 -3
- package/Picker/PickerTrigger.js +17 -2
- package/Picker/PickerTriggerWithSeparator.d.ts +124 -0
- package/Picker/PickerTriggerWithSeparator.js +80 -0
- package/Picker/RangePickerTrigger.d.ts +55 -4
- package/Picker/RangePickerTrigger.js +65 -7
- package/Picker/formatUtils.d.ts +34 -0
- package/Picker/formatUtils.js +124 -0
- package/Picker/index.d.ts +17 -6
- package/Picker/index.js +4 -1
- package/Picker/useDateInputFormatter.d.ts +52 -0
- package/Picker/useDateInputFormatter.js +382 -0
- package/Picker/usePickerValue.d.ts +1 -2
- package/Picker/usePickerValue.js +8 -13
- package/Popconfirm/Popconfirm.js +1 -1
- package/Popconfirm/index.d.ts +2 -1
- package/Popover/Popover.js +4 -8
- package/Popover/index.d.ts +2 -1
- package/Popper/Popper.d.ts +15 -10
- package/Popper/Popper.js +88 -17
- package/Popper/index.d.ts +2 -1
- package/Portal/Portal.d.ts +13 -5
- package/Portal/Portal.js +25 -10
- package/Portal/index.d.ts +4 -1
- package/Portal/index.js +1 -0
- package/Portal/portalRegistry.d.ts +17 -0
- package/Portal/portalRegistry.js +92 -0
- package/Progress/Progress.d.ts +23 -30
- package/Progress/Progress.js +71 -21
- package/Progress/index.d.ts +3 -2
- package/Provider/ConfigProvider.d.ts +1 -0
- package/Provider/ConfigProvider.js +1 -0
- package/Provider/context.js +1 -0
- package/Radio/Radio.d.ts +37 -4
- package/Radio/Radio.js +23 -12
- package/Radio/RadioGroup.d.ts +37 -8
- package/Radio/RadioGroup.js +6 -5
- package/Radio/RadioGroupContext.d.ts +2 -1
- package/Radio/RadioGroupContext.js +1 -0
- package/Radio/index.d.ts +5 -3
- package/ResultState/ResultState.d.ts +52 -0
- package/ResultState/ResultState.js +24 -0
- package/ResultState/index.d.ts +2 -0
- package/ResultState/index.js +1 -0
- package/Select/AutoComplete.d.ts +1 -1
- package/Select/AutoComplete.js +2 -1
- package/Select/Option.js +1 -0
- package/Select/Select.d.ts +1 -1
- package/Select/Select.js +2 -1
- package/Select/SelectControlContext.js +1 -0
- package/Select/SelectTrigger.d.ts +1 -87
- package/Select/SelectTrigger.js +26 -21
- package/Select/SelectTriggerTags.d.ts +1 -1
- package/Select/SelectTriggerTags.js +47 -18
- package/Select/TreeSelect.d.ts +1 -1
- package/Select/TreeSelect.js +2 -1
- package/Select/index.d.ts +14 -7
- package/Select/typings.d.ts +99 -0
- package/Select/useSelectTriggerTags.d.ts +15 -8
- package/Select/useSelectTriggerTags.js +83 -44
- package/Selection/Selection.d.ts +98 -0
- package/Selection/Selection.js +46 -0
- package/Selection/index.d.ts +12 -0
- package/Selection/index.js +5 -0
- package/Skeleton/Skeleton.d.ts +10 -3
- package/Skeleton/Skeleton.js +12 -4
- package/Skeleton/index.d.ts +2 -1
- package/Slider/Slider.d.ts +44 -7
- package/Slider/Slider.js +17 -13
- package/Slider/index.d.ts +5 -3
- package/Spin/Spin.d.ts +39 -0
- package/{Loading/Loading.js → Spin/Spin.js} +9 -9
- package/Spin/index.d.ts +2 -0
- package/Spin/index.js +1 -0
- package/Stepper/Step.d.ts +1 -35
- package/Stepper/Step.js +43 -8
- package/Stepper/Stepper.d.ts +1 -14
- package/Stepper/Stepper.js +49 -15
- package/Stepper/index.d.ts +5 -2
- package/Stepper/index.js +1 -0
- package/Stepper/typings.d.ts +77 -0
- package/Stepper/useStepDistance.d.ts +10 -0
- package/Stepper/useStepDistance.js +81 -0
- package/Stepper/useStepper.d.ts +21 -0
- package/Stepper/useStepper.js +26 -0
- package/Tab/Tab.d.ts +32 -0
- package/Tab/Tab.js +57 -0
- package/Tab/TabItem.d.ts +27 -0
- package/Tab/TabItem.js +18 -0
- package/Tab/index.d.ts +4 -0
- package/Tab/index.js +2 -0
- package/Table/Table.d.ts +75 -94
- package/Table/Table.js +216 -161
- package/Table/TableContext.d.ts +114 -51
- package/Table/TableContext.js +22 -3
- package/Table/components/TableBody.d.ts +5 -0
- package/Table/components/TableBody.js +102 -0
- package/Table/components/TableCell.d.ts +17 -0
- package/Table/components/TableCell.js +74 -0
- package/Table/components/TableColGroup.d.ts +4 -0
- package/Table/components/TableColGroup.js +206 -0
- package/Table/components/TableDragHandleCell.d.ts +9 -0
- package/Table/components/TableDragHandleCell.js +37 -0
- package/Table/components/TableExpandCell.d.ts +11 -0
- package/Table/components/TableExpandCell.js +44 -0
- package/Table/components/TableExpandedRow.d.ts +9 -0
- package/Table/components/TableExpandedRow.js +46 -0
- package/Table/components/TableHeader.d.ts +4 -0
- package/Table/components/TableHeader.js +125 -0
- package/Table/components/TablePagination.d.ts +3 -0
- package/Table/components/TablePagination.js +11 -0
- package/Table/components/TableResizeHandle.d.ts +13 -0
- package/Table/components/TableResizeHandle.js +115 -0
- package/Table/components/TableRow.d.ts +12 -0
- package/Table/components/TableRow.js +126 -0
- package/Table/components/TableSelectionCell.d.ts +13 -0
- package/Table/components/TableSelectionCell.js +35 -0
- package/Table/components/index.d.ts +10 -0
- package/Table/components/index.js +10 -0
- package/Table/hooks/index.d.ts +9 -0
- package/Table/hooks/index.js +8 -0
- package/Table/hooks/typings.d.ts +14 -0
- package/Table/hooks/useTableColumns.d.ts +8 -0
- package/Table/hooks/useTableColumns.js +91 -0
- package/Table/hooks/useTableDataSource.d.ts +57 -0
- package/Table/hooks/useTableDataSource.js +183 -0
- package/Table/hooks/useTableExpansion.d.ts +7 -0
- package/Table/hooks/useTableExpansion.js +52 -0
- package/Table/hooks/useTableFixedOffsets.d.ts +29 -0
- package/Table/hooks/useTableFixedOffsets.js +241 -0
- package/Table/hooks/useTableScroll.d.ts +12 -0
- package/Table/hooks/useTableScroll.js +58 -0
- package/Table/hooks/useTableSelection.d.ts +7 -0
- package/Table/hooks/useTableSelection.js +94 -0
- package/Table/hooks/useTableSorting.d.ts +6 -0
- package/Table/hooks/useTableSorting.js +32 -0
- package/Table/hooks/useTableVirtualization.d.ts +22 -0
- package/Table/hooks/useTableVirtualization.js +115 -0
- package/Table/index.d.ts +7 -7
- package/Table/index.js +22 -6
- package/Table/utils/index.d.ts +2 -0
- package/Table/utils/index.js +1 -0
- package/Table/utils/useTableRowSelection.d.ts +18 -0
- package/Table/utils/useTableRowSelection.js +63 -0
- package/Tag/Tag.d.ts +2 -25
- package/Tag/Tag.js +23 -13
- package/Tag/TagGroup.d.ts +12 -0
- package/Tag/TagGroup.js +41 -0
- package/Tag/index.d.ts +2 -1
- package/Tag/typings.d.ts +78 -0
- package/TextField/TextField.d.ts +78 -19
- package/TextField/TextField.js +58 -22
- package/TextField/index.d.ts +2 -1
- package/Textarea/Textarea.d.ts +19 -51
- package/Textarea/Textarea.js +13 -19
- package/Textarea/index.d.ts +2 -2
- package/TimePanel/TimePanel.d.ts +1 -22
- package/TimePanel/TimePanel.js +31 -26
- package/TimePanel/TimePanelAction.d.ts +2 -8
- package/TimePanel/TimePanelAction.js +2 -2
- package/TimePanel/TimePanelColumn.d.ts +0 -13
- package/TimePanel/TimePanelColumn.js +9 -11
- package/TimePanel/index.d.ts +6 -3
- package/TimePicker/TimePicker.d.ts +10 -1
- package/TimePicker/TimePicker.js +86 -35
- package/TimePicker/TimePickerPanel.d.ts +1 -2
- package/TimePicker/TimePickerPanel.js +2 -2
- package/TimePicker/index.d.ts +4 -2
- package/Toggle/Toggle.d.ts +46 -0
- package/Toggle/Toggle.js +29 -0
- package/Toggle/index.d.ts +3 -0
- package/Toggle/index.js +1 -0
- package/Tooltip/Tooltip.d.ts +13 -2
- package/Tooltip/Tooltip.js +56 -10
- package/Tooltip/index.d.ts +2 -1
- package/Tooltip/useDelayMouseEnterLeave.d.ts +1 -2
- package/Tooltip/useDelayMouseEnterLeave.js +10 -13
- package/Transition/Collapse.d.ts +2 -0
- package/Transition/Collapse.js +5 -6
- package/Transition/Fade.js +4 -4
- package/Transition/Rotate.d.ts +42 -0
- package/Transition/Rotate.js +30 -0
- package/Transition/Scale.d.ts +13 -0
- package/Transition/{Grow.js → Scale.js} +19 -16
- package/Transition/Slide.d.ts +7 -0
- package/Transition/{Zoom.js → Slide.js} +14 -12
- package/Transition/SlideFade.d.ts +3 -0
- package/Transition/SlideFade.js +5 -4
- package/Transition/Transition.d.ts +2 -2
- package/Transition/Translate.d.ts +14 -0
- package/Transition/Translate.js +94 -0
- package/Transition/index.d.ts +16 -6
- package/Transition/index.js +4 -2
- package/Transition/useAutoTransitionDuration.d.ts +1 -1
- package/Transition/useAutoTransitionDuration.js +3 -3
- package/Transition/useSetNodeTransition.js +0 -2
- package/Tree/TreeNode.js +7 -6
- package/Tree/index.d.ts +10 -5
- package/Typography/Typography.d.ts +6 -9
- package/Typography/Typography.js +7 -9
- package/Typography/index.d.ts +2 -5
- package/Upload/Upload.d.ts +175 -0
- package/Upload/Upload.js +279 -0
- package/Upload/UploadItem.d.ts +82 -0
- package/Upload/UploadItem.js +118 -0
- package/Upload/UploadPictureCard.d.ts +110 -0
- package/Upload/UploadPictureCard.js +101 -0
- package/Upload/Uploader.d.ts +161 -0
- package/Upload/Uploader.js +120 -0
- package/Upload/index.d.ts +8 -6
- package/Upload/index.js +4 -5
- package/Upload/upload-utils.d.ts +41 -0
- package/Upload/upload-utils.js +65 -0
- package/_internal/InputCheck/InputCheck.d.ts +15 -1
- package/_internal/InputCheck/InputCheck.js +6 -2
- package/_internal/InputCheck/InputCheckGroup.d.ts +11 -1
- package/_internal/InputCheck/InputCheckGroup.js +4 -2
- package/_internal/InputCheck/index.d.ts +4 -2
- package/_internal/InputTriggerPopper/InputTriggerPopper.js +15 -25
- package/_internal/InputTriggerPopper/index.d.ts +2 -1
- package/_internal/SlideFadeOverlay/SlideFadeOverlay.d.ts +3 -3
- package/_internal/SlideFadeOverlay/SlideFadeOverlay.js +5 -28
- package/_internal/SlideFadeOverlay/index.d.ts +2 -1
- package/_internal/SlideFadeOverlay/useTopStack.js +1 -0
- package/dayjs.d.ts +21 -0
- package/dayjs.js +2 -0
- package/hooks/useComposeRefs.js +1 -1
- package/hooks/useLastCallback.js +3 -1
- package/hooks/useScrollLock.d.ts +28 -0
- package/hooks/useScrollLock.js +134 -0
- package/index.d.ts +128 -58
- package/index.js +90 -80
- package/luxon.d.ts +21 -0
- package/luxon.js +2 -0
- package/moment.d.ts +21 -0
- package/moment.js +2 -0
- package/package.json +14 -17
- package/utils/composeRefs.js +0 -1
- package/utils/flatten-children.d.ts +12 -0
- package/utils/flatten-children.js +37 -0
- package/utils/get-css-variable-value.d.ts +2 -0
- package/utils/get-css-variable-value.js +12 -0
- package/Button/IconButton.d.ts +0 -21
- package/Button/IconButton.js +0 -13
- package/DateTimePicker/DateTimePickerPanel.d.ts +0 -28
- package/DateTimePicker/DateTimePickerPanel.js +0 -49
- package/Form/FormMessage.d.ts +0 -7
- package/Form/FormMessage.js +0 -18
- package/Form/useInputWithTagsModeValue.js +0 -86
- package/Loading/Loading.d.ts +0 -33
- package/Loading/index.d.ts +0 -1
- package/Loading/index.js +0 -1
- package/Overlay/Overlay.js +0 -31
- package/Overlay/index.d.ts +0 -1
- package/Overlay/index.js +0 -1
- package/Picker/useRangePickerValue.d.ts +0 -23
- package/Picker/useRangePickerValue.js +0 -99
- package/Switch/Switch.d.ts +0 -43
- package/Switch/Switch.js +0 -28
- package/Switch/index.d.ts +0 -2
- package/Switch/index.js +0 -1
- package/Table/TableBody.d.ts +0 -10
- package/Table/TableBody.js +0 -30
- package/Table/TableBodyRow.d.ts +0 -11
- package/Table/TableBodyRow.js +0 -64
- package/Table/TableCell.d.ts +0 -19
- package/Table/TableCell.js +0 -24
- package/Table/TableExpandedTable.d.ts +0 -11
- package/Table/TableExpandedTable.js +0 -28
- package/Table/TableHeader.d.ts +0 -3
- package/Table/TableHeader.js +0 -35
- package/Table/draggable/useTableDraggable.d.ts +0 -14
- package/Table/draggable/useTableDraggable.js +0 -64
- package/Table/editable/TableEditRenderWrapper.d.ts +0 -7
- package/Table/editable/TableEditRenderWrapper.js +0 -15
- package/Table/expandable/TableExpandable.d.ts +0 -27
- package/Table/expandable/TableExpandable.js +0 -24
- package/Table/pagination/TablePagination.d.ts +0 -10
- package/Table/pagination/TablePagination.js +0 -25
- package/Table/pagination/useTablePagination.d.ts +0 -8
- package/Table/pagination/useTablePagination.js +0 -29
- package/Table/refresh/TableRefresh.d.ts +0 -10
- package/Table/refresh/TableRefresh.js +0 -20
- package/Table/rowSelection/TableRowSelection.d.ts +0 -18
- package/Table/rowSelection/TableRowSelection.js +0 -92
- package/Table/rowSelection/useTableRowSelection.d.ts +0 -6
- package/Table/rowSelection/useTableRowSelection.js +0 -53
- package/Table/sorting/TableSortingIcon.d.ts +0 -10
- package/Table/sorting/TableSortingIcon.js +0 -32
- package/Table/sorting/useTableSorting.d.ts +0 -11
- package/Table/sorting/useTableSorting.js +0 -120
- package/Table/useTableFetchMore.d.ts +0 -10
- package/Table/useTableFetchMore.js +0 -50
- package/Table/useTableLoading.d.ts +0 -5
- package/Table/useTableLoading.js +0 -19
- package/Table/useTableScroll.d.ts +0 -596
- package/Table/useTableScroll.js +0 -294
- package/Tabs/Tab.d.ts +0 -18
- package/Tabs/Tab.js +0 -16
- package/Tabs/TabPane.d.ts +0 -14
- package/Tabs/TabPane.js +0 -18
- package/Tabs/Tabs.d.ts +0 -39
- package/Tabs/Tabs.js +0 -47
- package/Tabs/index.d.ts +0 -3
- package/Tabs/index.js +0 -3
- package/Tabs/useTabsOverflow.d.ts +0 -8
- package/Tabs/useTabsOverflow.js +0 -61
- package/Transition/Grow.d.ts +0 -12
- package/Transition/Zoom.d.ts +0 -7
- package/Upload/UploadButton.d.ts +0 -9
- package/Upload/UploadButton.js +0 -23
- package/Upload/UploadInput.d.ts +0 -20
- package/Upload/UploadInput.js +0 -24
- package/Upload/UploadPicture.d.ts +0 -49
- package/Upload/UploadPicture.js +0 -51
- package/Upload/UploadPictureBlock.d.ts +0 -20
- package/Upload/UploadPictureBlock.js +0 -81
- package/Upload/UploadPictureWall.d.ts +0 -81
- package/Upload/UploadPictureWall.js +0 -168
- package/Upload/UploadPictureWallItem.d.ts +0 -15
- package/Upload/UploadPictureWallItem.js +0 -18
- package/Upload/UploadResult.d.ts +0 -35
- package/Upload/UploadResult.js +0 -29
- package/utils/scroll-lock.d.ts +0 -2
- package/utils/scroll-lock.js +0 -24
package/Calendar/Calendar.js
CHANGED
|
@@ -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 {
|
|
20
|
-
const { calendarDaysProps, calendarMonthsProps, calendarWeeksProps, calendarYearsProps, className, disabledMonthSwitch, disableOnNext, disableOnPrev, disabledYearSwitch, displayMonthLocale =
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
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.
|
package/Calendar/CalendarCell.js
CHANGED
|
@@ -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,
|
|
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
|
-
|
|
7
|
-
|
|
8
|
-
|
|
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
|
-
|
|
15
|
-
|
|
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,
|
|
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',
|
|
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
|
-
|
|
21
|
-
|
|
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,
|
|
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.
|
|
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,
|
|
13
|
-
const { displayWeekDayLocale =
|
|
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
|
|
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
|
/**
|
package/Calendar/CalendarDays.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
|
|
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 {
|
|
16
|
-
const { className, displayWeekDayLocale =
|
|
17
|
-
const daysGrid = useMemo(() => getCalendarGrid(referenceDate), [getCalendarGrid, referenceDate]);
|
|
18
|
-
return (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
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 };
|