Skip to content

Commit

Permalink
[pickers] Add the variant and the orientation to the ownerState and t…
Browse files Browse the repository at this point in the history
…o the private context
  • Loading branch information
flaviendelangle committed Nov 14, 2024
1 parent e9c13ba commit 6b86c85
Show file tree
Hide file tree
Showing 22 changed files with 203 additions and 91 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import {
ExportedBaseToolbarProps,
useUtils,
DateOrTimeViewWithMeridiem,
WrapperVariant,
PickerVariant,
PickerRangeValue,
} from '@mui/x-date-pickers/internals';
import { usePickerTranslations } from '@mui/x-date-pickers/hooks';
Expand Down Expand Up @@ -43,7 +43,7 @@ export interface DateTimeRangePickerToolbarProps
Pick<UseRangePositionResponse, 'rangePosition' | 'onRangePositionChange'>,
ExportedDateTimeRangePickerToolbarProps {
ampm?: boolean;
toolbarVariant?: WrapperVariant;
toolbarVariant?: PickerVariant;
}

export interface ExportedDateTimeRangePickerToolbarProps extends ExportedBaseToolbarProps {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@ export const useDesktopRangePicker = <
>({
...pickerParams,
props,
wrapperVariant: 'desktop',
variant: 'desktop',
autoFocusView: false,
fieldRef: rangePosition === 'start' ? startFieldRef : endFieldRef,
localeText,
Expand Down Expand Up @@ -164,7 +164,7 @@ export const useDesktopRangePicker = <
TEnableAccessibleFieldDOMStructure,
InferError<TExternalProps>
>({
wrapperVariant: 'desktop',
variant: 'desktop',
fieldType,
open,
actions,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ import { PickersInputLocaleText } from '@mui/x-date-pickers/locales';
import {
onSpaceOrEnter,
UsePickerResponse,
WrapperVariant,
PickerVariant,
DateOrTimeViewWithMeridiem,
BaseSingleInputFieldProps,
PickerRangeValue,
Expand Down Expand Up @@ -106,7 +106,7 @@ export interface UseEnrichedRangePickerFieldPropsParams<
'open' | 'actions'
>,
UseRangePositionResponse {
wrapperVariant: WrapperVariant;
variant: PickerVariant;
fieldType: FieldType;
readOnly?: boolean;
labelId?: string;
Expand Down Expand Up @@ -134,7 +134,7 @@ const useMultiInputFieldSlotProps = <
TEnableAccessibleFieldDOMStructure extends boolean,
TError,
>({
wrapperVariant,
variant,
open,
actions,
readOnly,
Expand Down Expand Up @@ -251,7 +251,7 @@ const useMultiInputFieldSlotProps = <
// registering `onClick` listener on the root element as well to correctly handle cases where user is clicking on `label`
// which has `pointer-events: none` and due to DOM structure the `input` does not catch the click event
...(!readOnly && !fieldProps.disabled && { onClick: openRangeStartSelection }),
...(wrapperVariant === 'mobile' && { readOnly: true }),
...(variant === 'mobile' && { readOnly: true }),
};
if (anchorRef) {
InputProps = {
Expand All @@ -268,7 +268,7 @@ const useMultiInputFieldSlotProps = <
// registering `onClick` listener on the root element as well to correctly handle cases where user is clicking on `label`
// which has `pointer-events: none` and due to DOM structure the `input` does not catch the click event
...(!readOnly && !fieldProps.disabled && { onClick: openRangeEndSelection }),
...(wrapperVariant === 'mobile' && { readOnly: true }),
...(variant === 'mobile' && { readOnly: true }),
};
InputProps = resolvedComponentProps?.InputProps;
}
Expand Down Expand Up @@ -312,7 +312,7 @@ const useSingleInputFieldSlotProps = <
TEnableAccessibleFieldDOMStructure extends boolean,
TError,
>({
wrapperVariant,
variant,
open,
actions,
readOnly,
Expand Down Expand Up @@ -423,7 +423,7 @@ const useSingleInputFieldSlotProps = <
},
focused: open ? true : undefined,
...(labelId != null && { id: labelId }),
...(wrapperVariant === 'mobile' && { readOnly: true }),
...(variant === 'mobile' && { readOnly: true }),
// registering `onClick` listener on the root element as well to correctly handle cases where user is clicking on `label`
// which has `pointer-events: none` and due to DOM structure the `input` does not catch the click event
...(!readOnly && !fieldProps.disabled && { onClick: openPicker }),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ export const useMobileRangePicker = <
>({
...pickerParams,
props,
wrapperVariant: 'mobile',
variant: 'mobile',
autoFocusView: true,
fieldRef: rangePosition === 'start' ? startFieldRef : endFieldRef,
localeText,
Expand Down Expand Up @@ -139,7 +139,7 @@ export const useMobileRangePicker = <
TEnableAccessibleFieldDOMStructure,
InferError<TExternalProps>
>({
wrapperVariant: 'mobile',
variant: 'mobile',
fieldType,
open,
actions,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ export const useStaticRangePicker = <
rangePosition,
onRangePositionChange,
},
wrapperVariant: displayStaticWrapperAs,
variant: displayStaticWrapperAs,
});

const Layout = slots?.layout ?? PickerStaticLayout;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import {
DateTimePickerToolbarClasses,
getDateTimePickerToolbarUtilityClass,
} from './dateTimePickerToolbarClasses';
import { DateOrTimeViewWithMeridiem, WrapperVariant } from '../internals/models';
import { DateOrTimeViewWithMeridiem, PickerVariant } from '../internals/models';
import { useMeridiemMode } from '../internals/hooks/date-helpers-hooks';
import { MULTI_SECTION_CLOCK_SECTION_WIDTH } from '../internals/constants/dimensions';
import { formatMeridiem } from '../internals/utils/date-utils';
Expand All @@ -35,7 +35,7 @@ export interface ExportedDateTimePickerToolbarProps extends ExportedBaseToolbarP
export interface DateTimePickerToolbarProps
extends ExportedDateTimePickerToolbarProps,
MakeOptional<BaseToolbarProps<PickerValidDate | null, DateOrTimeViewWithMeridiem>, 'view'> {
toolbarVariant?: WrapperVariant;
toolbarVariant?: PickerVariant;
/**
* If provided, it will be used instead of `dateTimePickerToolbarTitle` from localization.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { BaseToolbarProps, ExportedBaseToolbarProps } from '../internals/models/
import { BaseTabsProps, ExportedBaseTabsProps } from '../internals/models/props/tabs';
import { UsePickerLayoutPropsResponseLayoutProps } from '../internals/hooks/usePicker/usePickerLayoutProps';
import { PickersLayoutClasses } from './pickersLayoutClasses';
import { DateOrTimeViewWithMeridiem, WrapperVariant } from '../internals/models/common';
import { DateOrTimeViewWithMeridiem, PickerVariant } from '../internals/models/common';
import { PickersShortcutsProps } from '../PickersShortcuts';
import {
ExportedPickersShortcutProps,
Expand Down Expand Up @@ -35,7 +35,7 @@ export interface ExportedPickersLayoutSlots<TValue, TView extends DateOrTimeView
}

export interface PickerLayoutOwnerState extends PickerOwnerState {
wrapperVariant: WrapperVariant;
wrapperVariant: PickerVariant;
isLandscape: boolean;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import * as React from 'react';
import { PickerOwnerState } from '../../models';
import { PickersInputLocaleText } from '../../locales';
import { LocalizationProvider } from '../../LocalizationProvider';
import { PickerOrientation, PickerVariant } from '../models';

export const PickerContext = React.createContext<PickerContextValue | null>(null);

Expand All @@ -11,6 +12,8 @@ export const PickerPrivateContext = React.createContext<PickerPrivateContextValu
isPickerReadOnly: false,
isPickerValueEmpty: false,
isPickerOpen: false,
pickerVariant: 'desktop',
pickerOrientation: 'portrait',
},
});

Expand Down Expand Up @@ -55,6 +58,31 @@ export interface PickerContextValue {
* `true` if the picker is open, `false` otherwise.
*/
open: boolean;
/**
* `true` if the picker is disabled, `false` otherwise.
*/
disabled: boolean;
/**
* `true` if the picker is read-only, `false` otherwise.
*/
readOnly: boolean;
/**
* The responsive variant of the picker.
* Is equal to "desktop" when using a desktop picker (like <DesktopDatePicker />).
* Is equal to "mobile" when using a mobile picker (like <MobileDatePicker />).
* Is equal to "mobile" or "desktop" when using a responsive picker (like <DatePicker />) depending on the `desktopModeMediaQuery` prop.
* Is equal to "mobile" or "desktop" when using a static picker (like <StaticDatePicker />) depending on the `displayStaticWrapperAs` prop.
* Is always equal to "desktop" if the component you are accessing the ownerState from is not wrapped by a picker.
*/
variant: PickerVariant;
/**
* The orientation of the picker.
* Is equal to "landscape" when the picker is in landscape orientation.
* Is equal to "portrait" when the picker is in portrait orientation.
* You can use the "orientation" on any picker component to force the orientation.
* Is always equal to "portrait" if the component you are accessing the ownerState from is not wrapped by a picker.
*/
orientation: PickerOrientation;
}
export interface PickerPrivateContextValue {
/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ export const useDesktopPicker = <
localeText,
autoFocusView: true,
additionalViewProps: {},
wrapperVariant: 'desktop',
variant: 'desktop',
});

const InputAdornment = slots.inputAdornment ?? MuiInputAdornment;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export const useMobilePicker = <
localeText,
autoFocusView: true,
additionalViewProps: {},
wrapperVariant: 'mobile',
variant: 'mobile',
});

const Field = slots.field;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import { usePickerViews } from './usePickerViews';
import { usePickerLayoutProps } from './usePickerLayoutProps';
import { FieldSection, InferError } from '../../../models';
import { DateOrTimeViewWithMeridiem } from '../../models';
import { usePickerOwnerState } from './usePickerOwnerState';
import { usePickerProvider } from './usePickerProvider';

export const usePicker = <
Expand All @@ -18,7 +17,7 @@ export const usePicker = <
props,
valueManager,
valueType,
wrapperVariant,
variant,
additionalViewProps,
validator,
autoFocusView,
Expand All @@ -44,7 +43,7 @@ export const usePicker = <
props,
valueManager,
valueType,
wrapperVariant,
variant,
validator,
});

Expand All @@ -65,17 +64,18 @@ export const usePicker = <

const pickerLayoutResponse = usePickerLayoutProps({
props,
wrapperVariant,
variant,
propsFromPickerValue: pickerValueResponse.layoutProps,
propsFromPickerViews: pickerViewsResponse.layoutProps,
});

const pickerOwnerState = usePickerOwnerState({ props, pickerValueResponse, valueManager });

const providerProps = usePickerProvider({
props,
pickerValueResponse,
ownerState: pickerOwnerState,
localeText,
valueManager,
variant,
views: pickerViewsResponse.views,
});

return {
Expand All @@ -96,6 +96,6 @@ export const usePicker = <
providerProps,

// Picker owner state
ownerState: pickerOwnerState,
ownerState: providerProps.privateContextValue.ownerState,
};
};
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ export interface UsePickerParams<
TAdditionalProps extends {},
> extends Pick<
UsePickerValueParams<TValue, TExternalProps>,
'valueManager' | 'valueType' | 'wrapperVariant' | 'validator'
'valueManager' | 'valueType' | 'variant' | 'validator'
>,
Pick<
UsePickerViewParams<TValue, TView, TSection, TExternalProps, TAdditionalProps>,
Expand All @@ -62,7 +62,7 @@ export interface UsePickerResponse<
TSection extends FieldSection,
TError,
> extends Omit<UsePickerValueResponse<TValue, TSection, TError>, 'viewProps' | 'layoutProps'>,
Omit<UsePickerViewsResponse<TView>, 'layoutProps'>,
Omit<UsePickerViewsResponse<TView>, 'layoutProps' | 'views'>,
UsePickerLayoutPropsResponse<TValue, TView> {
ownerState: PickerOwnerState;
providerProps: UsePickerProviderReturnValue;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useRtl } from '@mui/system/RtlProvider';
import { useIsLandscape } from '../useIsLandscape';
import { UsePickerValueLayoutResponse } from './usePickerValue.types';
import { UsePickerViewsLayoutResponse } from './usePickerViews';
import { DateOrTimeViewWithMeridiem, WrapperVariant } from '../../models/common';
import { DateOrTimeViewWithMeridiem, PickerVariant } from '../../models/common';
import { FormProps } from '../../models';

/**
Expand All @@ -24,7 +24,7 @@ export interface UsePickerLayoutPropsResponseLayoutProps<
UsePickerLayoutProps {
isLandscape: boolean;
isRtl: boolean;
wrapperVariant: WrapperVariant;
wrapperVariant: PickerVariant;
isValid: (value: TValue) => boolean;
}

Expand All @@ -36,7 +36,7 @@ export interface UsePickerLayoutPropsParams<TValue, TView extends DateOrTimeView
props: UsePickerLayoutProps;
propsFromPickerValue: UsePickerValueLayoutResponse<TValue>;
propsFromPickerViews: UsePickerViewsLayoutResponse<TView>;
wrapperVariant: WrapperVariant;
variant: PickerVariant;
}

/**
Expand All @@ -46,7 +46,7 @@ export const usePickerLayoutProps = <TValue, TView extends DateOrTimeViewWithMer
props,
propsFromPickerValue,
propsFromPickerViews,
wrapperVariant,
variant,
}: UsePickerLayoutPropsParams<TValue, TView>): UsePickerLayoutPropsResponse<TValue, TView> => {
const { orientation } = props;
const isLandscape = useIsLandscape(propsFromPickerViews.views, orientation);
Expand All @@ -57,7 +57,7 @@ export const usePickerLayoutProps = <TValue, TView extends DateOrTimeViewWithMer
...propsFromPickerValue,
isLandscape,
isRtl,
wrapperVariant,
wrapperVariant: variant,
disabled: props.disabled,
readOnly: props.readOnly,
};
Expand Down

This file was deleted.

Loading

0 comments on commit 6b86c85

Please sign in to comment.