@salutejs/plasma-new-hope 0.174.0-canary.1505.11483510462.0 → 0.174.0-canary.1505.11503860288.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (124) hide show
  1. package/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js +5 -1
  2. package/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js.map +1 -1
  3. package/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js +5 -1
  4. package/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js.map +1 -1
  5. package/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +5 -1
  6. package/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js.map +1 -1
  7. package/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js +5 -1
  8. package/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js.map +1 -1
  9. package/cjs/components/Combobox/ComboboxNew/Combobox.js +18 -7
  10. package/cjs/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  11. package/cjs/components/Combobox/ComboboxNew/utils/getInitialValue.js +27 -0
  12. package/cjs/components/Combobox/ComboboxNew/utils/getInitialValue.js.map +1 -0
  13. package/cjs/components/Combobox/ComboboxNew/utils/initialItemsTransform.js +9 -5
  14. package/cjs/components/Combobox/ComboboxNew/utils/initialItemsTransform.js.map +1 -1
  15. package/cjs/components/Select/utils/initialItemsTransform.js +6 -7
  16. package/cjs/components/Select/utils/initialItemsTransform.js.map +1 -1
  17. package/cjs/components/TextArea/TextArea.js +1 -1
  18. package/cjs/components/TextArea/TextArea.js.map +1 -1
  19. package/cjs/components/TextArea/TextArea.styles.js +2 -2
  20. package/cjs/components/TextArea/TextArea.styles.js.map +1 -1
  21. package/cjs/components/TextField/TextField.js +1 -1
  22. package/cjs/components/TextField/TextField.js.map +1 -1
  23. package/cjs/components/TextField/TextField.styles.js +2 -2
  24. package/cjs/components/TextField/TextField.styles.js.map +1 -1
  25. package/emotion/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js +5 -1
  26. package/emotion/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js +5 -1
  27. package/emotion/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +5 -1
  28. package/emotion/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js +5 -1
  29. package/emotion/cjs/components/Combobox/ComboboxNew/Combobox.js +17 -7
  30. package/emotion/cjs/components/Combobox/ComboboxNew/utils/getInitialValue.js +26 -0
  31. package/emotion/cjs/components/Combobox/ComboboxNew/utils/index.js +8 -1
  32. package/emotion/cjs/components/Combobox/ComboboxNew/utils/initialItemsTransform.js +19 -5
  33. package/emotion/cjs/components/Select/utils/initialItemsTransform.js +6 -7
  34. package/emotion/cjs/components/TextArea/TextArea.js +2 -2
  35. package/emotion/cjs/components/TextArea/TextArea.styles.js +20 -20
  36. package/emotion/cjs/components/TextField/TextField.js +2 -2
  37. package/emotion/cjs/components/TextField/TextField.styles.js +24 -24
  38. package/emotion/es/components/Calendar/ui/CalendarDays/CalendarDays.js +5 -1
  39. package/emotion/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js +5 -1
  40. package/emotion/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +5 -1
  41. package/emotion/es/components/Calendar/ui/CalendarYears/CalendarYears.js +5 -1
  42. package/emotion/es/components/Combobox/ComboboxNew/Combobox.js +18 -8
  43. package/emotion/es/components/Combobox/ComboboxNew/utils/getInitialValue.js +20 -0
  44. package/emotion/es/components/Combobox/ComboboxNew/utils/index.js +2 -1
  45. package/emotion/es/components/Combobox/ComboboxNew/utils/initialItemsTransform.js +19 -5
  46. package/emotion/es/components/Select/utils/initialItemsTransform.js +6 -7
  47. package/emotion/es/components/TextArea/TextArea.js +2 -2
  48. package/emotion/es/components/TextArea/TextArea.styles.js +20 -20
  49. package/emotion/es/components/TextField/TextField.js +2 -2
  50. package/emotion/es/components/TextField/TextField.styles.js +24 -24
  51. package/es/components/Calendar/ui/CalendarDays/CalendarDays.js +5 -1
  52. package/es/components/Calendar/ui/CalendarDays/CalendarDays.js.map +1 -1
  53. package/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js +5 -1
  54. package/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js.map +1 -1
  55. package/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +5 -1
  56. package/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js.map +1 -1
  57. package/es/components/Calendar/ui/CalendarYears/CalendarYears.js +5 -1
  58. package/es/components/Calendar/ui/CalendarYears/CalendarYears.js.map +1 -1
  59. package/es/components/Combobox/ComboboxNew/Combobox.js +18 -7
  60. package/es/components/Combobox/ComboboxNew/Combobox.js.map +1 -1
  61. package/es/components/Combobox/ComboboxNew/utils/getInitialValue.js +23 -0
  62. package/es/components/Combobox/ComboboxNew/utils/getInitialValue.js.map +1 -0
  63. package/es/components/Combobox/ComboboxNew/utils/initialItemsTransform.js +9 -5
  64. package/es/components/Combobox/ComboboxNew/utils/initialItemsTransform.js.map +1 -1
  65. package/es/components/Select/utils/initialItemsTransform.js +6 -7
  66. package/es/components/Select/utils/initialItemsTransform.js.map +1 -1
  67. package/es/components/TextArea/TextArea.js +1 -1
  68. package/es/components/TextArea/TextArea.js.map +1 -1
  69. package/es/components/TextArea/TextArea.styles.js +2 -2
  70. package/es/components/TextArea/TextArea.styles.js.map +1 -1
  71. package/es/components/TextField/TextField.js +1 -1
  72. package/es/components/TextField/TextField.js.map +1 -1
  73. package/es/components/TextField/TextField.styles.js +2 -2
  74. package/es/components/TextField/TextField.styles.js.map +1 -1
  75. package/package.json +2 -2
  76. package/styled-components/cjs/components/Calendar/ui/CalendarDays/CalendarDays.js +5 -1
  77. package/styled-components/cjs/components/Calendar/ui/CalendarMonths/CalendarMonths.js +5 -1
  78. package/styled-components/cjs/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +5 -1
  79. package/styled-components/cjs/components/Calendar/ui/CalendarYears/CalendarYears.js +5 -1
  80. package/styled-components/cjs/components/Combobox/ComboboxNew/Combobox.js +17 -7
  81. package/styled-components/cjs/components/Combobox/ComboboxNew/utils/getInitialValue.js +26 -0
  82. package/styled-components/cjs/components/Combobox/ComboboxNew/utils/index.js +8 -1
  83. package/styled-components/cjs/components/Combobox/ComboboxNew/utils/initialItemsTransform.js +19 -5
  84. package/styled-components/cjs/components/Select/utils/initialItemsTransform.js +6 -7
  85. package/styled-components/cjs/components/TextArea/TextArea.js +1 -1
  86. package/styled-components/cjs/components/TextArea/TextArea.styles.js +2 -2
  87. package/styled-components/cjs/components/TextField/TextField.js +1 -1
  88. package/styled-components/cjs/components/TextField/TextField.styles.js +2 -2
  89. package/styled-components/es/components/Calendar/ui/CalendarDays/CalendarDays.js +5 -1
  90. package/styled-components/es/components/Calendar/ui/CalendarMonths/CalendarMonths.js +5 -1
  91. package/styled-components/es/components/Calendar/ui/CalendarQuarters/CalendarQuarters.js +5 -1
  92. package/styled-components/es/components/Calendar/ui/CalendarYears/CalendarYears.js +5 -1
  93. package/styled-components/es/components/Combobox/ComboboxNew/Combobox.js +18 -8
  94. package/styled-components/es/components/Combobox/ComboboxNew/utils/getInitialValue.js +20 -0
  95. package/styled-components/es/components/Combobox/ComboboxNew/utils/index.js +2 -1
  96. package/styled-components/es/components/Combobox/ComboboxNew/utils/initialItemsTransform.js +19 -5
  97. package/styled-components/es/components/Select/utils/initialItemsTransform.js +6 -7
  98. package/styled-components/es/components/TextArea/TextArea.js +1 -1
  99. package/styled-components/es/components/TextArea/TextArea.styles.js +2 -2
  100. package/styled-components/es/components/TextField/TextField.js +1 -1
  101. package/styled-components/es/components/TextField/TextField.styles.js +2 -2
  102. package/types/components/Calendar/ui/CalendarDays/CalendarDays.d.ts.map +1 -1
  103. package/types/components/Calendar/ui/CalendarMonths/CalendarMonths.d.ts.map +1 -1
  104. package/types/components/Calendar/ui/CalendarQuarters/CalendarQuarters.d.ts.map +1 -1
  105. package/types/components/Calendar/ui/CalendarYears/CalendarYears.d.ts.map +1 -1
  106. package/types/components/Combobox/ComboboxNew/Combobox.d.ts.map +1 -1
  107. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts +7 -2
  108. package/types/components/Combobox/ComboboxNew/Combobox.types.d.ts.map +1 -1
  109. package/types/components/Combobox/ComboboxNew/utils/getInitialValue.d.ts +4 -0
  110. package/types/components/Combobox/ComboboxNew/utils/getInitialValue.d.ts.map +1 -0
  111. package/types/components/Combobox/ComboboxNew/utils/index.d.ts +1 -0
  112. package/types/components/Combobox/ComboboxNew/utils/index.d.ts.map +1 -1
  113. package/types/components/Combobox/ComboboxNew/utils/initialItemsTransform.d.ts.map +1 -1
  114. package/types/components/DatePicker/SingleDate/SingleDate.types.d.ts +4 -0
  115. package/types/components/DatePicker/SingleDate/SingleDate.types.d.ts.map +1 -1
  116. package/types/components/Select/utils/initialItemsTransform.d.ts.map +1 -1
  117. package/types/components/TextArea/TextArea.styles.d.ts +1 -1
  118. package/types/components/TextArea/TextArea.styles.d.ts.map +1 -1
  119. package/types/components/TextField/TextField.styles.d.ts +1 -1
  120. package/types/components/TextField/TextField.styles.d.ts.map +1 -1
  121. package/types/examples/plasma_b2c/components/Combobox/Combobox.d.ts +12 -0
  122. package/types/examples/plasma_b2c/components/Combobox/Combobox.d.ts.map +1 -1
  123. package/types/examples/plasma_web/components/Combobox/Combobox.d.ts +12 -0
  124. package/types/examples/plasma_web/components/Combobox/Combobox.d.ts.map +1 -1
