@alfalab/core-components-input-autocomplete 12.7.3 → 12.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/Component.responsive.d.ts +1 -1
  2. package/autocomplete-field/Component.js +1 -1
  3. package/autocomplete-field/index.css +2 -2
  4. package/autocomplete-mobile-field/Component.d.ts +1 -1
  5. package/autocomplete-mobile-field/Component.js +12 -6
  6. package/autocomplete-mobile-field/index.css +38 -9
  7. package/cssm/autocomplete-mobile-field/Component.d.ts +1 -1
  8. package/cssm/autocomplete-mobile-field/Component.js +11 -5
  9. package/cssm/autocomplete-mobile-field/index.module.css +31 -2
  10. package/cssm/mobile/Component.mobile.js +2 -2
  11. package/cssm/utils.d.ts +4 -0
  12. package/cssm/utils.js +4 -0
  13. package/cssm/vars.css +5 -0
  14. package/esm/autocomplete-field/Component.js +1 -1
  15. package/esm/autocomplete-field/index.css +2 -2
  16. package/esm/autocomplete-mobile-field/Component.d.ts +1 -1
  17. package/esm/autocomplete-mobile-field/Component.js +12 -6
  18. package/esm/autocomplete-mobile-field/index.css +38 -9
  19. package/esm/mobile/Component.mobile.js +3 -3
  20. package/esm/mobile/mobile.css +2 -2
  21. package/esm/utils.d.ts +4 -0
  22. package/esm/utils.js +4 -0
  23. package/mobile/Component.mobile.js +3 -3
  24. package/mobile/mobile.css +2 -2
  25. package/modern/autocomplete-field/Component.js +1 -1
  26. package/modern/autocomplete-field/index.css +2 -2
  27. package/modern/autocomplete-mobile-field/Component.d.ts +1 -1
  28. package/modern/autocomplete-mobile-field/Component.js +12 -6
  29. package/modern/autocomplete-mobile-field/index.css +38 -9
  30. package/modern/mobile/Component.mobile.js +3 -2
  31. package/modern/mobile/mobile.css +2 -2
  32. package/modern/utils.d.ts +4 -0
  33. package/modern/utils.js +4 -0
  34. package/moderncssm/autocomplete-mobile-field/Component.d.ts +1 -1
  35. package/moderncssm/autocomplete-mobile-field/Component.js +11 -5
  36. package/moderncssm/autocomplete-mobile-field/index.module.css +34 -6
  37. package/moderncssm/mobile/Component.mobile.js +2 -1
  38. package/moderncssm/utils.d.ts +4 -0
  39. package/moderncssm/utils.js +4 -0
  40. package/moderncssm/vars.css +5 -0
  41. package/package.json +8 -7
  42. package/src/autocomplete-mobile-field/Component.tsx +34 -15
  43. package/src/autocomplete-mobile-field/index.module.css +37 -0
  44. package/src/mobile/Component.mobile.tsx +2 -0
  45. package/src/utils.ts +4 -0
  46. package/src/vars.css +8 -0
  47. package/utils.d.ts +4 -0
  48. package/utils.js +4 -0
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import React from 'react';
3
3
  import { InputAutocompleteProps } from "./types";
4
- declare const InputAutocomplete: React.ForwardRefExoticComponent<InputAutocompleteProps & React.RefAttributes<HTMLInputElement | HTMLDivElement>>;
4
+ declare const InputAutocomplete: React.ForwardRefExoticComponent<InputAutocompleteProps & React.RefAttributes<HTMLDivElement | HTMLInputElement>>;
5
5
  export { InputAutocomplete };
@@ -15,7 +15,7 @@ var React__default = /*#__PURE__*/_interopDefaultCompat(React);
15
15
  var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
16
16
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
17
17
 
18
- var styles = {"arrow":"input-autocomplete__arrow_19eia","error":"input-autocomplete__error_19eia"};
18
+ var styles = {"arrow":"input-autocomplete__arrow_1p1u3","error":"input-autocomplete__error_1p1u3"};
19
19
  require('./index.css')
20
20
 
