@alfalab/core-components-input-autocomplete 11.0.3 → 11.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/Component.responsive.js +1 -0
  2. package/autocomplete-field/Component.js +1 -1
  3. package/autocomplete-field/index.css +2 -2
  4. package/autocomplete-mobile-field/Component.d.ts +1 -1
  5. package/autocomplete-mobile-field/Component.js +10 -5
  6. package/autocomplete-mobile-field/index.css +8 -8
  7. package/autocomplete-mobile-field/index.js +1 -0
  8. package/cssm/Component.responsive.js +1 -0
  9. package/cssm/autocomplete-mobile-field/Component.d.ts +1 -1
  10. package/cssm/autocomplete-mobile-field/Component.js +9 -4
  11. package/cssm/autocomplete-mobile-field/index.js +1 -0
  12. package/cssm/index.js +1 -0
  13. package/cssm/mobile/Component.mobile.js +5 -2
  14. package/cssm/mobile/Component.modal.mobile.js +1 -0
  15. package/cssm/mobile/index.js +1 -0
  16. package/esm/Component.responsive.js +1 -0
  17. package/esm/autocomplete-field/Component.js +1 -1
  18. package/esm/autocomplete-field/index.css +2 -2
  19. package/esm/autocomplete-mobile-field/Component.d.ts +1 -1
  20. package/esm/autocomplete-mobile-field/Component.js +10 -5
  21. package/esm/autocomplete-mobile-field/index.css +8 -8
  22. package/esm/autocomplete-mobile-field/index.js +1 -0
  23. package/esm/index.js +1 -0
  24. package/esm/mobile/Component.mobile.js +6 -3
  25. package/esm/mobile/Component.modal.mobile.js +1 -0
  26. package/esm/mobile/index.js +1 -0
  27. package/esm/mobile/mobile.css +2 -2
  28. package/index.js +1 -0
  29. package/mobile/Component.mobile.js +6 -3
  30. package/mobile/Component.modal.mobile.js +1 -0
  31. package/mobile/index.js +1 -0
  32. package/mobile/mobile.css +2 -2
  33. package/modern/Component.responsive.js +1 -0
  34. package/modern/autocomplete-field/Component.js +1 -1
  35. package/modern/autocomplete-field/index.css +2 -2
  36. package/modern/autocomplete-mobile-field/Component.d.ts +1 -1
  37. package/modern/autocomplete-mobile-field/Component.js +9 -4
  38. package/modern/autocomplete-mobile-field/index.css +8 -8
  39. package/modern/autocomplete-mobile-field/index.js +1 -0
  40. package/modern/index.js +1 -0
  41. package/modern/mobile/Component.mobile.js +7 -2
  42. package/modern/mobile/Component.modal.mobile.js +1 -0
  43. package/modern/mobile/index.js +1 -0
  44. package/modern/mobile/mobile.css +2 -2
  45. package/package.json +5 -5
  46. package/src/autocomplete-mobile-field/Component.tsx +27 -1
  47. package/src/mobile/Component.mobile.tsx +7 -1
@@ -18,6 +18,7 @@ require('lodash.throttle');
18
18
  require('@alfalab/core-components-select/mobile');
19
19
  require('./autocomplete-mobile-field/Component.js');
20
20
  require('@alfalab/core-components-form-control/mobile');
21
+ require('@alfalab/core-components-input/shared');
21
22
  require('@alfalab/core-components-shared');
22
23
  require('@alfalab/hooks');
23
24
  require('./utils.js');
@@ -14,7 +14,7 @@ var React__default = /*#__PURE__*/_interopDefaultCompat(React);
14
14
  var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
15
15
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
16
16
 
17
- var styles = {"arrow":"input-autocomplete__arrow_z2bi9","error":"input-autocomplete__error_z2bi9"};
17
+ var styles = {"arrow":"input-autocomplete__arrow_wt0tr","error":"input-autocomplete__error_wt0tr"};
18
18
  require('./index.css')
19
19
 
