@ucloud-fe/react-components
Version:
UCloud react components
173 lines (145 loc) • 7.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _newArrowCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/newArrowCheck"));
var _react = _interopRequireWildcard(require("react"));
var _ControllerContext = _interopRequireDefault(require("../../components/Form/ControllerContext"));
var _noop = _interopRequireDefault(require("../../utils/noop"));
var _useUncontrolled3 = _interopRequireDefault(require("../../hooks/useUncontrolled"));
var _style = require("./style");
var _excluded = ["value", "defaultValue", "onChange", "disabled", "size", "icon", "prefix", "suffix", "clearable", "block", "style", "status", "customStyle", "className", "onFocus", "onBlur", "onClear"];
var _this = void 0;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
var Input = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
var _this2 = this;
(0, _newArrowCheck2.default)(this, _this);
var _value = _ref.value,
defaultValue = _ref.defaultValue,
_onChange = _ref.onChange,
disabled = _ref.disabled,
_ref$size = _ref.size,
size = _ref$size === void 0 ? 'md' : _ref$size,
icon = _ref.icon,
prefix = _ref.prefix,
suffix = _ref.suffix,
clearable = _ref.clearable,
block = _ref.block,
style = _ref.style,
_status = _ref.status,
customStyle = _ref.customStyle,
className = _ref.className,
_ref$onFocus = _ref.onFocus,
onFocus = _ref$onFocus === void 0 ? _noop.default : _ref$onFocus,
_ref$onBlur = _ref.onBlur,
onBlur = _ref$onBlur === void 0 ? _noop.default : _ref$onBlur,
_ref$onClear = _ref.onClear,
onClear = _ref$onClear === void 0 ? _noop.default : _ref$onClear,
rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
var valueGetter = (0, _react.useCallback)(function (e) {
(0, _newArrowCheck2.default)(this, _this2);
return e.target.value;
}.bind(this), []);
var _useUncontrolled = (0, _useUncontrolled3.default)(_value, defaultValue || '', _onChange, {
getter: valueGetter
}),
_useUncontrolled2 = (0, _slicedToArray2.default)(_useUncontrolled, 2),
value = _useUncontrolled2[0],
onChange = _useUncontrolled2[1];
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
focused = _useState2[0],
setFocused = _useState2[1];
var inputRef = (0, _react.useRef)(null);
var focus = (0, _react.useCallback)(function (options) {
(0, _newArrowCheck2.default)(this, _this2);
inputRef.current && inputRef.current.focus(options);
}.bind(this), []);
(0, _react.useImperativeHandle)(ref, function () {
(0, _newArrowCheck2.default)(this, _this2);
return {
input: inputRef.current,
focus: focus
};
}.bind(this), [focus]);
var handleFocus = (0, _react.useCallback)(function (e) {
(0, _newArrowCheck2.default)(this, _this2);
setFocused(true);
onFocus(e);
}.bind(this), [onFocus]);
var handleBlur = (0, _react.useCallback)(function (e) {
(0, _newArrowCheck2.default)(this, _this2);
setFocused(false);
onBlur(e);
}.bind(this), [onBlur]);
var handleClearMouseDown = (0, _react.useCallback)(function (e) {
(0, _newArrowCheck2.default)(this, _this2);
e.preventDefault();
e.stopPropagation();
}.bind(this), []);
var handleClear = (0, _react.useCallback)(function (e) {
(0, _newArrowCheck2.default)(this, _this2);
if (disabled) return;
e.stopPropagation();
onClear();
var input = inputRef.current;
if (!input) return;
e.target = input;
e.currentTarget = input;
var cacheV = input.value;
if ((clearable === null || clearable === void 0 ? void 0 : clearable.callOnChange) !== false) {
input.value = '';
onChange(e);
input.value = cacheV;
}
if ((clearable === null || clearable === void 0 ? void 0 : clearable.autoFocus) !== false) {
input.focus();
}
}.bind(this), [clearable, disabled, onChange, onClear]);
var handleWrapMouseDown = (0, _react.useCallback)(function (e) {
var _inputRef$current;
(0, _newArrowCheck2.default)(this, _this2);
// 避免影响输入框的选中、移动光标等操作
if (e.target === inputRef.current) return;
e.preventDefault();
(_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.focus();
}.bind(this), []);
var _useContext = (0, _react.useContext)(_ControllerContext.default),
status = _useContext.status;
return /*#__PURE__*/_react.default.createElement(_style.InputWrap, {
size: size,
focused: focused,
style: style,
disabled: disabled,
status: _status || status,
customStyle: customStyle,
block: block,
className: className,
empty: !value,
onMouseDown: handleWrapMouseDown
}, /*#__PURE__*/_react.default.createElement(_style.Prefix, null, prefix), /*#__PURE__*/_react.default.createElement("span", {
className: _style.inputBlockWrapCls
}, /*#__PURE__*/_react.default.createElement("input", (0, _extends2.default)({}, rest, {
value: value,
onChange: onChange,
ref: inputRef,
onFocus: handleFocus,
onBlur: handleBlur,
disabled: disabled
})), /*#__PURE__*/_react.default.createElement(_style.Clear, {
clearable: clearable,
onMouseDown: handleClearMouseDown,
onClick: handleClear
})), /*#__PURE__*/_react.default.createElement(_style.Suffix, {
icon: icon
}, suffix));
}.bind(void 0));
var _default = /*#__PURE__*/_react.default.memo(Input);
exports.default = _default;