UNPKG

qm-bus

Version:

千米公有云业务组件库

309 lines (253 loc) 10.9 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _datePicker = require('antd/lib/date-picker'); var _datePicker2 = _interopRequireDefault(_datePicker); var _select = require('antd/lib/select'); var _select2 = _interopRequireDefault(_select); var _input = require('antd/lib/input'); var _input2 = _interopRequireDefault(_input); var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); 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 _class, _temp, _initialiseProps; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _WeekPicker = require('./WeekPicker'); var _WeekPicker2 = _interopRequireDefault(_WeekPicker); var _moment = require('moment'); var _moment2 = _interopRequireDefault(_moment); require('moment/locale/zh-cn'); require('./time-select.less'); 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; } _moment2.default.updateLocale('zh-cn', { week: { dow: 1 // 周一是一周的第一天 } }); var InputGroup = _input2.default.Group; var Option = _select2.default.Option; var MonthPicker = _datePicker2.default.MonthPicker; var TIME_RANGE_TRPE = { day: 'day', week: 'week', month: 'month' }; var TimeSelect = (_temp = _class = function (_Component) { _inherits(TimeSelect, _Component); function TimeSelect(props) { _classCallCheck(this, TimeSelect); var _this = _possibleConstructorReturn(this, (TimeSelect.__proto__ || Object.getPrototypeOf(TimeSelect)).call(this, props)); _initialiseProps.call(_this); _this.init(); return _this; } _createClass(TimeSelect, [{ key: 'componentDidUpdate', value: function componentDidUpdate(prevProps) { var value = prevProps.value; if (value !== this.props.value) { // const { timeRangeType = 'day', startTime = '', endTime = '' } = this.props.value // ? this.props.value // : {}; this.init(); // this.setState({ // timeRangeType, // startTime, // endTime, // }); } } /** * 根据不同的时间类型推算出时间区间 * @param {*} value * @param {*} timeRangeType */ }, { key: 'formatValue2Range', value: function formatValue2Range(value, timeRangeType) { // 开始时间 var startTime = (0, _moment2.default)(value).startOf(timeRangeType); // 结束时间 var endTime = (0, _moment2.default)(value).endOf(timeRangeType); return [startTime, endTime]; } /** 修改timeRangeType */ /** 选择了时间 */ }, { key: 'render', value: function render() { var timeRangeType = this.state.timeRangeType; var showSelectType = this.props.showSelectType; return _react2.default.createElement( InputGroup, { compact: true }, showSelectType && _react2.default.createElement( _select2.default, { value: timeRangeType, style: { width: '30%' }, onChange: this.onTypeChange }, _react2.default.createElement( Option, { value: 'day' }, '\u65E5' ), _react2.default.createElement( Option, { value: 'week' }, '\u5468' ), _react2.default.createElement( Option, { value: 'month' }, '\u6708' ) ), this._renderPicker() ); } /** 渲染日期选择框 */ }, { key: '_renderPicker', value: function _renderPicker() { var _state = this.state, timeRangeType = _state.timeRangeType, startTime = _state.startTime; var _props = this.props, dateFormat = _props.dateFormat, weekFormat = _props.weekFormat, monthFormat = _props.monthFormat, disabledDate = _props.disabledDate; var _disabledDate = disabledDate(), day = _disabledDate.day, week = _disabledDate.week, month = _disabledDate.month; var value = startTime ? (0, _moment2.default)(startTime) : null; switch (timeRangeType) { case 'day': return _react2.default.createElement(_datePicker2.default, { allowClear: false, value: value, format: dateFormat, onChange: this.onChangeHandle, style: { width: '70%' }, showToday: false, disabledDate: day }); case 'week': return _react2.default.createElement(_WeekPicker2.default, { value: value, format: weekFormat, onChange: this.onChangeHandle, style: { width: '70%' }, disabledDate: week }); case 'month': return _react2.default.createElement(MonthPicker, { allowClear: false, value: value, format: monthFormat, onChange: this.onChangeHandle, style: { width: '70%' }, disabledDate: month }); default: return null; } } }]); return TimeSelect; }(_react.Component), _class.defaultProps = { value: { timeRangeType: 'day', startTime: null, endTime: null }, onChange: function onChange() {}, format: 'YYYY-MM-DD', dateFormat: 'YYYY-MM-DD', weekFormat: 'YYYY-MM 第w周', monthFormat: 'YYYY-MM', dayDefaultVal: '', weekDefaultVal: '', monthDefaultVal: '', showSelectType: true, disabledDate: function disabledDate() { return { day: function day() {}, week: function week() {}, month: function month() {} }; } }, _initialiseProps = function _initialiseProps() { var _this2 = this; this.state = { timeRangeType: 'day', startTime: null, endTime: null }; this.init = function () { var props = _this2.props; var defaultState = { timeRangeType: 'day', startTime: '', endTime: '' }; if (props.value && props.value.startTime) { defaultState = _extends({}, defaultState, props.value); } else if (props.value && props.value.timeRangeType) { var timeRangeType = props.value.timeRangeType; defaultState.timeRangeType = timeRangeType; var defaultValue = _this2.props[timeRangeType + 'DefaultVal']; if (defaultValue) { var _formatValue2Range = _this2.formatValue2Range((0, _moment2.default)(defaultValue), timeRangeType), _formatValue2Range2 = _slicedToArray(_formatValue2Range, 2), startTime = _formatValue2Range2[0], endTime = _formatValue2Range2[1]; defaultState.startTime = startTime.format('YYYY-MM-DD'); defaultState.endTime = endTime.format('YYYY-MM-DD'); } } _this2.state = defaultState; _this2.setState({ startTime: defaultState.startTime, endTime: defaultState.endTime, timeRangeType: defaultState.timeRangeType }); }; this.onTypeChange = function (timeRangeType) { var value = { timeRangeType: timeRangeType, startTime: '', endTime: '' }; var defaultValue = _this2.props[timeRangeType + 'DefaultVal']; if (defaultValue) { var _formatValue2Range3 = _this2.formatValue2Range((0, _moment2.default)(defaultValue), timeRangeType), _formatValue2Range4 = _slicedToArray(_formatValue2Range3, 2), startTime = _formatValue2Range4[0], endTime = _formatValue2Range4[1]; value.startTime = startTime.format('YYYY-MM-DD'); value.endTime = endTime.format('YYYY-MM-DD'); } _this2.setState(value); _this2.props.onChange(value); }; this.onChangeHandle = function (date) { var _props2 = _this2.props, onChange = _props2.onChange, format = _props2.format; var timeRangeType = _this2.state.timeRangeType; var range = _this2.formatValue2Range(date, timeRangeType); var value = { timeRangeType: timeRangeType, startTime: range[0].format(format), endTime: range[1].format(format) }; _this2.setState(value); onChange(value); }; }, _temp); exports.default = function (props) { if (props.defaultValue) { var dayDefaultVal = (0, _moment2.default)(props.defaultValue); // 昨天 var weekDefaultVal = (0, _moment2.default)().weekday(-7); // 上周一 var monthDefaultVal = (0, _moment2.default)().subtract(1, 'months').startOf('month'); // 上个月一号 props = _extends({}, props, { dayDefaultVal: dayDefaultVal, weekDefaultVal: weekDefaultVal, monthDefaultVal: monthDefaultVal }); } return _react2.default.createElement(TimeSelect, props); };