UNPKG

jc-biz-components

Version:

jc component library based on Antd

141 lines (112 loc) 3.9 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _icon = require('antd/lib/icon'); var _icon2 = _interopRequireDefault(_icon); var _input = require('antd/lib/input'); var _input2 = _interopRequireDefault(_input); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); require('antd/lib/icon/style'); require('antd/lib/input/style'); var _react = require('react'); var _react2 = _interopRequireDefault(_react); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } // import styles from './style.css' var EditableCell = function (_Component) { (0, _inherits3['default'])(EditableCell, _Component); function EditableCell(props) { (0, _classCallCheck3['default'])(this, EditableCell); var _this = (0, _possibleConstructorReturn3['default'])(this, (EditableCell.__proto__ || Object.getPrototypeOf(EditableCell)).call(this, props)); _this.handleChange = function (e) { var value = e.target.value; value = value.replace(/[\D]/g, ''); if (!value && value !== _this.state.value) { _this.setState({ value: '', changed: true }); } else if (value && value !== _this.state.value) { _this.setState({ value: value * 1, changed: true }); } }; _this.check = function () { _this.setState({ editable: false }); if (_this.state.changed) { _this.props.onCheck(_this.state.value); _this.setState({ changed: false }); } }; _this.edit = function () { _this.setState({ editable: true }); }; _this.state = { value: props.value, editable: false, changed: null }; return _this; } (0, _createClass3['default'])(EditableCell, [{ key: 'componentWillReceiveProps', value: function componentWillReceiveProps(nextProp) { if (nextProp.value !== this.state.value) { this.setState({ value: nextProp.value }); } } }, { key: 'render', value: function render() { var _state = this.state, value = _state.value, editable = _state.editable, prefixCls = _state.prefixCls; return _react2['default'].createElement( 'div', { className: prefixCls }, editable ? _react2['default'].createElement( 'div', { className: prefixCls + '-input-wrapper' }, _react2['default'].createElement(_input2['default'], { maxLength: 4, value: value, onChange: this.handleChange, onPressEnter: this.check }), _react2['default'].createElement(_icon2['default'], { type: 'check', className: prefixCls + '-input-icon-check', onClick: this.check }) ) : _react2['default'].createElement( 'div', { className: prefixCls + '-text-wrapper' }, value || ' ', _react2['default'].createElement(_icon2['default'], { type: 'edit', className: prefixCls + '-icon', onClick: this.edit }) ) ); } }]); return EditableCell; }(_react.Component); EditableCell.defaultProps = { prefixCls: 'jc-editable-cell' }; exports['default'] = EditableCell; module.exports = exports['default'];