antd
Version:
An enterprise-class UI design language and React components implementation
126 lines (107 loc) • 3.96 kB
JavaScript
import _extends from "@babel/runtime/helpers/extends";
import _defineProperty from "@babel/runtime/helpers/defineProperty";
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
import _createClass from "@babel/runtime/helpers/createClass";
import _inherits from "@babel/runtime/helpers/inherits";
import _createSuper from "@babel/runtime/helpers/createSuper";
import * as React from 'react';
import RcTextArea from 'rc-textarea';
import omit from 'omit.js';
import classNames from 'classnames';
import ClearableLabeledInput from './ClearableLabeledInput';
import { ConfigConsumer } from '../config-provider';
import { fixControlledValue, resolveOnChange } from './Input';
var TextArea = /*#__PURE__*/function (_React$Component) {
_inherits(TextArea, _React$Component);
var _super = _createSuper(TextArea);
function TextArea(props) {
var _this;
_classCallCheck(this, TextArea);
_this = _super.call(this, props);
_this.focus = function () {
_this.resizableTextArea.textArea.focus();
};
_this.saveTextArea = function (textarea) {
_this.resizableTextArea = textarea === null || textarea === void 0 ? void 0 : textarea.resizableTextArea;
};
_this.saveClearableInput = function (clearableInput) {
_this.clearableInput = clearableInput;
};
_this.handleChange = function (e) {
_this.setValue(e.target.value);
resolveOnChange(_this.resizableTextArea.textArea, e, _this.props.onChange);
};
_this.handleReset = function (e) {
_this.setValue('', function () {
_this.focus();
});
resolveOnChange(_this.resizableTextArea.textArea, e, _this.props.onChange);
};
_this.renderTextArea = function (prefixCls, bordered) {
return /*#__PURE__*/React.createElement(RcTextArea, _extends({}, omit(_this.props, ['allowClear', 'bordered']), {
className: classNames(_this.props.className, _defineProperty({}, "".concat(prefixCls, "-borderless"), !bordered)),
prefixCls: prefixCls,
onChange: _this.handleChange,
ref: _this.saveTextArea
}));
};
_this.renderComponent = function (_ref) {
var getPrefixCls = _ref.getPrefixCls,
direction = _ref.direction;
var value = _this.state.value;
var _this$props = _this.props,
customizePrefixCls = _this$props.prefixCls,
_this$props$bordered = _this$props.bordered,
bordered = _this$props$bordered === void 0 ? true : _this$props$bordered;
var prefixCls = getPrefixCls('input', customizePrefixCls);
return /*#__PURE__*/React.createElement(ClearableLabeledInput, _extends({}, _this.props, {
prefixCls: prefixCls,
direction: direction,
inputType: "text",
value: fixControlledValue(value),
element: _this.renderTextArea(prefixCls, bordered),
handleReset: _this.handleReset,
ref: _this.saveClearableInput,
triggerFocus: _this.focus,
bordered: bordered
}));
};
var value = typeof props.value === 'undefined' ? props.defaultValue : props.value;
_this.state = {
value: value
};
return _this;
}
_createClass(TextArea, [{
key: "setValue",
value: function setValue(value, callback) {
if (!('value' in this.props)) {
this.setState({
value: value
}, callback);
}
}
}, {
key: "blur",
value: function blur() {
this.resizableTextArea.textArea.blur();
}
}, {
key: "render",
value: function render() {
return /*#__PURE__*/React.createElement(ConfigConsumer, null, this.renderComponent);
}
}], [{
key: "getDerivedStateFromProps",
value: function getDerivedStateFromProps(nextProps) {
if ('value' in nextProps) {
return {
value: nextProps.value
};
}
return null;
}
}]);
return TextArea;
}(React.Component);
export default TextArea;