@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.
- package/Component.responsive.js +1 -0
- package/autocomplete-field/Component.js +1 -1
- package/autocomplete-field/index.css +2 -2
- package/autocomplete-mobile-field/Component.d.ts +1 -1
- package/autocomplete-mobile-field/Component.js +10 -5
- package/autocomplete-mobile-field/index.css +8 -8
- package/autocomplete-mobile-field/index.js +1 -0
- package/cssm/Component.responsive.js +1 -0
- package/cssm/autocomplete-mobile-field/Component.d.ts +1 -1
- package/cssm/autocomplete-mobile-field/Component.js +9 -4
- package/cssm/autocomplete-mobile-field/index.js +1 -0
- package/cssm/index.js +1 -0
- package/cssm/mobile/Component.mobile.js +5 -2
- package/cssm/mobile/Component.modal.mobile.js +1 -0
- package/cssm/mobile/index.js +1 -0
- package/esm/Component.responsive.js +1 -0
- package/esm/autocomplete-field/Component.js +1 -1
- package/esm/autocomplete-field/index.css +2 -2
- package/esm/autocomplete-mobile-field/Component.d.ts +1 -1
- package/esm/autocomplete-mobile-field/Component.js +10 -5
- package/esm/autocomplete-mobile-field/index.css +8 -8
- package/esm/autocomplete-mobile-field/index.js +1 -0
- package/esm/index.js +1 -0
- package/esm/mobile/Component.mobile.js +6 -3
- package/esm/mobile/Component.modal.mobile.js +1 -0
- package/esm/mobile/index.js +1 -0
- package/esm/mobile/mobile.css +2 -2
- package/index.js +1 -0
- package/mobile/Component.mobile.js +6 -3
- package/mobile/Component.modal.mobile.js +1 -0
- package/mobile/index.js +1 -0
- package/mobile/mobile.css +2 -2
- package/modern/Component.responsive.js +1 -0
- package/modern/autocomplete-field/Component.js +1 -1
- package/modern/autocomplete-field/index.css +2 -2
- package/modern/autocomplete-mobile-field/Component.d.ts +1 -1
- package/modern/autocomplete-mobile-field/Component.js +9 -4
- package/modern/autocomplete-mobile-field/index.css +8 -8
- package/modern/autocomplete-mobile-field/index.js +1 -0
- package/modern/index.js +1 -0
- package/modern/mobile/Component.mobile.js +7 -2
- package/modern/mobile/Component.modal.mobile.js +1 -0
- package/modern/mobile/index.js +1 -0
- package/modern/mobile/mobile.css +2 -2
- package/package.json +5 -5
- package/src/autocomplete-mobile-field/Component.tsx +27 -1
- package/src/mobile/Component.mobile.tsx +7 -1
package/Component.responsive.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');
|
|
@@ -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-
|
|
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) {
|
|
@@ -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-
|
|
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
|
|
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,
|
|
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:
|
|
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-
|
|
21
|
+
} .input-autocomplete__component_ymkry {
|
|
22
22
|
width: 100%;
|
|
23
23
|
outline: none;
|
|
24
|
-
} .input-
|
|
24
|
+
} .input-autocomplete__field_ymkry:not(.input-autocomplete__disabled_ymkry) {
|
|
25
25
|
cursor: pointer;
|
|
26
|
-
} .input-
|
|
26
|
+
} .input-autocomplete__disabled_ymkry {
|
|
27
27
|
cursor: var(--disabled-cursor);
|
|
28
|
-
} .input-
|
|
28
|
+
} .input-autocomplete__placeholder_ymkry {
|
|
29
29
|
color: var(--color-light-text-secondary);
|
|
30
|
-
} .input-
|
|
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-
|
|
39
|
+
} .input-autocomplete__value_ymkry {
|
|
40
40
|
overflow: hidden;
|
|
41
41
|
text-overflow: ellipsis;
|
|
42
42
|
text-align: left;
|
|
43
|
-
} .input-
|
|
43
|
+
} .input-autocomplete__focusVisible_ymkry {
|
|
44
44
|
outline: 2px solid var(--focus-color);
|
|
45
45
|
outline-offset: 2px;
|
|
46
46
|
}
|
|
@@ -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
|
|
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,
|
|
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:
|
|
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');
|
package/cssm/mobile/index.js
CHANGED
|
@@ -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-
|
|
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) {
|
|
@@ -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-
|
|
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
|
|
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,
|
|
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:
|
|
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-
|
|
21
|
+
} .input-autocomplete__component_ymkry {
|
|
22
22
|
width: 100%;
|
|
23
23
|
outline: none;
|
|
24
|
-
} .input-
|
|
24
|
+
} .input-autocomplete__field_ymkry:not(.input-autocomplete__disabled_ymkry) {
|
|
25
25
|
cursor: pointer;
|
|
26
|
-
} .input-
|
|
26
|
+
} .input-autocomplete__disabled_ymkry {
|
|
27
27
|
cursor: var(--disabled-cursor);
|
|
28
|
-
} .input-
|
|
28
|
+
} .input-autocomplete__placeholder_ymkry {
|
|
29
29
|
color: var(--color-light-text-secondary);
|
|
30
|
-
} .input-
|
|
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-
|
|
39
|
+
} .input-autocomplete__value_ymkry {
|
|
40
40
|
overflow: hidden;
|
|
41
41
|
text-overflow: ellipsis;
|
|
42
42
|
text-align: left;
|
|
43
|
-
} .input-
|
|
43
|
+
} .input-autocomplete__focusVisible_ymkry {
|
|
44
44
|
outline: 2px solid var(--focus-color);
|
|
45
45
|
outline-offset: 2px;
|
|
46
46
|
}
|
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-
|
|
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:
|
|
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';
|
package/esm/mobile/index.js
CHANGED
|
@@ -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';
|
package/esm/mobile/mobile.css
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
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-
|
|
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-
|
|
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:
|
|
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:
|
|
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-
|
|
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-
|
|
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, }) => {
|
|
@@ -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-
|
|
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,
|
|
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:
|
|
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-
|
|
21
|
+
} .input-autocomplete__component_ymkry {
|
|
22
22
|
width: 100%;
|
|
23
23
|
outline: none;
|
|
24
|
-
} .input-
|
|
24
|
+
} .input-autocomplete__field_ymkry:not(.input-autocomplete__disabled_ymkry) {
|
|
25
25
|
cursor: pointer;
|
|
26
|
-
} .input-
|
|
26
|
+
} .input-autocomplete__disabled_ymkry {
|
|
27
27
|
cursor: var(--disabled-cursor);
|
|
28
|
-
} .input-
|
|
28
|
+
} .input-autocomplete__placeholder_ymkry {
|
|
29
29
|
color: var(--color-light-text-secondary);
|
|
30
|
-
} .input-
|
|
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-
|
|
39
|
+
} .input-autocomplete__value_ymkry {
|
|
40
40
|
overflow: hidden;
|
|
41
41
|
text-overflow: ellipsis;
|
|
42
42
|
text-align: left;
|
|
43
|
-
} .input-
|
|
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-
|
|
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
|
|
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';
|
package/modern/mobile/index.js
CHANGED
|
@@ -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';
|
package/modern/mobile/mobile.css
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
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-
|
|
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
|
+
"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": "^
|
|
18
|
-
"@alfalab/core-components-input": "^
|
|
19
|
-
"@alfalab/core-components-popover": "^6.
|
|
20
|
-
"@alfalab/core-components-select": "^
|
|
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
|
|
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
|
/>
|