From a235cea7568ec0dd2ea6d697ac39d12c9a590cc7 Mon Sep 17 00:00:00 2001 From: flavien Date: Tue, 29 Oct 2024 17:44:30 +0100 Subject: [PATCH 1/6] [pickers] Use the new ownerState in DateCalendar, DateRangeCalendar, MonthCalendar and YearCalendar --- .../DateRangeCalendar/DateRangeCalendar.tsx | 27 ++++++++---- .../DateRangeCalendar.types.ts | 17 +++----- .../src/DateCalendar/DateCalendar.tsx | 19 +++++---- .../src/DateCalendar/DateCalendar.types.ts | 4 +- .../src/DateCalendar/DayCalendar.tsx | 35 +++++++++------- .../x-date-pickers/src/DateCalendar/index.ts | 1 + .../src/MonthCalendar/MonthCalendar.tsx | 16 +++---- .../src/MonthCalendar/MonthCalendar.types.ts | 10 +++-- .../src/MonthCalendar/PickersMonth.tsx | 42 +++++++++++++------ .../src/YearCalendar/PickersYear.tsx | 42 +++++++++++++------ .../src/YearCalendar/YearCalendar.tsx | 16 +++---- .../src/YearCalendar/YearCalendar.types.ts | 10 +++-- .../x-date-pickers/src/internals/index.ts | 1 + scripts/x-date-pickers-pro.exports.json | 1 + scripts/x-date-pickers.exports.json | 1 + 15 files changed, 150 insertions(+), 92 deletions(-) diff --git a/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.tsx b/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.tsx index e41859e4304f6..606fb3fb0398b 100644 --- a/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.tsx +++ b/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.tsx @@ -25,11 +25,13 @@ import { DEFAULT_DESKTOP_MODE_MEDIA_QUERY, useControlledValueWithTimezone, useViews, + usePickersPrivateContext, } from '@mui/x-date-pickers/internals'; import { warnOnce } from '@mui/x-internals/warning'; import { PickerValidDate } from '@mui/x-date-pickers/models'; import { getReleaseInfo } from '../internals/utils/releaseInfo'; import { + DateRangeCalendarClasses, dateRangeCalendarClasses, getDateRangeCalendarUtilityClass, } from './dateRangeCalendarClasses'; @@ -62,7 +64,7 @@ const DateRangeCalendarRoot = styled('div', { name: 'MuiDateRangeCalendar', slot: 'Root', overridesResolver: (_, styles) => styles.root, -})<{ ownerState: DateRangeCalendarOwnerState }>({ +})<{ ownerState: DateRangeCalendarOwnerState }>({ display: 'flex', flexDirection: 'row', }); @@ -133,12 +135,14 @@ function useDateRangeCalendarDefaultizedProps( }; } -const useUtilityClasses = (ownerState: DateRangeCalendarOwnerState) => { - const { classes, isDragging } = ownerState; +const useUtilityClasses = ( + classes: Partial | undefined, + ownerState: DateRangeCalendarOwnerState, +) => { const slots = { root: ['root'], monthContainer: ['monthContainer'], - dayCalendar: [isDragging && 'dayDragging'], + dayCalendar: [ownerState.isDraggingDay && 'dayDragging'], }; return composeClasses(slots, getDateRangeCalendarUtilityClass, classes); @@ -172,6 +176,7 @@ const DateRangeCalendar = React.forwardRef(function DateRangeCalendar< referenceDate, onChange, className, + classes: classesProp, disableFuture, disablePast, minDate, @@ -299,8 +304,12 @@ const DateRangeCalendar = React.forwardRef(function DateRangeCalendar< timezone, }); - const ownerState = { ...props, isDragging }; - const classes = useUtilityClasses(ownerState); + const { ownerState: pickersOwnerState } = usePickersPrivateContext(); + const ownerState: DateRangeCalendarOwnerState = { + ...pickersOwnerState, + isDraggingDay: isDragging, + }; + const classes = useUtilityClasses(classesProp, ownerState); const draggingRange = React.useMemo>(() => { if (!valueDayRange[0] || !valueDayRange[1] || !rangeDragDay) { @@ -370,7 +379,7 @@ const DateRangeCalendar = React.forwardRef(function DateRangeCalendar< slots, slotProps, }, - ownerState: props, + ownerState, }); const prevValue = React.useRef | null>(null); @@ -455,7 +464,7 @@ const DateRangeCalendar = React.forwardRef(function DateRangeCalendar< const slotPropsForDayCalendar = { ...slotProps, day: (dayOwnerState) => { - const { day } = dayOwnerState; + const { day, isDaySelected } = dayOwnerState; const isSelectedStartDate = isStartOfRange(utils, day, valueDayRange); const isSelectedEndDate = isEndOfRange(utils, day, valueDayRange); const shouldInitDragging = !shouldDisableDragEditing && valueDayRange[0] && valueDayRange[1]; @@ -488,7 +497,7 @@ const DateRangeCalendar = React.forwardRef(function DateRangeCalendar< onMouseEnter: shouldHavePreview ? handleDayMouseEnter : undefined, // apply selected styling to the dragging start or end day isVisuallySelected: - dayOwnerState.selected || (isDragging && (isStartOfHighlighting || isEndOfHighlighting)), + isDaySelected || (isDragging && (isStartOfHighlighting || isEndOfHighlighting)), 'data-position': datePosition, ...dragEventHandlers, draggable: isElementDraggable ? true : undefined, diff --git a/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts b/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts index ac56c4d441496..7bcf8fe99e76f 100644 --- a/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts +++ b/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts @@ -2,12 +2,13 @@ import * as React from 'react'; import { SxProps } from '@mui/system'; import { SlotComponentProps } from '@mui/utils'; import { Theme } from '@mui/material/styles'; -import { PickerValidDate, TimezoneProps } from '@mui/x-date-pickers/models'; +import { PickerOwnerState, PickerValidDate, TimezoneProps } from '@mui/x-date-pickers/models'; import { PickersCalendarHeader, PickersCalendarHeaderSlots, PickersCalendarHeaderSlotProps, } from '@mui/x-date-pickers/PickersCalendarHeader'; +import { PickersDayOwnerState } from '@mui/x-date-pickers/DateCalendar'; import { BaseDateValidationProps, DefaultizedProps, @@ -16,7 +17,6 @@ import { DayCalendarSlotProps, PickersArrowSwitcherSlots, PickersArrowSwitcherSlotProps, - DayCalendarProps, ExportedUseViewsOptions, } from '@mui/x-date-pickers/internals'; import { DayRangeValidationProps } from '../internals/models/dateRange'; @@ -51,13 +51,9 @@ export interface DateRangeCalendarSlotProps calendarHeader?: SlotComponentProps< typeof PickersCalendarHeader, {}, - DateRangeCalendarProps - >; - day?: SlotComponentProps< - typeof DateRangePickerDay, - {}, - DayCalendarProps & { day: TDate; selected: boolean } + DateRangeCalendarOwnerState >; + day?: SlotComponentProps>; } export interface ExportedDateRangeCalendarProps @@ -156,9 +152,8 @@ export interface DateRangeCalendarProps availableRangePositions?: RangePosition[]; } -export interface DateRangeCalendarOwnerState - extends DateRangeCalendarProps { - isDragging: boolean; +export interface DateRangeCalendarOwnerState extends PickerOwnerState { + isDraggingDay: boolean; } export type DateRangeCalendarDefaultizedProps = DefaultizedProps< diff --git a/packages/x-date-pickers/src/DateCalendar/DateCalendar.tsx b/packages/x-date-pickers/src/DateCalendar/DateCalendar.tsx index 77af1660e28fa..edaa6b21f8dbe 100644 --- a/packages/x-date-pickers/src/DateCalendar/DateCalendar.tsx +++ b/packages/x-date-pickers/src/DateCalendar/DateCalendar.tsx @@ -25,15 +25,15 @@ import { } from '../internals/utils/date-utils'; import { PickerViewRoot } from '../internals/components/PickerViewRoot'; import { useDefaultReduceAnimations } from '../internals/hooks/useDefaultReduceAnimations'; -import { getDateCalendarUtilityClass } from './dateCalendarClasses'; +import { DateCalendarClasses, getDateCalendarUtilityClass } from './dateCalendarClasses'; import { BaseDateValidationProps } from '../internals/models/validation'; import { useControlledValueWithTimezone } from '../internals/hooks/useValueWithTimezone'; import { singleItemValueManager } from '../internals/utils/valueManagers'; import { VIEW_HEIGHT } from '../internals/constants/dimensions'; -import { PickerValidDate } from '../models'; +import { PickerOwnerState, PickerValidDate } from '../models'; +import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; -const useUtilityClasses = (ownerState: DateCalendarProps) => { - const { classes } = ownerState; +const useUtilityClasses = (classes: Partial | undefined) => { const slots = { root: ['root'], viewTransitionContainer: ['viewTransitionContainer'], @@ -73,7 +73,7 @@ const DateCalendarRoot = styled(PickerViewRoot, { name: 'MuiDateCalendar', slot: 'Root', overridesResolver: (props, styles) => styles.root, -})<{ ownerState: DateCalendarProps }>({ +})<{ ownerState: PickerOwnerState }>({ display: 'flex', flexDirection: 'column', height: VIEW_HEIGHT, @@ -83,7 +83,7 @@ const DateCalendarViewTransitionContainer = styled(PickersFadeTransitionGroup, { name: 'MuiDateCalendar', slot: 'ViewTransitionContainer', overridesResolver: (props, styles) => styles.viewTransitionContainer, -})<{ ownerState: DateCalendarProps }>({}); +})<{ ownerState: PickerOwnerState }>({}); type DateCalendarComponent = (( props: DateCalendarProps & React.RefAttributes, @@ -105,6 +105,7 @@ export const DateCalendar = React.forwardRef(function DateCalendar, ) { const utils = useUtils(); + const { ownerState } = usePickersPrivateContext(); const id = useId(); const props = useDateCalendarDefaultizedProps(inProps, 'MuiDateCalendar'); @@ -127,6 +128,7 @@ export const DateCalendar = React.forwardRef(function DateCalendar { @@ -295,8 +297,7 @@ export const DateCalendar = React.forwardRef(function DateCalendar> = { disablePast, diff --git a/packages/x-date-pickers/src/DateCalendar/DateCalendar.types.ts b/packages/x-date-pickers/src/DateCalendar/DateCalendar.types.ts index cc378565575de..8a872742b850d 100644 --- a/packages/x-date-pickers/src/DateCalendar/DateCalendar.types.ts +++ b/packages/x-date-pickers/src/DateCalendar/DateCalendar.types.ts @@ -17,7 +17,7 @@ import { DayValidationProps, } from '../internals/models/validation'; import { ExportedUseViewsOptions } from '../internals/hooks/useViews'; -import { DateView, PickerValidDate, TimezoneProps } from '../models'; +import { DateView, PickerOwnerState, PickerValidDate, TimezoneProps } from '../models'; import { DefaultizedProps } from '../internals/models/helpers'; import { ExportedYearCalendarProps, @@ -48,7 +48,7 @@ export interface DateCalendarSlotProps DayCalendarSlotProps, MonthCalendarSlotProps, YearCalendarSlotProps { - calendarHeader?: SlotComponentProps>; + calendarHeader?: SlotComponentProps; } export interface ExportedDateCalendarProps diff --git a/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx b/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx index 5348469f3c848..6e3ad31bc52ca 100644 --- a/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx +++ b/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx @@ -28,8 +28,10 @@ import { import { useIsDateDisabled } from './useIsDateDisabled'; import { findClosestEnabledDate, getWeekdays } from '../internals/utils/date-utils'; import { DayCalendarClasses, getDayCalendarUtilityClass } from './dayCalendarClasses'; -import { PickerValidDate, TimezoneProps } from '../models'; +import { PickerOwnerState, PickerValidDate, TimezoneProps } from '../models'; import { DefaultizedProps, SlotComponentPropsFromProps } from '../internals/models/helpers'; +import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; +import { DateCalendarClasses } from './dateCalendarClasses'; export interface DayCalendarSlots { /** @@ -41,11 +43,13 @@ export interface DayCalendarSlots { } export interface DayCalendarSlotProps { - day?: SlotComponentPropsFromProps< - PickersDayProps, - {}, - DayCalendarProps & { day: TDate; selected: boolean } - >; + day?: SlotComponentPropsFromProps, {}, PickersDayOwnerState>; +} + +export interface PickersDayOwnerState extends PickerOwnerState { + isDaySelected: boolean; + isDayDisabled: boolean; + day: TDate; } export interface ExportedDayCalendarProps @@ -120,8 +124,7 @@ export interface DayCalendarProps slotProps?: DayCalendarSlotProps; } -const useUtilityClasses = (ownerState: DayCalendarProps) => { - const { classes } = ownerState; +const useUtilityClasses = (classes: Partial | undefined) => { const slots = { root: ['root'], header: ['header'], @@ -267,11 +270,17 @@ function WrappedDay({ const utils = useUtils(); const now = useNow(timezone); + const { ownerState } = usePickersPrivateContext(); const isFocusableDay = focusableDay !== null && utils.isSameDay(day, focusableDay); const isSelected = selectedDays.some((selectedDay) => utils.isSameDay(selectedDay, day)); const isToday = utils.isSameDay(day, now); + const isDisabled = React.useMemo( + () => disabled || isDateDisabled(day), + [disabled, isDateDisabled, day], + ); + const Day = slots?.day ?? PickersDay; // We don't want to pass to ownerState down, to avoid re-rendering all the day whenever a prop changes. const { ownerState: dayOwnerState, ...dayProps } = useSlotProps({ @@ -286,14 +295,9 @@ function WrappedDay({ 'data-timestamp': utils.toJsDate(day).valueOf(), ...other, }, - ownerState: { ...parentProps, day, selected: isSelected }, + ownerState: { ...ownerState, day, isDayDisabled: isDisabled, isDaySelected: isSelected }, }); - const isDisabled = React.useMemo( - () => disabled || isDateDisabled(day), - [disabled, isDateDisabled, day], - ); - const outsideCurrentMonth = React.useMemo( () => utils.getMonth(day) !== currentMonthNumber, [utils, day, currentMonthNumber], @@ -343,6 +347,7 @@ export function DayCalendar(inProps: DayCalendarP const { onFocusedDayChange, className, + classes: classesProp, currentMonth, selectedDays, focusedDay, @@ -372,7 +377,7 @@ export function DayCalendar(inProps: DayCalendarP } = props; const now = useNow(timezone); - const classes = useUtilityClasses(props); + const classes = useUtilityClasses(classesProp); const isRtl = useRtl(); const isDateDisabled = useIsDateDisabled({ diff --git a/packages/x-date-pickers/src/DateCalendar/index.ts b/packages/x-date-pickers/src/DateCalendar/index.ts index 8e33e9e81f2a8..fcc80b87c4bb9 100644 --- a/packages/x-date-pickers/src/DateCalendar/index.ts +++ b/packages/x-date-pickers/src/DateCalendar/index.ts @@ -4,6 +4,7 @@ export type { DateCalendarSlots, DateCalendarSlotProps, } from './DateCalendar.types'; +export type { PickersDayOwnerState } from './DayCalendar'; export { getDateCalendarUtilityClass, dateCalendarClasses } from './dateCalendarClasses'; export type { DateCalendarClassKey, DateCalendarClasses } from './dateCalendarClasses'; diff --git a/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.tsx b/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.tsx index c4e8e501391e0..e4f1d636085fd 100644 --- a/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.tsx +++ b/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.tsx @@ -11,7 +11,7 @@ import { } from '@mui/utils'; import { PickersMonth } from './PickersMonth'; import { useUtils, useNow, useDefaultDates } from '../internals/hooks/useUtils'; -import { getMonthCalendarUtilityClass } from './monthCalendarClasses'; +import { getMonthCalendarUtilityClass, MonthCalendarClasses } from './monthCalendarClasses'; import { applyDefaultDate, getMonthsInYear } from '../internals/utils/date-utils'; import { DefaultizedProps } from '../internals/models/helpers'; import { MonthCalendarProps } from './MonthCalendar.types'; @@ -19,11 +19,10 @@ import { singleItemValueManager } from '../internals/utils/valueManagers'; import { SECTION_TYPE_GRANULARITY } from '../internals/utils/getDefaultReferenceDate'; import { useControlledValueWithTimezone } from '../internals/hooks/useValueWithTimezone'; import { DIALOG_WIDTH } from '../internals/constants/dimensions'; -import { PickerValidDate } from '../models'; - -const useUtilityClasses = (ownerState: MonthCalendarProps) => { - const { classes } = ownerState; +import { PickerOwnerState, PickerValidDate } from '../models'; +import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; +const useUtilityClasses = (classes: Partial | undefined) => { const slots = { root: ['root'], }; @@ -58,7 +57,7 @@ const MonthCalendarRoot = styled('div', { name: 'MuiMonthCalendar', slot: 'Root', overridesResolver: (props, styles) => styles.root, -})<{ ownerState: MonthCalendarProps }>({ +})<{ ownerState: PickerOwnerState }>({ display: 'flex', flexWrap: 'wrap', alignContent: 'stretch', @@ -88,6 +87,7 @@ export const MonthCalendar = React.forwardRef(function MonthCalendar(timezone); const isRtl = useRtl(); const utils = useUtils(); + const { ownerState } = usePickersPrivateContext(); const referenceDate = React.useMemo( () => @@ -138,8 +139,7 @@ export const MonthCalendar = React.forwardRef(function MonthCalendar utils.getMonth(now), [utils, now]); diff --git a/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts b/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts index f6e79866d913b..4716d3bb9bb03 100644 --- a/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts +++ b/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts @@ -3,10 +3,14 @@ import { SxProps } from '@mui/system'; import { Theme } from '@mui/material/styles'; import { MonthCalendarClasses } from './monthCalendarClasses'; import { BaseDateValidationProps, MonthValidationProps } from '../internals/models/validation'; -import { PickerValidDate, TimezoneProps } from '../models'; -import type { PickersMonthProps } from './PickersMonth'; +import { PickerOwnerState, PickerValidDate, TimezoneProps } from '../models'; import { SlotComponentPropsFromProps } from '../internals/models/helpers'; +export interface PickersMonthOwnerState extends PickerOwnerState { + isMonthSelected: boolean; + isMonthDisabled: boolean; +} + export interface MonthCalendarSlots { /** * Button displayed to render a single month in the `month` view. @@ -19,7 +23,7 @@ export interface MonthCalendarSlotProps { monthButton?: SlotComponentPropsFromProps< React.HTMLAttributes & { sx: SxProps }, {}, - PickersMonthProps + PickersMonthOwnerState >; } diff --git a/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx b/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx index 996df34b165b8..6803955353e61 100644 --- a/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx +++ b/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx @@ -9,7 +9,12 @@ import { pickersMonthClasses, PickersMonthClasses, } from './pickersMonthClasses'; -import { MonthCalendarSlotProps, MonthCalendarSlots } from './MonthCalendar.types'; +import { + MonthCalendarSlotProps, + MonthCalendarSlots, + PickersMonthOwnerState, +} from './MonthCalendar.types'; +import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; export interface ExportedPickersMonthProps { classes?: Partial; @@ -34,12 +39,17 @@ export interface PickersMonthProps extends ExportedPickersMonthProps { slotProps?: MonthCalendarSlotProps; } -const useUtilityClasses = (ownerState: PickersMonthProps) => { - const { disabled, selected, classes } = ownerState; - +const useUtilityClasses = ( + classes: Partial | undefined, + ownerState: PickersMonthOwnerState, +) => { const slots = { root: ['root'], - monthButton: ['monthButton', disabled && 'disabled', selected && 'selected'], + monthButton: [ + 'monthButton', + ownerState.isMonthDisabled && 'disabled', + ownerState.isMonthSelected && 'selected', + ], }; return composeClasses(slots, getPickersMonthUtilityClass, classes); @@ -50,7 +60,7 @@ const PickersMonthRoot = styled('div', { slot: 'Root', overridesResolver: (_, styles) => [styles.root], })<{ - ownerState: PickersMonthProps; + ownerState: PickersMonthOwnerState; }>({ display: 'flex', alignItems: 'center', @@ -68,7 +78,7 @@ const MonthCalendarButton = styled('button', { { [`&.${pickersMonthClasses.selected}`]: styles.selected }, ], })<{ - ownerState?: PickersMonthProps; + ownerState?: PickersMonthOwnerState; }>(({ theme }) => ({ color: 'unset', backgroundColor: 'transparent', @@ -117,9 +127,10 @@ export const PickersMonth = React.memo(function PickersMonth(inProps: PickersMon const { autoFocus, className, + classes: classesProp, children, - disabled, - selected, + disabled = false, + selected = false, value, tabIndex, onClick, @@ -136,7 +147,14 @@ export const PickersMonth = React.memo(function PickersMonth(inProps: PickersMon } = props; const ref = React.useRef(null); - const classes = useUtilityClasses(props); + const { ownerState: pickersOwnerState } = usePickersPrivateContext(); + const ownerState: PickersMonthOwnerState = { + ...pickersOwnerState, + isMonthDisabled: disabled, + isMonthSelected: selected, + }; + + const classes = useUtilityClasses(classesProp, ownerState); // We can't forward the `autoFocus` to the button because it is a native button, not a MUI Button useEnhancedEffect(() => { @@ -165,7 +183,7 @@ export const PickersMonth = React.memo(function PickersMonth(inProps: PickersMon onFocus: (event: React.FocusEvent) => onFocus(event, value), onBlur: (event: React.FocusEvent) => onBlur(event, value), }, - ownerState: props, + ownerState, className: classes.monthButton, }); @@ -173,7 +191,7 @@ export const PickersMonth = React.memo(function PickersMonth(inProps: PickersMon diff --git a/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx b/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx index 6425f9936431a..182b71503969a 100644 --- a/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx +++ b/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx @@ -9,7 +9,13 @@ import { pickersYearClasses, PickersYearClasses, } from './pickersYearClasses'; -import { YearCalendarSlotProps, YearCalendarSlots } from './YearCalendar.types'; +import { + PickersYearOwnerState, + YearCalendarSlotProps, + YearCalendarSlots, +} from './YearCalendar.types'; +import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; +import { PickerOwnerState } from '../models/pickers'; export interface ExportedPickersYearProps { classes?: Partial; @@ -33,12 +39,17 @@ export interface PickersYearProps extends ExportedPickersYearProps { slotProps?: YearCalendarSlotProps; } -const useUtilityClasses = (ownerState: PickersYearProps) => { - const { disabled, selected, classes } = ownerState; - +const useUtilityClasses = ( + classes: Partial | undefined, + ownerState: PickersYearOwnerState, +) => { const slots = { root: ['root'], - yearButton: ['yearButton', disabled && 'disabled', selected && 'selected'], + yearButton: [ + 'yearButton', + ownerState.isYearDisabled && 'disabled', + ownerState.isYearSelected && 'selected', + ], }; return composeClasses(slots, getPickersYearUtilityClass, classes); @@ -48,7 +59,7 @@ const PickersYearRoot = styled('div', { name: 'MuiPickersYear', slot: 'Root', overridesResolver: (_, styles) => [styles.root], -})<{ ownerState: PickersYearProps }>({ +})<{ ownerState: PickerOwnerState }>({ display: 'flex', alignItems: 'center', justifyContent: 'center', @@ -64,7 +75,7 @@ const YearCalendarButton = styled('button', { { [`&.${pickersYearClasses.disabled}`]: styles.disabled }, { [`&.${pickersYearClasses.selected}`]: styles.selected }, ], -})<{ ownerState: PickersYearProps }>(({ theme }) => ({ +})<{ ownerState: PickerOwnerState }>(({ theme }) => ({ color: 'unset', backgroundColor: 'transparent', border: 0, @@ -112,9 +123,10 @@ export const PickersYear = React.memo(function PickersYear(inProps: PickersYearP const { autoFocus, className, + classes: classesProp, children, - disabled, - selected, + disabled = false, + selected = false, value, tabIndex, onClick, @@ -130,7 +142,13 @@ export const PickersYear = React.memo(function PickersYear(inProps: PickersYearP } = props; const ref = React.useRef(null); - const classes = useUtilityClasses(props); + const { ownerState: pickersOwnerState } = usePickersPrivateContext(); + const ownerState: PickersYearOwnerState = { + ...pickersOwnerState, + isYearDisabled: disabled, + isYearSelected: selected, + }; + const classes = useUtilityClasses(classesProp, ownerState); // We can't forward the `autoFocus` to the button because it is a native button, not a MUI Button useEnhancedEffect(() => { @@ -158,7 +176,7 @@ export const PickersYear = React.memo(function PickersYear(inProps: PickersYearP onFocus: (event: React.FocusEvent) => onFocus(event, value), onBlur: (event: React.FocusEvent) => onBlur(event, value), }, - ownerState: props, + ownerState, className: classes.yearButton, }); @@ -166,7 +184,7 @@ export const PickersYear = React.memo(function PickersYear(inProps: PickersYearP diff --git a/packages/x-date-pickers/src/YearCalendar/YearCalendar.tsx b/packages/x-date-pickers/src/YearCalendar/YearCalendar.tsx index 54ba0510d32c1..130d4f5f65d5a 100644 --- a/packages/x-date-pickers/src/YearCalendar/YearCalendar.tsx +++ b/packages/x-date-pickers/src/YearCalendar/YearCalendar.tsx @@ -12,7 +12,7 @@ import { } from '@mui/utils'; import { PickersYear } from './PickersYear'; import { useUtils, useNow, useDefaultDates } from '../internals/hooks/useUtils'; -import { getYearCalendarUtilityClass } from './yearCalendarClasses'; +import { getYearCalendarUtilityClass, YearCalendarClasses } from './yearCalendarClasses'; import { DefaultizedProps } from '../internals/models/helpers'; import { applyDefaultDate } from '../internals/utils/date-utils'; import { YearCalendarProps } from './YearCalendar.types'; @@ -20,11 +20,10 @@ import { singleItemValueManager } from '../internals/utils/valueManagers'; import { SECTION_TYPE_GRANULARITY } from '../internals/utils/getDefaultReferenceDate'; import { useControlledValueWithTimezone } from '../internals/hooks/useValueWithTimezone'; import { DIALOG_WIDTH, MAX_CALENDAR_HEIGHT } from '../internals/constants/dimensions'; -import { PickerValidDate } from '../models'; - -const useUtilityClasses = (ownerState: YearCalendarProps) => { - const { classes } = ownerState; +import { PickerOwnerState, PickerValidDate } from '../models'; +import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; +const useUtilityClasses = (classes: Partial | undefined) => { const slots = { root: ['root'], }; @@ -60,7 +59,7 @@ const YearCalendarRoot = styled('div', { name: 'MuiYearCalendar', slot: 'Root', overridesResolver: (props, styles) => styles.root, -})<{ ownerState: YearCalendarProps }>({ +})<{ ownerState: PickerOwnerState }>({ display: 'flex', flexDirection: 'row', flexWrap: 'wrap', @@ -97,6 +96,7 @@ export const YearCalendar = React.forwardRef(function YearCalendar(timezone); const isRtl = useRtl(); const utils = useUtils(); + const { ownerState } = usePickersPrivateContext(); const referenceDate = React.useMemo( () => @@ -147,8 +148,7 @@ export const YearCalendar = React.forwardRef(function YearCalendar utils.getYear(now), [utils, now]); const selectedYear = React.useMemo(() => { diff --git a/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts b/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts index 8a3d3a94d946c..70846ec992592 100644 --- a/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts +++ b/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts @@ -3,10 +3,14 @@ import { SxProps } from '@mui/system'; import { Theme } from '@mui/material/styles'; import { YearCalendarClasses } from './yearCalendarClasses'; import { BaseDateValidationProps, YearValidationProps } from '../internals/models/validation'; -import { PickerValidDate, TimezoneProps } from '../models'; -import type { PickersYearProps } from './PickersYear'; +import { PickerOwnerState, PickerValidDate, TimezoneProps } from '../models'; import { SlotComponentPropsFromProps } from '../internals/models/helpers'; +export interface PickersYearOwnerState extends PickerOwnerState { + isYearSelected: boolean; + isYearDisabled: boolean; +} + export interface YearCalendarSlots { /** * Button displayed to render a single year in the `year` view. @@ -19,7 +23,7 @@ export interface YearCalendarSlotProps { yearButton?: SlotComponentPropsFromProps< React.HTMLAttributes & { sx: SxProps }, {}, - PickersYearProps + PickersYearOwnerState >; } diff --git a/packages/x-date-pickers/src/internals/index.ts b/packages/x-date-pickers/src/internals/index.ts index 49700d3461341..b37548997c4f7 100644 --- a/packages/x-date-pickers/src/internals/index.ts +++ b/packages/x-date-pickers/src/internals/index.ts @@ -84,6 +84,7 @@ export type { PickerViewRenderer, UsePickerViewsProps, } from './hooks/usePicker/usePickerViews'; +export { usePickersPrivateContext } from './hooks/usePickersPrivateContext'; export { useStaticPicker } from './hooks/useStaticPicker'; export type { StaticOnlyPickerProps, diff --git a/scripts/x-date-pickers-pro.exports.json b/scripts/x-date-pickers-pro.exports.json index 581ce00f24b3c..14a4fb6c5f526 100644 --- a/scripts/x-date-pickers-pro.exports.json +++ b/scripts/x-date-pickers-pro.exports.json @@ -267,6 +267,7 @@ { "name": "pickersDayClasses", "kind": "Variable" }, { "name": "PickersDayClasses", "kind": "Interface" }, { "name": "PickersDayClassKey", "kind": "TypeAlias" }, + { "name": "PickersDayOwnerState", "kind": "Interface" }, { "name": "PickersDayProps", "kind": "Interface" }, { "name": "pickersFadeTransitionGroupClasses", "kind": "Variable" }, { "name": "PickersFadeTransitionGroupClasses", "kind": "Interface" }, diff --git a/scripts/x-date-pickers.exports.json b/scripts/x-date-pickers.exports.json index 94e004c0da2de..9a70e0ecd8dfb 100644 --- a/scripts/x-date-pickers.exports.json +++ b/scripts/x-date-pickers.exports.json @@ -180,6 +180,7 @@ { "name": "pickersDayClasses", "kind": "Variable" }, { "name": "PickersDayClasses", "kind": "Interface" }, { "name": "PickersDayClassKey", "kind": "TypeAlias" }, + { "name": "PickersDayOwnerState", "kind": "Interface" }, { "name": "PickersDayProps", "kind": "Interface" }, { "name": "pickersFadeTransitionGroupClasses", "kind": "Variable" }, { "name": "PickersFadeTransitionGroupClasses", "kind": "Interface" }, From 4915d890b4013daa363f2ec3f5a22e30aebee139 Mon Sep 17 00:00:00 2001 From: flavien Date: Tue, 29 Oct 2024 18:36:14 +0100 Subject: [PATCH 2/6] Fix --- .../src/internals/hooks/usePickersPrivateContext.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts b/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts index 9d03e894944ad..822ae77145f81 100644 --- a/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts +++ b/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts @@ -1,12 +1,12 @@ 'use client'; import * as React from 'react'; -import { PickersContext, PickersPrivateContextValue } from '../components/PickersProvider'; +import { PickersPrivateContext, PickersPrivateContextValue } from '../components/PickersProvider'; /** * Returns the private context passed by the picker that wraps the current component. */ export const usePickersPrivateContext = () => { - const value = React.useContext(PickersContext) as PickersPrivateContextValue | null; + const value = React.useContext(PickersPrivateContext) as PickersPrivateContextValue | null; if (value == null) { throw new Error( 'MUI X: The `usePickersPrivateContext` can only be called in components that are used inside a picker component.', From 75e7bd0efee61cbc718bdb15588cc808144de1a7 Mon Sep 17 00:00:00 2001 From: flavien Date: Wed, 30 Oct 2024 10:08:38 +0100 Subject: [PATCH 3/6] Work --- .../src/internals/components/PickersProvider.tsx | 9 ++++++++- .../src/internals/hooks/usePickersPrivateContext.ts | 13 ++----------- packages/x-date-pickers/src/models/pickers.ts | 6 +++++- 3 files changed, 15 insertions(+), 13 deletions(-) diff --git a/packages/x-date-pickers/src/internals/components/PickersProvider.tsx b/packages/x-date-pickers/src/internals/components/PickersProvider.tsx index 0f1d329814724..36c5794492d44 100644 --- a/packages/x-date-pickers/src/internals/components/PickersProvider.tsx +++ b/packages/x-date-pickers/src/internals/components/PickersProvider.tsx @@ -5,7 +5,14 @@ import { LocalizationProvider } from '../../LocalizationProvider'; export const PickersContext = React.createContext(null); -export const PickersPrivateContext = React.createContext(null); +export const PickersPrivateContext = React.createContext({ + ownerState: { + isPickerDisabled: false, + isPickerReadOnly: false, + isPickerValueEmpty: false, + isPickerOpen: false, + }, +}); /** * Provides the context for the various parts of a picker component: diff --git a/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts b/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts index 822ae77145f81..d862d11186d0d 100644 --- a/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts +++ b/packages/x-date-pickers/src/internals/hooks/usePickersPrivateContext.ts @@ -1,17 +1,8 @@ 'use client'; import * as React from 'react'; -import { PickersPrivateContext, PickersPrivateContextValue } from '../components/PickersProvider'; +import { PickersPrivateContext } from '../components/PickersProvider'; /** * Returns the private context passed by the picker that wraps the current component. */ -export const usePickersPrivateContext = () => { - const value = React.useContext(PickersPrivateContext) as PickersPrivateContextValue | null; - if (value == null) { - throw new Error( - 'MUI X: The `usePickersPrivateContext` can only be called in components that are used inside a picker component.', - ); - } - - return value; -}; +export const usePickersPrivateContext = () => React.useContext(PickersPrivateContext); diff --git a/packages/x-date-pickers/src/models/pickers.ts b/packages/x-date-pickers/src/models/pickers.ts index d255b1519e291..69a2750e20f15 100644 --- a/packages/x-date-pickers/src/models/pickers.ts +++ b/packages/x-date-pickers/src/models/pickers.ts @@ -17,19 +17,23 @@ export type PickerValidDate = keyof PickerValidDateLookup extends never export interface PickerOwnerState { /** - * `true` if the value is currently empty. + * `true` if the value of the picker is currently empty. + * Is always `false` if the component you are accessing the ownerState from is not wrapped by a picker. */ isPickerValueEmpty: boolean; /** * `true` if the picker is open, `false` otherwise. + * Is always `false` if the component you are accessing the ownerState from is not wrapped by a picker. */ isPickerOpen: boolean; /** * `true` if the picker is disabled, `false` otherwise. + * Is always `false` if the component you are accessing the ownerState from is not wrapped by a picker. */ isPickerDisabled: boolean; /** * `true` if the picker is read-only, `false` otherwise. + * Is always `false` if the component you are accessing the ownerState from is not wrapped by a picker. */ isPickerReadOnly: boolean; } From 2c328480c63d1e778297f0d537c29a24411d74ee Mon Sep 17 00:00:00 2001 From: flavien Date: Wed, 6 Nov 2024 10:50:26 +0100 Subject: [PATCH 4/6] Code review: Lukas --- .../src/DateCalendar/DayCalendar.tsx | 4 ++-- packages/x-date-pickers/src/DateCalendar/index.ts | 2 +- .../src/MonthCalendar/MonthCalendar.types.ts | 4 ++-- .../src/MonthCalendar/PickersMonth.tsx | 14 +++++++------- .../src/YearCalendar/PickersYear.tsx | 10 +++++----- .../src/YearCalendar/YearCalendar.types.ts | 4 ++-- 6 files changed, 19 insertions(+), 19 deletions(-) diff --git a/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx b/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx index 3087658eb4545..2c56d7b9d8cf8 100644 --- a/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx +++ b/packages/x-date-pickers/src/DateCalendar/DayCalendar.tsx @@ -43,10 +43,10 @@ export interface DayCalendarSlots { } export interface DayCalendarSlotProps { - day?: SlotComponentPropsFromProps; + day?: SlotComponentPropsFromProps; } -export interface PickersDayOwnerState extends PickerOwnerState { +export interface PickerDayOwnerState extends PickerOwnerState { isDaySelected: boolean; isDayDisabled: boolean; day: PickerValidDate; diff --git a/packages/x-date-pickers/src/DateCalendar/index.ts b/packages/x-date-pickers/src/DateCalendar/index.ts index fcc80b87c4bb9..6829691b453d0 100644 --- a/packages/x-date-pickers/src/DateCalendar/index.ts +++ b/packages/x-date-pickers/src/DateCalendar/index.ts @@ -4,7 +4,7 @@ export type { DateCalendarSlots, DateCalendarSlotProps, } from './DateCalendar.types'; -export type { PickersDayOwnerState } from './DayCalendar'; +export type { PickerDayOwnerState as PickersDayOwnerState } from './DayCalendar'; export { getDateCalendarUtilityClass, dateCalendarClasses } from './dateCalendarClasses'; export type { DateCalendarClassKey, DateCalendarClasses } from './dateCalendarClasses'; diff --git a/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts b/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts index 6be0b17c45b1e..427026de066f9 100644 --- a/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts +++ b/packages/x-date-pickers/src/MonthCalendar/MonthCalendar.types.ts @@ -6,7 +6,7 @@ import { MonthCalendarClasses } from './monthCalendarClasses'; import { BaseDateValidationProps, MonthValidationProps } from '../internals/models/validation'; import { PickerOwnerState, PickerValidDate, TimezoneProps } from '../models'; -export interface PickersMonthOwnerState extends PickerOwnerState { +export interface PickerMonthOwnerState extends PickerOwnerState { isMonthSelected: boolean; isMonthDisabled: boolean; } @@ -23,7 +23,7 @@ export interface MonthCalendarSlotProps { monthButton?: SlotComponentPropsFromProps< React.HTMLAttributes & { sx: SxProps }, {}, - PickersMonthOwnerState + PickerMonthOwnerState >; } diff --git a/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx b/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx index 6803955353e61..1472fa21daa36 100644 --- a/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx +++ b/packages/x-date-pickers/src/MonthCalendar/PickersMonth.tsx @@ -12,7 +12,7 @@ import { import { MonthCalendarSlotProps, MonthCalendarSlots, - PickersMonthOwnerState, + PickerMonthOwnerState, } from './MonthCalendar.types'; import { usePickersPrivateContext } from '../internals/hooks/usePickersPrivateContext'; @@ -41,7 +41,7 @@ export interface PickersMonthProps extends ExportedPickersMonthProps { const useUtilityClasses = ( classes: Partial | undefined, - ownerState: PickersMonthOwnerState, + ownerState: PickerMonthOwnerState, ) => { const slots = { root: ['root'], @@ -60,7 +60,7 @@ const PickersMonthRoot = styled('div', { slot: 'Root', overridesResolver: (_, styles) => [styles.root], })<{ - ownerState: PickersMonthOwnerState; + ownerState: PickerMonthOwnerState; }>({ display: 'flex', alignItems: 'center', @@ -78,7 +78,7 @@ const MonthCalendarButton = styled('button', { { [`&.${pickersMonthClasses.selected}`]: styles.selected }, ], })<{ - ownerState?: PickersMonthOwnerState; + ownerState?: PickerMonthOwnerState; }>(({ theme }) => ({ color: 'unset', backgroundColor: 'transparent', @@ -147,9 +147,9 @@ export const PickersMonth = React.memo(function PickersMonth(inProps: PickersMon } = props; const ref = React.useRef(null); - const { ownerState: pickersOwnerState } = usePickersPrivateContext(); - const ownerState: PickersMonthOwnerState = { - ...pickersOwnerState, + const { ownerState: pickerOwnerState } = usePickersPrivateContext(); + const ownerState: PickerMonthOwnerState = { + ...pickerOwnerState, isMonthDisabled: disabled, isMonthSelected: selected, }; diff --git a/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx b/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx index 182b71503969a..e214e4bf2b3d9 100644 --- a/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx +++ b/packages/x-date-pickers/src/YearCalendar/PickersYear.tsx @@ -10,7 +10,7 @@ import { PickersYearClasses, } from './pickersYearClasses'; import { - PickersYearOwnerState, + PickerYearOwnerState, YearCalendarSlotProps, YearCalendarSlots, } from './YearCalendar.types'; @@ -41,7 +41,7 @@ export interface PickersYearProps extends ExportedPickersYearProps { const useUtilityClasses = ( classes: Partial | undefined, - ownerState: PickersYearOwnerState, + ownerState: PickerYearOwnerState, ) => { const slots = { root: ['root'], @@ -142,9 +142,9 @@ export const PickersYear = React.memo(function PickersYear(inProps: PickersYearP } = props; const ref = React.useRef(null); - const { ownerState: pickersOwnerState } = usePickersPrivateContext(); - const ownerState: PickersYearOwnerState = { - ...pickersOwnerState, + const { ownerState: pickerOwnerState } = usePickersPrivateContext(); + const ownerState: PickerYearOwnerState = { + ...pickerOwnerState, isYearDisabled: disabled, isYearSelected: selected, }; diff --git a/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts b/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts index 30ccdbd995ecf..821314c326a89 100644 --- a/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts +++ b/packages/x-date-pickers/src/YearCalendar/YearCalendar.types.ts @@ -6,7 +6,7 @@ import { YearCalendarClasses } from './yearCalendarClasses'; import { BaseDateValidationProps, YearValidationProps } from '../internals/models/validation'; import { PickerOwnerState, PickerValidDate, TimezoneProps } from '../models'; -export interface PickersYearOwnerState extends PickerOwnerState { +export interface PickerYearOwnerState extends PickerOwnerState { isYearSelected: boolean; isYearDisabled: boolean; } @@ -23,7 +23,7 @@ export interface YearCalendarSlotProps { yearButton?: SlotComponentPropsFromProps< React.HTMLAttributes & { sx: SxProps }, {}, - PickersYearOwnerState + PickerYearOwnerState >; } From d2a79af0fff2939e3a514c6bc36d71201f1d12d8 Mon Sep 17 00:00:00 2001 From: flavien Date: Wed, 6 Nov 2024 12:13:26 +0100 Subject: [PATCH 5/6] Review: Lukas --- .../src/DateRangeCalendar/DateRangeCalendar.types.ts | 4 ++-- packages/x-date-pickers/src/DateCalendar/index.ts | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts b/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts index 9a8c355894556..58643ecdf32d1 100644 --- a/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts +++ b/packages/x-date-pickers-pro/src/DateRangeCalendar/DateRangeCalendar.types.ts @@ -9,7 +9,7 @@ import { PickersCalendarHeaderSlots, PickersCalendarHeaderSlotProps, } from '@mui/x-date-pickers/PickersCalendarHeader'; -import { PickersDayOwnerState } from '@mui/x-date-pickers/DateCalendar'; +import { PickerDayOwnerState } from '@mui/x-date-pickers/DateCalendar'; import { BaseDateValidationProps, ExportedDayCalendarProps, @@ -54,7 +54,7 @@ export interface DateRangeCalendarSlotProps {}, DateRangeCalendarOwnerState >; - day?: SlotComponentProps; + day?: SlotComponentProps; } export interface ExportedDateRangeCalendarProps diff --git a/packages/x-date-pickers/src/DateCalendar/index.ts b/packages/x-date-pickers/src/DateCalendar/index.ts index 6829691b453d0..8aaa199a8fef4 100644 --- a/packages/x-date-pickers/src/DateCalendar/index.ts +++ b/packages/x-date-pickers/src/DateCalendar/index.ts @@ -4,7 +4,7 @@ export type { DateCalendarSlots, DateCalendarSlotProps, } from './DateCalendar.types'; -export type { PickerDayOwnerState as PickersDayOwnerState } from './DayCalendar'; +export type { PickerDayOwnerState } from './DayCalendar'; export { getDateCalendarUtilityClass, dateCalendarClasses } from './dateCalendarClasses'; export type { DateCalendarClassKey, DateCalendarClasses } from './dateCalendarClasses'; From 322686338d0b086035b2d984391e947bccc25833 Mon Sep 17 00:00:00 2001 From: flavien Date: Wed, 6 Nov 2024 13:01:14 +0100 Subject: [PATCH 6/6] Regen API --- scripts/x-date-pickers-pro.exports.json | 2 +- scripts/x-date-pickers.exports.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/scripts/x-date-pickers-pro.exports.json b/scripts/x-date-pickers-pro.exports.json index e7d0c89ab816c..b25c77e061348 100644 --- a/scripts/x-date-pickers-pro.exports.json +++ b/scripts/x-date-pickers-pro.exports.json @@ -249,6 +249,7 @@ { "name": "NonEmptyDateRange", "kind": "TypeAlias" }, { "name": "OnErrorProps", "kind": "Interface" }, { "name": "PickerChangeHandlerContext", "kind": "Interface" }, + { "name": "PickerDayOwnerState", "kind": "Interface" }, { "name": "PickerOwnerState", "kind": "Interface" }, { "name": "PickersActionBar", "kind": "Function" }, { "name": "PickersActionBarAction", "kind": "TypeAlias" }, @@ -266,7 +267,6 @@ { "name": "pickersDayClasses", "kind": "Variable" }, { "name": "PickersDayClasses", "kind": "Interface" }, { "name": "PickersDayClassKey", "kind": "TypeAlias" }, - { "name": "PickersDayOwnerState", "kind": "Interface" }, { "name": "PickersDayProps", "kind": "Interface" }, { "name": "pickersFadeTransitionGroupClasses", "kind": "Variable" }, { "name": "PickersFadeTransitionGroupClasses", "kind": "Interface" }, diff --git a/scripts/x-date-pickers.exports.json b/scripts/x-date-pickers.exports.json index 9a70e0ecd8dfb..5ec0e96bfc2e3 100644 --- a/scripts/x-date-pickers.exports.json +++ b/scripts/x-date-pickers.exports.json @@ -163,6 +163,7 @@ { "name": "MultiSectionDigitalClockSlots", "kind": "Interface" }, { "name": "OnErrorProps", "kind": "Interface" }, { "name": "PickerChangeHandlerContext", "kind": "Interface" }, + { "name": "PickerDayOwnerState", "kind": "Interface" }, { "name": "PickerOwnerState", "kind": "Interface" }, { "name": "PickersActionBar", "kind": "Function" }, { "name": "PickersActionBarAction", "kind": "TypeAlias" }, @@ -180,7 +181,6 @@ { "name": "pickersDayClasses", "kind": "Variable" }, { "name": "PickersDayClasses", "kind": "Interface" }, { "name": "PickersDayClassKey", "kind": "TypeAlias" }, - { "name": "PickersDayOwnerState", "kind": "Interface" }, { "name": "PickersDayProps", "kind": "Interface" }, { "name": "pickersFadeTransitionGroupClasses", "kind": "Variable" }, { "name": "PickersFadeTransitionGroupClasses", "kind": "Interface" },