UNPKG

zent

Version:

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

451 lines (342 loc) 17 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-checkbox"] = factory(require("react")); else root["zent-checkbox"] = 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 }); var _Checkbox = __webpack_require__(2); var _Checkbox2 = _interopRequireDefault(_Checkbox); var _Group = __webpack_require__(7); var _Group2 = _interopRequireDefault(_Group); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } _Checkbox2['default'].Group = _Group2['default']; exports['default'] = _Checkbox2['default']; module.exports = exports['default']; /***/ }, /* 2 */ /***/ function(module, exports, __webpack_require__) { 'use strict'; 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, _temp2; 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 _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return 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 Checkbox = (_temp2 = _class = function (_Component) { _inherits(Checkbox, _Component); function Checkbox() { var _ref; var _temp, _this, _ret; _classCallCheck(this, Checkbox); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Checkbox.__proto__ || Object.getPrototypeOf(Checkbox)).call.apply(_ref, [this].concat(args))), _this), _this.onChange = function (evt) { var props = _this.props; props.onChange({ target: _extends({}, props, { type: 'checkbox', checked: evt.target.checked }), preventDefault: function preventDefault() { evt.preventDefault(); }, stopPropagation: function stopPropagation() { evt.stopPropagation(); } }); }, _temp), _possibleConstructorReturn(_this, _ret); } _createClass(Checkbox, [{ key: 'render', value: function render() { var _classNames; var _props = this.props, checked = _props.checked, className = _props.className, style = _props.style, prefix = _props.prefix, disabled = _props.disabled, readOnly = _props.readOnly, children = _props.children, indeterminate = _props.indeterminate, value = _props.value, others = _objectWithoutProperties(_props, ['checked', 'className', 'style', 'prefix', 'disabled', 'readOnly', 'children', 'indeterminate', 'value']); var classString = (0, _classnames2['default'])((_classNames = {}, _defineProperty(_classNames, className, !!className), _defineProperty(_classNames, prefix + '-checkbox-wrap', true), _defineProperty(_classNames, prefix + '-checkbox-checked', !!checked), _defineProperty(_classNames, prefix + '-checkbox-disabled', disabled || readOnly), _defineProperty(_classNames, prefix + '-checkbox-indeterminate', indeterminate), _classNames)); return _react2['default'].createElement( 'label', { className: classString, style: style }, _react2['default'].createElement( 'span', { className: prefix + '-checkbox' }, _react2['default'].createElement('span', { className: prefix + '-checkbox-inner' }), _react2['default'].createElement('input', _extends({}, others, { type: 'checkbox', checked: checked && !indeterminate, disabled: disabled, readOnly: readOnly, onChange: this.onChange })) ), children !== undefined ? _react2['default'].createElement( 'span', null, children ) : null ); } }]); return Checkbox; }(_react.Component), _class.propTypes = { checked: _react2['default'].PropTypes.oneOfType([_react2['default'].PropTypes.number, _react2['default'].PropTypes.bool]), disabled: _react2['default'].PropTypes.bool, readOnly: _react2['default'].PropTypes.bool, indeterminate: _react2['default'].PropTypes.bool, onChange: _react2['default'].PropTypes.func, className: _react2['default'].PropTypes.string, style: _react2['default'].PropTypes.object, prefix: _react2['default'].PropTypes.string }, _class.defaultProps = { prefix: 'zent', className: '', style: {}, onChange: function onChange() {} }, _temp2); exports['default'] = Checkbox; 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 _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, _temp2; 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 _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return 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 findIndex(array, predicate) { for (var i = 0; i < array.length; i++) { if (predicate(array[i])) { return i; } } return -1; } var Group = (_temp2 = _class = function (_Component) { _inherits(Group, _Component); function Group() { var _ref; var _temp, _this, _ret; _classCallCheck(this, Group); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Group.__proto__ || Object.getPrototypeOf(Group)).call.apply(_ref, [this].concat(args))), _this), _this.onCheckboxChange = function (e) { var changedValue = e.target.value; var groupValue = _this.props.value.slice(); var isValueEqual = _this.props.isValueEqual; var index = findIndex(groupValue, function (val) { return isValueEqual(val, changedValue); }); if (index !== -1) { groupValue.splice(index, 1); } else { groupValue.push(changedValue); } _this.props.onChange(groupValue); }, _temp), _possibleConstructorReturn(_this, _ret); } _createClass(Group, [{ key: 'render', value: function render() { var _this2 = this, _classNames; var _props = this.props, className = _props.className, prefix = _props.prefix, style = _props.style, isValueEqual = _props.isValueEqual, value = _props.value; var children = _react2['default'].Children.map(this.props.children, function (checkbox) { if (checkbox && checkbox.props) { return _react2['default'].cloneElement(checkbox, _extends({}, checkbox.props, { onChange: _this2.onCheckboxChange, checked: findIndex(value, function (val) { return isValueEqual(val, checkbox.props.value); }) !== -1, disabled: checkbox.props.disabled !== void 0 ? checkbox.props.disabled : _this2.props.disabled, readOnly: checkbox.props.readOnly !== void 0 ? checkbox.props.readOnly : _this2.props.readOnly })); } }); var classString = (0, _classnames2['default'])((_classNames = {}, _defineProperty(_classNames, prefix + '-checkbox-group', true), _defineProperty(_classNames, className, !!className), _classNames)); return _react2['default'].createElement( 'div', { className: classString, style: style }, children ); } }]); return Group; }(_react.Component), _class.propTypes = { value: _react.PropTypes.array, isValueEqual: _react.PropTypes.func, onChange: _react.PropTypes.func, className: _react.PropTypes.string, style: _react.PropTypes.object, prefix: _react.PropTypes.string }, _class.defaultProps = { value: [], prefix: 'zent', className: '', style: {}, onChange: function onChange() {}, isValueEqual: function isValueEqual(a, b) { return a === b; } }, _temp2); exports['default'] = Group; module.exports = exports['default']; /***/ } /******/ ]) }); ;