20
20
  var AutocompleteField = function (_a) {
@@ -1,4 +1,4 @@
1
- /* hash: xfkzu */
2
- .input-autocomplete__arrow_z2bi9.input-autocomplete__error_z2bi9 ~ * {
1
+ /* hash: wsrha */
2
+ .input-autocomplete__arrow_wt0tr.input-autocomplete__error_wt0tr ~ * {
3
3
  display: none;
4
4
  }
@@ -15,5 +15,5 @@ type AutocompleteMobileFieldProps = FormControlMobileProps & Omit<BaseFieldProps
15
15
  */
16
16
  value?: string;
17
17
  };
18
- declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
18
+ declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
19
19
  export { AutocompleteMobileFieldProps, AutocompleteMobileField };
@@ -6,6 +6,7 @@ var tslib = require('tslib');
6
6
  var React = require('react');
7
7
  var cn = require('classnames');
8
8
  var mobile = require('@alfalab/core-components-form-control/mobile');
9
+ var shared = require('@alfalab/core-components-input/shared');
9
10
  var coreComponentsShared = require('@alfalab/core-components-shared');
10
11
  var hooks = require('@alfalab/hooks');
11
12
 
@@ -14,25 +15,29 @@ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'defau
14
15
  var React__default = /*#__PURE__*/_interopDefaultCompat(React);
15
16
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
16
17
 
17
- var styles = {"component":"input-autocomplete__component_gg3o5","field":"input-autocomplete__field_gg3o5","disabled":"input-autocomplete__disabled_gg3o5","placeholder":"input-autocomplete__placeholder_gg3o5","contentWrapper":"input-autocomplete__contentWrapper_gg3o5","value":"input-autocomplete__value_gg3o5","focusVisible":"input-autocomplete__focusVisible_gg3o5"};
18
+ var styles = {"component":"input-autocomplete__component_ymkry","field":"input-autocomplete__field_ymkry","disabled":"input-autocomplete__disabled_ymkry","placeholder":"input-autocomplete__placeholder_ymkry","contentWrapper":"input-autocomplete__contentWrapper_ymkry","value":"input-autocomplete__value_ymkry","focusVisible":"input-autocomplete__focusVisible_ymkry"};
18
19
  require('./index.css')
19
20
 
20
21
  var AutocompleteMobileField = function (_a) {
21
22
  var _b;
22
- var _c = _a.size, size = _c === void 0 ? 'm' : _c, open = _a.open, disabled = _a.disabled, value = _a.value, innerProps = _a.innerProps, dataTestId = _a.dataTestId, fieldClassName = _a.fieldClassName, _d = _a.labelView, labelView = _d === void 0 ? 'inner' : _d, placeholder = _a.placeholder, Arrow = _a.Arrow; _a.valueRenderer; _a.toggleMenu; _a.setSelectedItems; _a.selectedMultiple; _a.FormControlComponent; var restProps = tslib.__rest(_a, ["size", "open", "disabled", "value", "innerProps", "dataTestId", "fieldClassName", "labelView", "placeholder", "Arrow", "valueRenderer", "toggleMenu", "setSelectedItems", "selectedMultiple", "FormControlComponent"]);
23
- var _e = React.useState(false), focused = _e[0], setFocused = _e[1];
23
+ var _c = _a.size, size = _c === void 0 ? 'm' : _c, open = _a.open, disabled = _a.disabled, value = _a.value, innerProps = _a.innerProps, dataTestId = _a.dataTestId, fieldClassName = _a.fieldClassName, _d = _a.labelView, labelView = _d === void 0 ? 'inner' : _d, placeholder = _a.placeholder, Arrow = _a.Arrow; _a.valueRenderer; _a.toggleMenu; _a.setSelectedItems; _a.selectedMultiple; _a.FormControlComponent; var rightAddons = _a.rightAddons, error = _a.error, readOnly = _a.readOnly, clear = _a.clear, onClear = _a.onClear; _a.onInput; var _e = _a.colors, colors = _e === void 0 ? 'default' : _e, restProps = tslib.__rest(_a, ["size", "open", "disabled", "value", "innerProps", "dataTestId", "fieldClassName", "labelView", "placeholder", "Arrow", "valueRenderer", "toggleMenu", "setSelectedItems", "selectedMultiple", "FormControlComponent", "rightAddons", "error", "readOnly", "clear", "onClear", "onInput", "colors"]);
24
+ var _f = React.useState(false), focused = _f[0], setFocused = _f[1];
24
25
  var wrapperRef = React.useRef(null);
25
26
  var focusVisible = hooks.useFocus(wrapperRef, 'keyboard')[0];
26
27
  var filled = Boolean(value);
27
28
  var showPlaceholder = placeholder && !filled && labelView === 'outer';
29
+ var clearButtonVisible = clear && filled && !disabled && !readOnly;
28
30
  var tabIndex = innerProps.tabIndex, restInnerProps = tslib.__rest(innerProps, ["tabIndex"]);
29
31
  return (React__default.default.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: function () { return setFocused(true); }, onBlur: function () { return setFocused(false); } },
30
32
  React__default.default.createElement(mobile.FormControlMobile, tslib.__assign({ fieldClassName: cn__default.default(styles.field, fieldClassName, (_b = {},
31
33
  _b[styles.disabled] = disabled,
32
34
  _b[styles.focusVisible] = focusVisible,
33
- _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, rightAddons: Arrow, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'form-control'),
35
+ _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'form-control'),
34
36
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
35
- tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps),
37
+ tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps, { readOnly: readOnly, colors: colors, error: error, rightAddons: (Arrow || rightAddons || clearButtonVisible) && (React__default.default.createElement(React__default.default.Fragment, null,
38
+ clearButtonVisible && (React__default.default.createElement(shared.ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
39
+ rightAddons,
40
+ Arrow)) }),
36
41
  React__default.default.createElement("div", { className: styles.contentWrapper },
37
42
  showPlaceholder && React__default.default.createElement("span", { className: styles.placeholder }, placeholder),
38
43
  filled && React__default.default.createElement("div", { className: styles.value }, value)))));
@@ -1,4 +1,4 @@
1
- /* hash: r7aus */
1
+ /* hash: ru4db */
2
2
  :root {
3
3
  } /* deprecated */ :root {
4
4
  --color-light-border-link: #2288fa;
@@ -18,16 +18,16 @@
18
18
  } :root {
19
19
  --focus-color: var(--color-light-border-link);
20
20
  --disabled-cursor: not-allowed;
21
- } .input-autocomplete__component_gg3o5 {
21
+ } .input-autocomplete__component_ymkry {
22
22
  width: 100%;
23
23
  outline: none;
24
- } .input-autocomplete__field_gg3o5:not(.input-autocomplete__disabled_gg3o5) {
24
+ } .input-autocomplete__field_ymkry:not(.input-autocomplete__disabled_ymkry) {
25
25
  cursor: pointer;
26
- } .input-autocomplete__disabled_gg3o5 {
26
+ } .input-autocomplete__disabled_ymkry {
27
27
  cursor: var(--disabled-cursor);
28
- } .input-autocomplete__placeholder_gg3o5 {
28
+ } .input-autocomplete__placeholder_ymkry {
29
29
  color: var(--color-light-text-secondary);
30
- } .input-autocomplete__contentWrapper_gg3o5 {
30
+ } .input-autocomplete__contentWrapper_ymkry {
31
31
  font-size: 16px;
32
32
  line-height: 20px;
33
33
  font-weight: 400;
@@ -36,11 +36,11 @@
36
36
  text-overflow: ellipsis;
37
37
  overflow: hidden;
38
38
  width: 100%;
39
- } .input-autocomplete__value_gg3o5 {
39
+ } .input-autocomplete__value_ymkry {
40
40
  overflow: hidden;
41
41
  text-overflow: ellipsis;
42
42
  text-align: left;
43
- } .input-autocomplete__focusVisible_gg3o5 {
43
+ } .input-autocomplete__focusVisible_ymkry {
44
44
  outline: 2px solid var(--focus-color);
45
45
  outline-offset: 2px;
46
46
  }
@@ -7,6 +7,7 @@ require('tslib');
7
7
  require('react');
8
8
  require('classnames');
9
9
  require('@alfalab/core-components-form-control/mobile');
10
+ require('@alfalab/core-components-input/shared');
10
11
  require('@alfalab/core-components-shared');
11
12
  require('@alfalab/hooks');
12
13
 
@@ -19,6 +19,7 @@ require('lodash.throttle');
19
19
  require('@alfalab/core-components-select/cssm/mobile');
20
20
  require('./autocomplete-mobile-field/Component.js');
21
21
  require('@alfalab/core-components-form-control/cssm/mobile');
22
+ require('@alfalab/core-components-input/cssm/shared');
22
23
  require('@alfalab/core-components-shared/cssm');
23
24
  require('@alfalab/hooks');
24
25
  require('./autocomplete-mobile-field/index.module.css');
@@ -15,5 +15,5 @@ type AutocompleteMobileFieldProps = FormControlMobileProps & Omit<BaseFieldProps
15
15
  */
16
16
  value?: string;
17
17
  };
18
- declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
18
+ declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
19
19
  export { AutocompleteMobileFieldProps, AutocompleteMobileField };
@@ -6,6 +6,7 @@ var tslib = require('tslib');
6
6
  var React = require('react');
7
7
  var cn = require('classnames');
8
8
  var mobile = require('@alfalab/core-components-form-control/cssm/mobile');
9
+ var shared = require('@alfalab/core-components-input/cssm/shared');
9
10
  var coreComponentsShared = require('@alfalab/core-components-shared/cssm');
10
11
  var hooks = require('@alfalab/hooks');
11
12
  var styles = require('./index.module.css');
@@ -18,20 +19,24 @@ var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
18
19
 
19
20
  var AutocompleteMobileField = function (_a) {
20
21
  var _b;
21
- var _c = _a.size, size = _c === void 0 ? 'm' : _c, open = _a.open, disabled = _a.disabled, value = _a.value, innerProps = _a.innerProps, dataTestId = _a.dataTestId, fieldClassName = _a.fieldClassName, _d = _a.labelView, labelView = _d === void 0 ? 'inner' : _d, placeholder = _a.placeholder, Arrow = _a.Arrow; _a.valueRenderer; _a.toggleMenu; _a.setSelectedItems; _a.selectedMultiple; _a.FormControlComponent; var restProps = tslib.__rest(_a, ["size", "open", "disabled", "value", "innerProps", "dataTestId", "fieldClassName", "labelView", "placeholder", "Arrow", "valueRenderer", "toggleMenu", "setSelectedItems", "selectedMultiple", "FormControlComponent"]);
22
- var _e = React.useState(false), focused = _e[0], setFocused = _e[1];
22
+ var _c = _a.size, size = _c === void 0 ? 'm' : _c, open = _a.open, disabled = _a.disabled, value = _a.value, innerProps = _a.innerProps, dataTestId = _a.dataTestId, fieldClassName = _a.fieldClassName, _d = _a.labelView, labelView = _d === void 0 ? 'inner' : _d, placeholder = _a.placeholder, Arrow = _a.Arrow; _a.valueRenderer; _a.toggleMenu; _a.setSelectedItems; _a.selectedMultiple; _a.FormControlComponent; var rightAddons = _a.rightAddons, error = _a.error, readOnly = _a.readOnly, clear = _a.clear, onClear = _a.onClear; _a.onInput; var _e = _a.colors, colors = _e === void 0 ? 'default' : _e, restProps = tslib.__rest(_a, ["size", "open", "disabled", "value", "innerProps", "dataTestId", "fieldClassName", "labelView", "placeholder", "Arrow", "valueRenderer", "toggleMenu", "setSelectedItems", "selectedMultiple", "FormControlComponent", "rightAddons", "error", "readOnly", "clear", "onClear", "onInput", "colors"]);
23
+ var _f = React.useState(false), focused = _f[0], setFocused = _f[1];
23
24
  var wrapperRef = React.useRef(null);
24
25
  var focusVisible = hooks.useFocus(wrapperRef, 'keyboard')[0];
25
26
  var filled = Boolean(value);
26
27
  var showPlaceholder = placeholder && !filled && labelView === 'outer';
28
+ var clearButtonVisible = clear && filled && !disabled && !readOnly;
27
29
  var tabIndex = innerProps.tabIndex, restInnerProps = tslib.__rest(innerProps, ["tabIndex"]);
28
30
  return (React__default.default.createElement("div", { className: styles__default.default.component, ref: wrapperRef, onFocus: function () { return setFocused(true); }, onBlur: function () { return setFocused(false); } },
29
31
  React__default.default.createElement(mobile.FormControlMobile, tslib.__assign({ fieldClassName: cn__default.default(styles__default.default.field, fieldClassName, (_b = {},
30
32
  _b[styles__default.default.disabled] = disabled,
31
33
  _b[styles__default.default.focusVisible] = focusVisible,
32
- _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, rightAddons: Arrow, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'form-control'),
34
+ _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'form-control'),
33
35
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
34
- tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps),
36
+ tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps, { readOnly: readOnly, colors: colors, error: error, rightAddons: (Arrow || rightAddons || clearButtonVisible) && (React__default.default.createElement(React__default.default.Fragment, null,
37
+ clearButtonVisible && (React__default.default.createElement(shared.ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
38
+ rightAddons,
39
+ Arrow)) }),
35
40
  React__default.default.createElement("div", { className: styles__default.default.contentWrapper },
36
41
  showPlaceholder && React__default.default.createElement("span", { className: styles__default.default.placeholder }, placeholder),
37
42
  filled && React__default.default.createElement("div", { className: styles__default.default.value }, value)))));
@@ -7,6 +7,7 @@ require('tslib');
7
7
  require('react');
8
8
  require('classnames');
9
9
  require('@alfalab/core-components-form-control/cssm/mobile');
10
+ require('@alfalab/core-components-input/cssm/shared');
10
11
  require('@alfalab/core-components-shared/cssm');
11
12
  require('@alfalab/hooks');
12
13
  require('./index.module.css');
package/cssm/index.js CHANGED
@@ -19,6 +19,7 @@ require('lodash.throttle');
19
19
  require('@alfalab/core-components-select/cssm/mobile');
20
20
  require('./autocomplete-mobile-field/Component.js');
21
21
  require('@alfalab/core-components-form-control/cssm/mobile');
22
+ require('@alfalab/core-components-input/cssm/shared');
22
23
  require('@alfalab/core-components-shared/cssm');
23
24
  require('@alfalab/hooks');
24
25
  require('./autocomplete-mobile-field/index.module.css');
@@ -13,6 +13,7 @@ var autocompleteMobileField_Component = require('../autocomplete-mobile-field/Co
13
13
  var utils = require('../utils.js');
14
14
  var styles = require('./mobile.module.css');
15
15
  require('@alfalab/core-components-form-control/cssm/mobile');
16
+ require('@alfalab/core-components-input/cssm/shared');
16
17
  require('@alfalab/core-components-shared/cssm');
17
18
  require('@alfalab/hooks');
18
19
  require('../autocomplete-mobile-field/index.module.css');
@@ -59,6 +60,7 @@ var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, re
59
60
  setModalVisibility(false);
60
61
  restorePrevValue();
61
62
  };
63
+ var handleClear = function () { return onInput === null || onInput === void 0 ? void 0 : onInput(null, { value: '' }); };
62
64
  var handleExiting = function (node) {
63
65
  var _a, _b;
64
66
  (_a = targetRef.current) === null || _a === void 0 ? void 0 : _a.focus();
@@ -75,13 +77,14 @@ var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, re
75
77
  onTouchMove: handleOptionsListTouchMove,
76
78
  },
77
79
  _b);
80
+ var clear = (_c = inputProps === null || inputProps === void 0 ? void 0 : inputProps.clear) !== null && _c !== void 0 ? _c : false;
78
81
  return (React__default.default.createElement(Component, tslib.__assign({ Field: autocompleteMobileField_Component.AutocompleteMobileField }, restProps, (isBottomSheet
79
82
  ? { bottomSheetProps: componentProps }
80
83
  : { modalProps: componentProps }), { dataTestId: dataTestId, useWithApplyHook: false, showSearch: true, searchProps: {
81
84
  value: value,
82
85
  filterFn: utils.searchFilterStub,
83
- componentProps: tslib.__assign(tslib.__assign({ leftAddons: null, placeholder: placeholder }, inputProps), { className: cn__default.default(styles__default.default.input, inputProps === null || inputProps === void 0 ? void 0 : inputProps.className), clear: (_c = inputProps === null || inputProps === void 0 ? void 0 : inputProps.clear) !== null && _c !== void 0 ? _c : false, ref: mergeRefs__default.default([searchInputRef, inputProps === null || inputProps === void 0 ? void 0 : inputProps.ref]), onChange: onInput }),
84
- }, Search: Input, ref: mergeRefs__default.default([targetRef, ref]), open: isOpen, onOpen: handleOpen, Arrow: Arrow, placeholder: placeholder, label: label, size: size, name: name, multiple: multiple, optionsListProps: tslib.__assign({ footer: (React__default.default.createElement(shared.Footer, { showClear: true, handleClear: handleCancel, handleApply: handleApply, clearText: '\u041E\u0442\u043C\u0435\u043D\u0430', applyText: '\u041F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\u044C', dataTestId: dataTestId })) }, restProps.optionsListProps), fieldProps: tslib.__assign({ value: isOpen ? frozenValue.current : value }, restProps.fieldProps) })));
86
+ componentProps: tslib.__assign(tslib.__assign({ leftAddons: null, placeholder: placeholder }, inputProps), { className: cn__default.default(styles__default.default.input, inputProps === null || inputProps === void 0 ? void 0 : inputProps.className), clear: clear, ref: mergeRefs__default.default([searchInputRef, inputProps === null || inputProps === void 0 ? void 0 : inputProps.ref]), onChange: onInput }),
87
+ }, Search: Input, ref: mergeRefs__default.default([targetRef, ref]), open: isOpen, onOpen: handleOpen, Arrow: Arrow, placeholder: placeholder, label: label, size: size, name: name, multiple: multiple, optionsListProps: tslib.__assign({ footer: (React__default.default.createElement(shared.Footer, { showClear: true, handleClear: handleCancel, handleApply: handleApply, clearText: '\u041E\u0442\u043C\u0435\u043D\u0430', applyText: '\u041F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\u044C', dataTestId: dataTestId })) }, restProps.optionsListProps), fieldProps: tslib.__assign({ value: isOpen ? frozenValue.current : value, clear: clear, onClear: clear ? handleClear : undefined }, restProps.fieldProps) })));
85
88
  });
