UNPKG

zarm

Version:

基于 React 的移动端UI库

174 lines (137 loc) 7.54 kB
"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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _bem = require("@zarm-design/bem"); var _icons = require("@zarm-design/icons"); var _isFunction = _interopRequireDefault(require("lodash/isFunction")); var React = _interopRequireWildcard(require("react")); var _configProvider = require("../config-provider"); var _input = _interopRequireDefault(require("../input")); var _hooks = require("../utils/hooks"); var _resolveOnChange = require("../utils/resolveOnChange"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) { if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } } return n.default = e, t && t.set(e, n), n; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var SearchBar = /*#__PURE__*/React.forwardRef(function (props, ref) { var _ref; var className = props.className, style = props.style, shape = props.shape, icon = props.icon, placeholder = props.placeholder, showCancel = props.showCancel, cancelText = props.cancelText, _props$defaultValue = props.defaultValue, defaultValue = _props$defaultValue === void 0 ? '' : _props$defaultValue, onFocus = props.onFocus, onBlur = props.onBlur, onChange = props.onChange, onCancel = props.onCancel, onSubmit = props.onSubmit, restProps = (0, _objectWithoutProperties2.default)(props, ["className", "style", "shape", "icon", "placeholder", "showCancel", "cancelText", "defaultValue", "onFocus", "onBlur", "onChange", "onCancel", "onSubmit"]); var cancelRef = React.useRef(null); var inputRef = React.useRef(); var formRef = /*#__PURE__*/React.createRef(); var _useControllableEvent = (0, _hooks.useControllableEventValue)(_objectSpread(_objectSpread({}, props), {}, { defaultValue: defaultValue })), _useControllableEvent2 = (0, _slicedToArray2.default)(_useControllableEvent, 2), value = _useControllableEvent2[0], setValue = _useControllableEvent2[1]; var _React$useState = React.useState(false), _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2), isFocus = _React$useState2[0], setIsFocus = _React$useState2[1]; var _React$useContext = React.useContext(_configProvider.ConfigContext), prefixCls = _React$useContext.prefixCls, globalLocal = _React$useContext.locale; var bem = (0, _bem.createBEM)('search-bar', { prefixCls: prefixCls }); var locale = globalLocal === null || globalLocal === void 0 ? void 0 : globalLocal.SearchBar; var isShowCancel = React.useMemo(function () { if ((0, _isFunction.default)(showCancel)) { return showCancel(isFocus, value); } return showCancel && isFocus; }, [showCancel, isFocus]); var cls = bem([(_ref = {}, (0, _defineProperty2.default)(_ref, "".concat(shape), !!shape), (0, _defineProperty2.default)(_ref, "focus", isFocus), _ref), className]); var onInputFocus = function onInputFocus(e) { setIsFocus(true); onFocus === null || onFocus === void 0 ? void 0 : onFocus(e); }; var onInputBlur = function onInputBlur(e) { setIsFocus(false); onBlur === null || onBlur === void 0 ? void 0 : onBlur(e); }; var onInputChange = function onInputChange(e) { setValue === null || setValue === void 0 ? void 0 : setValue(e); }; var onFormSubmit = function onFormSubmit(e) { e === null || e === void 0 ? void 0 : e.preventDefault(); inputRef.current && inputRef.current.blur(); onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit(value); }; var onClickCancelButton = function onClickCancelButton(e) { var _inputRef$current; (0, _resolveOnChange.resolveOnChange)((_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.nativeElement, e, setValue); inputRef.current && inputRef.current.blur(); onCancel === null || onCancel === void 0 ? void 0 : onCancel(); }; React.useImperativeHandle(ref, function () { var _inputRef$current2, _inputRef$current3; return { focus: (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : _inputRef$current2.focus, blur: (_inputRef$current3 = inputRef.current) === null || _inputRef$current3 === void 0 ? void 0 : _inputRef$current3.blur, submit: onFormSubmit }; }); var renderCancel = function renderCancel() { return isShowCancel && /*#__PURE__*/React.createElement("div", { className: bem('cancel'), ref: cancelRef, onClick: onClickCancelButton }, cancelText || (locale === null || locale === void 0 ? void 0 : locale.cancelText)); }; var inputProps = _objectSpread({ type: 'search', placeholder: placeholder || locale && locale.placeholder, value: value, onFocus: onInputFocus, onBlur: onInputBlur, onChange: onInputChange }, restProps); return /*#__PURE__*/React.createElement("div", { className: cls, style: style }, /*#__PURE__*/React.createElement("form", { action: "#", className: bem('form'), onSubmit: onFormSubmit, ref: formRef }, /*#__PURE__*/React.createElement("div", { className: bem('content') }, icon !== null && /*#__PURE__*/React.createElement("div", { className: bem('icon') }, icon || /*#__PURE__*/React.createElement(_icons.Search, { size: "sm" })), /*#__PURE__*/React.createElement(_input.default, (0, _extends2.default)({ ref: inputRef }, inputProps))), renderCancel())); }); SearchBar.defaultProps = { shape: 'radius', clearable: true }; SearchBar.displayName = 'SearchBar'; var _default = SearchBar; exports.default = _default;