material-ui-datetime-range-picker
Version:
React Datetime Range Picker Component that Implements Google's Material Design Via Material-UI.
377 lines (328 loc) • 39.3 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
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 _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _reactEventListener = require('react-event-listener');
var _reactEventListener2 = _interopRequireDefault(_reactEventListener);
var _keycode = require('keycode');
var _keycode2 = _interopRequireDefault(_keycode);
var _transitions = require('../styles/transitions');
var _transitions2 = _interopRequireDefault(_transitions);
var _RangeCalendarMonth = require('./RangeCalendarMonth');
var _RangeCalendarMonth2 = _interopRequireDefault(_RangeCalendarMonth);
var _CalendarToolbar = require('./CalendarToolbar');
var _CalendarToolbar2 = _interopRequireDefault(_CalendarToolbar);
var _RangeTimePicker = require('./RangeTimePicker');
var _RangeTimePicker2 = _interopRequireDefault(_RangeTimePicker);
var _SlideIn = require('../internal/SlideIn');
var _SlideIn2 = _interopRequireDefault(_SlideIn);
var _parseNum = require('parse-num');
var _parseNum2 = _interopRequireDefault(_parseNum);
var _dateUtils = require('./dateUtils');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
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; }
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
var daysArray = [].concat(_toConsumableArray(Array(7)));
var RangeCalendar = function (_Component) {
_inherits(RangeCalendar, _Component);
function RangeCalendar() {
var _ref;
var _temp, _this, _ret;
_classCallCheck(this, RangeCalendar);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = RangeCalendar.__proto__ || Object.getPrototypeOf(RangeCalendar)).call.apply(_ref, [this].concat(args))), _this), _this.calendarRefs = {}, _this.handleWindowKeyDown = function (event) {
if (_this.props.open) {
switch ((0, _keycode2.default)(event)) {
case 'up':
if (event.altKey && event.shiftKey) {
_this.addSelectedYears(-1);
} else if (event.shiftKey) {
_this.addSelectedMonths(-1);
} else {
_this.addSelectedDays(-7);
}
break;
case 'down':
if (event.altKey && event.shiftKey) {
_this.addSelectedYears(1);
} else if (event.shiftKey) {
_this.addSelectedMonths(1);
} else {
_this.addSelectedDays(7);
}
break;
case 'right':
if (event.altKey && event.shiftKey) {
_this.addSelectedYears(1);
} else if (event.shiftKey) {
_this.addSelectedMonths(1);
} else {
_this.addSelectedDays(1);
}
break;
case 'left':
if (event.altKey && event.shiftKey) {
_this.addSelectedYears(-1);
} else if (event.shiftKey) {
_this.addSelectedMonths(-1);
} else {
_this.addSelectedDays(-1);
}
break;
}
}
}, _temp), _possibleConstructorReturn(_this, _ret);
}
_createClass(RangeCalendar, [{
key: 'getMinDate',
value: function getMinDate() {
return this.props[this.props.edit].minDate || this.props.utils.addYears(new Date(), -100);
}
}, {
key: 'getMaxDate',
value: function getMaxDate() {
return this.props[this.props.edit].maxDate || this.props.utils.addYears(new Date(), 100);
}
}, {
key: 'getSelectedDate',
value: function getSelectedDate() {
return this.props[this.props.edit].selectedDate;
}
}, {
key: 'isSelectedDateDisabled',
value: function isSelectedDateDisabled() {
if (this.calendarRefs.calendar) {
return this.calendarRefs.calendar.isSelectedDateDisabled();
} else {
return false;
}
}
}, {
key: 'addSelectedDays',
value: function addSelectedDays(days) {
this.props.setSelectedDate(this.props.utils.addDays(this.props[this.props.edit].selectedDate, days));
}
}, {
key: 'addSelectedMonths',
value: function addSelectedMonths(months) {
this.props.setSelectedDate(this.props.utils.addMonths(this.props[this.props.edit].selectedDate, months));
}
}, {
key: 'addSelectedYears',
value: function addSelectedYears(years) {
this.props.setSelectedDate(this.props.utils.addYears(this.props[this.props.edit].selectedDate, years));
}
}, {
key: 'getToolbarInteractions',
value: function getToolbarInteractions() {
var _props = this.props,
edit = _props.edit,
end = _props.end,
start = _props.start;
if (edit === 'end' && !end.displayDate) {
return {
prevMonth: this.props.utils.monthDiff(start.displayDate, this.getMinDate()) > 0,
nextMonth: this.props.utils.monthDiff(start.displayDate, this.getMaxDate()) < 0
};
} else {
return {
prevMonth: this.props.utils.monthDiff(this.props[this.props.edit].displayDate, this.getMinDate()) > 0,
nextMonth: this.props.utils.monthDiff(this.props[this.props.edit].displayDate, this.getMaxDate()) < 0
};
}
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var prepareStyles = this.context.muiTheme.prepareStyles;
var toolbarInteractions = this.getToolbarInteractions();
var calendarTextColor = this.context.muiTheme.datePicker.calendarTextColor;
var _props2 = this.props,
blockedDateTimeRanges = _props2.blockedDateTimeRanges,
calendarDateWidth = _props2.calendarDateWidth,
calendarTimeWidth = _props2.calendarTimeWidth,
cancelLabel = _props2.cancelLabel,
DateTimeFormat = _props2.DateTimeFormat,
dayButtonSize = _props2.dayButtonSize,
displayTime = _props2.displayTime,
edit = _props2.edit,
end = _props2.end,
firstDayOfWeek = _props2.firstDayOfWeek,
locale = _props2.locale,
okLabel = _props2.okLabel,
onTouchTapCancel = _props2.onTouchTapCancel,
onTouchTapOk = _props2.onTouchTapOk,
start = _props2.start,
utils = _props2.utils;
var width = displayTime ? calendarTimeWidth || '125px' : calendarDateWidth || '310px';
var buttonStateSize = (0, _parseNum2.default)(dayButtonSize || '34px');
var unit = (dayButtonSize || 'px').replace(/[0-9.]/g, '');
var styles = {
root: {
color: calendarTextColor,
userSelect: 'none',
width: width
},
calendar: {
display: 'flex',
flexDirection: 'column'
},
calendarContainer: {
display: 'flex',
alignContent: 'space-between',
justifyContent: 'space-between',
flexDirection: 'column',
fontSize: 12,
fontWeight: 400,
padding: '0px ' + buttonStateSize / 4 + unit,
transition: _transitions2.default.easeOut()
},
yearContainer: {
display: 'flex',
justifyContent: 'space-between',
flexDirection: 'column',
height: 272,
marginTop: 10,
overflow: 'hidden',
width: calendarDateWidth || '310px'
},
weekTitle: {
display: 'flex',
flexDirection: 'row',
justifyContent: 'space-between',
fontWeight: '500',
height: 20,
lineHeight: '15px',
opacity: '0.5',
textAlign: 'center'
},
weekTitleDay: {
margin: 'auto',
minWidth: dayButtonSize || '34px',
minHeight: dayButtonSize || '34px'
},
transitionSlide: {
height: 214
}
};
var weekTitleDayStyle = prepareStyles(styles.weekTitleDay);
return _react2.default.createElement(
'div',
{ style: prepareStyles(styles.root) },
_react2.default.createElement(_reactEventListener2.default, {
target: 'window',
onKeyDown: this.handleWindowKeyDown
}),
_react2.default.createElement(
'div',
{ style: prepareStyles(styles.calendar) },
!displayTime && _react2.default.createElement(
'div',
{ style: prepareStyles(styles.calendarContainer) },
_react2.default.createElement(_CalendarToolbar2.default, {
DateTimeFormat: DateTimeFormat,
locale: locale,
displayDate: this.props[edit].displayDate ? this.props[edit].displayDate : start.displayDate,
onMonthChange: this.props.onMonthChange,
prevMonth: toolbarInteractions.prevMonth,
nextMonth: toolbarInteractions.nextMonth
}),
_react2.default.createElement(
'div',
{ style: prepareStyles(styles.weekTitle) },
daysArray.map(function (event, i) {
return _react2.default.createElement(
'span',
{ key: i, style: weekTitleDayStyle },
(0, _dateUtils.localizedWeekday)(DateTimeFormat, locale, i, firstDayOfWeek)
);
})
),
_react2.default.createElement(
_SlideIn2.default,
{ direction: this.props[edit].transitionDirection, style: styles.transitionSlide },
_react2.default.createElement(_RangeCalendarMonth2.default, {
blockedDateTimeRanges: blockedDateTimeRanges,
DateTimeFormat: DateTimeFormat,
calendarDateWidth: calendarDateWidth,
edit: edit,
end: end,
dayButtonSize: dayButtonSize,
displayDate: this.props[edit].displayDate ? this.props[edit].displayDate : start.displayDate,
firstDayOfWeek: this.props.firstDayOfWeek,
key: this.props[edit].displayDate ? this.props[edit].displayDate.toDateString() : start.displayDate.toDateString(),
locale: locale,
onTouchTapDay: this.props.onTouchTapDay.bind(this),
ref: function ref(_ref2) {
return _this2.calendarRefs.calendar = _ref2;
},
start: start,
utils: utils
})
)
),
displayTime && _react2.default.createElement(_RangeTimePicker2.default, {
blockedDateTimeRanges: blockedDateTimeRanges,
edit: edit,
end: end,
locale: locale,
onTouchTapHour: this.props.onTouchTapHour.bind(this),
start: start,
utils: utils
})
)
);
}
}]);
return RangeCalendar;
}(_react.Component);
RangeCalendar.propTypes = {
DateTimeFormat: _propTypes2.default.func.isRequired,
autoOk: _propTypes2.default.bool,
blockedDateTimeRanges: _propTypes2.default.array,
calendarDateWidth: _propTypes2.default.string,
calendarTimeWidth: _propTypes2.default.string,
cancelLabel: _propTypes2.default.node,
dayButtonSize: _propTypes2.default.string,
disableYearSelection: _propTypes2.default.bool,
displayTime: _propTypes2.default.bool,
edit: _propTypes2.default.string.isRequired,
end: _propTypes2.default.object.isRequired,
firstDayOfWeek: _propTypes2.default.number,
initialDate: _propTypes2.default.object,
locale: _propTypes2.default.string.isRequired,
mode: _propTypes2.default.oneOf(['portrait', 'landscape']),
okLabel: _propTypes2.default.node,
onMonthChange: _propTypes2.default.func,
onTouchTapCancel: _propTypes2.default.func,
onTouchTapDay: _propTypes2.default.func,
onTouchTapHour: _propTypes2.default.func,
onTouchTapOk: _propTypes2.default.func,
open: _propTypes2.default.bool,
openToYearSelection: _propTypes2.default.bool,
setSelectedDate: _propTypes2.default.func.isRequired,
start: _propTypes2.default.object.isRequired,
utils: _propTypes2.default.object
};
RangeCalendar.defaultProps = {
DateTimeFormat: _dateUtils.dateTimeFormat,
disableYearSelection: false,
displayTime: false,
locale: 'en-US',
utils: _dateUtils.defaultUtils
};
RangeCalendar.contextTypes = {
muiTheme: _propTypes2.default.object.isRequired
};
exports.default = RangeCalendar;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DatePicker/RangeCalendar.js"],"names":["daysArray","Array","RangeCalendar","calendarRefs","handleWindowKeyDown","event","props","open","altKey","shiftKey","addSelectedYears","addSelectedMonths","addSelectedDays","edit","minDate","utils","addYears","Date","maxDate","selectedDate","calendar","isSelectedDateDisabled","days","setSelectedDate","addDays","months","addMonths","years","end","start","displayDate","prevMonth","monthDiff","getMinDate","nextMonth","getMaxDate","prepareStyles","context","muiTheme","toolbarInteractions","getToolbarInteractions","calendarTextColor","datePicker","blockedDateTimeRanges","calendarDateWidth","calendarTimeWidth","cancelLabel","DateTimeFormat","dayButtonSize","displayTime","firstDayOfWeek","locale","okLabel","onTouchTapCancel","onTouchTapOk","width","buttonStateSize","unit","replace","styles","root","color","userSelect","display","flexDirection","calendarContainer","alignContent","justifyContent","fontSize","fontWeight","padding","transition","transitions","easeOut","yearContainer","height","marginTop","overflow","weekTitle","lineHeight","opacity","textAlign","weekTitleDay","margin","minWidth","minHeight","transitionSlide","weekTitleDayStyle","onMonthChange","map","i","transitionDirection","toDateString","onTouchTapDay","bind","ref","onTouchTapHour","Component","propTypes","PropTypes","func","isRequired","autoOk","bool","array","string","node","disableYearSelection","object","number","initialDate","mode","oneOf","openToYearSelection","defaultProps","dateTimeFormat","defaultUtils","contextTypes"],"mappings":"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","file":"RangeCalendar.js","sourcesContent":["import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport EventListener from 'react-event-listener';\nimport keycode from 'keycode';\nimport transitions from '../styles/transitions';\nimport RangeCalendarMonth from './RangeCalendarMonth';\nimport CalendarToolbar from './CalendarToolbar';\nimport RangeTimePicker from './RangeTimePicker';\nimport SlideInTransitionGroup from '../internal/SlideIn';\nimport parseNum from 'parse-num';\n\nimport {\n  defaultUtils,\n  dateTimeFormat,\n  localizedWeekday,\n} from './dateUtils';\n\nconst daysArray = [...Array(7)];\n\nclass RangeCalendar extends Component {\n  static propTypes = {\n    DateTimeFormat: PropTypes.func.isRequired,\n    autoOk: PropTypes.bool,\n    blockedDateTimeRanges: PropTypes.array,\n    calendarDateWidth: PropTypes.string,\n    calendarTimeWidth: PropTypes.string,\n    cancelLabel: PropTypes.node,\n    dayButtonSize: PropTypes.string,\n    disableYearSelection: PropTypes.bool,\n    displayTime: PropTypes.bool,\n    edit: PropTypes.string.isRequired,\n    end: PropTypes.object.isRequired,\n    firstDayOfWeek: PropTypes.number,\n    initialDate: PropTypes.object,\n    locale: PropTypes.string.isRequired,\n    mode: PropTypes.oneOf(['portrait', 'landscape']),\n    okLabel: PropTypes.node,\n    onMonthChange: PropTypes.func,\n    onTouchTapCancel: PropTypes.func,\n    onTouchTapDay: PropTypes.func,\n    onTouchTapHour: PropTypes.func,\n    onTouchTapOk: PropTypes.func,\n    open: PropTypes.bool,\n    openToYearSelection: PropTypes.bool,\n    setSelectedDate: PropTypes.func.isRequired,\n    start: PropTypes.object.isRequired,\n    utils: PropTypes.object,\n  };\n\n  static defaultProps = {\n    DateTimeFormat: dateTimeFormat,\n    disableYearSelection: false,\n    displayTime: false,\n    locale: 'en-US',\n    utils: defaultUtils,\n  };\n\n  static contextTypes = {\n    muiTheme: PropTypes.object.isRequired,\n  };\n\n  calendarRefs = {};\n\n  getMinDate() {\n    return this.props[this.props.edit].minDate || this.props.utils.addYears(new Date(), -100);\n  }\n\n  getMaxDate() {\n    return this.props[this.props.edit].maxDate || this.props.utils.addYears(new Date(), 100);\n  }\n\n  getSelectedDate() {\n    return this.props[this.props.edit].selectedDate;\n  }\n\n  isSelectedDateDisabled() {\n    if (this.calendarRefs.calendar) {\n      return this.calendarRefs.calendar.isSelectedDateDisabled();\n    } else {\n      return false;\n    }\n  }\n\n  addSelectedDays(days) {\n    this.props.setSelectedDate(this.props.utils.addDays(this.props[this.props.edit].selectedDate, days));\n  }\n\n  addSelectedMonths(months) {\n    this.props.setSelectedDate(this.props.utils.addMonths(this.props[this.props.edit].selectedDate, months));\n  }\n\n  addSelectedYears(years) {\n    this.props.setSelectedDate(this.props.utils.addYears(this.props[this.props.edit].selectedDate, years));\n  }\n\n  getToolbarInteractions() {\n    const {edit, end, start} = this.props;\n    if (edit === 'end' && !end.displayDate) {\n      return {\n        prevMonth: this.props.utils.monthDiff(start.displayDate, this.getMinDate()) > 0,\n        nextMonth: this.props.utils.monthDiff(start.displayDate, this.getMaxDate()) < 0,\n      };\n    } else {\n      return {\n        prevMonth: this.props.utils.monthDiff(this.props[this.props.edit].displayDate, this.getMinDate()) > 0,\n        nextMonth: this.props.utils.monthDiff(this.props[this.props.edit].displayDate, this.getMaxDate()) < 0,\n      };\n    }\n  }\n\n  handleWindowKeyDown = (event) => {\n    if (this.props.open) {\n      switch (keycode(event)) {\n        case 'up':\n          if (event.altKey && event.shiftKey) {\n            this.addSelectedYears(-1);\n          } else if (event.shiftKey) {\n            this.addSelectedMonths(-1);\n          } else {\n            this.addSelectedDays(-7);\n          }\n          break;\n\n        case 'down':\n          if (event.altKey && event.shiftKey) {\n            this.addSelectedYears(1);\n          } else if (event.shiftKey) {\n            this.addSelectedMonths(1);\n          } else {\n            this.addSelectedDays(7);\n          }\n          break;\n\n        case 'right':\n          if (event.altKey && event.shiftKey) {\n            this.addSelectedYears(1);\n          } else if (event.shiftKey) {\n            this.addSelectedMonths(1);\n          } else {\n            this.addSelectedDays(1);\n          }\n          break;\n\n        case 'left':\n          if (event.altKey && event.shiftKey) {\n            this.addSelectedYears(-1);\n          } else if (event.shiftKey) {\n            this.addSelectedMonths(-1);\n          } else {\n            this.addSelectedDays(-1);\n          }\n          break;\n      }\n    }\n  };\n\n  render() {\n    const {prepareStyles} = this.context.muiTheme;\n    const toolbarInteractions = this.getToolbarInteractions();\n    const {calendarTextColor} = this.context.muiTheme.datePicker;\n    const {\n      blockedDateTimeRanges,\n      calendarDateWidth,\n      calendarTimeWidth,\n      cancelLabel, // eslint-disable-line no-unused-vars\n      DateTimeFormat,\n      dayButtonSize,\n      displayTime,\n      edit,\n      end,\n      firstDayOfWeek,\n      locale,\n      okLabel, // eslint-disable-line no-unused-vars\n      onTouchTapCancel, // eslint-disable-line no-unused-vars\n      onTouchTapOk, // eslint-disable-line no-unused-vars\n      start,\n      utils,\n    } = this.props;\n\n    const width = (displayTime ? (calendarTimeWidth || '125px') : (calendarDateWidth || '310px'));\n    const buttonStateSize = parseNum(dayButtonSize || '34px');\n    const unit = (dayButtonSize || 'px').replace(/[0-9.]/g, '');\n\n    const styles = {\n      root: {\n        color: calendarTextColor,\n        userSelect: 'none',\n        width: width,\n      },\n      calendar: {\n        display: 'flex',\n        flexDirection: 'column',\n      },\n      calendarContainer: {\n        display: 'flex',\n        alignContent: 'space-between',\n        justifyContent: 'space-between',\n        flexDirection: 'column',\n        fontSize: 12,\n        fontWeight: 400,\n        padding: `0px ${buttonStateSize / 4}${unit}`,\n        transition: transitions.easeOut(),\n      },\n      yearContainer: {\n        display: 'flex',\n        justifyContent: 'space-between',\n        flexDirection: 'column',\n        height: 272,\n        marginTop: 10,\n        overflow: 'hidden',\n        width: (calendarDateWidth || '310px'),\n      },\n      weekTitle: {\n        display: 'flex',\n        flexDirection: 'row',\n        justifyContent: 'space-between',\n        fontWeight: '500',\n        height: 20,\n        lineHeight: '15px',\n        opacity: '0.5',\n        textAlign: 'center',\n      },\n      weekTitleDay: {\n        margin: 'auto',\n        minWidth: dayButtonSize || '34px',\n        minHeight: dayButtonSize || '34px',\n      },\n      transitionSlide: {\n        height: 214,\n      },\n    };\n\n    const weekTitleDayStyle = prepareStyles(styles.weekTitleDay);\n\n    return (\n      <div style={prepareStyles(styles.root)}>\n        <EventListener\n          target=\"window\"\n          onKeyDown={this.handleWindowKeyDown}\n        />\n        <div style={prepareStyles(styles.calendar)}>\n          {!displayTime &&\n            <div style={prepareStyles(styles.calendarContainer)}>\n              <CalendarToolbar\n                DateTimeFormat={DateTimeFormat}\n                locale={locale}\n                displayDate={(this.props[edit].displayDate ? this.props[edit].displayDate : start.displayDate)}\n                onMonthChange={this.props.onMonthChange}\n                prevMonth={toolbarInteractions.prevMonth}\n                nextMonth={toolbarInteractions.nextMonth}\n              />\n              <div style={prepareStyles(styles.weekTitle)}>\n                {daysArray.map((event, i) => (\n                  <span key={i} style={weekTitleDayStyle}>\n                    {localizedWeekday(DateTimeFormat, locale, i, firstDayOfWeek)}\n                  </span>\n                ))}\n              </div>\n              <SlideInTransitionGroup direction={this.props[edit].transitionDirection} style={styles.transitionSlide}>\n                <RangeCalendarMonth\n                  blockedDateTimeRanges={blockedDateTimeRanges}\n                  DateTimeFormat={DateTimeFormat}\n                  calendarDateWidth={calendarDateWidth}\n                  edit={edit}\n                  end={end}\n                  dayButtonSize={dayButtonSize}\n                  displayDate={(this.props[edit].displayDate ? this.props[edit].displayDate : start.displayDate)}\n                  firstDayOfWeek={this.props.firstDayOfWeek}\n                  key={(this.props[edit].displayDate ?\n                    this.props[edit].displayDate.toDateString() : start.displayDate.toDateString())}\n                  locale={locale}\n                  onTouchTapDay={this.props.onTouchTapDay.bind(this)}\n                  ref={(ref) => this.calendarRefs.calendar = ref}\n                  start={start}\n                  utils={utils}\n                />\n              </SlideInTransitionGroup>\n            </div>\n          }\n          {displayTime &&\n            <RangeTimePicker\n              blockedDateTimeRanges={blockedDateTimeRanges}\n              edit={edit}\n              end={end}\n              locale={locale}\n              onTouchTapHour={this.props.onTouchTapHour.bind(this)}\n              start={start}\n              utils={utils}\n            />\n          }\n        </div>\n      </div>\n    );\n  }\n}\n\nexport default RangeCalendar;\n"]}