86
89
 
87
90
  exports.InputAutocompleteMobile = InputAutocompleteMobile;
@@ -12,6 +12,7 @@ require('@alfalab/core-components-select/cssm/mobile');
12
12
  require('@alfalab/core-components-select/cssm/shared');
13
13
  require('../autocomplete-mobile-field/Component.js');
14
14
  require('@alfalab/core-components-form-control/cssm/mobile');
15
+ require('@alfalab/core-components-input/cssm/shared');
15
16
  require('@alfalab/core-components-shared/cssm');
16
17
  require('@alfalab/hooks');
17
18
  require('../autocomplete-mobile-field/index.module.css');
@@ -13,6 +13,7 @@ require('@alfalab/core-components-select/cssm/mobile');
13
13
  require('@alfalab/core-components-select/cssm/shared');
14
14
  require('../autocomplete-mobile-field/Component.js');
15
15
  require('@alfalab/core-components-form-control/cssm/mobile');
16
+ require('@alfalab/core-components-input/cssm/shared');
16
17
  require('@alfalab/core-components-shared/cssm');
17
18
  require('@alfalab/hooks');
18
19
  require('../autocomplete-mobile-field/index.module.css');
@@ -14,6 +14,7 @@ import 'lodash.throttle';
14
14
  import '@alfalab/core-components-select/esm/mobile';