21
21
  var AutocompleteField = function (_a) {
@@ -1,4 +1,4 @@
1
- /* hash: 1tjnr */
2
- .input-autocomplete__arrow_19eia.input-autocomplete__error_19eia ~ * {
1
+ /* hash: 2ngor */
2
+ .input-autocomplete__arrow_1p1u3.input-autocomplete__error_1p1u3 ~ * {
3
3
  display: none;
4
4
  }
@@ -15,5 +15,5 @@ type AutocompleteMobileFieldProps = FormControlMobileProps & Omit<BaseFieldProps
15
15
  */
16
16
  value?: string;
17
17
  };
18
- declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, 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 };
@@ -8,6 +8,7 @@ var cn = require('classnames');
8
8
  var mobile = require('@alfalab/core-components-form-control/mobile');
9
9
  var shared = require('@alfalab/core-components-input/shared');
10
10
  var coreComponentsShared = require('@alfalab/core-components-shared');
11
+ var coreComponentsStatusBadge = require('@alfalab/core-components-status-badge');
11
12
  var hooks = require('@alfalab/hooks');
12
13
 
13
14
  function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
@@ -15,12 +16,12 @@ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'defau
15
16
  var React__default = /*#__PURE__*/_interopDefaultCompat(React);
16
17
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
17
18
 
18
- var styles = {"component":"input-autocomplete__component_w4hbu","field":"input-autocomplete__field_w4hbu","disabled":"input-autocomplete__disabled_w4hbu","placeholder":"input-autocomplete__placeholder_w4hbu","contentWrapper":"input-autocomplete__contentWrapper_w4hbu","value":"input-autocomplete__value_w4hbu","focusVisible":"input-autocomplete__focusVisible_w4hbu"};
19
+ var styles = {"component":"input-autocomplete__component_sy1zc","field":"input-autocomplete__field_sy1zc","disabled":"input-autocomplete__disabled_sy1zc","errorIcon":"input-autocomplete__errorIcon_sy1zc","size-40":"input-autocomplete__size-40_sy1zc","successIcon":"input-autocomplete__successIcon_sy1zc","placeholder":"input-autocomplete__placeholder_sy1zc","contentWrapper":"input-autocomplete__contentWrapper_sy1zc","value":"input-autocomplete__value_sy1zc","focusVisible":"input-autocomplete__focusVisible_sy1zc"};
19
20
  require('./index.css')
20
21
 
21
22
  var AutocompleteMobileField = function (_a) {
22
23
  var _b;
23
- var _c = _a.size, size = _c === void 0 ? 56 : _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 _c = _a.size, size = _c === void 0 ? 56 : _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, success = _a.success, 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", "success", "onClear", "onInput", "colors"]);
24
25
  var _f = React.useState(false), focused = _f[0], setFocused = _f[1];
25
26
  var wrapperRef = React.useRef(null);
26
27
  var focusVisible = hooks.useFocus(wrapperRef, 'keyboard')[0];
@@ -28,16 +29,21 @@ var AutocompleteMobileField = function (_a) {
28
29
  var showPlaceholder = placeholder && !filled && labelView === 'outer';
29
30
  var clearButtonVisible = clear && filled && !disabled && !readOnly;
30
31
  var tabIndex = innerProps.tabIndex, restInnerProps = tslib.__rest(innerProps, ["tabIndex"]);
32
+ var formRightAddons = (Arrow || rightAddons || clearButtonVisible || error || success) && (React__default.default.createElement(React__default.default.Fragment, null,
33
+ clearButtonVisible && (React__default.default.createElement(shared.ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
34
+ rightAddons,
35
+ Arrow,
36
+ error && (React__default.default.createElement("div", { className: cn__default.default(styles.errorIcon, styles["size-".concat(size)]), "data-addon": 'error-icon' },
37
+ React__default.default.createElement(coreComponentsStatusBadge.StatusBadge, { view: 'negative-alert', size: size === 40 ? 16 : 20, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'error-icon') }))),
38
+ success && !error && (React__default.default.createElement("div", { className: cn__default.default(styles.successIcon, styles["size-".concat(size)]) },
39
+ React__default.default.createElement(coreComponentsStatusBadge.StatusBadge, { view: 'positive-checkmark', size: size === 40 ? 16 : 20, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'success-icon') })))));
31
40
  return (React__default.default.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: function () { return setFocused(true); }, onBlur: function () { return setFocused(false); } },
32
41
  React__default.default.createElement(mobile.FormControlMobile, tslib.__assign({ fieldClassName: cn__default.default(styles.field, fieldClassName, (_b = {},
33
42
  _b[styles.disabled] = disabled,
34
43
  _b[styles.focusVisible] = focusVisible,
35
44
  _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'form-control'),
36
45
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
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)) }),
46
+ tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps, { readOnly: readOnly, colors: colors, error: error, rightAddons: formRightAddons }),
41
47
  React__default.default.createElement("div", { className: styles.contentWrapper },
42
48
  showPlaceholder && React__default.default.createElement("span", { className: styles.placeholder }, placeholder),
43
49
  filled && React__default.default.createElement("div", { className: styles.value }, value)))));
