@mui/x-date-pickers-pro
Version:
The Pro plan edition of the MUI X Date and Time Picker components.
52 lines (51 loc) • 2.63 kB
JavaScript
'use client';
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useTimeRangeManager = useTimeRangeManager;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var React = _interopRequireWildcard(require("react"));
var _hooks = require("@mui/x-date-pickers/hooks");
var _internals = require("@mui/x-date-pickers/internals");
var _valueManagers = require("../internals/utils/valueManagers");
var _validation = require("../validation");
var _dateUtils = require("../internals/utils/date-utils");
function useTimeRangeManager(parameters = {}) {
const {
enableAccessibleFieldDOMStructure = true,
dateSeparator,
ampm
} = parameters;
return React.useMemo(() => ({
valueType: 'time',
validator: _validation.validateTimeRange,
internal_valueManager: _valueManagers.rangeValueManager,
internal_fieldValueManager: (0, _valueManagers.getRangeFieldValueManager)({
dateSeparator
}),
internal_enableAccessibleFieldDOMStructure: enableAccessibleFieldDOMStructure,
internal_useApplyDefaultValuesToFieldInternalProps: useApplyDefaultValuesToTimeRangeFieldInternalProps,
internal_useOpenPickerButtonAriaLabel: createUseOpenPickerButtonAriaLabel(ampm)
}), [enableAccessibleFieldDOMStructure, dateSeparator, ampm]);
}
function createUseOpenPickerButtonAriaLabel(ampm) {
return function useOpenPickerButtonAriaLabel(value) {
const adapter = (0, _hooks.usePickerAdapter)();
const translations = (0, _hooks.usePickerTranslations)();
return React.useMemo(() => {
const formatKey = ampm ?? adapter.is12HourCycleInCurrentLocale() ? 'fullTime12h' : 'fullTime24h';
return translations.openRangePickerDialogue((0, _dateUtils.formatRange)(adapter, value, formatKey));
}, [value, translations, adapter]);
};
}
function useApplyDefaultValuesToTimeRangeFieldInternalProps(internalProps) {
const adapter = (0, _hooks.usePickerAdapter)();
const validationProps = (0, _internals.useApplyDefaultValuesToTimeValidationProps)(internalProps);
const ampm = React.useMemo(() => internalProps.ampm ?? adapter.is12HourCycleInCurrentLocale(), [internalProps.ampm, adapter]);
return React.useMemo(() => (0, _extends2.default)({}, internalProps, validationProps, {
format: internalProps.format ?? (ampm ? adapter.formats.fullTime12h : adapter.formats.fullTime24h)
}), [internalProps, validationProps, ampm, adapter]);
}
;