15
15
  import './autocomplete-mobile-field/Component.js';
16
16
  import '@alfalab/core-components-form-control/esm/mobile';
17
+ import '@alfalab/core-components-input/esm/shared';
17
18
  import '@alfalab/core-components-shared/esm';
18
19
  import '@alfalab/hooks';
19
20
  import './utils.js';
@@ -4,7 +4,7 @@ import mergeRefs from 'react-merge-refs';
4
4
  import cn from 'classnames';
5
5
  import { InputDesktop } from '@alfalab/core-components-input/esm/desktop';
6
6
 
7
- var styles = {"arrow":"input-autocomplete__arrow_z2bi9","error":"input-autocomplete__error_z2bi9"};
7
+ var styles = {"arrow":"input-autocomplete__arrow_wt0tr","error":"input-autocomplete__error_wt0tr"};
8
8
  require('./index.css')
9
9
 
10
10
  var AutocompleteField = function (_a) {
@@ -1,4 +1,4 @@
1
- /* hash: xfkzu */
2
- .input-autocomplete__arrow_z2bi9.input-autocomplete__error_z2bi9 ~ * {
1
+ /* hash: wsrha */
2
+ .input-autocomplete__arrow_wt0tr.input-autocomplete__error_wt0tr ~ * {
3
3
  display: none;
4
4
  }
@@ -15,5 +15,5 @@ type AutocompleteMobileFieldProps = FormControlMobileProps & Omit<BaseFieldProps
15
15
  */
16
16
  value?: string;
17
17
  };
18
- declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
18
+ declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
19
19
  export { AutocompleteMobileFieldProps, AutocompleteMobileField };
@@ -2,28 +2,33 @@ import { __rest, __assign } from 'tslib';
2
2
  import React, { useState, useRef } from 'react';
3
3
  import cn from 'classnames';
4
4
  import { FormControlMobile } from '@alfalab/core-components-form-control/esm/mobile';
5
+ import { ClearButton } from '@alfalab/core-components-input/esm/shared';
5
6
  import { getDataTestId } from '@alfalab/core-components-shared/esm';
6
7
  import { useFocus } from '@alfalab/hooks';
7
8
 
8
- var styles = {"component":"input-autocomplete__component_gg3o5","field":"input-autocomplete__field_gg3o5","disabled":"input-autocomplete__disabled_gg3o5","placeholder":"input-autocomplete__placeholder_gg3o5","contentWrapper":"input-autocomplete__contentWrapper_gg3o5","value":"input-autocomplete__value_gg3o5","focusVisible":"input-autocomplete__focusVisible_gg3o5"};
9
+ var styles = {"component":"input-autocomplete__component_ymkry","field":"input-autocomplete__field_ymkry","disabled":"input-autocomplete__disabled_ymkry","placeholder":"input-autocomplete__placeholder_ymkry","contentWrapper":"input-autocomplete__contentWrapper_ymkry","value":"input-autocomplete__value_ymkry","focusVisible":"input-autocomplete__focusVisible_ymkry"};
9
10
  require('./index.css')
10
11
 
11
12
  var AutocompleteMobileField = function (_a) {
12
13
  var _b;
13
- var _c = _a.size, size = _c === void 0 ? 'm' : _c, open = _a.open, disabled = _a.disabled, value = _a.value, innerProps = _a.innerProps, dataTestId = _a.dataTestId, fieldClassName = _a.fieldClassName, _d = _a.labelView, labelView = _d === void 0 ? 'inner' : _d, placeholder = _a.placeholder, Arrow = _a.Arrow; _a.valueRenderer; _a.toggleMenu; _a.setSelectedItems; _a.selectedMultiple; _a.FormControlComponent; var restProps = __rest(_a, ["size", "open", "disabled", "value", "innerProps", "dataTestId", "fieldClassName", "labelView", "placeholder", "Arrow", "valueRenderer", "toggleMenu", "setSelectedItems", "selectedMultiple", "FormControlComponent"]);
14
- var _e = useState(false), focused = _e[0], setFocused = _e[1];
14
+ var _c = _a.size, size = _c === void 0 ? 'm' : _c, open = _a.open, disabled = _a.disabled, value = _a.value, innerProps = _a.innerProps, dataTestId = _a.dataTestId, fieldClassName = _a.fieldClassName, _d = _a.labelView, labelView = _d === void 0 ? 'inner' : _d, placeholder = _a.placeholder, Arrow = _a.Arrow; _a.valueRenderer; _a.toggleMenu; _a.setSelectedItems; _a.selectedMultiple; _a.FormControlComponent; var rightAddons = _a.rightAddons, error = _a.error, readOnly = _a.readOnly, clear = _a.clear, onClear = _a.onClear; _a.onInput; var _e = _a.colors, colors = _e === void 0 ? 'default' : _e, restProps = __rest(_a, ["size", "open", "disabled", "value", "innerProps", "dataTestId", "fieldClassName", "labelView", "placeholder", "Arrow", "valueRenderer", "toggleMenu", "setSelectedItems", "selectedMultiple", "FormControlComponent", "rightAddons", "error", "readOnly", "clear", "onClear", "onInput", "colors"]);
15
+ var _f = useState(false), focused = _f[0], setFocused = _f[1];
15
16
  var wrapperRef = useRef(null);
16
17
  var focusVisible = useFocus(wrapperRef, 'keyboard')[0];
17
18
  var filled = Boolean(value);
18
19
  var showPlaceholder = placeholder && !filled && labelView === 'outer';
20
+ var clearButtonVisible = clear && filled && !disabled && !readOnly;
19
21
  var tabIndex = innerProps.tabIndex, restInnerProps = __rest(innerProps, ["tabIndex"]);
20
22
  return (React.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: function () { return setFocused(true); }, onBlur: function () { return setFocused(false); } },
21
23
  React.createElement(FormControlMobile, __assign({ fieldClassName: cn(styles.field, fieldClassName, (_b = {},
22
24
  _b[styles.disabled] = disabled,
23
25
  _b[styles.focusVisible] = focusVisible,
24
- _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, rightAddons: Arrow, dataTestId: getDataTestId(dataTestId, 'form-control'),
26
+ _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: getDataTestId(dataTestId, 'form-control'),
25
27
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
26
- tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps),
28
+ tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps, { readOnly: readOnly, colors: colors, error: error, rightAddons: (Arrow || rightAddons || clearButtonVisible) && (React.createElement(React.Fragment, null,
29
+ clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
30
+ rightAddons,
31
+ Arrow)) }),
27
32
  React.createElement("div", { className: styles.contentWrapper },
28
33
  showPlaceholder && React.createElement("span", { className: styles.placeholder }, placeholder),
29
34
  filled && React.createElement("div", { className: styles.value }, value)))));
@@ -1,4 +1,4 @@
1
- /* hash: r7aus */
1
+ /* hash: ru4db */
2
2
  :root {
3
3
  } /* deprecated */ :root {
4
4
  --color-light-border-link: #2288fa;
@@ -18,16 +18,16 @@
18
18
  } :root {
19
19
  --focus-color: var(--color-light-border-link);
20
20
  --disabled-cursor: not-allowed;
21
- } .input-autocomplete__component_gg3o5 {
21
+ } .input-autocomplete__component_ymkry {
22
22
  width: 100%;
23
23
  outline: none;
24
- } .input-autocomplete__field_gg3o5:not(.input-autocomplete__disabled_gg3o5) {
24
+ } .input-autocomplete__field_ymkry:not(.input-autocomplete__disabled_ymkry) {
25
25
  cursor: pointer;
26
- } .input-autocomplete__disabled_gg3o5 {
26
+ } .input-autocomplete__disabled_ymkry {
27
27
  cursor: var(--disabled-cursor);
28
- } .input-autocomplete__placeholder_gg3o5 {
28
+ } .input-autocomplete__placeholder_ymkry {
29
29
  color: var(--color-light-text-secondary);
30
- } .input-autocomplete__contentWrapper_gg3o5 {
30
+ } .input-autocomplete__contentWrapper_ymkry {
31
31
  font-size: 16px;
32
32
  line-height: 20px;
33
33
  font-weight: 400;
@@ -36,11 +36,11 @@
36
36
  text-overflow: ellipsis;
37
37
  overflow: hidden;
38
38
  width: 100%;
39
- } .input-autocomplete__value_gg3o5 {
39
+ } .input-autocomplete__value_ymkry {
40
40
  overflow: hidden;
41
41
  text-overflow: ellipsis;
42
42
  text-align: left;
43
- } .input-autocomplete__focusVisible_gg3o5 {
43
+ } .input-autocomplete__focusVisible_ymkry {
44
44
  outline: 2px solid var(--focus-color);
45
45
  outline-offset: 2px;
46
46
  }
@@ -3,5 +3,6 @@ import 'tslib';
3
3
  import 'react';
4
4
  import 'classnames';
5
5
  import '@alfalab/core-components-form-control/esm/mobile';
6
+ import '@alfalab/core-components-input/esm/shared';
6
7
  import '@alfalab/core-components-shared/esm';
7
8
  import '@alfalab/hooks';
package/esm/index.js CHANGED
@@ -14,6 +14,7 @@ import 'lodash.throttle';
14
14
  import '@alfalab/core-components-select/esm/mobile';
15
15
  import './autocomplete-mobile-field/Component.js';
16
16
  import '@alfalab/core-components-form-control/esm/mobile';
17
+ import '@alfalab/core-components-input/esm/shared';
17
18
  import '@alfalab/core-components-shared/esm';
18
19
  import '@alfalab/hooks';
19
20
  import './utils.js';
@@ -8,10 +8,11 @@ import { Footer } from '@alfalab/core-components-select/esm/shared';
8
8
  import { AutocompleteMobileField } from '../autocomplete-mobile-field/Component.js';
9
9
  import { searchFilterStub } from '../utils.js';
10
10
  import '@alfalab/core-components-form-control/esm/mobile';
11
+ import '@alfalab/core-components-input/esm/shared';
11
12
  import '@alfalab/core-components-shared/esm';
12
13
  import '@alfalab/hooks';
13
14
 
14
- var styles = {"input":"input-autocomplete__input_dae0s"};
15
+ var styles = {"input":"input-autocomplete__input_fjopa"};
15
16
  require('./mobile.css')
16
17
 
17
18
  var InputAutocompleteMobile = React.forwardRef(function (_a, ref) {
@@ -48,6 +49,7 @@ var InputAutocompleteMobile = React.forwardRef(function (_a, ref) {
48
49
  setModalVisibility(false);
49
50
  restorePrevValue();
50
51
  };
52
+ var handleClear = function () { return onInput === null || onInput === void 0 ? void 0 : onInput(null, { value: '' }); };
51
53
  var handleExiting = function (node) {
52
54
  var _a, _b;
53
55
  (_a = targetRef.current) === null || _a === void 0 ? void 0 : _a.focus();
@@ -64,13 +66,14 @@ var InputAutocompleteMobile = React.forwardRef(function (_a, ref) {
64
66
  onTouchMove: handleOptionsListTouchMove,
65
67
  },
66
68
  _b);
69
+ var clear = (_c = inputProps === null || inputProps === void 0 ? void 0 : inputProps.clear) !== null && _c !== void 0 ? _c : false;
67
70
  return (React.createElement(Component, __assign({ Field: AutocompleteMobileField }, restProps, (isBottomSheet
68
71
  ? { bottomSheetProps: componentProps }
69
72
  : { modalProps: componentProps }), { dataTestId: dataTestId, useWithApplyHook: false, showSearch: true, searchProps: {
70
73
  value: value,
71
74
  filterFn: searchFilterStub,
72
- componentProps: __assign(__assign({ leftAddons: null, placeholder: placeholder }, inputProps), { className: cn(styles.input, inputProps === null || inputProps === void 0 ? void 0 : inputProps.className), clear: (_c = inputProps === null || inputProps === void 0 ? void 0 : inputProps.clear) !== null && _c !== void 0 ? _c : false, ref: mergeRefs([searchInputRef, inputProps === null || inputProps === void 0 ? void 0 : inputProps.ref]), onChange: onInput }),
73
- }, Search: Input, ref: mergeRefs([targetRef, ref]), open: isOpen, onOpen: handleOpen, Arrow: Arrow, placeholder: placeholder, label: label, size: size, name: name, multiple: multiple, optionsListProps: __assign({ footer: (React.createElement(Footer, { showClear: true, handleClear: handleCancel, handleApply: handleApply, clearText: '\u041E\u0442\u043C\u0435\u043D\u0430', applyText: '\u041F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\u044C', dataTestId: dataTestId })) }, restProps.optionsListProps), fieldProps: __assign({ value: isOpen ? frozenValue.current : value }, restProps.fieldProps) })));
75
+ componentProps: __assign(__assign({ leftAddons: null, placeholder: placeholder }, inputProps), { className: cn(styles.input, inputProps === null || inputProps === void 0 ? void 0 : inputProps.className), clear: clear, ref: mergeRefs([searchInputRef, inputProps === null || inputProps === void 0 ? void 0 : inputProps.ref]), onChange: onInput }),
76
+ }, Search: Input, ref: mergeRefs([targetRef, ref]), open: isOpen, onOpen: handleOpen, Arrow: Arrow, placeholder: placeholder, label: label, size: size, name: name, multiple: multiple, optionsListProps: __assign({ footer: (React.createElement(Footer, { showClear: true, handleClear: handleCancel, handleApply: handleApply, clearText: '\u041E\u0442\u043C\u0435\u043D\u0430', applyText: '\u041F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\u044C', dataTestId: dataTestId })) }, restProps.optionsListProps), fieldProps: __assign({ value: isOpen ? frozenValue.current : value, clear: clear, onClear: clear ? handleClear : undefined }, restProps.fieldProps) })));
74
77
  });