@@ -1,4 +1,4 @@
1
- /* hash: nwkke */
1
+ /* hash: vou0l */
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,26 +15,55 @@
15
15
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
16
16
 
17
17
  /* новые значения, используйте их */
18
- } :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 */
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
  /* новые значения, используйте их */
21
23
 
22
24
  /* no-unit может приводить к проблемам в calc (#1559) */
23
25
  /* stylelint-disable-next-line length-zero-no-unit */
26
+ --gap-4: var(--gap-2xs);
27
+ --gap-12: var(--gap-s);
24
28
  } :root {
25
29
  } :root {
26
30
  --focus-color: var(--color-light-status-info);
27
31
  --disabled-cursor: not-allowed;
28
- } /* сбрасывает синюю подсветку при нажатии */ .input-autocomplete__component_w4hbu {
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_sy1zc {
29
40
  width: 100%;
30
41
  outline: none;
31
- } .input-autocomplete__field_w4hbu:not(.input-autocomplete__disabled_w4hbu) {
42
+ } .input-autocomplete__field_sy1zc:not(.input-autocomplete__disabled_sy1zc) {
32
43
  cursor: pointer;
33
- } .input-autocomplete__disabled_w4hbu {
44
+ } .input-autocomplete__errorIcon_sy1zc {
45
+ display: var(--input-error-icon-display)
46
+ } .input-autocomplete__errorIcon_sy1zc:not(:only-child) {
47
+ margin-left: var(--gap-4);
48
+ } .input-autocomplete__errorIcon_sy1zc.input-autocomplete__size-40_sy1zc:not(:only-child) {
49
+ margin-left: 6px;
50
+ } * + .input-autocomplete__errorIcon_sy1zc {
51
+ display: var(--input-error-icon-not-alone-display);
52
+ } button[class*='eye'] + .input-autocomplete__errorIcon_sy1zc {
53
+ margin-right: var(--gap-12);
54
+ } .input-autocomplete__successIcon_sy1zc {
55
+ display: var(--input-success-icon-display)
56
+ } .input-autocomplete__successIcon_sy1zc:not(:only-child) {
57
+ margin-left: var(--gap-4);
58
+ } .input-autocomplete__successIcon_sy1zc.input-autocomplete__size-40_sy1zc:not(:only-child) {
59
+ margin-left: 6px;
60
+ } button[class*='eye'] + .input-autocomplete__successIcon_sy1zc {
61
+ margin-right: var(--gap-12);
62
+ } .input-autocomplete__disabled_sy1zc {
34
63
  cursor: var(--disabled-cursor);
35
- } .input-autocomplete__placeholder_w4hbu {
64
+ } .input-autocomplete__placeholder_sy1zc {
36
65
  color: var(--color-light-text-secondary);
37
- } .input-autocomplete__contentWrapper_w4hbu {
66
+ } .input-autocomplete__contentWrapper_sy1zc {
38
67
  font-size: 16px;
39
68
  line-height: 20px;
40
69
  font-weight: 400;
@@ -43,11 +72,11 @@
43
72
  text-overflow: ellipsis;
44
73
  overflow: hidden;
45
74
  width: 100%;
46
- } .input-autocomplete__value_w4hbu {
75
+ } .input-autocomplete__value_sy1zc {
47
76
  overflow: hidden;
48
77
  text-overflow: ellipsis;
49
78
  text-align: left;
50
- } .input-autocomplete__focusVisible_w4hbu {
79
+ } .input-autocomplete__focusVisible_sy1zc {
51
80
  outline: 2px solid var(--focus-color);
52
81
  outline-offset: 2px;
53
82
  }
@@ -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 };
@@ -8,6 +8,7 @@ var cn = require('classnames');
8
8
  var mobile = require('@alfalab/core-components-form-control/cssm/mobile');
