Input.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. var _typeof = require("@babel/runtime/helpers/typeof");
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
  10. var React = _interopRequireWildcard(require("react"));
  11. var _classnames = _interopRequireDefault(require("classnames"));
  12. var _ref = require("rc-util/lib/ref");
  13. var _warning = require("rc-util/lib/warning");
  14. var _composeProps = _interopRequireDefault(require("rc-util/lib/composeProps"));
  15. var _excluded = ["prefixCls", "id", "inputElement", "autoFocus", "autoComplete", "editable", "activeDescendantId", "value", "open", "attrs"];
  16. 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); }
  17. 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 && Object.prototype.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; }
  18. var Input = function Input(props, ref) {
  19. var prefixCls = props.prefixCls,
  20. id = props.id,
  21. inputElement = props.inputElement,
  22. autoFocus = props.autoFocus,
  23. autoComplete = props.autoComplete,
  24. editable = props.editable,
  25. activeDescendantId = props.activeDescendantId,
  26. value = props.value,
  27. open = props.open,
  28. attrs = props.attrs,
  29. restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
  30. var inputNode = inputElement || /*#__PURE__*/React.createElement("input", null);
  31. var _inputNode = inputNode,
  32. originRef = _inputNode.ref,
  33. originProps = _inputNode.props;
  34. (0, _warning.warning)(!('maxLength' in inputNode.props), "Passing 'maxLength' to input element directly may not work because input in BaseSelect is controlled.");
  35. inputNode = /*#__PURE__*/React.cloneElement(inputNode, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  36. type: 'search'
  37. }, (0, _composeProps.default)(restProps, originProps, true)), {}, {
  38. // Override over origin props
  39. id: id,
  40. ref: (0, _ref.composeRef)(ref, originRef),
  41. autoComplete: autoComplete || 'off',
  42. autoFocus: autoFocus,
  43. className: (0, _classnames.default)("".concat(prefixCls, "-selection-search-input"), originProps === null || originProps === void 0 ? void 0 : originProps.className),
  44. role: 'combobox',
  45. 'aria-expanded': open || false,
  46. 'aria-haspopup': 'listbox',
  47. 'aria-owns': "".concat(id, "_list"),
  48. 'aria-autocomplete': 'list',
  49. 'aria-controls': "".concat(id, "_list"),
  50. 'aria-activedescendant': open ? activeDescendantId : undefined
  51. }, attrs), {}, {
  52. value: editable ? value : '',
  53. readOnly: !editable,
  54. unselectable: !editable ? 'on' : null,
  55. style: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originProps.style), {}, {
  56. opacity: editable ? null : 0
  57. })
  58. }));
  59. return inputNode;
  60. };
  61. var RefInput = /*#__PURE__*/React.forwardRef(Input);
  62. if (process.env.NODE_ENV !== 'production') {
  63. RefInput.displayName = 'Input';
  64. }
  65. var _default = exports.default = RefInput;