UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

148 lines (115 loc) 4.78 kB
"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;