9
9
  var shared = require('@alfalab/core-components-input/cssm/shared');
10
10
  var coreComponentsShared = require('@alfalab/core-components-shared/cssm');
11
+ var coreComponentsStatusBadge = require('@alfalab/core-components-status-badge/cssm');
11
12
  var hooks = require('@alfalab/hooks');
12
13
  var styles = require('./index.module.css');
13
14
 
@@ -19,7 +20,7 @@ var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
19
20
 
20
21
  var AutocompleteMobileField = function (_a) {
21
22
  var _b;
22
- var _c = _a.size, size = _c === void 0 ? 56 : _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 _c = _a.size, size = _c === void 0 ? 56 : _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, success = _a.success, 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", "success", "onClear", "onInput", "colors"]);
23
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];
@@ -27,16 +28,21 @@ var AutocompleteMobileField = function (_a) {
27
28
  var showPlaceholder = placeholder && !filled && labelView === 'outer';
28
29
  var clearButtonVisible = clear && filled && !disabled && !readOnly;
29
30
  var tabIndex = innerProps.tabIndex, restInnerProps = tslib.__rest(innerProps, ["tabIndex"]);
31
+ var formRightAddons = (Arrow || rightAddons || clearButtonVisible || error || success) && (React__default.default.createElement(React__default.default.Fragment, null,
32
+ clearButtonVisible && (React__default.default.createElement(shared.ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
33
+ rightAddons,
34
+ Arrow,
35
+ error && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.errorIcon, styles__default.default["size-".concat(size)]), "data-addon": 'error-icon' },
36
+ React__default.default.createElement(coreComponentsStatusBadge.StatusBadge, { view: 'negative-alert', size: size === 40 ? 16 : 20, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'error-icon') }))),
37
+ success && !error && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.successIcon, styles__default.default["size-".concat(size)]) },
38
+ React__default.default.createElement(coreComponentsStatusBadge.StatusBadge, { view: 'positive-checkmark', size: size === 40 ? 16 : 20, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'success-icon') })))));
30
39
  return (React__default.default.createElement("div", { className: styles__default.default.component, ref: wrapperRef, onFocus: function () { return setFocused(true); }, onBlur: function () { return setFocused(false); } },
31
40
  React__default.default.createElement(mobile.FormControlMobile, tslib.__assign({ fieldClassName: cn__default.default(styles__default.default.field, fieldClassName, (_b = {},
32
41
  _b[styles__default.default.disabled] = disabled,
33
42
  _b[styles__default.default.focusVisible] = focusVisible,
34
43
  _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'form-control'),
35
44
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
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)) }),
45
+ tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps, { readOnly: readOnly, colors: colors, error: error, rightAddons: formRightAddons }),
40
46
  React__default.default.createElement("div", { className: styles__default.default.contentWrapper },
41
47
  showPlaceholder && React__default.default.createElement("span", { className: styles__default.default.placeholder }, placeholder),
42
48
  filled && React__default.default.createElement("div", { className: styles__default.default.value }, value)))));
@@ -14,21 +14,50 @@
14
14
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
15
15
 
16
16
  /* новые значения, используйте их */
