antd
Version:
An enterprise-class UI design language and React components implementation
148 lines (115 loc) • 4.78 kB
JavaScript
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
var React = _interopRequireWildcard(require("react"));
var _rcTextarea = _interopRequireDefault(require("rc-textarea"));
var _omit = _interopRequireDefault(require("omit.js"));
var _classnames = _interopRequireDefault(require("classnames"));
var _ClearableLabeledInput = _interopRequireDefault(require("./ClearableLabeledInput"));
var _configProvider = require("../config-provider");
var _Input = require("./Input");
var TextArea = /*#__PURE__*/function (_React$Component) {
(0, _inherits2["default"])(TextArea, _React$Component);
var _super = (0, _createSuper2["default"])(TextArea);
function TextArea(props) {
var _this;
(0, _classCallCheck2["default"])(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);
(0, _Input.resolveOnChange)(_this.resizableTextArea.textArea, e, _this.props.onChange);
};
_this.handleReset = function (e) {
_this.setValue('', function () {
_this.focus();
});
(0, _Input.resolveOnChange)(_this.resizableTextArea.textArea, e, _this.props.onChange);
};
_this.renderTextArea = function (prefixCls, bordered) {
return /*#__PURE__*/React.createElement(_rcTextarea["default"], (0, _extends2["default"])({}, (0, _omit["default"])(_this.props, ['allowClear', 'bordered']), {
className: (0, _classnames["default"])(_this.props.className, (0, _defineProperty2["default"])({}, "".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["default"], (0, _extends2["default"])({}, _this.props, {
prefixCls: prefixCls,
direction: direction,
inputType: "text",
value: (0, _Input.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;
}
(0, _createClass2["default"])(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(_configProvider.ConfigConsumer, null, this.renderComponent);
}
}], [{
key: "getDerivedStateFromProps",
value: function getDerivedStateFromProps(nextProps) {
if ('value' in nextProps) {
return {
value: nextProps.value
};
}
return null;
}
}]);
return TextArea;
}(React.Component);
var _default = TextArea;
exports["default"] = _default;
;