75
78
 
76
79
  export { InputAutocompleteMobile };
@@ -8,6 +8,7 @@ import '@alfalab/core-components-select/esm/mobile';
8
8
  import '@alfalab/core-components-select/esm/shared';
9
9
  import '../autocomplete-mobile-field/Component.js';
10
10
  import '@alfalab/core-components-form-control/esm/mobile';
11
+ import '@alfalab/core-components-input/esm/shared';
11
12
  import '@alfalab/core-components-shared/esm';
12
13
  import '@alfalab/hooks';
13
14
  import '../utils.js';
@@ -9,6 +9,7 @@ import '@alfalab/core-components-select/esm/mobile';
9
9
  import '@alfalab/core-components-select/esm/shared';
10
10
  import '../autocomplete-mobile-field/Component.js';
11
11
  import '@alfalab/core-components-form-control/esm/mobile';
12
+ import '@alfalab/core-components-input/esm/shared';
12
13
  import '@alfalab/core-components-shared/esm';
13
14
  import '@alfalab/hooks';
14
15
  import '../utils.js';
@@ -1,4 +1,4 @@
1
- /* hash: 5n9cn */
1
+ /* hash: 1otm4 */
2
2
  :root {
3
3
  } /* deprecated */ :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
4
4
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
@@ -14,6 +14,6 @@
14
14
  } :root {
15
15
  } :root {
16
16
  } :root {
17
- } .input-autocomplete__input_dae0s {
17
+ } .input-autocomplete__input_fjopa {
18
18
  width: auto;
19
19
  }
package/index.js CHANGED
@@ -18,6 +18,7 @@ require('lodash.throttle');
18
18
  require('@alfalab/core-components-select/mobile');
