@alfalab/core-components-input-autocomplete 12.7.2 → 12.8.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/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 +12 -6
- package/autocomplete-mobile-field/index.css +41 -9
- package/cssm/autocomplete-mobile-field/Component.d.ts +1 -1
- package/cssm/autocomplete-mobile-field/Component.js +11 -5
- package/cssm/autocomplete-mobile-field/index.module.css +34 -2
- package/cssm/mobile/Component.mobile.js +2 -2
- package/cssm/mobile/mobile.module.css +3 -0
- package/cssm/utils.d.ts +4 -0
- package/cssm/utils.js +4 -0
- package/cssm/vars.css +5 -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 +12 -6
- package/esm/autocomplete-mobile-field/index.css +41 -9
- package/esm/mobile/Component.mobile.js +3 -3
- package/esm/mobile/mobile.css +5 -2
- package/esm/utils.d.ts +4 -0
- package/esm/utils.js +4 -0
- package/mobile/Component.mobile.js +3 -3
- package/mobile/mobile.css +5 -2
- 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 +12 -6
- package/modern/autocomplete-mobile-field/index.css +41 -9
- package/modern/mobile/Component.mobile.js +3 -2
- package/modern/mobile/mobile.css +5 -2
- package/modern/utils.d.ts +4 -0
- package/modern/utils.js +4 -0
- package/moderncssm/autocomplete-mobile-field/Component.d.ts +1 -1
- package/moderncssm/autocomplete-mobile-field/Component.js +11 -5
- package/moderncssm/autocomplete-mobile-field/index.module.css +34 -6
- package/moderncssm/mobile/Component.mobile.js +2 -1
- package/moderncssm/utils.d.ts +4 -0
- package/moderncssm/utils.js +4 -0
- package/moderncssm/vars.css +5 -0
- package/package.json +8 -7
- package/src/autocomplete-mobile-field/Component.tsx +34 -15
- package/src/autocomplete-mobile-field/index.module.css +37 -0
- package/src/mobile/Component.mobile.tsx +2 -0
- package/src/utils.ts +4 -0
- package/src/vars.css +8 -0
- package/utils.d.ts +4 -0
- package/utils.js +4 -0
package/esm/mobile/mobile.css
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: nn24i */
|
|
2
2
|
: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 */ /* 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 */
|
|
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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
@@ -16,8 +16,11 @@
|
|
|
16
16
|
} :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 */
|
|
17
17
|
|
|
18
18
|
/* новые значения, используйте их */
|
|
19
|
+
|
|
20
|
+
/* no-unit может приводить к проблемам в calc (#1559) */
|
|
21
|
+
/* stylelint-disable-next-line length-zero-no-unit */
|
|
19
22
|
} :root {
|
|
20
23
|
} :root {
|
|
21
|
-
} /* сбрасывает синюю подсветку при нажатии */ .input-
|
|
24
|
+
} /* сбрасывает синюю подсветку при нажатии */ .input-autocomplete__input_q01i2 {
|
|
22
25
|
width: auto;
|
|
23
26
|
}
|
package/esm/utils.d.ts
CHANGED
|
@@ -9,6 +9,8 @@ declare function getInputAutocompleteDesktopTestIds(dataTestId: string): {
|
|
|
9
9
|
fieldLeftAddons: string;
|
|
10
10
|
fieldRightAddons: string;
|
|
11
11
|
fieldError: string;
|
|
12
|
+
fieldErrorIcon: string;
|
|
13
|
+
fieldSuccessIcon: string;
|
|
12
14
|
fieldHint: string;
|
|
13
15
|
};
|
|
14
16
|
declare function getInputAutocompleteMobileTestIds(dataTestId: string): {
|
|
@@ -28,6 +30,8 @@ declare function getInputAutocompleteMobileTestIds(dataTestId: string): {
|
|
|
28
30
|
fieldLeftAddons: string;
|
|
29
31
|
fieldRightAddons: string;
|
|
30
32
|
fieldError: string;
|
|
33
|
+
fieldErrorIcon: string;
|
|
34
|
+
fieldSuccessIcon: string;
|
|
31
35
|
fieldHint: string;
|
|
32
36
|
searchInput: string;
|
|
33
37
|
searchFormControl: string;
|
package/esm/utils.js
CHANGED
|
@@ -14,6 +14,8 @@ function getInputAutocompleteDesktopTestIds(dataTestId) {
|
|
|
14
14
|
fieldLeftAddons: getDataTestId(dataTestId, 'field-form-control-left-addons'),
|
|
15
15
|
fieldRightAddons: getDataTestId(dataTestId, 'field-form-control-right-addons'),
|
|
16
16
|
fieldError: getDataTestId(dataTestId, 'field-form-control-error-message'),
|
|
17
|
+
fieldErrorIcon: getDataTestId(dataTestId, 'field-form-control-error-icon'),
|
|
18
|
+
fieldSuccessIcon: getDataTestId(dataTestId, 'field-form-control-success-icon'),
|
|
17
19
|
fieldHint: getDataTestId(dataTestId, 'field-form-control-hint'),
|
|
18
20
|
};
|
|
19
21
|
}
|
|
@@ -35,6 +37,8 @@ function getInputAutocompleteMobileTestIds(dataTestId) {
|
|
|
35
37
|
fieldLeftAddons: getDataTestId(dataTestId, 'field-form-control-left-addons'),
|
|
36
38
|
fieldRightAddons: getDataTestId(dataTestId, 'field-form-control-right-addons'),
|
|
37
39
|
fieldError: getDataTestId(dataTestId, 'field-form-control-error-message'),
|
|
40
|
+
fieldErrorIcon: getDataTestId(dataTestId, 'field-error-icon'),
|
|
41
|
+
fieldSuccessIcon: getDataTestId(dataTestId, 'field-success-icon'),
|
|
38
42
|
fieldHint: getDataTestId(dataTestId, 'field-form-control-hint'),
|
|
39
43
|
searchInput: getDataTestId(dataTestId, 'search'),
|
|
40
44
|
searchFormControl: getDataTestId(dataTestId, 'search-form-control'),
|
|
@@ -20,13 +20,13 @@ var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
|
|
|
20
20
|
var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
|
|
21
21
|
var throttle__default = /*#__PURE__*/_interopDefaultCompat(throttle);
|
|
22
22
|
|
|
23
|
-
var styles = {"input":"input-
|
|
23
|
+
var styles = {"input":"input-autocomplete__input_q01i2"};
|
|
24
24
|
require('./mobile.css')
|
|
25
25
|
|
|
26
26
|
var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, ref) {
|
|
27
27
|
var _b;
|
|
28
28
|
var _c;
|
|
29
|
-
var Input = _a.Input, value = _a.value, name = _a.name, _d = _a.Arrow, Arrow = _d === void 0 ? null : _d, label = _a.label, _e = _a.placeholder, placeholder = _e === void 0 ? '' : _e, _f = _a.size, size = _f === void 0 ? 48 : _f, openProp = _a.open, onInput = _a.onInput, onOpen = _a.onOpen, multiple = _a.multiple, inputProps = _a.inputProps, _g = _a.isBottomSheet, isBottomSheet = _g === void 0 ? true : _g, dataTestId = _a.dataTestId, transitionProps = _a.transitionProps, onCancel = _a.onCancel, onApply = _a.onApply, title = _a.title, restProps = tslib.__rest(_a, ["Input", "value", "name", "Arrow", "label", "placeholder", "size", "open", "onInput", "onOpen", "multiple", "inputProps", "isBottomSheet", "dataTestId", "transitionProps", "onCancel", "onApply", "title"]);
|
|
29
|
+
var Input = _a.Input, value = _a.value, name = _a.name, _d = _a.Arrow, Arrow = _d === void 0 ? null : _d, label = _a.label, _e = _a.placeholder, placeholder = _e === void 0 ? '' : _e, _f = _a.size, size = _f === void 0 ? 48 : _f, openProp = _a.open, onInput = _a.onInput, onOpen = _a.onOpen, multiple = _a.multiple, inputProps = _a.inputProps, _g = _a.isBottomSheet, isBottomSheet = _g === void 0 ? true : _g, dataTestId = _a.dataTestId, transitionProps = _a.transitionProps, onCancel = _a.onCancel, onApply = _a.onApply, title = _a.title, success = _a.success, restProps = tslib.__rest(_a, ["Input", "value", "name", "Arrow", "label", "placeholder", "size", "open", "onInput", "onOpen", "multiple", "inputProps", "isBottomSheet", "dataTestId", "transitionProps", "onCancel", "onApply", "title", "success"]);
|
|
30
30
|
var _h = React.useState(false), open = _h[0], setOpen = _h[1];
|
|
31
31
|
var frozenValue = React.useRef('');
|
|
32
32
|
var searchInputRef = React.useRef(null);
|
|
@@ -87,7 +87,7 @@ var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, re
|
|
|
87
87
|
value: value,
|
|
88
88
|
filterFn: utils.searchFilterStub,
|
|
89
89
|
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: function (_, payload) { return onInput === null || onInput === void 0 ? void 0 : onInput(payload.value, enums.OnInputReason.Change); } }),
|
|
90
|
-
}, 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 ? inputProps === null || inputProps === void 0 ? void 0 : inputProps.onClear : undefined }, restProps.fieldProps) })));
|
|
90
|
+
}, 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 ? inputProps === null || inputProps === void 0 ? void 0 : inputProps.onClear : undefined, success: success }, restProps.fieldProps) })));
|
|
91
91
|
});
|
|
92
92
|
|
|
93
93
|
exports.InputAutocompleteMobile = InputAutocompleteMobile;
|
package/mobile/mobile.css
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: nn24i */
|
|
2
2
|
: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 */ /* 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 */
|
|
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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
@@ -16,8 +16,11 @@
|
|
|
16
16
|
} :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 */
|
|
17
17
|
|
|
18
18
|
/* новые значения, используйте их */
|
|
19
|
+
|
|
20
|
+
/* no-unit может приводить к проблемам в calc (#1559) */
|
|
21
|
+
/* stylelint-disable-next-line length-zero-no-unit */
|
|
19
22
|
} :root {
|
|
20
23
|
} :root {
|
|
21
|
-
} /* сбрасывает синюю подсветку при нажатии */ .input-
|
|
24
|
+
} /* сбрасывает синюю подсветку при нажатии */ .input-autocomplete__input_q01i2 {
|
|
22
25
|
width: auto;
|
|
23
26
|
}
|
|
@@ -4,7 +4,7 @@ import cn from 'classnames';
|
|
|
4
4
|
import { InputDesktop } from '@alfalab/core-components-input/modern/desktop';
|
|
5
5
|
import { OnInputReason } from '../enums.js';
|
|
6
6
|
|
|
7
|
-
const styles = {"arrow":"input-
|
|
7
|
+
const styles = {"arrow":"input-autocomplete__arrow_1rhd7","error":"input-autocomplete__error_1rhd7"};
|
|
8
8
|
require('./index.css')
|
|
9
9
|
|
|
10
10
|
const AutocompleteField = ({ label, labelView = 'inner', placeholder, size, Arrow, Input = InputDesktop, value, error, success, hint, disabled, readOnly, onInput, inputProps = {}, innerProps, dataTestId, }) => {
|
|
@@ -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, rightAddons, error, readOnly, clear, onClear, onInput, colors, ...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, success, onClear, onInput, colors, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
|
|
19
19
|
export { AutocompleteMobileFieldProps, AutocompleteMobileField };
|
|
@@ -3,12 +3,13 @@ import cn from 'classnames';
|
|
|
3
3
|
import { FormControlMobile } from '@alfalab/core-components-form-control/modern/mobile';
|
|
4
4
|
import { ClearButton } from '@alfalab/core-components-input/modern/shared';
|
|
5
5
|
import { getDataTestId } from '@alfalab/core-components-shared/modern';
|
|
6
|
+
import { StatusBadge } from '@alfalab/core-components-status-badge/modern';
|
|
6
7
|
import { useFocus } from '@alfalab/hooks';
|
|
7
8
|
|
|
8
|
-
const styles = {"component":"input-
|
|
9
|
+
const styles = {"component":"input-autocomplete__component_h7anv","field":"input-autocomplete__field_h7anv","disabled":"input-autocomplete__disabled_h7anv","errorIcon":"input-autocomplete__errorIcon_h7anv","size-40":"input-autocomplete__size-40_h7anv","successIcon":"input-autocomplete__successIcon_h7anv","placeholder":"input-autocomplete__placeholder_h7anv","contentWrapper":"input-autocomplete__contentWrapper_h7anv","value":"input-autocomplete__value_h7anv","focusVisible":"input-autocomplete__focusVisible_h7anv"};
|
|
9
10
|
require('./index.css')
|
|
10
11
|
|
|
11
|
-
const AutocompleteMobileField = ({ size = 56, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView = 'inner', placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors = 'default', ...restProps }) => {
|
|
12
|
+
const AutocompleteMobileField = ({ size = 56, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView = 'inner', placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, success, onClear, onInput, colors = 'default', ...restProps }) => {
|
|
12
13
|
const [focused, setFocused] = useState(false);
|
|
13
14
|
const wrapperRef = useRef(null);
|
|
14
15
|
const [focusVisible] = useFocus(wrapperRef, 'keyboard');
|
|
@@ -16,16 +17,21 @@ const AutocompleteMobileField = ({ size = 56, open, disabled, value, innerProps,
|
|
|
16
17
|
const showPlaceholder = placeholder && !filled && labelView === 'outer';
|
|
17
18
|
const clearButtonVisible = clear && filled && !disabled && !readOnly;
|
|
18
19
|
const { tabIndex, ...restInnerProps } = innerProps;
|
|
20
|
+
const formRightAddons = (Arrow || rightAddons || clearButtonVisible || error || success) && (React.createElement(React.Fragment, null,
|
|
21
|
+
clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
|
|
22
|
+
rightAddons,
|
|
23
|
+
Arrow,
|
|
24
|
+
error && (React.createElement("div", { className: cn(styles.errorIcon, styles[`size-${size}`]), "data-addon": 'error-icon' },
|
|
25
|
+
React.createElement(StatusBadge, { view: 'negative-alert', size: size === 40 ? 16 : 20, dataTestId: getDataTestId(dataTestId, 'error-icon') }))),
|
|
26
|
+
success && !error && (React.createElement("div", { className: cn(styles.successIcon, styles[`size-${size}`]) },
|
|
27
|
+
React.createElement(StatusBadge, { view: 'positive-checkmark', size: size === 40 ? 16 : 20, dataTestId: getDataTestId(dataTestId, 'success-icon') })))));
|
|
19
28
|
return (React.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: () => setFocused(true), onBlur: () => setFocused(false) },
|
|
20
29
|
React.createElement(FormControlMobile, { fieldClassName: cn(styles.field, fieldClassName, {
|
|
21
30
|
[styles.disabled]: disabled,
|
|
22
31
|
[styles.focusVisible]: focusVisible,
|
|
23
32
|
}), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: getDataTestId(dataTestId, 'form-control'),
|
|
24
33
|
// downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
|
|
25
|
-
tabIndex: open ? undefined : tabIndex, ...restProps, ...restInnerProps, readOnly: readOnly, colors: colors, error: error, rightAddons:
|
|
26
|
-
clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
|
|
27
|
-
rightAddons,
|
|
28
|
-
Arrow)) },
|
|
34
|
+
tabIndex: open ? undefined : tabIndex, ...restProps, ...restInnerProps, readOnly: readOnly, colors: colors, error: error, rightAddons: formRightAddons },
|
|
29
35
|
React.createElement("div", { className: styles.contentWrapper },
|
|
30
36
|
showPlaceholder && React.createElement("span", { className: styles.placeholder }, placeholder),
|
|
31
37
|
filled && React.createElement("div", { className: styles.value }, value)))));
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: jgwuw */
|
|
2
2
|
: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 */ /* 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 */
|
|
3
3
|
} /* deprecated */ :root {
|
|
4
4
|
--color-light-status-info: #2288fa;
|
|
@@ -15,23 +15,55 @@
|
|
|
15
15
|
} :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
16
16
|
|
|
17
17
|
/* новые значения, используйте их */
|
|
18
|
-
} :root { /* deprecated */
|
|
18
|
+
} :root { /* deprecated */
|
|
19
|
+
--gap-2xs: 4px; /* deprecated */ /* deprecated */
|
|
20
|
+
--gap-s: 12px; /* 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 */
|
|
19
21
|
|
|
20
22
|
/* новые значения, используйте их */
|
|
23
|
+
|
|
24
|
+
/* no-unit может приводить к проблемам в calc (#1559) */
|
|
25
|
+
/* stylelint-disable-next-line length-zero-no-unit */
|
|
26
|
+
--gap-4: var(--gap-2xs);
|
|
27
|
+
--gap-12: var(--gap-s);
|
|
21
28
|
} :root {
|
|
22
29
|
} :root {
|
|
23
30
|
--focus-color: var(--color-light-status-info);
|
|
24
31
|
--disabled-cursor: not-allowed;
|
|
25
|
-
} /* сбрасывает синюю подсветку при нажатии */
|
|
32
|
+
} /* сбрасывает синюю подсветку при нажатии */ :root {
|
|
33
|
+
/* display */
|
|
34
|
+
--input-error-icon-display: none;
|
|
35
|
+
--input-success-icon-display: flex;
|
|
36
|
+
|
|
37
|
+
/* управляет видимостью иконки ошибки, если она стоит рядом с другой иконкой */
|
|
38
|
+
--input-error-icon-not-alone-display: none;
|
|
39
|
+
} .input-autocomplete__component_h7anv {
|
|
26
40
|
width: 100%;
|
|
27
41
|
outline: none;
|
|
28
|
-
} .input-
|
|
42
|
+
} .input-autocomplete__field_h7anv:not(.input-autocomplete__disabled_h7anv) {
|
|
29
43
|
cursor: pointer;
|
|
30
|
-
} .input-
|
|
44
|
+
} .input-autocomplete__errorIcon_h7anv {
|
|
45
|
+
display: var(--input-error-icon-display)
|
|
46
|
+
} .input-autocomplete__errorIcon_h7anv:not(:only-child) {
|
|
47
|
+
margin-left: var(--gap-4);
|
|
48
|
+
} .input-autocomplete__errorIcon_h7anv.input-autocomplete__size-40_h7anv:not(:only-child) {
|
|
49
|
+
margin-left: 6px;
|
|
50
|
+
} * + .input-autocomplete__errorIcon_h7anv {
|
|
51
|
+
display: var(--input-error-icon-not-alone-display);
|
|
52
|
+
} button[class*='eye'] + .input-autocomplete__errorIcon_h7anv {
|
|
53
|
+
margin-right: var(--gap-12);
|
|
54
|
+
} .input-autocomplete__successIcon_h7anv {
|
|
55
|
+
display: var(--input-success-icon-display)
|
|
56
|
+
} .input-autocomplete__successIcon_h7anv:not(:only-child) {
|
|
57
|
+
margin-left: var(--gap-4);
|
|
58
|
+
} .input-autocomplete__successIcon_h7anv.input-autocomplete__size-40_h7anv:not(:only-child) {
|
|
59
|
+
margin-left: 6px;
|
|
60
|
+
} button[class*='eye'] + .input-autocomplete__successIcon_h7anv {
|
|
61
|
+
margin-right: var(--gap-12);
|
|
62
|
+
} .input-autocomplete__disabled_h7anv {
|
|
31
63
|
cursor: var(--disabled-cursor);
|
|
32
|
-
} .input-
|
|
64
|
+
} .input-autocomplete__placeholder_h7anv {
|
|
33
65
|
color: var(--color-light-text-secondary);
|
|
34
|
-
} .input-
|
|
66
|
+
} .input-autocomplete__contentWrapper_h7anv {
|
|
35
67
|
font-size: 16px;
|
|
36
68
|
line-height: 20px;
|
|
37
69
|
font-weight: 400;
|
|
@@ -40,11 +72,11 @@
|
|
|
40
72
|
text-overflow: ellipsis;
|
|
41
73
|
overflow: hidden;
|
|
42
74
|
width: 100%;
|
|
43
|
-
} .input-
|
|
75
|
+
} .input-autocomplete__value_h7anv {
|
|
44
76
|
overflow: hidden;
|
|
45
77
|
text-overflow: ellipsis;
|
|
46
78
|
text-align: left;
|
|
47
|
-
} .input-
|
|
79
|
+
} .input-autocomplete__focusVisible_h7anv {
|
|
48
80
|
outline: 2px solid var(--focus-color);
|
|
49
81
|
outline-offset: 2px;
|
|
50
82
|
}
|
|
@@ -8,10 +8,10 @@ import { AutocompleteMobileField } from '../autocomplete-mobile-field/Component.
|
|
|
8
8
|
import { OnInputReason } from '../enums.js';
|
|
9
9
|
import { searchFilterStub } from '../utils.js';
|
|
10
10
|
|
|
11
|
-
const styles = {"input":"input-
|
|
11
|
+
const styles = {"input":"input-autocomplete__input_q01i2"};
|
|
12
12
|
require('./mobile.css')
|
|
13
13
|
|
|
14
|
-
const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow = null, label, placeholder = '', size = 48, open: openProp, onInput, onOpen, multiple, inputProps, isBottomSheet = true, dataTestId, transitionProps, onCancel, onApply, title, ...restProps }, ref) => {
|
|
14
|
+
const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow = null, label, placeholder = '', size = 48, open: openProp, onInput, onOpen, multiple, inputProps, isBottomSheet = true, dataTestId, transitionProps, onCancel, onApply, title, success, ...restProps }, ref) => {
|
|
15
15
|
const [open, setOpen] = useState(false);
|
|
16
16
|
const frozenValue = useRef('');
|
|
17
17
|
const searchInputRef = useRef(null);
|
|
@@ -86,6 +86,7 @@ const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow =
|
|
|
86
86
|
value: isOpen ? frozenValue.current : value,
|
|
87
87
|
clear,
|
|
88
88
|
onClear: clear ? inputProps?.onClear : undefined,
|
|
89
|
+
success,
|
|
89
90
|
...restProps.fieldProps,
|
|
90
91
|
} }));
|
|
91
92
|
});
|
package/modern/mobile/mobile.css
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: nn24i */
|
|
2
2
|
: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 */ /* 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 */
|
|
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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
|
|
@@ -16,8 +16,11 @@
|
|
|
16
16
|
} :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 */
|
|
17
17
|
|
|
18
18
|
/* новые значения, используйте их */
|
|
19
|
+
|
|
20
|
+
/* no-unit может приводить к проблемам в calc (#1559) */
|
|
21
|
+
/* stylelint-disable-next-line length-zero-no-unit */
|
|
19
22
|
} :root {
|
|
20
23
|
} :root {
|
|
21
|
-
} /* сбрасывает синюю подсветку при нажатии */ .input-
|
|
24
|
+
} /* сбрасывает синюю подсветку при нажатии */ .input-autocomplete__input_q01i2 {
|
|
22
25
|
width: auto;
|
|
23
26
|
}
|
package/modern/utils.d.ts
CHANGED
|
@@ -9,6 +9,8 @@ declare function getInputAutocompleteDesktopTestIds(dataTestId: string): {
|
|
|
9
9
|
fieldLeftAddons: string;
|
|
10
10
|
fieldRightAddons: string;
|
|
11
11
|
fieldError: string;
|
|
12
|
+
fieldErrorIcon: string;
|
|
13
|
+
fieldSuccessIcon: string;
|
|
12
14
|
fieldHint: string;
|
|
13
15
|
};
|
|
14
16
|
declare function getInputAutocompleteMobileTestIds(dataTestId: string): {
|
|
@@ -28,6 +30,8 @@ declare function getInputAutocompleteMobileTestIds(dataTestId: string): {
|
|
|
28
30
|
fieldLeftAddons: string;
|
|
29
31
|
fieldRightAddons: string;
|
|
30
32
|
fieldError: string;
|
|
33
|
+
fieldErrorIcon: string;
|
|
34
|
+
fieldSuccessIcon: string;
|
|
31
35
|
fieldHint: string;
|
|
32
36
|
searchInput: string;
|
|
33
37
|
searchFormControl: string;
|
package/modern/utils.js
CHANGED
|
@@ -14,6 +14,8 @@ function getInputAutocompleteDesktopTestIds(dataTestId) {
|
|
|
14
14
|
fieldLeftAddons: getDataTestId(dataTestId, 'field-form-control-left-addons'),
|
|
15
15
|
fieldRightAddons: getDataTestId(dataTestId, 'field-form-control-right-addons'),
|
|
16
16
|
fieldError: getDataTestId(dataTestId, 'field-form-control-error-message'),
|
|
17
|
+
fieldErrorIcon: getDataTestId(dataTestId, 'field-form-control-error-icon'),
|
|
18
|
+
fieldSuccessIcon: getDataTestId(dataTestId, 'field-form-control-success-icon'),
|
|
17
19
|
fieldHint: getDataTestId(dataTestId, 'field-form-control-hint'),
|
|
18
20
|
};
|
|
19
21
|
}
|
|
@@ -35,6 +37,8 @@ function getInputAutocompleteMobileTestIds(dataTestId) {
|
|
|
35
37
|
fieldLeftAddons: getDataTestId(dataTestId, 'field-form-control-left-addons'),
|
|
36
38
|
fieldRightAddons: getDataTestId(dataTestId, 'field-form-control-right-addons'),
|
|
37
39
|
fieldError: getDataTestId(dataTestId, 'field-form-control-error-message'),
|
|
40
|
+
fieldErrorIcon: getDataTestId(dataTestId, 'field-error-icon'),
|
|
41
|
+
fieldSuccessIcon: getDataTestId(dataTestId, 'field-success-icon'),
|
|
38
42
|
fieldHint: getDataTestId(dataTestId, 'field-form-control-hint'),
|
|
39
43
|
searchInput: getDataTestId(dataTestId, 'search'),
|
|
40
44
|
searchFormControl: getDataTestId(dataTestId, 'search-form-control'),
|
|
@@ -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, rightAddons, error, readOnly, clear, onClear, onInput, colors, ...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, success, onClear, onInput, colors, ...restProps }: AutocompleteMobileFieldProps & FieldProps) => React.JSX.Element;
|
|
19
19
|
export { AutocompleteMobileFieldProps, AutocompleteMobileField };
|
|
@@ -3,10 +3,11 @@ import cn from 'classnames';
|
|
|
3
3
|
import { FormControlMobile } from '@alfalab/core-components-form-control/moderncssm/mobile';
|
|
4
4
|
import { ClearButton } from '@alfalab/core-components-input/moderncssm/shared';
|
|
5
5
|
import { getDataTestId } from '@alfalab/core-components-shared/moderncssm';
|
|
6
|
+
import { StatusBadge } from '@alfalab/core-components-status-badge/moderncssm';
|
|
6
7
|
import { useFocus } from '@alfalab/hooks';
|
|
7
8
|
import styles from './index.module.css';
|
|
8
9
|
|
|
9
|
-
const AutocompleteMobileField = ({ size = 56, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView = 'inner', placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, onClear, onInput, colors = 'default', ...restProps }) => {
|
|
10
|
+
const AutocompleteMobileField = ({ size = 56, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView = 'inner', placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, rightAddons, error, readOnly, clear, success, onClear, onInput, colors = 'default', ...restProps }) => {
|
|
10
11
|
const [focused, setFocused] = useState(false);
|
|
11
12
|
const wrapperRef = useRef(null);
|
|
12
13
|
const [focusVisible] = useFocus(wrapperRef, 'keyboard');
|
|
@@ -14,16 +15,21 @@ const AutocompleteMobileField = ({ size = 56, open, disabled, value, innerProps,
|
|
|
14
15
|
const showPlaceholder = placeholder && !filled && labelView === 'outer';
|
|
15
16
|
const clearButtonVisible = clear && filled && !disabled && !readOnly;
|
|
16
17
|
const { tabIndex, ...restInnerProps } = innerProps;
|
|
18
|
+
const formRightAddons = (Arrow || rightAddons || clearButtonVisible || error || success) && (React.createElement(React.Fragment, null,
|
|
19
|
+
clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
|
|
20
|
+
rightAddons,
|
|
21
|
+
Arrow,
|
|
22
|
+
error && (React.createElement("div", { className: cn(styles.errorIcon, styles[`size-${size}`]), "data-addon": 'error-icon' },
|
|
23
|
+
React.createElement(StatusBadge, { view: 'negative-alert', size: size === 40 ? 16 : 20, dataTestId: getDataTestId(dataTestId, 'error-icon') }))),
|
|
24
|
+
success && !error && (React.createElement("div", { className: cn(styles.successIcon, styles[`size-${size}`]) },
|
|
25
|
+
React.createElement(StatusBadge, { view: 'positive-checkmark', size: size === 40 ? 16 : 20, dataTestId: getDataTestId(dataTestId, 'success-icon') })))));
|
|
17
26
|
return (React.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: () => setFocused(true), onBlur: () => setFocused(false) },
|
|
18
27
|
React.createElement(FormControlMobile, { fieldClassName: cn(styles.field, fieldClassName, {
|
|
19
28
|
[styles.disabled]: disabled,
|
|
20
29
|
[styles.focusVisible]: focusVisible,
|
|
21
30
|
}), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: getDataTestId(dataTestId, 'form-control'),
|
|
22
31
|
// downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
|
|
23
|
-
tabIndex: open ? undefined : tabIndex, ...restProps, ...restInnerProps, readOnly: readOnly, colors: colors, error: error, rightAddons:
|
|
24
|
-
clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
|
|
25
|
-
rightAddons,
|
|
26
|
-
Arrow)) },
|
|
32
|
+
tabIndex: open ? undefined : tabIndex, ...restProps, ...restInnerProps, readOnly: readOnly, colors: colors, error: error, rightAddons: formRightAddons },
|
|
27
33
|
React.createElement("div", { className: styles.contentWrapper },
|
|
28
34
|
showPlaceholder && React.createElement("span", { className: styles.placeholder }, placeholder),
|
|
29
35
|
filled && React.createElement("div", { className: styles.value }, value)))));
|
|
@@ -1,22 +1,52 @@
|
|
|
1
1
|
/* */
|
|
2
|
+
:root {
|
|
3
|
+
/* display */
|
|
4
|
+
--input-error-icon-display: none;
|
|
5
|
+
--input-success-icon-display: flex;
|
|
2
6
|
|
|
7
|
+
/* управляет видимостью иконки ошибки, если она стоит рядом с другой иконкой */
|
|
8
|
+
--input-error-icon-not-alone-display: none;
|
|
9
|
+
}
|
|
3
10
|
.component {
|
|
4
11
|
width: 100%;
|
|
5
12
|
outline: none;
|
|
6
13
|
}
|
|
7
|
-
|
|
8
14
|
.field:not(.disabled) {
|
|
9
15
|
cursor: pointer;
|
|
10
16
|
}
|
|
11
|
-
|
|
17
|
+
.errorIcon {
|
|
18
|
+
display: var(--input-error-icon-display)
|
|
19
|
+
}
|
|
20
|
+
.errorIcon:not(:only-child) {
|
|
21
|
+
margin-left: var(--gap-4);
|
|
22
|
+
}
|
|
23
|
+
.errorIcon.size-40:not(:only-child) {
|
|
24
|
+
margin-left: 6px;
|
|
25
|
+
}
|
|
26
|
+
* + .errorIcon {
|
|
27
|
+
display: var(--input-error-icon-not-alone-display);
|
|
28
|
+
}
|
|
29
|
+
button[class*='eye'] + .errorIcon {
|
|
30
|
+
margin-right: var(--gap-12);
|
|
31
|
+
}
|
|
32
|
+
.successIcon {
|
|
33
|
+
display: var(--input-success-icon-display)
|
|
34
|
+
}
|
|
35
|
+
.successIcon:not(:only-child) {
|
|
36
|
+
margin-left: var(--gap-4);
|
|
37
|
+
}
|
|
38
|
+
.successIcon.size-40:not(:only-child) {
|
|
39
|
+
margin-left: 6px;
|
|
40
|
+
}
|
|
41
|
+
button[class*='eye'] + .successIcon {
|
|
42
|
+
margin-right: var(--gap-12);
|
|
43
|
+
}
|
|
12
44
|
.disabled {
|
|
13
45
|
cursor: var(--disabled-cursor);
|
|
14
46
|
}
|
|
15
|
-
|
|
16
47
|
.placeholder {
|
|
17
48
|
color: var(--color-light-text-secondary);
|
|
18
49
|
}
|
|
19
|
-
|
|
20
50
|
.contentWrapper {
|
|
21
51
|
font-size: 16px;
|
|
22
52
|
line-height: 20px;
|
|
@@ -27,13 +57,11 @@
|
|
|
27
57
|
overflow: hidden;
|
|
28
58
|
width: 100%;
|
|
29
59
|
}
|
|
30
|
-
|
|
31
60
|
.value {
|
|
32
61
|
overflow: hidden;
|
|
33
62
|
text-overflow: ellipsis;
|
|
34
63
|
text-align: left;
|
|
35
64
|
}
|
|
36
|
-
|
|
37
65
|
.focusVisible {
|
|
38
66
|
outline: 2px solid var(--focus-color);
|
|
39
67
|
outline-offset: 2px;
|
|
@@ -9,7 +9,7 @@ import { OnInputReason } from '../enums.js';
|
|
|
9
9
|
import { searchFilterStub } from '../utils.js';
|
|
10
10
|
import styles from './mobile.module.css';
|
|
11
11
|
|
|
12
|
-
const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow = null, label, placeholder = '', size = 48, open: openProp, onInput, onOpen, multiple, inputProps, isBottomSheet = true, dataTestId, transitionProps, onCancel, onApply, title, ...restProps }, ref) => {
|
|
12
|
+
const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow = null, label, placeholder = '', size = 48, open: openProp, onInput, onOpen, multiple, inputProps, isBottomSheet = true, dataTestId, transitionProps, onCancel, onApply, title, success, ...restProps }, ref) => {
|
|
13
13
|
const [open, setOpen] = useState(false);
|
|
14
14
|
const frozenValue = useRef('');
|
|
15
15
|
const searchInputRef = useRef(null);
|
|
@@ -84,6 +84,7 @@ const InputAutocompleteMobile = React.forwardRef(({ Input, value, name, Arrow =
|
|
|
84
84
|
value: isOpen ? frozenValue.current : value,
|
|
85
85
|
clear,
|
|
86
86
|
onClear: clear ? inputProps?.onClear : undefined,
|
|
87
|
+
success,
|
|
87
88
|
...restProps.fieldProps,
|
|
88
89
|
} }));
|
|
89
90
|
});
|