UNPKG

rsuite

Version:

A suite of react components

201 lines (161 loc) 7.42 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose")); var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose")); var React = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _propTypes = _interopRequireDefault(require("prop-types")); var _lodash = _interopRequireDefault(require("lodash")); var _MonthDropdown = _interopRequireDefault(require("./MonthDropdown")); var _TimeDropdown = _interopRequireDefault(require("./TimeDropdown")); var _View = _interopRequireDefault(require("./View")); var _Header = _interopRequireDefault(require("./Header")); var _utils = require("../utils"); var _disabledTime = _interopRequireWildcard(require("../utils/disabledTime")); var _formatUtils = require("../utils/formatUtils"); var _dateFns = require("date-fns"); var _utils2 = require("../@types/utils"); var CalendarState = (0, _utils2.tuple)('DROP_TIME', 'DROP_MONTH'); var Calendar = /*#__PURE__*/ function (_React$Component) { (0, _inheritsLoose2.default)(Calendar, _React$Component); function Calendar() { var _this; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this; _this.disabledDate = function (date) { var disabledDate = _this.props.disabledDate; if (disabledDate && disabledDate(date)) { return true; } return false; }; _this.disabledTime = function (date) { return (0, _disabledTime.default)(_this.props, date); }; _this.handleMoveForword = function () { var _this$props = _this.props, onMoveForword = _this$props.onMoveForword, pageDate = _this$props.pageDate; onMoveForword && onMoveForword((0, _dateFns.addMonths)(pageDate, 1)); }; _this.handleMoveBackward = function () { var _this$props2 = _this.props, onMoveBackward = _this$props2.onMoveBackward, pageDate = _this$props2.pageDate; onMoveBackward && onMoveBackward((0, _dateFns.addMonths)(pageDate, -1)); }; return _this; } var _proto = Calendar.prototype; _proto.render = function render() { var _classNames; var _this$props3 = this.props, calendarState = _this$props3.calendarState, pageDate = _this$props3.pageDate, onSelect = _this$props3.onSelect, onToggleMonthDropdown = _this$props3.onToggleMonthDropdown, onToggleTimeDropdown = _this$props3.onToggleTimeDropdown, onChangePageDate = _this$props3.onChangePageDate, onChangePageTime = _this$props3.onChangePageTime, format = _this$props3.format, calendarRef = _this$props3.calendarRef, className = _this$props3.className, isoWeek = _this$props3.isoWeek, limitEndYear = _this$props3.limitEndYear, classPrefix = _this$props3.classPrefix, renderTitle = _this$props3.renderTitle, renderToolbar = _this$props3.renderToolbar, renderCell = _this$props3.renderCell, showWeekNumbers = _this$props3.showWeekNumbers, rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props3, ["calendarState", "pageDate", "onSelect", "onToggleMonthDropdown", "onToggleTimeDropdown", "onChangePageDate", "onChangePageTime", "format", "calendarRef", "className", "isoWeek", "limitEndYear", "classPrefix", "renderTitle", "renderToolbar", "renderCell", "showWeekNumbers"]); var showDate = (0, _formatUtils.shouldDate)(format); var showTime = (0, _formatUtils.shouldTime)(format); var showMonth = (0, _formatUtils.shouldMonth)(format); var onlyShowTime = showTime && !showDate && !showMonth; var onlyShowMonth = showMonth && !showDate && !showTime; var dropTime = calendarState === 'DROP_TIME' || onlyShowTime; var dropMonth = calendarState === 'DROP_MONTH' || onlyShowMonth; var addPrefix = (0, _utils.prefix)(classPrefix); var calendarClasses = (0, _classnames.default)(className, classPrefix, (_classNames = {}, _classNames[addPrefix('show-time-dropdown')] = dropTime, _classNames[addPrefix('show-month-dropdown')] = dropMonth, _classNames)); var unhandled = (0, _utils.getUnhandledProps)(Calendar, rest); var timeDropdownProps = _lodash.default.pick(rest, _disabledTime.calendarOnlyProps); return React.createElement("div", (0, _extends2.default)({}, unhandled, { className: calendarClasses, ref: calendarRef }), React.createElement(_Header.default, { date: pageDate, format: format, showMonth: showMonth, showDate: showDate, showTime: showTime, disabledDate: this.disabledDate, disabledTime: this.disabledTime, onMoveForword: this.handleMoveForword, onMoveBackward: this.handleMoveBackward, onToggleMonthDropdown: onToggleMonthDropdown, onToggleTimeDropdown: onToggleTimeDropdown, renderTitle: renderTitle, renderToolbar: renderToolbar }), showDate && React.createElement(_View.default, { key: "MonthView", activeDate: pageDate, onSelect: onSelect, isoWeek: isoWeek, disabledDate: this.disabledDate, renderCell: renderCell, showWeekNumbers: showWeekNumbers }), showMonth && React.createElement(_MonthDropdown.default, { date: pageDate, onSelect: onChangePageDate, show: dropMonth, limitEndYear: limitEndYear, disabledMonth: this.disabledDate }), showTime && React.createElement(_TimeDropdown.default, (0, _extends2.default)({}, timeDropdownProps, { date: pageDate, format: format, show: dropTime, onSelect: onChangePageTime }))); }; return Calendar; }(React.Component); Calendar.propTypes = { pageDate: _propTypes.default.instanceOf(Date), calendarState: _propTypes.default.oneOf(CalendarState), calendarRef: _propTypes.default.func, format: _propTypes.default.string, isoWeek: _propTypes.default.bool, limitEndYear: _propTypes.default.number, className: _propTypes.default.string, classPrefix: _propTypes.default.string, disabledDate: _propTypes.default.func, //disabledHours: PropTypes.func, //disabledMinutes: PropTypes.func, //disabledSeconds: PropTypes.func, //hideHours: PropTypes.func, //hideMinutes: PropTypes.func, //hideSeconds: PropTypes.func, onMoveForword: _propTypes.default.func, onMoveBackward: _propTypes.default.func, onSelect: _propTypes.default.func, onToggleMonthDropdown: _propTypes.default.func, onToggleTimeDropdown: _propTypes.default.func, onChangePageDate: _propTypes.default.func, onChangePageTime: _propTypes.default.func, renderTitle: _propTypes.default.func, renderToolbar: _propTypes.default.func, renderCell: _propTypes.default.func }; var _default = (0, _utils.defaultProps)({ classPrefix: 'calendar' })(Calendar); exports.default = _default; module.exports = exports.default;