@@ -88,6 +88,9 @@ export var CalendarDays = function CalendarDays(_ref) {
88
88
  }
89
89
  onHoverDay === null || onHoverDay === void 0 || onHoverDay(selectedDate);
90
90
  }, [getSelectedDate, onHoverDay, value]);
91
+ var handleMouseOutGrid = function handleMouseOutGrid() {
92
+ return onHoverDay === null || onHoverDay === void 0 ? void 0 : onHoverDay(undefined);
93
+ };
91
94
  var getRefs = function getRefs(element, isDayInCurrentMonth, i, j) {
92
95
  if (isDayInCurrentMonth) {
93
96
  outerRefs.current[i + offset][j] = element;
@@ -102,7 +105,8 @@ export var CalendarDays = function CalendarDays(_ref) {
102
105
  return /*#__PURE__*/React.createElement(StyledCalendarDays, {
103
106
  role: "grid",
104
107
  "aria-labelledby": "id-grid-label",
105
- onKeyDown: onKeyDown
108
+ onKeyDown: onKeyDown,
109
+ onMouseLeave: handleMouseOutGrid
106
110
  }, _StyledCalendarDaysHi || (_StyledCalendarDaysHi = /*#__PURE__*/React.createElement(StyledCalendarDaysHint, {
107
111
  id: "withShift"
108
112
  }, "\u0414\u043B\u044F \u043D\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u0438 \u0442\u043E\u043B\u044C\u043A\u043E \u043F\u043E \u0434\u043E\u0441\u0442\u0443\u043F\u043D\u044B\u043C \u0434\u0430\u0442\u0430\u043C \u0443\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0439\u0442\u0435 \u043A\u043B\u0430\u0432\u0438\u0448\u0443 Shift.")), /*#__PURE__*/React.createElement(StyledFlex, {
@@ -92,6 +92,9 @@ export var CalendarMonths = function CalendarMonths(_ref) {
92
92
  }
93
93
  onHoverMonth === null || onHoverMonth === void 0 || onHoverMonth(selectedDate);
94
94
  }, [getSelectedDate, onHoverMonth, value]);
95
+ var handleMouseOutGrid = function handleMouseOutGrid() {
96
+ return onHoverMonth === null || onHoverMonth === void 0 ? void 0 : onHoverMonth(undefined);
97
+ };
95
98
  var getRefs = useCallback(function (element, i, j) {
96
99
  outerRefs.current[i + offset][j] = element;
97
100
  }, [offset, outerRefs]);
@@ -104,7 +107,8 @@ export var CalendarMonths = function CalendarMonths(_ref) {
104
107
  return /*#__PURE__*/React.createElement(StyledCalendarMonths, {
105
108
  role: "grid",
106
109
  "aria-labelledby": "id-grid-label",
107
- onKeyDown: onKeyDown
110
+ onKeyDown: onKeyDown,
111
+ onMouseLeave: handleMouseOutGrid
108
112
  }, months.map(function (month, i) {
109
113
  return /*#__PURE__*/React.createElement(StyledFlex, {
110
114
  role: "row",
@@ -90,6 +90,9 @@ export var CalendarQuarters = function CalendarQuarters(_ref) {
90
90
  }
91
91
  onHoverQuarter === null || onHoverQuarter === void 0 || onHoverQuarter(selectedDate);
92
92
  }, [getSelectedDate, onHoverQuarter, value]);
93
+ var handleMouseOutGrid = function handleMouseOutGrid() {
94
+ return onHoverQuarter === null || onHoverQuarter === void 0 ? void 0 : onHoverQuarter(undefined);
95
+ };
93
96
  var getRefs = useCallback(function (element, i, j) {
94
97
  outerRefs.current[i + offset][j] = element;
95
98
  }, [offset, outerRefs]);
@@ -102,7 +105,8 @@ export var CalendarQuarters = function CalendarQuarters(_ref) {
102
105
  return /*#__PURE__*/React.createElement(StyledCalendarQuarters, {
103
106
  role: "grid",
104
107
  "aria-labelledby": "id-grid-label",
105
- onKeyDown: onKeyDown
108
+ onKeyDown: onKeyDown,
109
+ onMouseLeave: handleMouseOutGrid
106
110
  }, quarters.map(function (quarter, i) {
107
111
  return /*#__PURE__*/React.createElement(StyledFlex, {
108
112
  role: "row",
@@ -92,6 +92,9 @@ export var CalendarYears = function CalendarYears(_ref) {
92
92
  }
93
93
  onHoverYear === null || onHoverYear === void 0 || onHoverYear(selectedDate);
94
94
  }, [getSelectedDate, onHoverYear, value]);
95
+ var handleMouseOutGrid = function handleMouseOutGrid() {
96
+ return onHoverYear === null || onHoverYear === void 0 ? void 0 : onHoverYear(undefined);
97
+ };
95
98
  var getRefs = useCallback(function (element, i, j) {
96
99
  outerRefs.current[i + offset][j] = element;
97
100
  }, [outerRefs]);
@@ -104,7 +107,8 @@ export var CalendarYears = function CalendarYears(_ref) {
104
107
  return /*#__PURE__*/React.createElement(StyledCalendarYears, {
105
108
  role: "grid",
106
109
  "aria-labelledby": "id-grid-label",
107
- onKeyDown: onKeyDown
110
+ onKeyDown: onKeyDown,
111
+ onMouseLeave: handleMouseOutGrid
108
112
  }, years.map(function (year, i) {
109
113
  return /*#__PURE__*/React.createElement(StyledFlex, {
110
114
  role: "row",
@@ -1,4 +1,4 @@
1
- var _excluded = ["multiple", "value", "onChange", "isTargetAmount", "items", "placement", "label", "placeholder", "helperText", "contentLeft", "textBefore", "textAfter", "variant", "listOverflow", "listHeight", "listWidth", "portal", "renderItem", "view", "size", "labelPlacement", "readOnly", "disabled", "alwaysOpened", "filter", "closeAfterSelect"];
1
+ var _excluded = ["multiple", "value", "onChange", "isTargetAmount", "items", "placement", "label", "placeholder", "helperText", "contentLeft", "textBefore", "textAfter", "variant", "listOverflow", "listHeight", "listWidth", "portal", "renderItem", "view", "size", "labelPlacement", "readOnly", "disabled", "alwaysOpened", "filter", "closeAfterSelect", "renderValue"];
2
2
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
3
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
4
4
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
@@ -16,7 +16,7 @@ import { sizeToIconSize } from '../../Select/utils';
16
16
  import { classes } from './Combobox.tokens';
17
17
  import { FloatingPopover } from './FloatingPopover';
18
18
  import { useKeyNavigation, getItemByFocused } from './hooks/useKeyboardNavigation';
19
- import { initialItemsTransform, updateAncestors, updateDescendants, updateSingleAncestors, filterItems, getItemId } from './utils';
19
+ import { initialItemsTransform, updateAncestors, updateDescendants, updateSingleAncestors, filterItems, getItemId, getInitialValue } from './utils';
20
20
  import { Inner, StyledTextField } from './ui';
21
21
  import { pathReducer, focusedPathReducer } from './reducers';
22
22
  import { getPathMap, getTreeMaps } from './hooks/getPathMaps';
@@ -62,6 +62,7 @@ export var comboboxRoot = function comboboxRoot(Root) {
62
62
  alwaysOpened = _props$alwaysOpened === void 0 ? false : _props$alwaysOpened,
63
63
  filter = props.filter,
64
64
  outerCloseAfterSelect = props.closeAfterSelect,
65
+ renderValue = props.renderValue,
65
66
  rest = _objectWithoutProperties(props, _excluded);
66
67
  // Создаем структуры для быстрой работы с деревом
67
68
  var _useMemo = useMemo(function () {
@@ -79,7 +80,7 @@ export var comboboxRoot = function comboboxRoot(Root) {
79
80
  _useState4 = _slicedToArray(_useState3, 2),
80
81
  internalValue = _useState4[0],
81
82
  setInternalValue = _useState4[1];
82
- var value = outerValue || internalValue;
83
+ var value = outerValue !== null && outerValue !== undefined ? getInitialValue(outerValue, valueToItemMap) : internalValue;
83
84
  var inputRef = useRef(null);
84
85
  var floatingPopoverRef = useRef(null);
85
86
  var inputForkRef = useForkRef(inputRef, ref);
@@ -276,14 +277,17 @@ export var comboboxRoot = function comboboxRoot(Root) {
276
277
  }
277
278
  };
278
279
  var getChips = function getChips() {
279
- if (multiple) {
280
+ if (multiple && Array.isArray(value)) {
280
281
  if (value.length === 0) return [];
281
282
  if (isTargetAmount) {
282
283
  return ["\u0412\u044B\u0431\u0440\u0430\u043D\u043E ".concat(value.length)];
283
284
  }
284
- return value.map(function (value) {
285
- return valueToItemMap.get(value).label;
286
- });
285
+ var mapper = renderValue && function (stringValue) {
286
+ return renderValue(valueToItemMap.get(stringValue));
287
+ } || function (stringValue) {
288
+ return valueToItemMap.get(stringValue).label;
289
+ };
290
+ return value.map(mapper);
287
291
  }
288
292
  return [];
289
293
  };
@@ -311,6 +315,7 @@ export var comboboxRoot = function comboboxRoot(Root) {
311
315
  // В данном эффекте мы следим за изменениями value снаружи и вносим коррективы в дерево чекбоксов.
312
316
  // Пример: когда юзер очистил value извне, тогда нужно пройтись по элементам и выключить все чекбоксы.
313
317
  useLayoutEffect(function () {
318
+ var _valueToItemMap$get4;
314
319
  var checkedCopy = new Map(checked);
315
320
  checkedCopy.forEach(function (_, key) {
316
321
  checkedCopy.set(key, false);
@@ -328,7 +333,12 @@ export var comboboxRoot = function comboboxRoot(Root) {
328
333
  }
329
334
  }
330
335
  setChecked(checkedCopy);
331
- }, [value]);
336
+ setTextValue(((_valueToItemMap$get4 = valueToItemMap.get(outerValue)) === null || _valueToItemMap$get4 === void 0 ? void 0 : _valueToItemMap$get4.label) || '');
337
+
338
+ // В deps мы кладем именно outerValue и internalValue, а не просто value.
339
+ // Т.к. вначале нужно отфильтровать и провалидировать outerValue и результат положить в переменную.
340
+ // А переменную, содержащую сложные типы данных, нельзя помещать в deps.
341
+ }, [outerValue, internalValue]);
332
342
  return /*#__PURE__*/React.createElement(Root, {
333
343
  size: size,
334
344
  view: view,
@@ -0,0 +1,20 @@
1
+ // Утилита предназначена для фильтрации элементов в value, которые отсутствуют в items.
2
+ // Эти элементы игнорируются и не участвуют в дальнейшей работе компонента.
3
+ export var getInitialValue = function getInitialValue(outerValue, valueToItemMap) {
4
+ if (Array.isArray(outerValue)) {
5
+ if (outerValue.length === 0) {
6
+ return [];
7
+ }
8
+ var updatedValue = [];
9
+ outerValue.forEach(function (value) {
10
+ if (valueToItemMap.has(value)) {
11
+ updatedValue.push(value);
12
+ }
13
+ });
14
+ return updatedValue;
15
+ }
16
+ if (valueToItemMap.has(outerValue)) {
17
+ return outerValue;
18
+ }
19
+ return '';
20
+ };
@@ -4,4 +4,5 @@ export { updateAncestors } from './updateAncestors';
4
4
  export { updateSingleAncestors } from './updateSingleAncestors';
5
5
  export { sizeToIconSize } from './sizeToIconSize';
6
6
  export { filterItems } from './filterItems';
7
- export { getItemId } from './getItemId';
7
+ export { getItemId } from './getItemId';
8
+ export { getInitialValue } from './getInitialValue';
@@ -1,11 +1,25 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
8
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
9
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
10
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
11
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
12
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
1
13
  // Проходимся по массиву items и добавляем в каждый item ключ parent, который ссылается на item родителя.
2
14
  // Дает возможность прохода к корневому элементу (снизу вверх).
15
+ // На выходе получаем глубокую копию исходного массива items.
3
16
  export var initialItemsTransform = function initialItemsTransform(items, parent) {
4
- items.forEach(function (item) {
5
- item.parent = parent;
6
- if (item.items) {
7
- item.items = initialItemsTransform(item.items, item);
17
+ return _toConsumableArray(items).map(function (item) {
18
+ var itemCopy = _objectSpread({}, item);
19
+ itemCopy.parent = parent;
20
+ if (itemCopy.items) {
21
+ itemCopy.items = initialItemsTransform(itemCopy.items, itemCopy);
8
22
  }
23
+ return itemCopy;
9
24
  });
10
- return items;
11
25
  };
@@ -14,13 +14,12 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len
14
14
  // Дает возможность прохода к корневому элементу (снизу вверх).
15
15
  // На выходе получаем глубокую копию исходного массива items.
16
16
  export var initialItemsTransform = function initialItemsTransform(items, parent) {
17
- var newItems = _toConsumableArray(items);
18
- newItems.forEach(function (item) {
19
- var newItem = _objectSpread({}, item);
20
- newItem.parent = parent;
21
- if (item.items) {
22
- item.items = initialItemsTransform(item.items, item);
17
+ return _toConsumableArray(items).map(function (item) {
18
+ var itemCopy = _objectSpread({}, item);
19
+ itemCopy.parent = parent;
20
+ if (itemCopy.items) {
21
+ itemCopy.items = initialItemsTransform(itemCopy.items, itemCopy);
23
22
  }
23
+ return itemCopy;
24
24
  });
25
- return newItems;
26
25
  };
@@ -43,7 +43,7 @@ var innerPlaceholderUp = classes.innerPlaceholderUp,
43
43
  styledPlaceholder = classes.styledPlaceholder,
44
44
  styledHelpers = classes.styledHelpers;
45
45
  var optionalText = 'optional';
46
- var base = /*#__PURE__*/css(applyDynamicLabel, ";position:relative;box-sizing:border-box;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextArea/TextArea.tsx"],"names":[],"mappings":"AAkDgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback, useRef, MouseEventHandler } from 'react';\nimport { css } from '@emotion/react';\nimport { useForkRef, useResizeObserver } from '@salutejs/plasma-core';\n\nimport { cx, mergeRefs } from '../../utils';\nimport type { RootProps } from '../../engines/types';\nimport { useOutsideClick } from '../../hooks';\n\nimport { applyDynamicLabel } from './mixins';\nimport { useAutoResize, ROOT_FONT_SIZE } from './hooks';\nimport {\n    StyledContent,\n    StyledHelpers,\n    StyledLeftHelper,\n    StyledRightHelper,\n    StyledLabel,\n    StyledPlaceholder,\n    StyledTextArea,\n    StyledTextAreaWrapper,\n    StyledContainer,\n    StyledIndicator,\n    StyledOptionalText,\n    OuterLabelWrapper,\n    StyledIndicatorWrapper,\n    StyledHintWrapper,\n    TitleCaption,\n} from './TextArea.styles';\nimport { classes } from './TextArea.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as clearCSS } from './variations/_clear/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as hintViewCSS } from './variations/_hint-view/base';\nimport { base as hintSizeCSS } from './variations/_hint-size/base';\nimport type { TextAreaProps, TextAreaRootProps } from './TextArea.types';\nimport { HintComponent } from './ui/Hint/Hint';\n\nconst {\n    innerPlaceholderUp,\n    focusedOuterPlaceholderColor,\n    hidePlaceHolder,\n    styledContainer,\n    styledTextArea,\n    styledTextAreaWrapper,\n    styledPlaceholder,\n    styledHelpers,\n} = classes;\n\nconst optionalText = 'optional';\n\nconst base = css`\n    ${applyDynamicLabel};\n\n    position: relative;\n    box-sizing: border-box;\n`;\n\n// TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c\nconst fallbackStatusMap = {\n    '': 'primary',\n    success: 'positive',\n    warning: 'warning',\n    error: 'negative',\n};\n\nconst HINT_DEFAULT_OFFSET: [number, number] = [0, 0];\n\n// TODO: Перенести этот метод в файл applyDynamicLabel.ts\nexport const getDynamicLabelClasses = (props: TextAreaProps, focused: boolean) => {\n    const { readOnly, label, labelPlacement, rows, value, size } = props;\n\n    // Добавить класс отвечающий за изменение цвета плейсхолдера при фокусе\n    const withFocusedOuterUpPlaceholder =\n        !readOnly && focused && (!label || labelPlacement === 'outer') ? focusedOuterPlaceholderColor : undefined;\n\n    // Добавить класс отвечающий за поднятие и уменьшение плейсхолдера\n    const withInnerPlaceholderUp =\n        labelPlacement === 'inner' &&\n        label &&\n        !rows &&\n        size !== 'xs' &&\n        ((!readOnly && (value || focused)) || (readOnly && value))\n            ? innerPlaceholderUp\n            : undefined;\n\n    // Добавить класс отвечающий за скрытие плейсхолдера\n    const withHidePlaceholder =\n        (value && !label) ||\n        (labelPlacement === 'inner' && ((focused && !readOnly) || value) && label && rows) ||\n        (labelPlacement === 'outer' && value) ||\n        (labelPlacement === 'inner' && size === 'xs' && value)\n            ? hidePlaceHolder\n            : undefined;\n\n    return [withFocusedOuterUpPlaceholder, withInnerPlaceholderUp, withHidePlaceholder];\n};\n\nexport const textAreaRoot = (Root: RootProps<HTMLTextAreaElement, TextAreaRootProps>) =>\n    forwardRef<HTMLTextAreaElement, TextAreaProps>((props, innerRef) => {\n        const {\n            helperText,\n            status,\n            resize,\n            rightHelper,\n            leftHelper,\n            contentRight,\n            autoResize = false,\n            minAuto = 0,\n            maxAuto,\n            label,\n            labelPlacement = 'inner',\n            titleCaption,\n            placeholder,\n            defaultValue,\n            height,\n            width,\n            value,\n            disabled,\n            required = false,\n            requiredPlacement = 'right',\n            optional = false,\n            clear,\n            hasDivider,\n            size,\n            view,\n            id,\n            style,\n            className,\n            readOnly,\n            rows,\n            cols,\n            hintTrigger = 'hover',\n            hintText,\n            hintView = 'default',\n            hintSize = 'm',\n            hintTargetIcon,\n            hintPlacement = 'auto',\n            hintHasArrow,\n            hintOffset = HINT_DEFAULT_OFFSET,\n            hintWidth,\n            hintContentLeft,\n            onChange,\n            ...rest\n        } = props;\n\n        const [isHintVisible, setIsHintVisible] = useState(false);\n        const [helperWidth, setHelperWidth] = useState<string>(width ? `${width}rem` : '100%');\n        const [focused, setFocused] = useState(false);\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n\n        const hintRef = useOutsideClick<HTMLDivElement>(() => {\n            setIsHintVisible(false);\n        });\n        const hintInnerRef = useRef<HTMLDivElement>(null);\n        const hintForkRef = useForkRef(hintRef, hintInnerRef);\n\n        const innerOptional = required ? false : optional;\n        const hasHelper = Boolean(leftHelper || rightHelper || helperText);\n        const hasOuterLabel = Boolean(label && labelPlacement === 'outer');\n        const hasInnerLabel = Boolean(label && labelPlacement === 'inner' && size !== 'xs');\n        const hasPlaceholderOptional = innerOptional && !hasOuterLabel;\n\n        const overriddenView = status !== undefined ? fallbackStatusMap[status] : view;\n        const textareaHelperId = id ? `${id}-helper` : undefined;\n        const applyCustomWidth = resize !== 'horizontal' && resize !== 'both' && !cols;\n        const placeholderLabel = hasInnerLabel ? label : placeholder;\n\n        const clearClass = clear ? classes.clear : undefined;\n        const hasHintClass = hintText ? classes.hasHint : undefined;\n        const hasRightContentClass = contentRight ? classes.hasRightContent : undefined;\n        const hasDividerClass = hasDivider ? classes.hasDivider : undefined;\n        const requiredPlacementClass = requiredPlacement === 'right' ? classes.requiredAlignRight : undefined;\n\n        const handleHintShow = () => setIsHintVisible(true);\n        const handleHintHide = () => setIsHintVisible(false);\n        const handleHintClick: MouseEventHandler = (event) => {\n            if (!hintText || hintTrigger !== 'click') {\n                return;\n            }\n\n            event.stopPropagation();\n            const targetIsPopover = event.target === hintInnerRef.current;\n            const rootHasTarget = hintInnerRef.current?.contains(event.target as Element);\n\n            if (!targetIsPopover && !rootHasTarget) {\n                setIsHintVisible(true);\n            }\n        };\n\n        useResizeObserver(outerRef, (currentElement) => {\n            const { width: inlineWidth } = currentElement.style;\n\n            if (inlineWidth || cols) {\n                const { width: elementWidth } = currentElement.getBoundingClientRect();\n                setHelperWidth(`${elementWidth / ROOT_FONT_SIZE}rem`);\n            }\n        });\n\n        useAutoResize(autoResize || Boolean(clear), outerRef, value, minAuto, maxAuto);\n\n        const onFocusHandler = useCallback(() => {\n            setFocused(true);\n        }, []);\n\n        const onBlurHandler = useCallback(() => {\n            setFocused(false);\n        }, []);\n\n        const onChangeHandler = useCallback(\n            (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n                // INFO: Для крайне редких кейсов, когда value снаружи не контролируется\n                if (value === undefined) {\n                    setUncontrolledValue(event?.target.value);\n                }\n\n                onChange?.(event);\n            },\n            [value, onChange],\n        );\n\n        const handleTextAreaFocus = () => {\n            if (readOnly || disabled || !outerRef?.current) {\n                return;\n            }\n\n            outerRef.current.scrollTo({\n                top: 0,\n                left: outerRef.current.offsetLeft,\n                behavior: 'smooth',\n            });\n\n            outerRef.current.focus();\n        };\n\n        const dynamicLabelClasses = getDynamicLabelClasses(\n            {\n                size,\n                readOnly,\n                label,\n                labelPlacement,\n                value: value || uncontrolledValue || defaultValue,\n                rows,\n            },\n            focused,\n        );\n\n        const optionalTextNode = innerOptional ? (\n            <StyledOptionalText inheritFont={!hasOuterLabel}>\n                {Boolean(hasPlaceholderOptional ? placeholderLabel : label) && '\\xa0'}\n                {optionalText}\n            </StyledOptionalText>\n        ) : null;\n\n        return (\n            <Root\n                view={overriddenView}\n                size={size}\n                disabled={disabled}\n                readOnly={readOnly}\n                clear={clear}\n                style={{ width: helperWidth, ...style }}\n                className={cx(clearClass, hasDividerClass, hasHintClass, className)}\n                onClick={handleTextAreaFocus}\n                {...(hintText && { hintView, hintSize })}\n            >\n                {(hasOuterLabel || titleCaption) && (\n                    <OuterLabelWrapper isInnnerLabel={labelPlacement === 'inner'}>\n                        {hasOuterLabel && (\n                            <StyledIndicatorWrapper>\n                                <StyledLabel>{label}</StyledLabel>\n\n                                {hintText && (\n                                    <StyledHintWrapper>\n                                        <HintComponent\n                                            ref={hintForkRef}\n                                            hintText={hintText}\n                                            hintTrigger={hintTrigger}\n                                            isHintVisible={isHintVisible}\n                                            hintTargetIcon={hintTargetIcon}\n                                            hintPlacement={hintPlacement}\n                                            hintHasArrow={hintHasArrow}\n                                            hintOffset={hintOffset}\n                                            hintWidth={hintWidth}\n                                            hintContentLeft={hintContentLeft}\n                                            handleHintShow={handleHintShow}\n                                            handleHintHide={handleHintHide}\n                                            handleHintClick={handleHintClick}\n                                        />\n                                    </StyledHintWrapper>\n                                )}\n                                {required && (\n                                    <StyledIndicator\n                                        className={cx(\n                                            classes.outerLabelPlacement,\n                                            requiredPlacementClass,\n                                            hasHintClass,\n                                        )}\n                                    />\n                                )}\n                                {optionalTextNode}\n                            </StyledIndicatorWrapper>\n                        )}\n                        {titleCaption && <TitleCaption>{titleCaption}</TitleCaption>}\n                    </OuterLabelWrapper>\n                )}\n                <StyledContainer\n                    className={cx(styledContainer, ...dynamicLabelClasses)}\n                    width={helperWidth}\n                    onFocus={onFocusHandler}\n                    onBlur={onBlurHandler}\n                >\n                    {!hasOuterLabel && (\n                        <>\n                            {required && (\n                                <StyledIndicator className={cx(classes.innerLabelPlacement, requiredPlacementClass)} />\n                            )}\n                            {hintText && (\n                                <StyledHintWrapper className={classes.innerLabelPlacement}>\n                                    <HintComponent\n                                        ref={hintForkRef}\n                                        hintText={hintText}\n                                        hintTrigger={hintTrigger}\n                                        isHintVisible={isHintVisible}\n                                        hintTargetIcon={hintTargetIcon}\n                                        hintPlacement={hintPlacement}\n                                        hintHasArrow={hintHasArrow}\n                                        hintOffset={hintOffset}\n                                        hintWidth={hintWidth}\n                                        hintContentLeft={hintContentLeft}\n                                        handleHintShow={handleHintShow}\n                                        handleHintHide={handleHintHide}\n                                        handleHintClick={handleHintClick}\n                                    />\n                                </StyledHintWrapper>\n                            )}\n                        </>\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={styledTextAreaWrapper} hasHelper={hasHelper}>\n                        <StyledTextArea\n                            className={cx(styledTextArea, hasRightContentClass)}\n                            id={id}\n                            hasContentRight={Boolean(contentRight)}\n                            hasHelper={hasHelper}\n                            applyCustomWidth={applyCustomWidth}\n                            ref={mergeRefs(outerRef, innerRef)}\n                            disabled={disabled}\n                            height={autoResize || Boolean(clear) ? minAuto : height}\n                            width={width}\n                            placeholder={placeholderLabel}\n                            aria-describedby={textareaHelperId}\n                            value={value}\n                            readOnly={readOnly}\n                            rows={rows}\n                            cols={cols}\n                            resize={resize}\n                            defaultValue={defaultValue}\n                            onChange={onChangeHandler}\n                            {...rest}\n                        />\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {(leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper>{rightHelper}</StyledRightHelper>}\n                        </StyledHelpers>\n                    )}\n                    {placeholderLabel && (\n                        <StyledPlaceholder\n                            hasContentRight={Boolean(contentRight)}\n                            className={styledPlaceholder}\n                            htmlFor={id}\n                        >\n                            {placeholderLabel}\n                            {!hasOuterLabel && optionalTextNode}\n                        </StyledPlaceholder>\n                    )}\n                </StyledContainer>\n            </Root>\n        );\n    });\n\nexport const textAreaConfig = {\n    name: 'TextArea',\n    tag: 'div',\n    layout: textAreaRoot,\n    base,\n    variations: {\n        size: {\n            css: sizeCSS,\n        },\n        view: {\n            css: viewCSS,\n        },\n        clear: {\n            css: clearCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        readOnly: {\n            attrs: true,\n        },\n        hintView: {\n            css: hintViewCSS,\n        },\n        hintSize: {\n            css: hintSizeCSS,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'primary',\n    },\n};\n"]} */"));
46
+ var base = /*#__PURE__*/css(applyDynamicLabel, ";position:relative;box-sizing:border-box;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextArea/TextArea.tsx"],"names":[],"mappings":"AAkDgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback, useRef, MouseEventHandler } from 'react';\nimport { css } from '@emotion/react';\nimport { useForkRef, useResizeObserver } from '@salutejs/plasma-core';\n\nimport { cx, mergeRefs } from '../../utils';\nimport type { RootProps } from '../../engines/types';\nimport { useOutsideClick } from '../../hooks';\n\nimport { applyDynamicLabel } from './mixins';\nimport { useAutoResize, ROOT_FONT_SIZE } from './hooks';\nimport {\n    StyledContent,\n    StyledHelpers,\n    StyledLeftHelper,\n    StyledRightHelper,\n    StyledLabel,\n    StyledPlaceholder,\n    StyledTextArea,\n    StyledTextAreaWrapper,\n    StyledContainer,\n    StyledIndicator,\n    StyledOptionalText,\n    OuterLabelWrapper,\n    StyledIndicatorWrapper,\n    StyledHintWrapper,\n    TitleCaption,\n} from './TextArea.styles';\nimport { classes } from './TextArea.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as clearCSS } from './variations/_clear/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as hintViewCSS } from './variations/_hint-view/base';\nimport { base as hintSizeCSS } from './variations/_hint-size/base';\nimport type { TextAreaProps, TextAreaRootProps } from './TextArea.types';\nimport { HintComponent } from './ui/Hint/Hint';\n\nconst {\n    innerPlaceholderUp,\n    focusedOuterPlaceholderColor,\n    hidePlaceHolder,\n    styledContainer,\n    styledTextArea,\n    styledTextAreaWrapper,\n    styledPlaceholder,\n    styledHelpers,\n} = classes;\n\nconst optionalText = 'optional';\n\nconst base = css`\n    ${applyDynamicLabel};\n\n    position: relative;\n    box-sizing: border-box;\n`;\n\n// TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c\nconst fallbackStatusMap = {\n    '': 'primary',\n    success: 'positive',\n    warning: 'warning',\n    error: 'negative',\n};\n\nconst HINT_DEFAULT_OFFSET: [number, number] = [0, 0];\n\n// TODO: Перенести этот метод в файл applyDynamicLabel.ts\nexport const getDynamicLabelClasses = (props: TextAreaProps, focused: boolean) => {\n    const { readOnly, label, labelPlacement, rows, value, size } = props;\n\n    // Добавить класс отвечающий за изменение цвета плейсхолдера при фокусе\n    const withFocusedOuterUpPlaceholder =\n        !readOnly && focused && (!label || labelPlacement === 'outer') ? focusedOuterPlaceholderColor : undefined;\n\n    // Добавить класс отвечающий за поднятие и уменьшение плейсхолдера\n    const withInnerPlaceholderUp =\n        labelPlacement === 'inner' &&\n        label &&\n        !rows &&\n        size !== 'xs' &&\n        ((!readOnly && (value || focused)) || (readOnly && value))\n            ? innerPlaceholderUp\n            : undefined;\n\n    // Добавить класс отвечающий за скрытие плейсхолдера\n    const withHidePlaceholder =\n        (value && !label) ||\n        (labelPlacement === 'inner' && ((focused && !readOnly) || value) && label && rows) ||\n        (labelPlacement === 'outer' && value) ||\n        (labelPlacement === 'inner' && size === 'xs' && value)\n            ? hidePlaceHolder\n            : undefined;\n\n    return [withFocusedOuterUpPlaceholder, withInnerPlaceholderUp, withHidePlaceholder];\n};\n\nexport const textAreaRoot = (Root: RootProps<HTMLTextAreaElement, TextAreaRootProps>) =>\n    forwardRef<HTMLTextAreaElement, TextAreaProps>((props, innerRef) => {\n        const {\n            helperText,\n            status,\n            resize,\n            rightHelper,\n            leftHelper,\n            contentRight,\n            autoResize = false,\n            minAuto = 0,\n            maxAuto,\n            label,\n            labelPlacement = 'inner',\n            titleCaption,\n            placeholder,\n            defaultValue,\n            height,\n            width,\n            value,\n            disabled,\n            required = false,\n            requiredPlacement = 'right',\n            optional = false,\n            clear,\n            hasDivider,\n            size,\n            view,\n            id,\n            style,\n            className,\n            readOnly,\n            rows,\n            cols,\n            hintTrigger = 'hover',\n            hintText,\n            hintView = 'default',\n            hintSize = 'm',\n            hintTargetIcon,\n            hintPlacement = 'auto',\n            hintHasArrow,\n            hintOffset = HINT_DEFAULT_OFFSET,\n            hintWidth,\n            hintContentLeft,\n            onChange,\n            ...rest\n        } = props;\n\n        const [isHintVisible, setIsHintVisible] = useState(false);\n        const [helperWidth, setHelperWidth] = useState<string>(width ? `${width}rem` : '100%');\n        const [focused, setFocused] = useState(false);\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n\n        const hintRef = useOutsideClick<HTMLDivElement>(() => {\n            setIsHintVisible(false);\n        });\n        const hintInnerRef = useRef<HTMLDivElement>(null);\n        const hintForkRef = useForkRef(hintRef, hintInnerRef);\n\n        const innerOptional = required ? false : optional;\n        const hasHelper = Boolean(leftHelper || rightHelper || helperText);\n        const hasOuterLabel = Boolean(label && labelPlacement === 'outer');\n        const hasInnerLabel = Boolean(label && labelPlacement === 'inner' && size !== 'xs');\n        const hasPlaceholderOptional = innerOptional && !hasOuterLabel;\n\n        const overriddenView = status !== undefined ? fallbackStatusMap[status] : view;\n        const textareaHelperId = id ? `${id}-helper` : undefined;\n        const applyCustomWidth = resize !== 'horizontal' && resize !== 'both' && !cols;\n        const placeholderLabel = hasInnerLabel ? label : placeholder;\n\n        const clearClass = clear ? classes.clear : undefined;\n        const hasHintClass = hintText ? classes.hasHint : undefined;\n        const hasRightContentClass = contentRight ? classes.hasRightContent : undefined;\n        const hasDividerClass = hasDivider ? classes.hasDivider : undefined;\n        const requiredPlacementClass = requiredPlacement === 'right' ? classes.requiredAlignRight : undefined;\n\n        const handleHintShow = () => setIsHintVisible(true);\n        const handleHintHide = () => setIsHintVisible(false);\n        const handleHintClick: MouseEventHandler = (event) => {\n            if (!hintText || hintTrigger !== 'click') {\n                return;\n            }\n\n            event.stopPropagation();\n            const targetIsPopover = event.target === hintInnerRef.current;\n            const rootHasTarget = hintInnerRef.current?.contains(event.target as Element);\n\n            if (!targetIsPopover && !rootHasTarget) {\n                setIsHintVisible(true);\n            }\n        };\n\n        useResizeObserver(outerRef, (currentElement) => {\n            const { width: inlineWidth } = currentElement.style;\n\n            if (inlineWidth || cols) {\n                const { width: elementWidth } = currentElement.getBoundingClientRect();\n                setHelperWidth(`${elementWidth / ROOT_FONT_SIZE}rem`);\n            }\n        });\n\n        useAutoResize(autoResize || Boolean(clear), outerRef, value, minAuto, maxAuto);\n\n        const onFocusHandler = useCallback(() => {\n            setFocused(true);\n        }, []);\n\n        const onBlurHandler = useCallback(() => {\n            setFocused(false);\n        }, []);\n\n        const onChangeHandler = useCallback(\n            (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n                // INFO: Для крайне редких кейсов, когда value снаружи не контролируется\n                if (value === undefined) {\n                    setUncontrolledValue(event?.target.value);\n                }\n\n                onChange?.(event);\n            },\n            [value, onChange],\n        );\n\n        const handleTextAreaFocus = () => {\n            if (readOnly || disabled || !outerRef?.current) {\n                return;\n            }\n\n            outerRef.current.scrollTo({\n                top: 0,\n                left: outerRef.current.offsetLeft,\n                behavior: 'smooth',\n            });\n\n            outerRef.current.focus();\n        };\n\n        const dynamicLabelClasses = getDynamicLabelClasses(\n            {\n                size,\n                readOnly,\n                label,\n                labelPlacement,\n                value: value || uncontrolledValue || defaultValue,\n                rows,\n            },\n            focused,\n        );\n\n        const optionalTextNode = innerOptional ? (\n            <StyledOptionalText inheritFont={!hasOuterLabel}>\n                {Boolean(hasPlaceholderOptional ? placeholderLabel : label) && '\\xa0'}\n                {optionalText}\n            </StyledOptionalText>\n        ) : null;\n\n        return (\n            <Root\n                view={overriddenView}\n                size={size}\n                disabled={disabled}\n                readOnly={readOnly}\n                clear={clear}\n                style={{ width: helperWidth, ...style }}\n                className={cx(clearClass, hasDividerClass, hasHintClass, className)}\n                onClick={handleTextAreaFocus}\n                {...(hintText && { hintView, hintSize })}\n            >\n                {(hasOuterLabel || titleCaption) && (\n                    <OuterLabelWrapper isInnerLabel={labelPlacement === 'inner'}>\n                        {hasOuterLabel && (\n                            <StyledIndicatorWrapper>\n                                <StyledLabel>{label}</StyledLabel>\n\n                                {hintText && (\n                                    <StyledHintWrapper>\n                                        <HintComponent\n                                            ref={hintForkRef}\n                                            hintText={hintText}\n                                            hintTrigger={hintTrigger}\n                                            isHintVisible={isHintVisible}\n                                            hintTargetIcon={hintTargetIcon}\n                                            hintPlacement={hintPlacement}\n                                            hintHasArrow={hintHasArrow}\n                                            hintOffset={hintOffset}\n                                            hintWidth={hintWidth}\n                                            hintContentLeft={hintContentLeft}\n                                            handleHintShow={handleHintShow}\n                                            handleHintHide={handleHintHide}\n                                            handleHintClick={handleHintClick}\n                                        />\n                                    </StyledHintWrapper>\n                                )}\n                                {required && (\n                                    <StyledIndicator\n                                        className={cx(\n                                            classes.outerLabelPlacement,\n                                            requiredPlacementClass,\n                                            hasHintClass,\n                                        )}\n                                    />\n                                )}\n                                {optionalTextNode}\n                            </StyledIndicatorWrapper>\n                        )}\n                        {titleCaption && <TitleCaption>{titleCaption}</TitleCaption>}\n                    </OuterLabelWrapper>\n                )}\n                <StyledContainer\n                    className={cx(styledContainer, ...dynamicLabelClasses)}\n                    width={helperWidth}\n                    onFocus={onFocusHandler}\n                    onBlur={onBlurHandler}\n                >\n                    {!hasOuterLabel && (\n                        <>\n                            {required && (\n                                <StyledIndicator className={cx(classes.innerLabelPlacement, requiredPlacementClass)} />\n                            )}\n                            {hintText && (\n                                <StyledHintWrapper className={classes.innerLabelPlacement}>\n                                    <HintComponent\n                                        ref={hintForkRef}\n                                        hintText={hintText}\n                                        hintTrigger={hintTrigger}\n                                        isHintVisible={isHintVisible}\n                                        hintTargetIcon={hintTargetIcon}\n                                        hintPlacement={hintPlacement}\n                                        hintHasArrow={hintHasArrow}\n                                        hintOffset={hintOffset}\n                                        hintWidth={hintWidth}\n                                        hintContentLeft={hintContentLeft}\n                                        handleHintShow={handleHintShow}\n                                        handleHintHide={handleHintHide}\n                                        handleHintClick={handleHintClick}\n                                    />\n                                </StyledHintWrapper>\n                            )}\n                        </>\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={styledTextAreaWrapper} hasHelper={hasHelper}>\n                        <StyledTextArea\n                            className={cx(styledTextArea, hasRightContentClass)}\n                            id={id}\n                            hasContentRight={Boolean(contentRight)}\n                            hasHelper={hasHelper}\n                            applyCustomWidth={applyCustomWidth}\n                            ref={mergeRefs(outerRef, innerRef)}\n                            disabled={disabled}\n                            height={autoResize || Boolean(clear) ? minAuto : height}\n                            width={width}\n                            placeholder={placeholderLabel}\n                            aria-describedby={textareaHelperId}\n                            value={value}\n                            readOnly={readOnly}\n                            rows={rows}\n                            cols={cols}\n                            resize={resize}\n                            defaultValue={defaultValue}\n                            onChange={onChangeHandler}\n                            {...rest}\n                        />\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {(leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper>{rightHelper}</StyledRightHelper>}\n                        </StyledHelpers>\n                    )}\n                    {placeholderLabel && (\n                        <StyledPlaceholder\n                            hasContentRight={Boolean(contentRight)}\n                            className={styledPlaceholder}\n                            htmlFor={id}\n                        >\n                            {placeholderLabel}\n                            {!hasOuterLabel && optionalTextNode}\n                        </StyledPlaceholder>\n                    )}\n                </StyledContainer>\n            </Root>\n        );\n    });\n\nexport const textAreaConfig = {\n    name: 'TextArea',\n    tag: 'div',\n    layout: textAreaRoot,\n    base,\n    variations: {\n        size: {\n            css: sizeCSS,\n        },\n        view: {\n            css: viewCSS,\n        },\n        clear: {\n            css: clearCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        readOnly: {\n            attrs: true,\n        },\n        hintView: {\n            css: hintViewCSS,\n        },\n        hintSize: {\n            css: hintSizeCSS,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'primary',\n    },\n};\n"]} */"));
47
47
 
48
48
  // TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c
49
49
  var fallbackStatusMap = {
@@ -242,7 +242,7 @@ export var textAreaRoot = function textAreaRoot(Root) {
242
242
  hintView: hintView,
243
243
  hintSize: hintSize
244
244
  }), (hasOuterLabel || titleCaption) && /*#__PURE__*/React.createElement(OuterLabelWrapper, {
245
- isInnnerLabel: labelPlacement === 'inner'
245
+ isInnerLabel: labelPlacement === 'inner'
246
246
  }, hasOuterLabel && /*#__PURE__*/React.createElement(StyledIndicatorWrapper, null, /*#__PURE__*/React.createElement(StyledLabel, null, label), hintText && /*#__PURE__*/React.createElement(StyledHintWrapper, null, /*#__PURE__*/React.createElement(HintComponent, {
247
247
  ref: hintForkRef,
248
248
  hintText: hintText,