@mui/x-date-pickers
Version:
The community edition of the Date and Time Picker components (MUI X).
178 lines • 5.61 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import * as React from 'react';
import Stack, { stackClasses } from '@mui/material/Stack';
import Typography from '@mui/material/Typography';
import { textFieldClasses } from '@mui/material/TextField';
import { pickersTextFieldClasses } from "../../PickersTextField/index.js";
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
const getChildTypeFromChildName = childName => {
if (childName.match(/^([A-Za-z]+)Range(Calendar|Clock)$/)) {
return 'multi-panel-UI-view';
}
if (childName.match(/^([A-Za-z]*)(DigitalClock)$/)) {
return 'Tall-UI-view';
}
if (childName.match(/^Static([A-Za-z]+)/) || childName.match(/^([A-Za-z]+)(Calendar|Clock)$/)) {
return 'UI-view';
}
if (childName.match(/^MultiInput([A-Za-z]+)RangeField$/) || childName.match(/^([A-Za-z]+)RangePicker$/)) {
return 'multi-input-range-field';
}
if (childName.match(/^SingleInput([A-Za-z]+)RangeField$/)) {
return 'single-input-range-field';
}
return 'single-input-field';
};
const getSupportedSectionFromChildName = childName => {
if (childName.includes('DateTime')) {
return 'date-time';
}
if (childName.includes('Date')) {
return 'date';
}
return 'time';
};
/**
* WARNING: This is an internal component used in documentation to achieve a desired layout.
* Please do not use it in your application.
*/
export function DemoItem(props) {
const {
label,
children,
component,
sx: sxProp
} = props;
let spacing;
let sx = sxProp;
if (component && getChildTypeFromChildName(component) === 'multi-input-range-field') {
spacing = 1.5;
sx = _extends({}, sx, {
[`& .${textFieldClasses.root}`]: {
flexGrow: 1
}
});
} else {
spacing = 1;
}
return /*#__PURE__*/_jsxs(Stack, {
direction: "column",
alignItems: "stretch",
spacing: spacing,
sx: sx,
children: [label && /*#__PURE__*/_jsx(Typography, {
variant: "body2",
children: label
}), children]
});
}
DemoItem.displayName = 'DemoItem';
const isDemoItem = child => {
if (/*#__PURE__*/React.isValidElement(child) && typeof child.type !== 'string') {
// @ts-ignore
return child.type.displayName === 'DemoItem';
}
return false;
};
/**
* WARNING: This is an internal component used in documentation to achieve a desired layout.
* Please do not use it in your application.
*/
export function DemoContainer(props) {
const {
children,
components,
sx: sxProp
} = props;
const childrenTypes = new Set();
const childrenSupportedSections = new Set();
components.forEach(childName => {
childrenTypes.add(getChildTypeFromChildName(childName));
childrenSupportedSections.add(getSupportedSectionFromChildName(childName));
});
const getSpacing = direction => {
if (direction === 'row') {
return childrenTypes.has('UI-view') || childrenTypes.has('Tall-UI-view') ? 3 : 2;
}
return childrenTypes.has('UI-view') ? 4 : 3;
};
let direction;
let spacing;
let extraSx = {};
let demoItemSx = {};
const sx = _extends({
overflow: 'auto',
// Add padding as overflow can hide the outline text field label.
pt: 1
}, sxProp);
if (components.length > 2 || childrenTypes.has('multi-input-range-field') || childrenTypes.has('single-input-range-field') || childrenTypes.has('multi-panel-UI-view') || childrenTypes.has('UI-view') || childrenSupportedSections.has('date-time')) {
direction = 'column';
spacing = getSpacing('column');
} else {
direction = {
xs: 'column',
lg: 'row'
};
spacing = {
xs: getSpacing('column'),
lg: getSpacing('row')
};
}
if (childrenTypes.has('UI-view')) {
// noop
} else if (childrenTypes.has('single-input-range-field')) {
if (!childrenSupportedSections.has('date-time')) {
extraSx = {
[`& > .${textFieldClasses.root}, & > .${pickersTextFieldClasses.root}`]: {
minWidth: 300
}
};
} else {
extraSx = {
[`& > .${textFieldClasses.root}, & > .${pickersTextFieldClasses.root}`]: {
minWidth: {
xs: 300,
// If demo also contains MultiInputDateTimeRangeField, increase width to avoid cutting off the value.
md: childrenTypes.has('multi-input-range-field') ? 460 : 400
}
}
};
}
} else if (childrenSupportedSections.has('date-time')) {
extraSx = {
[`& > .${textFieldClasses.root}, & > .${pickersTextFieldClasses.root}`]: {
minWidth: 270
}
};
if (childrenTypes.has('multi-input-range-field')) {
// increase width for the multi input date time range fields
demoItemSx = {
[`& > .${stackClasses.root} > .${textFieldClasses.root}, & > .${stackClasses.root} > .${pickersTextFieldClasses.root}`]: {
minWidth: 210
}
};
}
} else {
extraSx = {
[`& > .${textFieldClasses.root}, & > .${pickersTextFieldClasses.root}`]: {
minWidth: 200
}
};
}
const finalSx = _extends({}, sx, extraSx);
return /*#__PURE__*/_jsx(Stack, {
direction: direction,
spacing: spacing,
sx: finalSx,
children: React.Children.map(children, child => {
if (/*#__PURE__*/React.isValidElement(child) && isDemoItem(child)) {
// Inject sx styles to the `DemoItem` if it is a direct child of `DemoContainer`.
// @ts-ignore
return /*#__PURE__*/React.cloneElement(child, {
sx: _extends({}, extraSx, demoItemSx)
});
}
return child;
})
});
}