@elastic/eui
Version:
Elastic UI Component Library
280 lines (276 loc) • 13.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.EuiFieldSearchClass = exports.EuiFieldSearch = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _services = require("../../../services");
var _browser = require("../../../services/browser");
var _i18n = require("../../i18n");
var _form_control_layout = require("../form_control_layout");
var _validatable_control = require("../validatable_control");
var _eui_form_context = require("../eui_form_context");
var _field_search = require("./field_search.styles");
var _react2 = require("@emotion/react");
var _excluded = ["stylesMemoizer", "className", "id", "name", "placeholder", "isInvalid", "disabled", "fullWidth", "isLoading", "inputRef", "incremental", "compressed", "onSearch", "isClearable", "append", "prepend"];
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 _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
var isSearchSupported = false;
var EuiFieldSearchClass = exports.EuiFieldSearchClass = /*#__PURE__*/function (_Component) {
function EuiFieldSearchClass() {
var _this;
(0, _classCallCheck2.default)(this, EuiFieldSearchClass);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _callSuper(this, EuiFieldSearchClass, [].concat(args));
(0, _defineProperty2.default)(_this, "state", {
value: _this.props.value || String(_this.props.defaultValue || '')
});
(0, _defineProperty2.default)(_this, "inputElement", null);
(0, _defineProperty2.default)(_this, "cleanups", []);
(0, _defineProperty2.default)(_this, "onClear", function () {
// clear the field's value
// 1. React doesn't listen for `change` events, instead it maps `input` events to `change`
// 2. React only fires the mapped `change` event if the element's value has changed
// 3. An input's value is, in addition to other methods, tracked by intercepting element.value = '...'
//
// So we have to go below the element's value setter to avoid React intercepting it,
// only then will React treat the value as different and fire its `change` event
//
// https://stackoverflow.com/questions/23892547/what-is-the-best-way-to-trigger-onchange-event-in-react-js
var nativeInputValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value');
var nativeInputValueSetter = nativeInputValue ? nativeInputValue.set : undefined;
if (nativeInputValueSetter) {
nativeInputValueSetter.call(_this.inputElement, '');
}
// dispatch input event
var event = new Event('input', {
bubbles: true,
cancelable: false
});
if (_this.inputElement) {
_this.inputElement.dispatchEvent(event);
// set focus on the search field
_this.inputElement.focus();
_this.inputElement.dispatchEvent(new Event('change'));
}
_this.setState({
value: ''
});
var _this$props = _this.props,
incremental = _this$props.incremental,
onSearch = _this$props.onSearch;
if (onSearch && incremental) {
onSearch('');
}
});
(0, _defineProperty2.default)(_this, "setRef", function (inputElement) {
_this.inputElement = inputElement;
if (_this.props.inputRef) {
_this.props.inputRef(inputElement);
}
});
(0, _defineProperty2.default)(_this, "onKeyUp", function (event, incremental, onSearch) {
_this.setState({
value: event.target.value
});
if (_this.props.onKeyUp) {
_this.props.onKeyUp(event);
if (event.defaultPrevented) {
return;
}
}
if (onSearch && (event.key !== _services.keys.ENTER && incremental || event.key === _services.keys.ENTER && !isSearchSupported)) {
onSearch(event.target.value);
}
});
return _this;
}
(0, _inherits2.default)(EuiFieldSearchClass, _Component);
return (0, _createClass2.default)(EuiFieldSearchClass, [{
key: "componentDidMount",
value: function componentDidMount() {
var _this2 = this;
if (!this.inputElement) return;
isSearchSupported = _browser.Browser.isEventSupported('search', this.inputElement);
if (isSearchSupported) {
var onSearch = function onSearch(event) {
if (_this2.props.onSearch) {
if (!event || !event.target || event.defaultPrevented) return;
_this2.props.onSearch(event.target.value);
}
};
this.inputElement.addEventListener('search', onSearch);
this.cleanups.push(function () {
if (!_this2.inputElement) return;
_this2.inputElement.removeEventListener('search', onSearch);
});
}
var onChange = function onChange(event) {
if (event.target && event.target.value !== _this2.state.value) {
_this2.setState({
value: event.target.value
});
if (_this2.props.onSearch) {
_this2.props.onSearch(event.target.value);
}
}
};
this.inputElement.addEventListener('change', onChange);
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
this.cleanups.forEach(function (cleanup) {
return cleanup();
});
}
}, {
key: "render",
value: function render() {
var _this3 = this;
var _ref = this.context,
defaultFullWidth = _ref.defaultFullWidth;
var _this$props2 = this.props,
stylesMemoizer = _this$props2.stylesMemoizer,
className = _this$props2.className,
id = _this$props2.id,
name = _this$props2.name,
placeholder = _this$props2.placeholder,
isInvalid = _this$props2.isInvalid,
disabled = _this$props2.disabled,
_this$props2$fullWidt = _this$props2.fullWidth,
fullWidth = _this$props2$fullWidt === void 0 ? defaultFullWidth : _this$props2$fullWidt,
isLoading = _this$props2.isLoading,
inputRef = _this$props2.inputRef,
incremental = _this$props2.incremental,
compressed = _this$props2.compressed,
onSearch = _this$props2.onSearch,
_isClearable = _this$props2.isClearable,
append = _this$props2.append,
prepend = _this$props2.prepend,
rest = (0, _objectWithoutProperties2.default)(_this$props2, _excluded);
var value = this.props.value;
if (typeof this.props.value !== 'string') value = this.state.value;
// Set actual value of isClearable if value exists as well
var isClearable = Boolean(_isClearable && value && !rest.readOnly && !disabled);
var classes = (0, _classnames.default)('euiFieldSearch', {
'euiFieldSearch-isLoading': isLoading,
'euiFieldSearch-isClearable': isClearable,
'euiFieldSearch-isInvalid': isInvalid
}, className);
var styles = stylesMemoizer(_field_search.euiFieldSearchStyles);
var cssStyles = [styles.euiFieldSearch, compressed ? styles.compressed : styles.uncompressed, fullWidth ? styles.fullWidth : styles.formWidth, (prepend || append) && styles.inGroup];
return (0, _react2.jsx)(_i18n.EuiI18n, {
token: "euiFieldSearch.clearSearchButtonLabel",
default: "Clear search input"
}, function (clearSearchButtonLabel) {
return (0, _react2.jsx)(_form_control_layout.EuiFormControlLayout, {
icon: "search",
fullWidth: fullWidth,
isLoading: isLoading,
isInvalid: isInvalid,
isDisabled: disabled,
clear: isClearable ? {
onClick: _this3.onClear,
'aria-label': clearSearchButtonLabel,
'data-test-subj': 'clearSearchButton'
} : undefined,
compressed: compressed,
append: append,
prepend: prepend
}, (0, _react2.jsx)(_validatable_control.EuiValidatableControl, {
isInvalid: isInvalid
}, (0, _react2.jsx)("input", (0, _extends2.default)({
type: "search",
id: id,
name: name,
placeholder: placeholder,
className: classes,
css: cssStyles,
onKeyUp: function onKeyUp(e) {
return _this3.onKeyUp(e, incremental, onSearch);
},
disabled: disabled,
ref: _this3.setRef
}, rest))));
});
}
}]);
}(_react.Component);
(0, _defineProperty2.default)(EuiFieldSearchClass, "contextType", _eui_form_context.FormContext);
(0, _defineProperty2.default)(EuiFieldSearchClass, "defaultProps", {
isLoading: false,
incremental: false,
compressed: false,
isClearable: true
});
EuiFieldSearchClass.propTypes = {
name: _propTypes.default.string,
id: _propTypes.default.string,
placeholder: _propTypes.default.string,
value: _propTypes.default.string,
isInvalid: _propTypes.default.bool,
/**
* Expand to fill 100% of the parent.
* Defaults to `fullWidth` prop of `<EuiForm>`.
* @default false
*/
fullWidth: _propTypes.default.bool,
isLoading: _propTypes.default.bool,
/**
* Called when the user presses [Enter] OR on change if the incremental prop is `true`.
* If you don't need the on[Enter] functionality, prefer using onChange
*/
onSearch: _propTypes.default.func,
/**
* When `true` the search will be executed (that is, the `onSearch` will be called) as the
* user types.
*/
incremental: _propTypes.default.bool,
/**
* when `true` creates a shorter height input
*/
compressed: _propTypes.default.bool,
inputRef: _propTypes.default.func,
/**
* Shows a button that quickly clears any input
*/
isClearable: _propTypes.default.bool,
/**
* Creates an input group with element(s) coming before input
* `string` | `ReactElement` or an array of these
*/
prepend: _propTypes.default.oneOfType([_propTypes.default.oneOfType([_propTypes.default.string.isRequired, _propTypes.default.element.isRequired]).isRequired, _propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.string.isRequired, _propTypes.default.element.isRequired]).isRequired).isRequired]),
/**
* Creates an input group with element(s) coming after input.
* `string` | `ReactElement` or an array of these
*/
append: _propTypes.default.oneOfType([_propTypes.default.oneOfType([_propTypes.default.string.isRequired, _propTypes.default.element.isRequired]).isRequired, _propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.string.isRequired, _propTypes.default.element.isRequired]).isRequired).isRequired]),
className: _propTypes.default.string,
"aria-label": _propTypes.default.string,
"data-test-subj": _propTypes.default.string,
css: _propTypes.default.any
};
var EuiFieldSearch = exports.EuiFieldSearch = (0, _services.withEuiStylesMemoizer)(EuiFieldSearchClass);