UNPKG

material-ui-datetime-range-picker

Version:

React Datetime Range Picker Component that Implements Google's Material Design Via Material-UI.

863 lines (814 loc) 87.5 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _simpleAssign = require('simple-assign'); var _simpleAssign2 = _interopRequireDefault(_simpleAssign); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _getMuiTheme = require('material-ui/styles/getMuiTheme'); var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); var _dateUtils = require('./dateUtils'); var _DateRangePickerDialog = require('./DateRangePickerDialog'); var _DateRangePickerDialog2 = _interopRequireDefault(_DateRangePickerDialog); var _SvgIcon = require('@material-ui/core/SvgIcon'); var _SvgIcon2 = _interopRequireDefault(_SvgIcon); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var DateRangePicker = function (_Component) { _inherits(DateRangePicker, _Component); function DateRangePicker() { var _ref; var _temp, _this, _ret; _classCallCheck(this, DateRangePicker); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = DateRangePicker.__proto__ || Object.getPrototypeOf(DateRangePicker)).call.apply(_ref, [this].concat(args))), _this), _this.state = { dialogVisible: false, startDate: undefined, endDate: undefined, selectedStartDate: undefined, selectedEndDate: undefined }, _this.handleAccept = function (dates, keepOpen) { if (!_this.isControlled()) { _this.setState({ startDate: dates.start, endDate: dates.end, dialogVisible: keepOpen || false, selectedStartDate: dates.start, selectedEndDate: dates.end }); if (_this.props.onChange) { _this.props.onChange(null, dates); } } else { _this.setState({ dialogVisible: keepOpen || false }); if (_this.props.onChange) { _this.props.onChange(null, dates); } } }, _this.handleUpdate = function (dates) { _this.setState({ selectedStartDate: dates.start, selectedEndDate: dates.end }); }, _this.handleShow = function () { _this.setState({ dialogVisible: true }); if (_this.props.onShow) _this.props.onShow(); }, _this.handleDismiss = function (dates) { _this.setState({ selectedStartDate: undefined, selectedEndDate: undefined, dialogVisible: false }); if (_this.props.onDismiss) _this.props.onDismiss(null, dates); }, _this.handleFocus = function (event) { event.target.blur(); if (_this.props.onFocus) { _this.props.onFocus(event); } }, _this.handleTouchTap = function (showRef, startEnd, dateTime, disabled, event) { if (!disabled) { if (_this.props.onClick) { _this.props.onClick(event); } if (!_this.props.disabled) { setTimeout(function () { _this.openDialog(showRef, startEnd, dateTime); }, 0); } } }, _this.formatDate = function (date) { if (_this.props.locale) { var DateTimeFormat = _this.props.DateTimeFormat || _dateUtils.dateTimeFormat; return new DateTimeFormat(_this.props.locale, { day: 'numeric', month: 'numeric', year: 'numeric' }).format(date); } else { return (0, _dateUtils.formatIso)(date); } }, _this.dropdownArrow = function (disabled) { var layout = _this.props.layout; var style = { fill: disabled ? '#a2a2a2' : '#757575', width: '10px', height: '6px', marginRight: '10px' }; return layout !== 'single' && _react2.default.createElement( _SvgIcon2.default, { viewBox: '3064 -23442 10 6', style: style }, _react2.default.createElement('path', { d: 'M23.07,10a.707.707,0,0,1-.479-.19.684.684,0,0,1,0-.949L26.485,5,22.591,1.139a.684.684,0,0,1,0-.949.7.7,0,0,1,.957,0L28.4,5,23.549,9.81A.652.652,0,0,1,23.07,10Z' // eslint-disable-line max-len , transform: 'translate(3074 -23464.4) rotate(90)' }) ); }, _temp), _possibleConstructorReturn(_this, _ret); } _createClass(DateRangePicker, [{ key: 'getChildContext', value: function getChildContext() { return { muiTheme: this.getTheme() }; } }, { key: 'getTheme', value: function getTheme() { return this.context.muiTheme || (0, _getMuiTheme2.default)(); } }, { key: 'UNSAFE_componentWillMount', value: function UNSAFE_componentWillMount() { var newDates = this.getControlledDate(); if (this.isControlled() && newDates) { this.setState({ startDate: newDates.start, endDate: newDates.end }); } else { this.setState({ startDate: undefined, endDate: undefined }); } } }, { key: 'UNSAFE_componentWillReceiveProps', value: function UNSAFE_componentWillReceiveProps(nextProps) { if (this.isControlled()) { var newDates = this.getControlledDate(nextProps); if (newDates) { if (newDates.start && newDates.end && !(0, _dateUtils.isEqualDateTime)(this.state.startDate, newDates.start) || !(0, _dateUtils.isEqualDateTime)(this.state.endDate, newDates.end) || !(0, _dateUtils.isEqualDateTime)(this.state.selectedStartDate, newDates.start) || !(0, _dateUtils.isEqualDateTime)(this.state.selectedEndDate, newDates.end)) { this.setState({ startDate: newDates.start, endDate: newDates.end, selectedStartDate: newDates.start, selectedEndDate: newDates.end }); } } else if (this.props.value && this.props.value.start && this.props.value.end && nextProps.value && !nextProps.value.start && !nextProps.value.end) { this.setState({ dialogStartDate: new Date(), dialogEndDate: new Date(), dialogVisible: false, startDate: undefined, endDate: undefined, selectedStartDate: undefined, selectedEndDate: undefined }, this.refs.dialogWindow.reset.bind(this)); } } } }, { key: 'getDates', value: function getDates() { return { startDate: this.state.startDate, endDate: this.state.endDate }; } /** * Open the date-picker dialog programmatically from a parent. */ }, { key: 'openDialog', value: function openDialog(showRef, startEnd, dateTime) { /** * if the date is not selected then set it to new date * (get the current system date while doing so) * else set it to the currently selected date */ var allRefs = { startDate: this.refs.startdatefield, startTime: this.refs.starttimefield, endDate: this.refs.enddatefield, endTime: this.refs.endtimefield }; if (!this.state.dialogVisible) { if (this.state.startDate !== undefined && this.state.endDate !== undefined) { this.setState({ dialogStartDate: this.getDates().startDate, dialogEndDate: this.getDates().endDate, selectedStartDate: undefined, selectedEndDate: undefined }, this.refs.dialogWindow.show.bind(this, showRef, startEnd, dateTime, allRefs)); } else { this.setState({ dialogStartDate: new Date(), dialogEndDate: new Date(), selectedStartDate: undefined, selectedEndDate: undefined }, this.refs.dialogWindow.show.bind(this, showRef, startEnd, dateTime, allRefs)); } } } /** * Alias for `openDialog()` for an api consistent with TextField. */ // focus() { // this.openDialog(); // } }, { key: 'isControlled', value: function isControlled() { return this.props.hasOwnProperty('value'); } }, { key: 'getControlledDate', value: function getControlledDate() { var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props; if (props.value && (props.value.start instanceof Date || props.value.end instanceof Date)) { return props.value; } } }, { key: 'formatDateForDisplay', value: function formatDateForDisplay(date, label) { if (date instanceof Date) { if (this.props.locale) { return new Intl.DateTimeFormat(this.props.locale, { day: '2-digit', month: '2-digit', year: '2-digit' }).format(date); } else { return new Intl.DateTimeFormat('en-US', { day: '2-digit', month: '2-digit', year: '2-digit' }).format(date); } } else { return label; } } }, { key: 'formatTimeForDisplay', value: function formatTimeForDisplay(date, label) { if (date instanceof Date) { if (this.props.locale) { return new Intl.DateTimeFormat(this.props.locale, { hour: '2-digit', minute: '2-digit', hour12: true }).format(date); } else { return new Intl.DateTimeFormat('en-US', { hour: '2-digit', minute: '2-digit', hour12: true }).format(date); } } else { return label; } } }, { key: 'divider', value: function divider() { var layout = this.props.layout; return layout === 'single' && _react2.default.createElement( 'span', { style: { margin: 'auto 10px', color: '#757575' } }, '-' ); } }, { key: 'timeStyle', value: function timeStyle(disabled) { var layout = this.props.layout; return _extends({ height: '38px', lineHeight: '38px', paddingLeft: layout !== 'single' ? '10px' : '5px', display: 'flex', justifyContent: 'space-between', alignItems: 'center', cursor: disabled ? 'not-allowed' : 'pointer', color: '#757575' }, layout !== 'single' ? { width: '99px', border: '1px solid #e5e5e5' } : {}); } }, { key: 'dateStyle', value: function dateStyle(disabled) { var layout = this.props.layout; return _extends({ height: '38px', lineHeight: '38px', paddingLeft: layout === 'single' ? '0px' : '10px', display: 'flex', justifyContent: 'space-between', alignItems: 'center', cursor: disabled ? 'not-allowed' : 'pointer', color: '#757575' }, layout !== 'single' ? { width: '117px', border: '1px solid #e5e5e5' } : {}); } }, { key: 'getStyles', value: function getStyles() { var layout = this.props.layout; return { textField: { display: 'flex', justifyContent: layout !== 'single' ? 'space-between' : 'flex-start', alignItems: 'center', flexWrap: layout === 'single' ? 'nowrap' : 'wrap' }, endContainer: _extends({ display: 'flex', justifyContent: 'space-between' }, layout !== 'single' ? { width: '100%' } : {}), startContainer: _extends({ display: 'flex', justifyContent: 'space-between' }, layout !== 'single' ? { width: '100%', marginBottom: '16px' } : {}) }; } }, { key: 'render', value: function render() { var _props = this.props, DateTimeFormat = _props.DateTimeFormat, autoOk = _props.autoOk, autoOpenField = _props.autoOpenField, blockedDateTimeRanges = _props.blockedDateTimeRanges, calendarDateWidth = _props.calendarDateWidth, calendarTimeWidth = _props.calendarTimeWidth, cancelLabel = _props.cancelLabel, className = _props.className, container = _props.container, dayButtonSize = _props.dayButtonSize, display = _props.display, end = _props.end, endLabel = _props.endLabel, endLabelDate = _props.endLabelDate, endLabelTime = _props.endLabelTime, firstDayOfWeek = _props.firstDayOfWeek, formatDisplay = _props.formatDisplay, layout = _props.layout, locale = _props.locale, mode = _props.mode, okLabel = _props.okLabel, onDismiss = _props.onDismiss, onFocus = _props.onFocus, onShow = _props.onShow, onClick = _props.onClick, showCalendarDate = _props.showCalendarDate, showCalendarStatus = _props.showCalendarStatus, start = _props.start, startLabel = _props.startLabel, startLabelDate = _props.startLabelDate, startLabelTime = _props.startLabelTime, style = _props.style, textFieldStyle = _props.textFieldStyle, utils = _props.utils, other = _objectWithoutProperties(_props, ['DateTimeFormat', 'autoOk', 'autoOpenField', 'blockedDateTimeRanges', 'calendarDateWidth', 'calendarTimeWidth', 'cancelLabel', 'className', 'container', 'dayButtonSize', 'display', 'end', 'endLabel', 'endLabelDate', 'endLabelTime', 'firstDayOfWeek', 'formatDisplay', 'layout', 'locale', 'mode', 'okLabel', 'onDismiss', 'onFocus', 'onShow', 'onClick', 'showCalendarDate', 'showCalendarStatus', 'start', 'startLabel', 'startLabelDate', 'startLabelTime', 'style', 'textFieldStyle', 'utils']); var _getTheme = this.getTheme(), prepareStyles = _getTheme.prepareStyles; var styles = this.getStyles(); var _state = this.state, selectedStartDate = _state.selectedStartDate, selectedEndDate = _state.selectedEndDate, startDate = _state.startDate, endDate = _state.endDate; var starting = selectedStartDate ? selectedStartDate : startDate; var ending = selectedEndDate ? selectedEndDate : endDate; var formattedStartDate = this.formatDateForDisplay(starting, startLabelDate); var formattedStartTime = this.formatTimeForDisplay(starting, startLabelTime); var formattedEndDate = this.formatDateForDisplay(ending, endLabelDate); var formattedEndTime = this.formatTimeForDisplay(ending, endLabelTime); var startInfo = { dateRef: 'startdatefield', onClickDate: this.handleTouchTap.bind(this, this.refs.startdatefield, 'start', 'date', false), formattedDate: formattedStartDate, timeRef: 'starttimefield', onClickTime: this.handleTouchTap.bind(this, this.refs.starttimefield, 'start', 'time', formattedStartDate === startLabelDate), formattedTime: formattedStartTime }; var endInfo = { dateRef: 'enddatefield', onClickDate: this.handleTouchTap.bind(this, this.refs.enddatefield, 'end', 'date', formattedStartDate === startLabelDate), formattedDate: formattedEndDate, timeRef: 'endtimefield', onClickTime: this.handleTouchTap.bind(this, this.refs.endtimefield, 'end', 'time', formattedEndDate === endLabelDate), formattedTime: formattedEndTime }; return _react2.default.createElement( 'div', { className: className, style: prepareStyles((0, _simpleAssign2.default)({}, style)) }, display ? display(startInfo, endInfo, this.handleFocus) : _react2.default.createElement( 'div', { style: (0, _simpleAssign2.default)({}, styles.textField, textFieldStyle) }, layout !== 'single' && _react2.default.createElement( 'div', { style: { width: '100%', fontWeight: 'semibold', marginBottom: '5px', fontSize: '15px' } }, 'Pick Up' ), _react2.default.createElement( 'div', { style: styles.startContainer }, _react2.default.createElement( 'div', { style: this.dateStyle(), ref: 'startdatefield', onFocus: this.handleFocus, onClick: this.handleTouchTap.bind(this, this.refs.startdatefield, 'start', 'date', false) }, _react2.default.createElement( 'span', null, formattedStartDate ), layout === 'single' && formattedStartDate !== startLabelDate && _react2.default.createElement( 'span', null, ',' ), this.dropdownArrow() ), _react2.default.createElement( 'div', { style: this.timeStyle(formattedStartDate === startLabelDate), ref: 'starttimefield', onFocus: this.handleFocus, onClick: this.handleTouchTap.bind(this, this.refs.starttimefield, 'start', 'time', formattedStartDate === startLabelDate) }, _react2.default.createElement( 'span', null, formattedStartTime ), this.dropdownArrow() ) ), this.divider(), layout !== 'single' && _react2.default.createElement( 'div', { style: { width: '100%', fontWeight: 'semibold', marginBottom: '5px', fontSize: '15px' } }, 'Drop Off' ), _react2.default.createElement( 'div', { style: styles.endContainer }, _react2.default.createElement( 'div', { style: this.dateStyle(formattedStartDate === startLabelDate), ref: 'enddatefield', onFocus: this.handleFocus, onClick: this.handleTouchTap.bind(this, this.refs.enddatefield, 'end', 'date', formattedStartDate === startLabelDate) }, _react2.default.createElement( 'span', null, formattedEndDate ), layout === 'single' && formattedEndDate !== endLabelDate && _react2.default.createElement( 'span', null, ',' ), this.dropdownArrow() ), _react2.default.createElement( 'div', { style: this.timeStyle(formattedEndDate === endLabelDate), ref: 'endtimefield', onFocus: this.handleFocus, onClick: this.handleTouchTap.bind(this, this.refs.endtimefield, 'end', 'time', formattedEndDate === endLabelDate) }, _react2.default.createElement( 'span', null, formattedEndTime ), this.dropdownArrow() ) ) ), _react2.default.createElement(_DateRangePickerDialog2.default, { DateTimeFormat: DateTimeFormat, autoOk: autoOk, autoOpenField: autoOpenField, blockedDateTimeRanges: blockedDateTimeRanges, calendarDateWidth: calendarDateWidth, calendarTimeWidth: calendarTimeWidth, cancelLabel: cancelLabel, container: container, dayButtonSize: dayButtonSize, end: end, endLabel: endLabel, firstDayOfWeek: firstDayOfWeek, initialStartDate: this.state.dialogStartDate, initialEndDate: this.state.dialogEndDate, locale: locale, showCalendarDate: showCalendarDate, showCalendarStatus: showCalendarStatus, mode: mode, okLabel: okLabel, onAccept: this.handleAccept, onUpdate: this.handleUpdate, onShow: this.handleShow, onDismiss: this.handleDismiss, ref: 'dialogWindow', start: start, startLabel: startLabel, utils: utils }) ); } }]); return DateRangePicker; }(_react.Component); DateRangePicker.propTypes = { /** * Constructor for date formatting for the specified `locale`. * The constructor must follow this specification: ECMAScript Internationalization API 1.0 (ECMA-402). * `Intl.DateTimeFormat` is supported by most modern browsers, see http://caniuse.com/#search=intl, * otherwise https://github.com/andyearnshaw/Intl.js is a good polyfill. * * By default, a built-in `DateTimeFormat` is used which supports the 'en-US' `locale`. */ DateTimeFormat: _propTypes2.default.func, /** * If true, automatically accept and close the picker on select a date. */ autoOk: _propTypes2.default.bool, /** * If true, automatically open the next datetime element */ autoOpenField: _propTypes2.default.bool, /** * Used to block datetime ranges on the date range picker */ blockedDateTimeRanges: _propTypes2.default.arrayOf(_propTypes2.default.shape({ /** * The end datetime of a blocked range */ end: _propTypes2.default.object, /** * The start datetime of a blocked range */ start: _propTypes2.default.object })), /** * Override the default width of the calendar when displaying days. */ calendarDateWidth: _propTypes2.default.string, /** * Override the default width of the calendar when displaying times. */ calendarTimeWidth: _propTypes2.default.string, /** * Override the default text of the 'Cancel' button. */ cancelLabel: _propTypes2.default.node, /** * The css class name of the root element. */ className: _propTypes2.default.string, /** * Used to control how the Date Picker will be displayed when the input field is focused. * `dialog` (default) displays the DatePicker as a dialog with a modal. * `inline` displays the DatePicker below the input field (similar to auto complete). */ container: _propTypes2.default.oneOf(['dialog', 'inline']), /** * Override the default size of day buttons. */ dayButtonSize: _propTypes2.default.string, /** * Disables the DatePicker. */ disabled: _propTypes2.default.bool, /** * Custom display function for date time fields. */ display: _propTypes2.default.func, /** * This is the container for attributes and methods specific to the 'end' calendar. */ end: _propTypes2.default.shape({ /** * This is the initial date value of the component. * If either `value` or `valueLink` is provided they will override this * prop with `value` taking precedence. */ defaultDate: _propTypes2.default.object, /** * The ending of a range of valid dates. The range includes the endDate. * The default value is current date + 100 years. */ maxDate: _propTypes2.default.object, /** * The beginning of a range of valid dates. The range includes the startDate. * The default value is current date - 100 years. */ minDate: _propTypes2.default.object, /** * Callback function used to determine if a day's entry should be disabled on the calendar. * * @param {object} day Date object of a day. * @returns {boolean} Indicates whether the day should be disabled. */ shouldDisableDate: _propTypes2.default.func }), /** * Override the default text of the 'End' label. */ endLabel: _propTypes2.default.string, /** * Override the default text of the 'End' label for dates. */ endLabelDate: _propTypes2.default.string, /** * Override the default text of the 'End' label for times. */ endLabelTime: _propTypes2.default.string, /** * Used to change the first day of week. It varies from * Saturday to Monday between different locales. * The allowed range is 0 (Sunday) to 6 (Saturday). * The default is `1`, Monday, as per ISO 8601. */ firstDayOfWeek: _propTypes2.default.number, /** * Override the default display formatting. */ formatDisplay: _propTypes2.default.func, /** * Determines if the component will show multiple boxes and the behavior * when a user interacts with it. */ layout: _propTypes2.default.string, /** * Locale used for formatting the `DatePicker` date strings. Other than for 'en-US', you * must provide a `DateTimeFormat` that supports the chosen `locale`. */ locale: _propTypes2.default.string, /** * Tells the component to display the picker in portrait or landscape mode. */ mode: _propTypes2.default.oneOf(['portrait', 'landscape']), /** * Override the default text of the 'OK' button. */ okLabel: _propTypes2.default.node, /** * Callback function that is fired when the date value changes. * * @param {null} null Since there is no particular event associated with the change, * the first argument will always be null. * @param {object} date The new date. */ onChange: _propTypes2.default.func, /** * Callback function that is fired when a touch tap event occurs on the Date Picker's `TextField`. * * @param {object} event TouchTap event targeting the `TextField`. */ onClick: _propTypes2.default.func, /** * Callback function that is fired when the Date Picker's dialog is dismissed. * * @param {null} null Since there is no particular event associated with the dismiss, * the first argument will always be null. * @param {object} date The new date or null dates. */ onDismiss: _propTypes2.default.func, /** * Callback function that is fired when the Date Picker's `TextField` gains focus. */ onFocus: _propTypes2.default.func, /** * Callback function that is fired when the Date Picker's dialog is shown. */ onShow: _propTypes2.default.func, /** * Shows the calendar date/time display. Defaults to false. */ showCalendarDate: _propTypes2.default.bool, /** * Shows the current step in the date/time selection. Defaults to false. */ showCalendarStatus: _propTypes2.default.bool, /** * This is the container for attributes and methods specific to the 'start' calendar. */ start: _propTypes2.default.shape({ /** * This is the initial date value of the component. * If either `value` or `valueLink` is provided they will override this * prop with `value` taking precedence. */ defaultDate: _propTypes2.default.object, /** * The ending of a range of valid dates. The range includes the endDate. * The default value is current date + 100 years. */ maxDate: _propTypes2.default.object, /** * The beginning of a range of valid dates. The range includes the startDate. * The default value is current date - 100 years. */ minDate: _propTypes2.default.object, /** * Callback function used to determine if a day's entry should be disabled on the calendar. * * @param {object} day Date object of a day. * @returns {boolean} Indicates whether the day should be disabled. */ shouldDisableDate: _propTypes2.default.func }), /** * Override the default text of the 'Start' label. */ startLabel: _propTypes2.default.string, /** * Override the default text of the 'Start' label for dates. */ startLabelDate: _propTypes2.default.string, /** * Override the default text of the 'Start' label for times. */ startLabelTime: _propTypes2.default.string, /** * Override the inline-styles of the root element. */ style: _propTypes2.default.object, /** * Override the inline-styles of DatePicker's TextField element. */ textFieldStyle: _propTypes2.default.object, /** * This object should contain methods needed to build the calendar system. * * Useful for building a custom calendar system. Refer to the * [source code](https://github.com/callemall/material-ui/blob/master/src/DatePicker/dateUtils.js) * and an [example implementation](https://github.com/alitaheri/material-ui-persian-date-picker-utils) * for more information. */ utils: _propTypes2.default.object, /** * Sets the date for the Date Picker programmatically. */ value: _propTypes2.default.shape({ /** * The end date */ end: _propTypes2.default.object, /** * The start date */ start: _propTypes2.default.object }) }; DateRangePicker.defaultProps = { autoOk: false, container: 'dialog', disabled: false, endLabel: 'End', endLabelDate: 'Date', endLabelTime: 'Time', firstDayOfWeek: 1, startLabel: 'Start', startLabelDate: 'Date', startLabelTime: 'Time', style: {} }; DateRangePicker.contextTypes = { muiTheme: _propTypes2.default.object }; DateRangePicker.childContextTypes = { muiTheme: _propTypes2.default.object }; exports.default = DateRangePicker; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DatePicker/DateRangePicker.js"],"names":["DateRangePicker","state","dialogVisible","startDate","undefined","endDate","selectedStartDate","selectedEndDate","handleAccept","dates","keepOpen","isControlled","setState","start","end","props","onChange","handleUpdate","handleShow","onShow","handleDismiss","onDismiss","handleFocus","event","target","blur","onFocus","handleTouchTap","showRef","startEnd","dateTime","disabled","onClick","setTimeout","openDialog","formatDate","date","locale","DateTimeFormat","dateTimeFormat","day","month","year","format","dropdownArrow","layout","style","fill","width","height","marginRight","muiTheme","getTheme","context","newDates","getControlledDate","nextProps","value","dialogStartDate","Date","dialogEndDate","refs","dialogWindow","reset","bind","allRefs","startdatefield","startTime","starttimefield","enddatefield","endTime","endtimefield","getDates","show","hasOwnProperty","label","Intl","hour","minute","hour12","margin","color","lineHeight","paddingLeft","display","justifyContent","alignItems","cursor","border","textField","flexWrap","endContainer","startContainer","marginBottom","autoOk","autoOpenField","blockedDateTimeRanges","calendarDateWidth","calendarTimeWidth","cancelLabel","className","container","dayButtonSize","endLabel","endLabelDate","endLabelTime","firstDayOfWeek","formatDisplay","mode","okLabel","showCalendarDate","showCalendarStatus","startLabel","startLabelDate","startLabelTime","textFieldStyle","utils","other","prepareStyles","styles","getStyles","starting","ending","formattedStartDate","formatDateForDisplay","formattedStartTime","formatTimeForDisplay","formattedEndDate","formattedEndTime","startInfo","dateRef","onClickDate","formattedDate","timeRef","onClickTime","formattedTime","endInfo","fontWeight","fontSize","dateStyle","timeStyle","divider","Component","propTypes","PropTypes","func","bool","arrayOf","shape","object","string","node","oneOf","defaultDate","maxDate","minDate","shouldDisableDate","number","defaultProps","contextTypes","childContextTypes"],"mappings":"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