17
- } :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
+ } :root { /* deprecated */
18
+ --gap-2xs: 4px; /* deprecated */ /* deprecated */
19
+ --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 */
18
20
 
19
21
  /* новые значения, используйте их */
20
22
 
21
23
  /* no-unit может приводить к проблемам в calc (#1559) */
22
24
  /* stylelint-disable-next-line length-zero-no-unit */
25
+ --gap-4: var(--gap-2xs);
26
+ --gap-12: var(--gap-s);
23
27
  } :root {
24
28
  } :root {
25
29
  --focus-color: var(--color-light-status-info);
26
30
  --disabled-cursor: not-allowed;
27
- } /* сбрасывает синюю подсветку при нажатии */ .component {
31
+ } /* сбрасывает синюю подсветку при нажатии */ :root {
32
+ /* display */
33
+ --input-error-icon-display: none;
34
+ --input-success-icon-display: flex;
35
+
36
+ /* управляет видимостью иконки ошибки, если она стоит рядом с другой иконкой */
37
+ --input-error-icon-not-alone-display: none;
38
+ } .component {
28
39
  width: 100%;
29
40
  outline: none;
30
41
  } .field:not(.disabled) {
31
42
  cursor: pointer;
43
+ } .errorIcon {
44
+ display: var(--input-error-icon-display)
45
+ } .errorIcon:not(:only-child) {
46
+ margin-left: var(--gap-4);
47
+ } .errorIcon.size-40:not(:only-child) {
48
+ margin-left: 6px;
49
+ } * + .errorIcon {
50
+ display: var(--input-error-icon-not-alone-display);
51
+ } button[class*='eye'] + .errorIcon {
52
+ margin-right: var(--gap-12);
53
+ } .successIcon {
54
+ display: var(--input-success-icon-display)
55
+ } .successIcon:not(:only-child) {
56
+ margin-left: var(--gap-4);
57
+ } .successIcon.size-40:not(:only-child) {
58
+ margin-left: 6px;
59
+ } button[class*='eye'] + .successIcon {
60
+ margin-right: var(--gap-12);
32
61
  } .disabled {
33
62
  cursor: var(--disabled-cursor);
34
63
  } .placeholder {
@@ -25,7 +25,7 @@ var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
25
25
  var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, ref) {
26
26
  var _b;
27
27
  var _c;
28
- 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"]);
28
+ 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"]);
29
29
  var _h = React.useState(false), open = _h[0], setOpen = _h[1];
30
30
  var frozenValue = React.useRef('');
31
31
  var searchInputRef = React.useRef(null);
@@ -86,7 +86,7 @@ var InputAutocompleteMobile = React__default.default.forwardRef(function (_a, re
86
86
  value: value,
87
87
  filterFn: utils.searchFilterStub,
88
88
  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: function (_, payload) { return onInput === null || onInput === void 0 ? void 0 : onInput(payload.value, enums.OnInputReason.Change); } }),
89
- }, 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) })));
89
+ }, 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) })));
90
90
  });
91
91
 
92
92
  exports.InputAutocompleteMobile = InputAutocompleteMobile;
package/cssm/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/cssm/utils.js CHANGED
@@ -18,6 +18,8 @@ function getInputAutocompleteDesktopTestIds(dataTestId) {
18
18
  fieldLeftAddons: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-left-addons'),
19
19
  fieldRightAddons: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-right-addons'),
20
20
  fieldError: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-error-message'),
21
+ fieldErrorIcon: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-error-icon'),
22
+ fieldSuccessIcon: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-success-icon'),
21
23
  fieldHint: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-hint'),
22
24
  };
23
25
  }
