choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
205 lines (174 loc) • 7.14 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"];
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard")["default"];
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _PureRenderMixin = _interopRequireDefault(require("../util/PureRenderMixin"));
var _excluded = ["prefixCls", "className", "style", "name", "id", "type", "disabled", "readOnly", "tabIndex", "onClick", "onFocus", "onBlur", "autoFocus", "value", "checkedValue", "unCheckedValue"];
var Checkbox = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(Checkbox, _Component);
var _super = (0, _createSuper2["default"])(Checkbox);
function Checkbox(_props) {
var _this;
(0, _classCallCheck2["default"])(this, Checkbox);
_this = _super.call(this, _props);
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleChange", function (e) {
var _assertThisInitialize = (0, _assertThisInitialized2["default"])(_this),
props = _assertThisInitialize.props;
if (props.disabled) {
return;
}
if (!('checked' in props)) {
_this.setState({
checked: e.target.checked
});
}
var _props$checkedValue = props.checkedValue,
checkedValue = _props$checkedValue === void 0 ? true : _props$checkedValue,
_props$unCheckedValue = props.unCheckedValue,
unCheckedValue = _props$unCheckedValue === void 0 ? false : _props$unCheckedValue;
var checked = e.target.checked;
var value = checked ? checkedValue : unCheckedValue;
props.onChange({
target: (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, props), {}, {
checked: value
}),
stopPropagation: function stopPropagation() {
e.stopPropagation();
},
preventDefault: function preventDefault() {
e.preventDefault();
},
nativeEvent: e.nativeEvent
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "saveInput", function (node) {
_this.input = node;
});
var _checked = false;
if ('checked' in _props) {
_checked = !!_props.checked;
} else if ('value' in _props) {
_checked = _props.checkedValue === _props.value;
} else {
_checked = !!_props.defaultChecked;
}
_this.state = {
checked: _checked
};
return _this;
}
(0, _createClass2["default"])(Checkbox, [{
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(nextProps) {
if ('checked' in nextProps) {
this.setState({
checked: nextProps.checked
}); // modified by njq.niu@hand-china.com
} else if ('value' in nextProps) {
this.setState({
checked: nextProps.checkedValue === nextProps.value
});
}
}
}, {
key: "shouldComponentUpdate",
value: function shouldComponentUpdate() {
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _PureRenderMixin["default"].shouldComponentUpdate.apply(this, args);
}
}, {
key: "focus",
value: function focus() {
this.input.focus();
}
}, {
key: "blur",
value: function blur() {
this.input.blur();
}
}, {
key: "render",
value: function render() {
var _classNames;
var _this$props = this.props,
prefixCls = _this$props.prefixCls,
className = _this$props.className,
style = _this$props.style,
name = _this$props.name,
id = _this$props.id,
type = _this$props.type,
disabled = _this$props.disabled,
readOnly = _this$props.readOnly,
tabIndex = _this$props.tabIndex,
onClick = _this$props.onClick,
onFocus = _this$props.onFocus,
onBlur = _this$props.onBlur,
autoFocus = _this$props.autoFocus,
value = _this$props.value,
checkedValue = _this$props.checkedValue,
unCheckedValue = _this$props.unCheckedValue,
others = (0, _objectWithoutProperties2["default"])(_this$props, _excluded);
var globalProps = Object.keys(others).reduce(function (prev, key) {
if (key.substr(0, 5) === 'aria-' || key.substr(0, 5) === 'data-' || key === 'role') {
prev[key] = others[key];
}
return prev;
}, {});
var checked = this.state.checked;
var classString = (0, _classnames["default"])(prefixCls, className, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-checked"), checked), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-disabled"), disabled), _classNames));
return /*#__PURE__*/_react["default"].createElement("span", {
className: classString,
style: style
}, /*#__PURE__*/_react["default"].createElement("input", (0, _extends2["default"])({
name: name,
id: id,
type: type,
readOnly: readOnly,
disabled: disabled,
tabIndex: tabIndex,
className: "".concat(prefixCls, "-input"),
checked: !!checked,
onClick: onClick,
onFocus: onFocus,
onBlur: onBlur,
onChange: this.handleChange,
autoFocus: autoFocus,
ref: this.saveInput,
value: value
}, globalProps)), /*#__PURE__*/_react["default"].createElement("span", {
className: "".concat(prefixCls, "-inner")
}));
}
}]);
return Checkbox;
}(_react.Component);
exports["default"] = Checkbox;
(0, _defineProperty2["default"])(Checkbox, "defaultProps", {
prefixCls: 'rc-checkbox',
className: '',
style: {},
type: 'checkbox',
defaultChecked: false,
onFocus: function onFocus() {},
onBlur: function onBlur() {},
onChange: function onChange() {},
checkedValue: true,
unCheckedValue: false
});
//# sourceMappingURL=Checkbox.js.map