19
19
  require('./autocomplete-mobile-field/Component.js');
20
20
  require('@alfalab/core-components-form-control/mobile');
21
+ require('@alfalab/core-components-input/shared');
21
22
  require('@alfalab/core-components-shared');
22
23
  require('@alfalab/hooks');
23
24
  require('./utils.js');
@@ -12,6 +12,7 @@ var shared = require('@alfalab/core-components-select/shared');
12
12
  var autocompleteMobileField_Component = require('../autocomplete-mobile-field/Component.js');
13
13
  var utils = require('../utils.js');
14
14
  require('@alfalab/core-components-form-control/mobile');
15
+ require('@alfalab/core-components-input/shared');
15
16
  require('@alfalab/core-components-shared');
16
17
  require('@alfalab/hooks');
17
18
 
@@ -22,7 +23,7 @@ var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
22
23
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
23
24
  var throttle__default = /*#__PURE__*/_interopDefaultCompat(throttle);
24
25
 
25
- var styles = {"input":"input-autocomplete__input_dae0s"};
26
+ var styles = {"input":"input-autocomplete__input_fjopa"};
26
27
  require('./mobile.css')
27
28
 
28
29
  var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, ref) {
@@ -59,6 +60,7 @@ var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, re
59
60
  setModalVisibility(false);
60
61
  restorePrevValue();
61
62
  };
63
+ var handleClear = function () { return onInput === null || onInput === void 0 ? void 0 : onInput(null, { value: '' }); };
62
64
  var handleExiting = function (node) {
63
65
  var _a, _b;
64
66
  (_a = targetRef.current) === null || _a === void 0 ? void 0 : _a.focus();
@@ -75,13 +77,14 @@ var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, re
75
77
  onTouchMove: handleOptionsListTouchMove,
76
78
  },
77
79
  _b);
80
+ var clear = (_c = inputProps === null || inputProps === void 0 ? void 0 : inputProps.clear) !== null && _c !== void 0 ? _c : false;
78
81
  return (React__default.default.createElement(Component, tslib.__assign({ Field: autocompleteMobileField_Component.AutocompleteMobileField }, restProps, (isBottomSheet
79
82
  ? { bottomSheetProps: componentProps }
80
83
  : { modalProps: componentProps }), { dataTestId: dataTestId, useWithApplyHook: false, showSearch: true, searchProps: {
81
84
  value: value,
82
85
  filterFn: utils.searchFilterStub,
83
- componentProps: tslib.__assign(tslib.__assign({ leftAddons: null, placeholder: placeholder }, inputProps), { className: cn__default.default(styles.input, inputProps === null || inputProps === void 0 ? void 0 : inputProps.className), clear: (_c = inputProps === null || inputProps === void 0 ? void 0 : inputProps.clear) !== null && _c !== void 0 ? _c : false, ref: mergeRefs__default.default([searchInputRef, inputProps === null || inputProps === void 0 ? void 0 : inputProps.ref]), onChange: onInput }),
84
- }, Search: Input, ref: mergeRefs__default.default([targetRef, ref]), open: isOpen, onOpen: handleOpen, Arrow: Arrow, placeholder: placeholder, label: label, size: size, name: name, multiple: multiple, optionsListProps: tslib.__assign({ footer: (React__default.default.createElement(shared.Footer, { showClear: true, handleClear: handleCancel, handleApply: handleApply, clearText: '\u041E\u0442\u043C\u0435\u043D\u0430', applyText: '\u041F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\u044C', dataTestId: dataTestId })) }, restProps.optionsListProps), fieldProps: tslib.__assign({ value: isOpen ? frozenValue.current : value }, restProps.fieldProps) })));
86
+ componentProps: tslib.__assign(tslib.__assign({ leftAddons: null, placeholder: placeholder }, inputProps), { className: cn__default.default(styles.input, inputProps === null || inputProps === void 0 ? void 0 : inputProps.className), clear: clear, ref: mergeRefs__default.default([searchInputRef, inputProps === null || inputProps === void 0 ? void 0 : inputProps.ref]), onChange: onInput }),
87
+ }, Search: Input, ref: mergeRefs__default.default([targetRef, ref]), open: isOpen, onOpen: handleOpen, Arrow: Arrow, placeholder: placeholder, label: label, size: size, name: name, multiple: multiple, optionsListProps: tslib.__assign({ footer: (React__default.default.createElement(shared.Footer, { showClear: true, handleClear: handleCancel, handleApply: handleApply, clearText: '\u041E\u0442\u043C\u0435\u043D\u0430', applyText: '\u041F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\u044C', dataTestId: dataTestId })) }, restProps.optionsListProps), fieldProps: tslib.__assign({ value: isOpen ? frozenValue.current : value, clear: clear, onClear: clear ? handleClear : undefined }, restProps.fieldProps) })));
85
88
  });
86
89
 
87
90
  exports.InputAutocompleteMobile = InputAutocompleteMobile;
@@ -12,6 +12,7 @@ require('@alfalab/core-components-select/mobile');
12
12
  require('@alfalab/core-components-select/shared');
13
13
  require('../autocomplete-mobile-field/Component.js');
14
14
  require('@alfalab/core-components-form-control/mobile');
15
+ require('@alfalab/core-components-input/shared');
15
16
  require('@alfalab/core-components-shared');
16
17
  require('@alfalab/hooks');
17
18
  require('../utils.js');
package/mobile/index.js CHANGED
@@ -13,6 +13,7 @@ require('@alfalab/core-components-select/mobile');
13
13
  require('@alfalab/core-components-select/shared');
14
14
  require('../autocomplete-mobile-field/Component.js');
15
15
  require('@alfalab/core-components-form-control/mobile');
16
+ require('@alfalab/core-components-input/shared');
16
17
  require('@alfalab/core-components-shared');
17
18
  require('@alfalab/hooks');
18
19
  require('../utils.js');
package/mobile/mobile.css CHANGED
@@ -1,4 +1,4 @@
1
- /* hash: 5n9cn */
1
+ /* hash: 1otm4 */
2
2
  :root {
3
3
  } /* deprecated */ :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
4
4
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
@@ -14,6 +14,6 @@
14
14
  } :root {
15
15
  } :root {
16
16
  } :root {
17
- } .input-autocomplete__input_dae0s {
17
+ } .input-autocomplete__input_fjopa {
18
18
  width: auto;
19
19
  }
@@ -13,6 +13,7 @@ import 'lodash.throttle';
13
13
  import '@alfalab/core-components-select/modern/mobile';
14
14
  import './autocomplete-mobile-field/Component.js';
15
15
  import '@alfalab/core-components-form-control/modern/mobile';
16
+ import '@alfalab/core-components-input/modern/shared';
16
17
  import '@alfalab/core-components-shared/modern';
17
18
  import '@alfalab/hooks';
18
19
  import './utils.js';
@@ -3,7 +3,7 @@ import mergeRefs from 'react-merge-refs';
3
3
  import cn from 'classnames';
4
4
  import { InputDesktop } from '@alfalab/core-components-input/modern/desktop';
5
5
 
6
- const styles = {"arrow":"input-autocomplete__arrow_z2bi9","error":"input-autocomplete__error_z2bi9"};
6
+ const styles = {"arrow":"input-autocomplete__arrow_wt0tr","error":"input-autocomplete__error_wt0tr"};
7
7
  require('./index.css')
8
8
 