@@ -39,6 +41,8 @@ function getInputAutocompleteMobileTestIds(dataTestId) {
39
41
  fieldLeftAddons: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-left-addons'),
40
42
  fieldRightAddons: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-right-addons'),
41
43
  fieldError: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-error-message'),
44
+ fieldErrorIcon: coreComponentsShared.getDataTestId(dataTestId, 'field-error-icon'),
45
+ fieldSuccessIcon: coreComponentsShared.getDataTestId(dataTestId, 'field-success-icon'),
42
46
  fieldHint: coreComponentsShared.getDataTestId(dataTestId, 'field-form-control-hint'),
43
47
  searchInput: coreComponentsShared.getDataTestId(dataTestId, 'search'),
44
48
  searchFormControl: coreComponentsShared.getDataTestId(dataTestId, 'search-form-control'),
package/cssm/vars.css ADDED
@@ -0,0 +1,5 @@
1
+ :root {
2
+ /* display */
3
+
4
+ /* управляет видимостью иконки ошибки, если она стоит рядом с другой иконкой */
5
+ }
@@ -5,7 +5,7 @@ import cn from 'classnames';
5
5
  import { InputDesktop } from '@alfalab/core-components-input/esm/desktop';
6
6
  import { OnInputReason } from '../enums.js';
7
7
 
8
- var styles = {"arrow":"input-autocomplete__arrow_19eia","error":"input-autocomplete__error_19eia"};
8
+ var styles = {"arrow":"input-autocomplete__arrow_1p1u3","error":"input-autocomplete__error_1p1u3"};
9
9
  require('./index.css')
10
10
 
11
11
  var AutocompleteField = function (_a) {
@@ -1,4 +1,4 @@
1
- /* hash: 1tjnr */
2
- .input-autocomplete__arrow_19eia.input-autocomplete__error_19eia ~ * {
1
+ /* hash: 2ngor */
2
+ .input-autocomplete__arrow_1p1u3.input-autocomplete__error_1p1u3 ~ * {
3
3
  display: none;
4
4
  }
@@ -15,5 +15,5 @@ type AutocompleteMobileFieldProps = FormControlMobileProps & Omit<BaseFieldProps
15
15
  */
16
16
  value?: string;
17
17
  };
18
- declare const AutocompleteMobileField: ({ size, open, disabled, value, innerProps, dataTestId, fieldClassName, labelView, placeholder, Arrow, valueRenderer, toggleMenu, setSelectedItems, selectedMultiple, FormControlComponent, 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 };
@@ -4,14 +4,15 @@ import cn from 'classnames';
4
4
  import { FormControlMobile } from '@alfalab/core-components-form-control/esm/mobile';
5
5
  import { ClearButton } from '@alfalab/core-components-input/esm/shared';
6
6
  import { getDataTestId } from '@alfalab/core-components-shared/esm';
7
+ import { StatusBadge } from '@alfalab/core-components-status-badge/esm';
7
8
  import { useFocus } from '@alfalab/hooks';
8
9
 
9
- var styles = {"component":"input-autocomplete__component_w4hbu","field":"input-autocomplete__field_w4hbu","disabled":"input-autocomplete__disabled_w4hbu","placeholder":"input-autocomplete__placeholder_w4hbu","contentWrapper":"input-autocomplete__contentWrapper_w4hbu","value":"input-autocomplete__value_w4hbu","focusVisible":"input-autocomplete__focusVisible_w4hbu"};
10
+ var styles = {"component":"input-autocomplete__component_sy1zc","field":"input-autocomplete__field_sy1zc","disabled":"input-autocomplete__disabled_sy1zc","errorIcon":"input-autocomplete__errorIcon_sy1zc","size-40":"input-autocomplete__size-40_sy1zc","successIcon":"input-autocomplete__successIcon_sy1zc","placeholder":"input-autocomplete__placeholder_sy1zc","contentWrapper":"input-autocomplete__contentWrapper_sy1zc","value":"input-autocomplete__value_sy1zc","focusVisible":"input-autocomplete__focusVisible_sy1zc"};
10
11
  require('./index.css')
11
12
 
12
13
  var AutocompleteMobileField = function (_a) {
13
14
  var _b;
14
- var _c = _a.size, size = _c === void 0 ? 56 : _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 _c = _a.size, size = _c === void 0 ? 56 : _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, success = _a.success, 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", "success", "onClear", "onInput", "colors"]);
15
16
  var _f = useState(false), focused = _f[0], setFocused = _f[1];
16
17
  var wrapperRef = useRef(null);
17
18
  var focusVisible = useFocus(wrapperRef, 'keyboard')[0];
@@ -19,16 +20,21 @@ var AutocompleteMobileField = function (_a) {
19
20
  var showPlaceholder = placeholder && !filled && labelView === 'outer';
20
21
  var clearButtonVisible = clear && filled && !disabled && !readOnly;
21
22
  var tabIndex = innerProps.tabIndex, restInnerProps = __rest(innerProps, ["tabIndex"]);
23
+ var formRightAddons = (Arrow || rightAddons || clearButtonVisible || error || success) && (React.createElement(React.Fragment, null,
24
+ clearButtonVisible && (React.createElement(ClearButton, { onClick: onClear, disabled: disabled, colors: colors })),
25
+ rightAddons,
26
+ Arrow,
27
+ error && (React.createElement("div", { className: cn(styles.errorIcon, styles["size-".concat(size)]), "data-addon": 'error-icon' },
28
+ React.createElement(StatusBadge, { view: 'negative-alert', size: size === 40 ? 16 : 20, dataTestId: getDataTestId(dataTestId, 'error-icon') }))),
29
+ success && !error && (React.createElement("div", { className: cn(styles.successIcon, styles["size-".concat(size)]) },
30
+ React.createElement(StatusBadge, { view: 'positive-checkmark', size: size === 40 ? 16 : 20, dataTestId: getDataTestId(dataTestId, 'success-icon') })))));
22
31
  return (React.createElement("div", { className: styles.component, ref: wrapperRef, onFocus: function () { return setFocused(true); }, onBlur: function () { return setFocused(false); } },
23
32
  React.createElement(FormControlMobile, __assign({ fieldClassName: cn(styles.field, fieldClassName, (_b = {},
24
33
  _b[styles.disabled] = disabled,
25
34
  _b[styles.focusVisible] = focusVisible,
26
35
  _b)), block: true, size: size, focused: focused, disabled: disabled, filled: filled, labelView: labelView, dataTestId: getDataTestId(dataTestId, 'form-control'),
27
36
  // downshift устанавливает фокус на таргет поле после выбора опции, не даем ему это сделать пока открыт список, иначе поле поиска будет терять фокус
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)) }),
37
+ tabIndex: open ? undefined : tabIndex }, restProps, restInnerProps, { readOnly: readOnly, colors: colors, error: error, rightAddons: formRightAddons }),
32
38
  React.createElement("div", { className: styles.contentWrapper },
33
39
  showPlaceholder && React.createElement("span", { className: styles.placeholder }, placeholder),
34
40
  filled && React.createElement("div", { className: styles.value }, value)))));
@@ -1,4 +1,4 @@
1
- /* hash: nwkke */
1
+ /* hash: vou0l */
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,26 +15,55 @@
15
15
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
16
16
 
17
17
  /* новые значения, используйте их */
18
- } :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 */
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
  /* новые значения, используйте их */
