You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
148 lines
4.7 KiB
148 lines
4.7 KiB
"use strict";
|
|
|
|
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; |