9
9
  const AutocompleteField = ({ label, labelView = 'inner', placeholder, size, Arrow, Input = InputDesktop, value, error, success, hint, disabled, readOnly, onInput, inputProps = {}, innerProps, }) => {
@@ -1,4 +1,4 @@
1
- /* hash: xfkzu */
2
- .input-autocomplete__arrow_z2bi9.input-autocomplete__error_z2bi9 ~ * {
1
+ /* hash: wsrha */
2
+ .input-autocomplete__arrow_wt0tr.input-autocomplete__error_wt0tr ~ * {
3
3
  display: none;
4
4
  }
@@ -15,5 +15,5 @@ type AutocompleteMobileFieldProps = FormControlMobileProps & Omit<BaseFieldProps
15
15
  */
16
16
  value?: string;
17
17
  };
18
- declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
18
+ declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
19
19
  export { AutocompleteMobileFieldProps, AutocompleteMobileField };
@@ -1,26 +1,31 @@
1
1
  import React, { useState, useRef } from 'react';
2
2
  import cn from 'classnames';
3
3
  import { FormControlMobile } from '@alfalab/core-components-form-control/modern/mobile';
4
+ import { ClearButton } from '@alfalab/core-components-input/modern/shared';
4
5
  import { getDataTestId } from '@alfalab/core-components-shared/modern';
5
6
  import { useFocus } from '@alfalab/hooks';
6
7
 
7
- const styles = {"component":"input-autocomplete__component_gg3o5","field":"input-autocomplete__field_gg3o5","disabled":"input-autocomplete__disabled_gg3o5","placeholder":"input-autocomplete__placeholder_gg3o5","contentWrapper":"input-autocomplete__contentWrapper_gg3o5","value":"input-autocomplete__value_gg3o5","focusVisible":"input-autocomplete__focusVisible_gg3o5"};
8
+ const styles = {"component":"input-autocomplete__component_ymkry","field":"input-autocomplete__field_ymkry","disabled":"input-autocomplete__disabled_ymkry","placeholder":"input-autocomplete__placeholder_ymkry","contentWrapper":"input-autocomplete__contentWrapper_ymkry","value":"input-autocomplete__value_ymkry","focusVisible":"input-autocomplete__focusVisible_ymkry"};
8
9
  require('./index.css')
9
10
 
10
- const AutocompleteMobileField = ({ size = 'm', open, disabled, value, innerProps, dataTestId, fieldClassName, labelView = 'inner', placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, ...restProps }) => {
11
+ const AutocompleteMobileField = ({ size = 'm', open, disabled, value, innerProps, dataTestId, fieldClassName, labelView = 'inner', placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors = 'default', ...restProps }) => {
11
12
  const [focused, setFocused] = useState(false);
12
13
  const wrapperRef = useRef(null);
13
14
  const [focusVisible] = useFocus(wrapperRef, 'keyboard');
14
15
  const filled = Boolean(value);
15
16
  const showPlaceholder = placeholder && !filled && labelView === 'outer';
17
+ const clearButtonVisible = clear && filled && !disabled && !readOnly;
16
18
  const { tabIndex, ...restInnerProps } = innerProps;
17
19
  return (React.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: () => setFocused(true), onBlur: () => setFocused(false) },
18
20
  React.createElement(FormControlMobile, { fieldClassName: cn(styles.field, fieldClassName, {
19
21
  [styles.disabled]: disabled,
20
22
  [styles.focusVisible]: focusVisible,
21
- }), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, rightAddons: Arrow, dataTestId: getDataTestId(dataTestId, 'form-control'),
23
+ }), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: getDataTestId(dataTestId, 'form-control'),
22
24
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
23
- tabIndex: open ? undefined : tabIndex, ...restProps, ...restInnerProps },
25
+ tabIndex: open ? undefined : tabIndex, ...restProps, ...restInnerProps, readOnly: readOnly, colors: colors, error: error, rightAddons: (Arrow || rightAddons || clearButtonVisible) && (React.createElement(React.Fragment, null,
26
+ clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
27
+ rightAddons,
28
+ Arrow)) },
24
29
  React.createElement("div", { className: styles.contentWrapper },
25
30
  showPlaceholder && React.createElement("span", { className: styles.placeholder }, placeholder),
26
31
  filled && React.createElement("div", { className: styles.value }, value)))));
@@ -1,4 +1,4 @@
1
- /* hash: r7aus */
1
+ /* hash: ru4db */
2
2
  :root {
3
3
  } /* deprecated */ :root {
4
4
  --color-light-border-link: #2288fa;
@@ -18,16 +18,16 @@
18
18
  } :root {
19
19
  --focus-color: var(--color-light-border-link);
20
20
  --disabled-cursor: not-allowed;
21
- } .input-autocomplete__component_gg3o5 {
21
+ } .input-autocomplete__component_ymkry {
22
22
  width: 100%;
23
23
  outline: none;
24
- } .input-autocomplete__field_gg3o5:not(.input-autocomplete__disabled_gg3o5) {
24
+ } .input-autocomplete__field_ymkry:not(.input-autocomplete__disabled_ymkry) {
25
25
  cursor: pointer;
26
- } .input-autocomplete__disabled_gg3o5 {
26
+ } .input-autocomplete__disabled_ymkry {
27
27
  cursor: var(--disabled-cursor);
28
- } .input-autocomplete__placeholder_gg3o5 {
28
+ } .input-autocomplete__placeholder_ymkry {
29
29
  color: var(--color-light-text-secondary);
30
- } .input-autocomplete__contentWrapper_gg3o5 {
30
+ } .input-autocomplete__contentWrapper_ymkry {
31
31
  font-size: 16px;
32
32
  line-height: 20px;
33
33
  font-weight: 400;
@@ -36,11 +36,11 @@
36
36
  text-overflow: ellipsis;
37
37
  overflow: hidden;
38
38
  width: 100%;
39
- } .input-autocomplete__value_gg3o5 {
39
+ } .input-autocomplete__value_ymkry {
40
40
  overflow: hidden;
41
41
  text-overflow: ellipsis;
42
42
  text-align: left;
43
- } .input-autocomplete__focusVisible_gg3o5 {
43
+ } .input-autocomplete__focusVisible_ymkry {
44
44
  outline: 2px solid var(--focus-color);
45
45
  outline-offset: 2px;
46
46
  }
@@ -2,5 +2,6 @@ export { AutocompleteMobileField } from './Component.js';
2
2
  import 'react';
3
3
  import 'classnames';
4
4
  import '@alfalab/core-components-form-control/modern/mobile';
5
+ import '@alfalab/core-components-input/modern/shared';
5
6
  import '@alfalab/core-components-shared/modern';
6
7
  import '@alfalab/hooks';
package/modern/index.js CHANGED
@@ -13,6 +13,7 @@ import 'lodash.throttle';
13
13
  import '@alfalab/core-components-select/modern/mobile';
14
14
  import './autocomplete-mobile-field/Component.js';
15
15
  import '@alfalab/core-components-form-control/modern/mobile';
16
+ import '@alfalab/core-components-input/modern/shared';
16
17
  import '@alfalab/core-components-shared/modern';
17
18
  import '@alfalab/hooks';
18
19
  import './utils.js';
@@ -7,10 +7,11 @@ import { Footer } from '@alfalab/core-components-select/modern/shared';
7
7
  import { AutocompleteMobileField } from '../autocomplete-mobile-field/Component.js';
8
8
  import { searchFilterStub } from '../utils.js';
9
9
  import '@alfalab/core-components-form-control/modern/mobile';
10
+ import '@alfalab/core-components-input/modern/shared';
10
11
  import '@alfalab/core-components-shared/modern';
11
12
  import '@alfalab/hooks';
12
13
 
13
- const styles = {"input":"input-autocomplete__input_dae0s"};
14
+ const styles = {"input":"input-autocomplete__input_fjopa"};
14
15
  require('./mobile.css')
15
16
 
16
17
  const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow = null, label, placeholder = '', size = 's', open: openProp, onInput, onOpen, multiple, inputProps, isBottomSheet = true, dataTestId, transitionProps, ...restProps }, ref) => {
@@ -42,6 +43,7 @@ const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow =
42
43
  setModalVisibility(false);
43
44
  restorePrevValue();
44
45
  };
46
+ const handleClear = () => onInput?.(null, { value: '' });
45
47
  const handleExiting = (node) => {
46
48
  targetRef.current?.focus();
47
49
  transitionProps?.onExiting?.(node);
@@ -59,6 +61,7 @@ const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow =
59
61
  onTouchMove: handleOptionsListTouchMove,
60
62
  },