21
23
 
22
24
  /* no-unit может приводить к проблемам в calc (#1559) */
23
25
  /* stylelint-disable-next-line length-zero-no-unit */
26
+ --gap-4: var(--gap-2xs);
27
+ --gap-12: var(--gap-s);
24
28
  } :root {
25
29
  } :root {
26
30
  --focus-color: var(--color-light-status-info);
27
31
  --disabled-cursor: not-allowed;
28
- } /* сбрасывает синюю подсветку при нажатии */ .input-autocomplete__component_w4hbu {
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_sy1zc {
29
40
  width: 100%;
30
41
  outline: none;
31
- } .input-autocomplete__field_w4hbu:not(.input-autocomplete__disabled_w4hbu) {
42
+ } .input-autocomplete__field_sy1zc:not(.input-autocomplete__disabled_sy1zc) {
32
43
  cursor: pointer;
33
- } .input-autocomplete__disabled_w4hbu {
44
+ } .input-autocomplete__errorIcon_sy1zc {
45
+ display: var(--input-error-icon-display)
46
+ } .input-autocomplete__errorIcon_sy1zc:not(:only-child) {
47
+ margin-left: var(--gap-4);
48
+ } .input-autocomplete__errorIcon_sy1zc.input-autocomplete__size-40_sy1zc:not(:only-child) {
49
+ margin-left: 6px;
50
+ } * + .input-autocomplete__errorIcon_sy1zc {
51
+ display: var(--input-error-icon-not-alone-display);
52
+ } button[class*='eye'] + .input-autocomplete__errorIcon_sy1zc {
53
+ margin-right: var(--gap-12);
54
+ } .input-autocomplete__successIcon_sy1zc {
55
+ display: var(--input-success-icon-display)
56
+ } .input-autocomplete__successIcon_sy1zc:not(:only-child) {
57
+ margin-left: var(--gap-4);
58
+ } .input-autocomplete__successIcon_sy1zc.input-autocomplete__size-40_sy1zc:not(:only-child) {
59
+ margin-left: 6px;
60
+ } button[class*='eye'] + .input-autocomplete__successIcon_sy1zc {
61
+ margin-right: var(--gap-12);
62
+ } .input-autocomplete__disabled_sy1zc {
34
63
  cursor: var(--disabled-cursor);
35
- } .input-autocomplete__placeholder_w4hbu {
64
+ } .input-autocomplete__placeholder_sy1zc {
36
65
  color: var(--color-light-text-secondary);
37
- } .input-autocomplete__contentWrapper_w4hbu {
66
+ } .input-autocomplete__contentWrapper_sy1zc {
38
67
  font-size: 16px;
39
68
  line-height: 20px;
40
69
  font-weight: 400;
@@ -43,11 +72,11 @@
43
72
  text-overflow: ellipsis;
44
73
  overflow: hidden;
45
74
  width: 100%;
46
- } .input-autocomplete__value_w4hbu {
75
+ } .input-autocomplete__value_sy1zc {
47
76
  overflow: hidden;
48
77
  text-overflow: ellipsis;
49
78
  text-align: left;
50
- } .input-autocomplete__focusVisible_w4hbu {
79
+ } .input-autocomplete__focusVisible_sy1zc {
51
80
  outline: 2px solid var(--focus-color);
52
81
  outline-offset: 2px;
53
82
  }
@@ -9,13 +9,13 @@ import { AutocompleteMobileField } from '../autocomplete-mobile-field/Component.
9
9
  import { OnInputReason } from '../enums.js';
10
10
  import { searchFilterStub } from '../utils.js';
11
11
 
12
- var styles = {"input":"input-autocomplete__input_1uzwc"};
12
+ var styles = {"input":"input-autocomplete__input_1l8s5"};
13
13
  require('./mobile.css')
14
14
 
15
15
  var InputAutocompleteMobile = React.forwardRef(function (_a, ref) {
16
16
  var _b;
17
17
  var _c;
18
- 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 = __rest(_a, ["Input", "value", "name", "Arrow", "label", "placeholder", "size", "open", "onInput", "onOpen", "multiple", "inputProps", "isBottomSheet", "dataTestId", "transitionProps", "onCancel", "onApply", "title"]);
18
+ 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 = __rest(_a, ["Input", "value", "name", "Arrow", "label", "placeholder", "size", "open", "onInput", "onOpen", "multiple", "inputProps", "isBottomSheet", "dataTestId", "transitionProps", "onCancel", "onApply", "title", "success"]);
19
19
  var _h = useState(false), open = _h[0], setOpen = _h[1];
20
20
  var frozenValue = useRef('');
21
21
  var searchInputRef = useRef(null);
@@ -76,7 +76,7 @@ var InputAutocompleteMobile = React.forwardRef(function (_a, ref) {
76
76
  value: value,
77
77
  filterFn: searchFilterStub,
78
78
  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: function (_, payload) { return onInput === null || onInput === void 0 ? void 0 : onInput(payload.value, OnInputReason.Change); } }),
79
- }, 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 ? inputProps === null || inputProps === void 0 ? void 0 : inputProps.onClear : undefined }, restProps.fieldProps) })));
79
+ }, 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 ? inputProps === null || inputProps === void 0 ? void 0 : inputProps.onClear : undefined, success: success }, restProps.fieldProps) })));
80
80
  });
81
81
 
82
82
  export { InputAutocompleteMobile };