42 lines
1.8 KiB
JavaScript
42 lines
1.8 KiB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
import { singleItemFieldValueManager, singleItemValueManager } from '../internals/utils/valueManagers';
|
|
import { useField } from '../internals/hooks/useField';
|
|
import { validateDateTime } from '../internals/utils/validation/validateDateTime';
|
|
import { applyDefaultDate } from '../internals/utils/date-utils';
|
|
import { useUtils, useDefaultDates } from '../internals/hooks/useUtils';
|
|
import { splitFieldInternalAndForwardedProps } from '../internals/utils/fields';
|
|
const useDefaultizedDateTimeField = props => {
|
|
const utils = useUtils();
|
|
const defaultDates = useDefaultDates();
|
|
const ampm = props.ampm ?? utils.is12HourCycleInCurrentLocale();
|
|
const defaultFormat = ampm ? utils.formats.keyboardDateTime12h : utils.formats.keyboardDateTime24h;
|
|
return _extends({}, props, {
|
|
disablePast: props.disablePast ?? false,
|
|
disableFuture: props.disableFuture ?? false,
|
|
format: props.format ?? defaultFormat,
|
|
disableIgnoringDatePartForTimeValidation: Boolean(props.minDateTime || props.maxDateTime),
|
|
minDate: applyDefaultDate(utils, props.minDateTime ?? props.minDate, defaultDates.minDate),
|
|
maxDate: applyDefaultDate(utils, props.maxDateTime ?? props.maxDate, defaultDates.maxDate),
|
|
minTime: props.minDateTime ?? props.minTime,
|
|
maxTime: props.maxDateTime ?? props.maxTime
|
|
});
|
|
};
|
|
export const useDateTimeField = ({
|
|
props: inProps,
|
|
inputRef
|
|
}) => {
|
|
const props = useDefaultizedDateTimeField(inProps);
|
|
const {
|
|
forwardedProps,
|
|
internalProps
|
|
} = splitFieldInternalAndForwardedProps(props, 'date-time');
|
|
return useField({
|
|
inputRef,
|
|
forwardedProps,
|
|
internalProps,
|
|
valueManager: singleItemValueManager,
|
|
fieldValueManager: singleItemFieldValueManager,
|
|
validator: validateDateTime,
|
|
valueType: 'date-time'
|
|
});
|
|
}; |