UNPKG

zent

Version:

一套前端设计语言和基于React的实现

1,410 lines (1,122 loc) 115 kB
(function webpackUniversalModuleDefinition(root, factory) { if(typeof define === 'function' && define.amd) define(["react"], factory); else if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(require("react")); else if(typeof exports === 'object') exports["zent-datetimepicker"] = factory(require("react")); else root["zent-datetimepicker"] = factory(root["React"]); })(this, function(__WEBPACK_EXTERNAL_MODULE_3__) { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) /******/ return installedModules[moduleId].exports; /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ exports: {}, /******/ id: moduleId, /******/ loaded: false /******/ }; /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ // Flag the module as loaded /******/ module.loaded = true; /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ // __webpack_public_path__ /******/ __webpack_require__.p = ""; /******/ // Load entry module and return exports /******/ return __webpack_require__(0); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /***/ function(module, exports, __webpack_require__) { module.exports = __webpack_require__(1); /***/ }, /* 1 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.DateRangePicker = exports.MonthPicker = exports.DatePicker = undefined; var _DatePicker = __webpack_require__(2); var _DatePicker2 = _interopRequireDefault(_DatePicker); var _MonthPicker = __webpack_require__(27); var _MonthPicker2 = _interopRequireDefault(_MonthPicker); var _DateRangePicker = __webpack_require__(28); var _DateRangePicker2 = _interopRequireDefault(_DateRangePicker); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } exports['default'] = _DatePicker2['default']; exports.DatePicker = _DatePicker2['default']; exports.MonthPicker = _MonthPicker2['default']; exports.DateRangePicker = _DateRangePicker2['default']; /***/ }, /* 2 */ /***/ function(module, exports, __webpack_require__) { '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 _class, _temp, _initialiseProps; var _react = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _classnames = __webpack_require__(4); var _classnames2 = _interopRequireDefault(_classnames); var _DatePanel = __webpack_require__(7); var _DatePanel2 = _interopRequireDefault(_DatePanel); var _PanelFooter = __webpack_require__(24); var _PanelFooter2 = _interopRequireDefault(_PanelFooter); var _utils = __webpack_require__(12); var _format = __webpack_require__(25); var _clickOutside = __webpack_require__(26); var _clickOutside2 = _interopRequireDefault(_clickOutside); var _constants = __webpack_require__(14); 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; } var returnType = 'string'; var DatePicker = (_temp = _class = function (_Component) { _inherits(DatePicker, _Component); function DatePicker(props) { _classCallCheck(this, DatePicker); var _this = _possibleConstructorReturn(this, (DatePicker.__proto__ || Object.getPrototypeOf(DatePicker)).call(this, props)); _initialiseProps.call(_this); var showPlaceholder = void 0; var selected = void 0; var actived = void 0; if (props.value) { if (typeof props.value === 'number') returnType = 'numer'; if (props.value instanceof Date) returnType = 'date'; var tmpDate = (0, _format.parseDate)(props.value, props.format); if (!tmpDate) { showPlaceholder = true; actived = new Date(); } else { showPlaceholder = false; actived = selected = tmpDate; } } else { showPlaceholder = true; actived = new Date(); } _this.state = { value: selected && (0, _format.formatDate)(selected, props.format), actived: actived, selected: selected, activedTime: actived, openPanel: false, showPlaceholder: showPlaceholder }; return _this; } _createClass(DatePicker, [{ key: 'componentWillReceiveProps', value: function componentWillReceiveProps(next) { if (next.value) { var showPlaceholder = false; var selected = (0, _format.parseDate)(next.value, next.format || this.props.format); this.setState({ value: (0, _format.formatDate)(selected, next.format || this.props.format), actived: selected, selected: selected, activedTime: selected, openPanel: false, showPlaceholder: showPlaceholder }); } else { var _showPlaceholder = true; var actived = new Date(); this.setState({ value: '', actived: actived, selected: '', activedTime: actived, openPanel: false, showPlaceholder: _showPlaceholder }); } } }, { key: 'getReturnValue', value: function getReturnValue(date, format) { if (returnType === 'numer') { return date.getTime(); } else if (returnType === 'date') { return date; } else if (returnType === 'string') { return (0, _format.formatDate)(date, format); } } }, { key: 'render', value: function render() { var _this2 = this; var state = this.state; var props = this.props; var prefixCls = props.prefix + '-datetime-picker ' + props.className; var inputCls = (0, _classnames2['default'])({ 'picker-input': true, 'picker-input--filled': !state.showPlaceholder, 'picker-input--disabled': props.disabled }); var showTime = void 0; var datePicker = void 0; if (props.showTime) { showTime = _extends({}, { actived: state.activedTime, format: _constants.TIME_PROPS.format, disabledTime: _constants.TIME_PROPS.disabledTime }, props.showTime || {}, { disabledTime: props.disabledTime && props.disabledTime(), onChange: this.onChangeTime }); } if (state.openPanel) { var linkCls = (0, _classnames2['default'])({ 'link--current': true, 'link--disabled': this.isDisabled(_utils.CURRENT_DAY) }); datePicker = _react2['default'].createElement( 'div', { className: 'date-picker' }, _react2['default'].createElement(_DatePanel2['default'], { showTime: showTime, actived: state.actived, selected: state.selected, disabledDate: this.isDisabled, onSelect: this.onSelectDate, onChange: this.onChangeDate }), _react2['default'].createElement(_PanelFooter2['default'], { linkText: '\u4ECA\u5929', linkCls: linkCls, onClickLink: function onClickLink() { return _this2.onSelectDate(_utils.CURRENT_DAY); }, onClickButton: this.onConfirm }) ); } return _react2['default'].createElement( 'div', { className: prefixCls, ref: function ref(_ref) { return _this2.picker = _ref; } }, _react2['default'].createElement( 'div', { className: 'picker-wrapper' }, _react2['default'].createElement( 'div', { className: inputCls, onClick: this.onClickInput }, state.showPlaceholder ? props.placeholder : state.value, _react2['default'].createElement('span', { className: 'zenticon zenticon-calendar-o' }), _react2['default'].createElement('span', { onClick: this.onClearInput, className: 'zenticon zenticon-close-circle' }) ), state.openPanel ? datePicker : '' ) ); } }]); return DatePicker; }(_react.Component), _class.defaultProps = _constants.DATE_PROPS, _initialiseProps = function _initialiseProps() { var _this3 = this; this.clickOutside = function (e) { if (!_this3.picker.contains(e.target)) { _this3.setState({ openPanel: false }); } }; this.onChangeDate = function (val) { _this3.setState({ actived: val }); }; this.onSelectDate = function (val) { if (_this3.isDisabled(val)) { return; } _this3.setState({ actived: val, selected: val }); }; this.isDisabled = function (val) { var props = _this3.props; if (props.disabledDate && props.disabledDate(val)) return true; if (props.min && val < new Date(props.min)) return true; if (props.max && val > new Date(props.max)) return true; return false; }; this.onChangeTime = function (val) { _this3.setState({ activedTime: val }); }; this.onClickInput = function () { if (_this3.props.disabled) return; _this3.setState({ openPanel: !_this3.state.openPanel }); }; this.onClearInput = function () { _this3.props.onChange(''); }; this.onConfirm = function () { var _state = _this3.state, selected = _state.selected, activedTime = _state.activedTime; var _props = _this3.props, format = _props.format, showTime = _props.showTime; var value = void 0; var ret = void 0; if (!selected) return; if (showTime) { var tmp = new Date(selected.getFullYear(), selected.getMonth(), selected.getDate(), activedTime.getHours(), activedTime.getMinutes(), activedTime.getSeconds()); value = (0, _format.formatDate)(tmp, format); ret = _this3.getReturnValue(tmp, format); } else { value = (0, _format.formatDate)(selected, format); ret = _this3.getReturnValue(selected, format); } _this3.setState({ value: value, openPanel: false, showPlaceholder: false }); _this3.props.onChange(ret); }; }, _temp); exports['default'] = (0, _clickOutside2['default'])(DatePicker); module.exports = exports['default']; /***/ }, /* 3 */ /***/ function(module, exports) { module.exports = __WEBPACK_EXTERNAL_MODULE_3__; /***/ }, /* 4 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _classnames = __webpack_require__(5); Object.defineProperty(exports, 'default', { enumerable: true, get: function get() { return _interopRequireDefault(_classnames)['default']; } }); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } module.exports = exports['default']; /***/ }, /* 5 */ /***/ function(module, exports, __webpack_require__) { var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;'use strict'; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; /*! Copyright (c) 2016 Jed Watson. Licensed under the MIT License (MIT), see http://jedwatson.github.io/classnames */ /* global define */ (function () { 'use strict'; var hasOwn = {}.hasOwnProperty; function classNames() { var classes = []; for (var i = 0; i < arguments.length; i++) { var arg = arguments[i]; if (!arg) continue; var argType = typeof arg === 'undefined' ? 'undefined' : _typeof(arg); if (argType === 'string' || argType === 'number') { classes.push(arg); } else if (Array.isArray(arg)) { classes.push(classNames.apply(null, arg)); } else if (argType === 'object') { for (var key in arg) { if (hasOwn.call(arg, key) && arg[key]) { classes.push(key); } } } } return classes.join(' '); } if (typeof module !== 'undefined' && module.exports) { module.exports = classNames; } else if ("function" === 'function' && _typeof(__webpack_require__(6)) === 'object' && __webpack_require__(6)) { // register as 'classnames', consistent with npm package name !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function () { return classNames; }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); } else { window.classNames = classNames; } })(); /***/ }, /* 6 */ /***/ function(module, exports) { /* WEBPACK VAR INJECTION */(function(__webpack_amd_options__) {module.exports = __webpack_amd_options__; /* WEBPACK VAR INJECTION */}.call(exports, {})) /***/ }, /* 7 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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 = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _PanelHeader = __webpack_require__(8); var _PanelHeader2 = _interopRequireDefault(_PanelHeader); var _DatePanelBody = __webpack_require__(11); var _DatePanelBody2 = _interopRequireDefault(_DatePanelBody); var _MonthPanel = __webpack_require__(15); var _MonthPanel2 = _interopRequireDefault(_MonthPanel); var _TimePanel = __webpack_require__(19); var _TimePanel2 = _interopRequireDefault(_TimePanel); var _utils = __webpack_require__(12); 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; } var DatePanel = function (_Component) { _inherits(DatePanel, _Component); function DatePanel(props) { _classCallCheck(this, DatePanel); var _this = _possibleConstructorReturn(this, (DatePanel.__proto__ || Object.getPrototypeOf(DatePanel)).call(this, props)); _this.prevMonth = function () { var prev = (0, _utils.goMonths)(_this.props.actived, -1); _this.props.onChange(prev); }; _this.nextMonth = function () { var next = (0, _utils.goMonths)(_this.props.actived, 1); _this.props.onChange(next); }; _this.showMonth = function () { _this.setState({ showMonth: true, showTime: false }); }; _this.onSelectMonth = function (val, hide) { _this.props.onChange(val); _this.setState({ showMonth: hide || false, showTime: _this.props.showTime !== undefined && !hide }); }; _this.state = { showTime: props.showTime !== undefined, showMonth: false }; return _this; } /* * 在 monthPicker 的时候选择年不隐藏 monthPanel. */ _createClass(DatePanel, [{ key: 'render', value: function render() { var state = this.state; var props = this.props; var title = props.actived.getFullYear() + '\u5E74' + (props.actived.getMonth() + 1) + '\u6708'; var monthPanel = void 0; var timePanel = void 0; if (state.showMonth) { monthPanel = _react2['default'].createElement(_MonthPanel2['default'], { actived: props.actived, selected: props.selected, onSelect: this.onSelectMonth }); } if (props.showTime) { timePanel = _react2['default'].createElement(_TimePanel2['default'], { actived: props.showTime.actived, format: props.showTime.format, disabledTime: props.showTime.disabledTime, onChange: props.showTime.onChange }); } return _react2['default'].createElement( 'div', { className: 'date-panel' }, _react2['default'].createElement(_PanelHeader2['default'], { title: title, onClick: this.showMonth, prev: this.prevMonth, next: this.nextMonth }), _react2['default'].createElement(_DatePanelBody2['default'], { actived: props.actived, range: props.range, selected: props.selected, disabledDate: props.disabledDate, onSelect: props.onSelect, onHover: props.onHover }), state.showMonth ? monthPanel : '', state.showTime ? timePanel : '' ); } }]); return DatePanel; }(_react.Component); exports['default'] = DatePanel; module.exports = exports['default']; /***/ }, /* 8 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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; var _react = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _zentIcon = __webpack_require__(9); var _zentIcon2 = _interopRequireDefault(_zentIcon); 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; } var PanelHeader = (_temp = _class = function (_Component) { _inherits(PanelHeader, _Component); function PanelHeader() { _classCallCheck(this, PanelHeader); return _possibleConstructorReturn(this, (PanelHeader.__proto__ || Object.getPrototypeOf(PanelHeader)).apply(this, arguments)); } _createClass(PanelHeader, [{ key: 'render', value: function render() { return _react2['default'].createElement( 'div', { className: 'panel__header' }, this.props.showPrev ? _react2['default'].createElement( 'span', { className: 'link--prev', onClick: this.props.prev }, _react2['default'].createElement(_zentIcon2['default'], { type: 'right' }) ) : null, _react2['default'].createElement( 'span', { className: 'panel__title', onClick: this.props.onClick }, this.props.title ), this.props.showNext ? _react2['default'].createElement( 'span', { className: 'link--next', onClick: this.props.next }, _react2['default'].createElement(_zentIcon2['default'], { type: 'right' }) ) : null ); } }]); return PanelHeader; }(_react.Component), _class.defaultProps = { showPrev: true, showNext: true }, _temp); exports['default'] = PanelHeader; module.exports = exports['default']; /***/ }, /* 9 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; var _Icon = __webpack_require__(10); var _Icon2 = _interopRequireDefault(_Icon); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } exports['default'] = _Icon2['default']; module.exports = exports['default']; /***/ }, /* 10 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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; var _react = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _classnames = __webpack_require__(4); var _classnames2 = _interopRequireDefault(_classnames); 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 === 'undefined' ? 'undefined' : _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 === 'undefined' ? 'undefined' : _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 Icon = (_temp = _class = function (_Component) { _inherits(Icon, _Component); function Icon() { _classCallCheck(this, Icon); return _possibleConstructorReturn(this, (Icon.__proto__ || Object.getPrototypeOf(Icon)).apply(this, arguments)); } _createClass(Icon, [{ key: 'render', value: function render() { var _props = this.props, type = _props.type, className = _props.className, spin = _props.spin, otherProps = _objectWithoutProperties(_props, ['type', 'className', 'spin']); var cls = (0, _classnames2['default'])('zenticon', 'zenticon-' + type, className, { 'zenticon-spin': spin }); return _react2['default'].createElement('i', _extends({ className: cls }, otherProps)); } }]); return Icon; }(_react.Component), _class.propTypes = { type: _react.PropTypes.string.isRequired, className: _react.PropTypes.string, spin: _react.PropTypes.bool }, _class.defaultProps = { className: '', spin: false }, _temp); exports['default'] = Icon; module.exports = exports['default']; /***/ }, /* 11 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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 = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _utils = __webpack_require__(12); var _classnames = __webpack_require__(4); var _classnames2 = _interopRequireDefault(_classnames); var _PanelCell = __webpack_require__(13); var _PanelCell2 = _interopRequireDefault(_PanelCell); 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; } var ROW = 6; var COL = 7; var DatePanelBody = function (_Component) { _inherits(DatePanelBody, _Component); function DatePanelBody() { _classCallCheck(this, DatePanelBody); return _possibleConstructorReturn(this, (DatePanelBody.__proto__ || Object.getPrototypeOf(DatePanelBody)).apply(this, arguments)); } _createClass(DatePanelBody, [{ key: 'isSelected', value: function isSelected(val) { if (!this.props.selected) { return false; } var selectedDate = this.props.selected; if (Array.isArray(selectedDate)) { var i = 0; selectedDate.forEach(function (item) { (0, _utils.isSameDate)(val, item) ? i++ : ''; }); return i > 0; } return (0, _utils.isSameDate)(val, selectedDate); } }, { key: 'isInRange', value: function isInRange(val) { var range = this.props.range; if (Array.isArray(range) && range[0] && range[1]) { if (val > range[0] && val < range[1]) { return true; } } return false; } }, { key: 'days', value: function days() { var props = this.props; var days = []; var index = 0; var copy = new Date(props.actived.getFullYear(), props.actived.getMonth(), props.actived.getDate()); var firstDay = new Date(copy.setDate(1)); var diff = parseInt(firstDay.getDay(), 10); for (var rowIndex = 0; rowIndex < ROW; rowIndex++) { days[rowIndex] = []; for (var colIndex = 0; colIndex < COL; colIndex++) { var val = (0, _utils.goDays)(firstDay, index - diff); var isBefore = (0, _utils.isBeforeMonth)(val, props.actived); var isAfter = (0, _utils.isAfterMonth)(val, props.actived); var isCurrent = (0, _utils.isSameDate)(val, _utils.CURRENT); var isDisabled = props.disabledDate(val); var isSelected = this.isSelected(val); var isInRange = this.isInRange(val); var className = (0, _classnames2['default'])({ 'panel__cell date-panel__cell': true, 'panel__cell--different': isBefore || isAfter, 'panel__cell--current': !isDisabled && isCurrent, 'panel__cell--disabled': isDisabled, 'panel__cell--selected': isSelected, 'panel__cell--in-range': isInRange }); days[rowIndex][colIndex] = { text: val.getDate(), value: val, isDisabled: isDisabled, className: className }; index++; } } return days; } }, { key: 'render', value: function render() { var props = this.props; var days = this.days(); return _react2['default'].createElement( 'table', { className: 'date-table panel__table' }, _react2['default'].createElement( 'thead', null, _react2['default'].createElement( 'tr', null, _react2['default'].createElement( 'th', null, '\u65E5' ), _react2['default'].createElement( 'th', null, '\u4E00' ), _react2['default'].createElement( 'th', null, '\u4E8C' ), _react2['default'].createElement( 'th', null, '\u4E09' ), _react2['default'].createElement( 'th', null, '\u56DB' ), _react2['default'].createElement( 'th', null, '\u4E94' ), _react2['default'].createElement( 'th', null, '\u516D' ) ) ), _react2['default'].createElement(_PanelCell2['default'], { onSelect: props.onSelect, onHover: props.onHover, cells: days }) ); } }]); return DatePanelBody; }(_react.Component); exports['default'] = DatePanelBody; module.exports = exports['default']; /***/ }, /* 12 */ /***/ function(module, exports) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var CURRENT = exports.CURRENT = new Date(); var CURRENT_DAY = exports.CURRENT_DAY = new Date(CURRENT.getFullYear(), CURRENT.getMonth(), CURRENT.getDate()); var CURRENT_YEAR = exports.CURRENT_YEAR = CURRENT.getFullYear(); var CURRENT_MONTH = exports.CURRENT_MONTH = CURRENT.getMonth(); var CURRENT_DATE = exports.CURRENT_DATE = CURRENT.getDate(); var ONEDAY = exports.ONEDAY = 24 * 60 * 60 * 1000; var padLeft = exports.padLeft = function padLeft(val) { return val < 10 ? '0' + val : val; }; var getMonthStr = exports.getMonthStr = function getMonthStr(val) { return val.getFullYear() + '-' + padLeft(val.getMonth() + 1); }; var getDateStr = exports.getDateStr = function getDateStr(val) { return val.getFullYear() + '-' + padLeft(val.getMonth() + 1) + '-' + val.getDate(); }; var isSameDate = exports.isSameDate = function isSameDate(val, cmp) { return val.getFullYear() === cmp.getFullYear() && val.getMonth() === cmp.getMonth() && val.getDate() === cmp.getDate(); }; var isCurrentMonth = exports.isCurrentMonth = function isCurrentMonth(val) { return val.getMonth() === CURRENT_MONTH; }; var isBeforeMonth = exports.isBeforeMonth = function isBeforeMonth(val, cpr) { if (val.getFullYear() < cpr.getFullYear()) { return true; } return val.getFullYear() === cpr.getFullYear() && val.getMonth() < cpr.getMonth(); }; var isAfterMonth = exports.isAfterMonth = function isAfterMonth(val, cpr) { if (val.getFullYear() > cpr.getFullYear()) { return true; } return val.getFullYear() === cpr.getFullYear() && val.getMonth() > cpr.getMonth(); }; var goDays = exports.goDays = function goDays(val, diff) { return new Date(val.getTime() + diff * ONEDAY); }; var goMonths = exports.goMonths = function goMonths(val, diff) { var cp = new Date(val); return new Date(cp.setMonth(cp.getMonth() + diff)); }; var goYears = exports.goYears = function goYears(val, diff) { var cp = new Date(val); return new Date(cp.setFullYear(cp.getFullYear() + diff)); }; var isArray = exports.isArray = function isArray(val) { return Array.isArray(val); }; var isFunction = exports.isFunction = function isFunction(val) { return Object.prototype.toString.call(val) === '[object Function]'; }; /***/ }, /* 13 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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, _temp2; var _react = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _constants = __webpack_require__(14); 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; } var PanelCell = (_temp2 = _class = function (_Component) { _inherits(PanelCell, _Component); function PanelCell() { var _ref; var _temp, _this, _ret; _classCallCheck(this, PanelCell); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = PanelCell.__proto__ || Object.getPrototypeOf(PanelCell)).call.apply(_ref, [this].concat(args))), _this), _this.onClickCell = function (cell) { !cell.isDisabled && _this.props.onSelect(cell.value); }, _temp), _possibleConstructorReturn(_this, _ret); } _createClass(PanelCell, [{ key: 'render', value: function render() { var _this2 = this; var _props = this.props, cells = _props.cells, onHover = _props.onHover; var trs = cells.map(function (row, i) { var tds = row.map(function (col, j) { return _react2['default'].createElement( 'td', { className: 'grid-cell', role: 'gridcell', key: j }, _react2['default'].createElement( 'div', { onClick: function onClick() { return _this2.onClickCell(col); }, onMouseOver: function onMouseOver() { return onHover(col.value); }, className: col.className, title: col.value }, col.text ) ); }); return _react2['default'].createElement( 'tr', { role: 'row', key: i }, tds ); }); return _react2['default'].createElement( 'tbody', null, trs ); } }]); return PanelCell; }(_react.Component), _class.defaultProps = _constants.CELL_PROPS, _temp2); exports['default'] = PanelCell; module.exports = exports['default']; /***/ }, /* 14 */ /***/ function(module, exports) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.noop = noop; function noop() {} var CELL_PROPS = exports.CELL_PROPS = { onHover: noop }; var TIME_PROPS = exports.TIME_PROPS = { className: '', prefix: 'zent', value: '', format: 'HH:MM:ss', placeholder: '请选择时间', disabledTime: noop, onChange: noop }; var DATE_PROPS = exports.DATE_PROPS = { className: '', prefix: 'zent', format: 'yyyy-mm-dd', placeholder: '请选择日期', showTime: false, disabledDate: '', min: '', max: '', onChange: noop }; var MONTH_PROPS = exports.MONTH_PROPS = { className: '', prefix: 'zent', value: '', format: 'yyyy-mm', placeholder: '请选择月份', disabledDate: noop, onChange: noop }; var RANGE_PROPS = exports.RANGE_PROPS = { className: '', prefix: 'zent', value: '', format: 'yyyy-mm-dd', placeholder: ['开始日期', '结束日期'], showTime: false, disabledDate: noop, onChange: noop }; /***/ }, /* 15 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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 = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _PanelHeader = __webpack_require__(8); var _PanelHeader2 = _interopRequireDefault(_PanelHeader); var _MonthPanelBody = __webpack_require__(16); var _MonthPanelBody2 = _interopRequireDefault(_MonthPanelBody); var _YearPanel = __webpack_require__(17); var _YearPanel2 = _interopRequireDefault(_YearPanel); var _utils = __webpack_require__(12); 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; } var MonthPanel = function (_Component) { _inherits(MonthPanel, _Component); function MonthPanel(props) { _classCallCheck(this, MonthPanel); var _this = _possibleConstructorReturn(this, (MonthPanel.__proto__ || Object.getPrototypeOf(MonthPanel)).call(this, props)); _this.prevYear = function () { var prev = (0, _utils.goYears)(_this.props.actived, -1); _this.props.onSelect(prev, true); }; _this.nextYear = function () { var next = (0, _utils.goYears)(_this.props.actived, 1); _this.props.onSelect(next, true); }; _this.showYearPanel = function () { _this.setState({ showYear: true }); }; _this.onSelectYear = function (val) { _this.setState({ showYear: false }); var d = new Date(_this.props.actived); d.setFullYear(val); _this.props.onSelect(d, true); }; _this.onSelectMonth = function (val) { var d = new Date(_this.props.actived); d.setMonth(val); _this.props.onSelect(d); }; _this.state = { showYear: false }; return _this; } _createClass(MonthPanel, [{ key: 'render', value: function render() { var props = this.props; var state = this.state; var title = props.actived.getFullYear() + '\u5E74'; var yearPanel = void 0; if (state.showYear) { yearPanel = _react2['default'].createElement(_YearPanel2['default'], { actived: props.actived, onSelect: this.onSelectYear }); } return _react2['default'].createElement( 'div', { className: 'month-panel' }, _react2['default'].createElement(_PanelHeader2['default'], { title: title, onClick: this.showYearPanel, prev: this.prevYear, next: this.nextYear }), _react2['default'].createElement(_MonthPanelBody2['default'], { actived: props.actived, selected: props.selected, onSelect: this.onSelectMonth }), state.showYear ? yearPanel : '' ); } }]); return MonthPanel; }(_react.Component); exports['default'] = MonthPanel; module.exports = exports['default']; /***/ }, /* 16 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports['default'] = undefined; 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 = __webpack_require__(3); var _react2 = _interopRequireDefault(_react); var _classnames = __webpack_require__(4); var _classnames2 = _interopRequireDefault(_classnames); var _PanelCell = __webpack_require__(13); var _PanelCell2 = _interopRequireDefault(_PanelCell); var _utils = __webpack_require__(12); 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; } var ROW = 4; var COL = 3; var MonthPanelBody = function (_Component) { _inherits(MonthPanelBody, _Component); function MonthPanelBody() { _classCallCheck(this, MonthPanelBody); return _possibleConstructorReturn(this, (MonthPanelBody.__proto__ || Object.getPrototypeOf(MonthPanelBody)).apply(this, arguments)); } _createClass(MonthPanelBody, [{ key: 'isSelected', value: function isSelected(val) { return val === this.props.actived.getMonth(); } }, { key: 'getMonths', value: function getMonths() { var months = []; var index = 0; for (var rowIndex = 0; rowIndex < ROW; rowIndex++) { months[rowIndex] = []; for (var colIndex = 0; colIndex < COL; colIndex++) { var isCurrent = index === _utils.CURRENT_MONTH; var isSelected = this.isSelected(index); var className = (0, _classnames2['default'])({ 'panel__cell month-panel__cell': true, 'panel__cell--current': isCurrent, 'panel__cell--selected': isSelected }); months[rowIndex][colIndex] = { text: index + 1 + '\u6708', value: index, className: className