61
63
  };
64
+ const clear = inputProps?.clear ?? false;
62
65
  return (React.createElement(Component, { Field: AutocompleteMobileField, ...restProps, ...(isBottomSheet
63
66
  ? { bottomSheetProps: componentProps }
64
67
  : { modalProps: componentProps }), dataTestId: dataTestId, useWithApplyHook: false, showSearch: true, searchProps: {
@@ -69,7 +72,7 @@ const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow =
69
72
  placeholder,
70
73
  ...inputProps,
71
74
  className: cn(styles.input, inputProps?.className),
72
- clear: inputProps?.clear ?? false,
75
+ clear,
73
76
  ref: mergeRefs([searchInputRef, inputProps?.ref]),
74
77
  onChange: onInput,
75
78
  },
@@ -78,6 +81,8 @@ const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow =
78
81
  ...restProps.optionsListProps,
79
82
  }, fieldProps: {
80
83
  value: isOpen ? frozenValue.current : value,
84
+ clear,
85
+ onClear: clear ? handleClear : undefined,
81
86
  ...restProps.fieldProps,
82
87
  } }));
83
88
  });
@@ -7,6 +7,7 @@ import '@alfalab/core-components-select/modern/mobile';
7
7
  import '@alfalab/core-components-select/modern/shared';
8
8
  import '../autocomplete-mobile-field/Component.js';
9
9
  import '@alfalab/core-components-form-control/modern/mobile';
10
+ import '@alfalab/core-components-input/modern/shared';
10
11
  import '@alfalab/core-components-shared/modern';
11
12
  import '@alfalab/hooks';
12
13
  import '../utils.js';
@@ -8,6 +8,7 @@ import '@alfalab/core-components-select/modern/mobile';
8
8
  import '@alfalab/core-components-select/modern/shared';
9
9
  import '../autocomplete-mobile-field/Component.js';
10
10
  import '@alfalab/core-components-form-control/modern/mobile';
11
+ import '@alfalab/core-components-input/modern/shared';
11
12
  import '@alfalab/core-components-shared/modern';
12
13
  import '@alfalab/hooks';
13
14
  import '../utils.js';
@@ -1,4 +1,4 @@
1
- /* hash: 5n9cn */
1
+ /* hash: 1otm4 */
2
2
  :root {
3
3
  } /* deprecated */ :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
4
4
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
@@ -14,6 +14,6 @@
14
14
  } :root {
15
15
  } :root {
16
16
  } :root {
17
- } .input-autocomplete__input_dae0s {
17
+ } .input-autocomplete__input_fjopa {
18
18
  width: auto;
19
19
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alfalab/core-components-input-autocomplete",
3
- "version": "11.0.3",
3
+ "version": "11.1.0",
4
4
  "description": "",
5
5
  "keywords": [],
6
6
  "license": "MIT",
@@ -14,10 +14,10 @@
14
14
  "react": "^16.9.0 || ^17.0.1 || ^18.0.0"
15
15
  },
16
16
  "dependencies": {
17
- "@alfalab/core-components-form-control": "^11.1.0",
18
- "@alfalab/core-components-input": "^13.0.2",
19
- "@alfalab/core-components-popover": "^6.1.0",
20
- "@alfalab/core-components-select": "^16.0.3",
17
+ "@alfalab/core-components-form-control": "^12.0.0",
18
+ "@alfalab/core-components-input": "^14.0.0",
19
+ "@alfalab/core-components-popover": "^6.2.0",
20
+ "@alfalab/core-components-select": "^17.0.0",
21
21
  "@alfalab/core-components-shared": "^0.8.0",
22
22
  "@alfalab/core-components-mq": "^4.2.0",
23
23
  "@alfalab/hooks": "^1.13.0",
@@ -5,6 +5,7 @@ import {
5
5
  FormControlMobile,
6
6
  FormControlMobileProps,
7
7
  } from '@alfalab/core-components-form-control/mobile';
8
+ import { ClearButton } from '@alfalab/core-components-input/shared';
8
9
  import type { FieldProps as BaseFieldProps } from '@alfalab/core-components-select/shared';
9
10
  import { getDataTestId } from '@alfalab/core-components-shared';
10
11
  import { useFocus } from '@alfalab/hooks';
@@ -42,6 +43,13 @@ export const AutocompleteMobileField = ({
42
43
  setSelectedItems,
43
44
  selectedMultiple,
44
45
  FormControlComponent,
46
+ rightAddons,
47
+ error,
48
+ readOnly,
49
+ clear,
50
+ onClear,
51
+ onInput,
52
+ colors = 'default',
45
53
  ...restProps
46
54
  }: AutocompleteMobileFieldProps & FieldProps) => {
47
55
  const [focused, setFocused] = useState(false);
@@ -52,6 +60,7 @@ export const AutocompleteMobileField = ({
52
60
 
53
61
  const filled = Boolean(value);
54
62
  const showPlaceholder = placeholder && !filled && labelView === 'outer';
63
+ const clearButtonVisible = clear && filled && !disabled && !readOnly;
55
64
 
56
65
  const { tabIndex, ...restInnerProps } = innerProps;
57
66
 
@@ -73,12 +82,29 @@ export const AutocompleteMobileField = ({
73
82
  disabled={disabled}
74
83
  filled={filled}
75
84
  labelView={labelView}
76
- rightAddons={Arrow}
77
85
  dataTestId={getDataTestId(dataTestId, 'form-control')}
78
86
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
79
87
  tabIndex={open ? undefined : tabIndex}
80
88
  {...restProps}
81
89
  {...restInnerProps}
90
+ readOnly={readOnly}
91
+ colors={colors}
92
+ error={error}
93
+ rightAddons={
94
+ (Arrow || rightAddons || clearButtonVisible) && (
95
+ <React.Fragment>
96
+ {clearButtonVisible && (
97
+ <ClearButton
98
+ onClick={onClear}
99
+ disabled={disabled}
100
+ colors={colors}
101
+ />
102
+ )}
103
+ {rightAddons}
104
+ {Arrow}
105
+ </React.Fragment>
106
+ )
107
+ }
82
108
  >
83
109
  <div className={styles.contentWrapper}>
84
110
  {showPlaceholder && <span className={styles.placeholder}>{placeholder}</span>}
@@ -85,6 +85,8 @@ export const InputAutocompleteMobile = React.forwardRef(
85
85
  restorePrevValue();
86
86
  };
87
87
 
88
+ const handleClear = () => onInput?.(null, { value: '' });
89
+
88
90
  const handleExiting = (node: HTMLElement) => {
89
91
  targetRef.current?.focus();
90
92
  transitionProps?.onExiting?.(node);
@@ -108,6 +110,8 @@ export const InputAutocompleteMobile = React.forwardRef(
108
110
  },
109
111
  };
110
112
 
113
+ const clear = inputProps?.clear ?? false;
114
+
111
115
  return (
112
116
  <Component
113
117
  Field={AutocompleteMobileField}
@@ -126,7 +130,7 @@ export const InputAutocompleteMobile = React.forwardRef(
126
130
  placeholder,
127
131
  ...inputProps,
128
132
  className: cn(styles.input, inputProps?.className),
129
- clear: inputProps?.clear ?? false,
133
+ clear,
130
134
  ref: mergeRefs([searchInputRef, inputProps?.ref as Ref<HTMLInputElement>]),
131
135
  onChange: onInput,
132
136
  },
@@ -156,6 +160,8 @@ export const InputAutocompleteMobile = React.forwardRef(
156
160
  }}
157
161
  fieldProps={{
158
162
  value: isOpen ? frozenValue.current : value,
163
+ clear,
164
+ onClear: clear ? handleClear : undefined,
159
165
  ...(restProps.fieldProps as AnyObject),
160
166
  }}
161
167
  />