@salutejs/plasma-new-hope 0.327.0-canary.2010.15752302924.0 → 0.327.0-canary.2016.15703018170.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (231) hide show
  1. package/cjs/components/Autocomplete/Autocomplete.css +1 -1
  2. package/cjs/components/Combobox/ComboboxNew/Combobox.css +1 -1
  3. package/cjs/components/DatePicker/RangeDate/RangeDate.css +1 -1
  4. package/cjs/components/DatePicker/RangeDate/RangeDatePopover/RangeDatePopover.css +1 -1
  5. package/cjs/components/DatePicker/SingleDate/SingleDate.css +1 -1
  6. package/cjs/components/Mask/Mask.js +3 -3
  7. package/cjs/components/Mask/Mask.js.map +1 -1
  8. package/cjs/components/Pagination/Pagination.css +1 -1
  9. package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +1 -1
  10. package/cjs/components/Range/Range.css +1 -1
  11. package/cjs/components/Select/Select.css +1 -1
  12. package/cjs/components/Select/ui/Target/Target.css +1 -1
  13. package/cjs/components/Select/ui/Target/ui/Textfield/Textfield.css +1 -1
  14. package/cjs/components/Slider/Slider.css +1 -1
  15. package/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +1 -1
  16. package/cjs/components/Table/Table.css +1 -1
  17. package/cjs/components/Table/ui/Cell/Cell.css +1 -1
  18. package/cjs/components/Table/ui/EditableCell/EditableCell.css +1 -1
  19. package/cjs/components/Table/ui/HeadCell/HeadCell.css +1 -1
  20. package/cjs/components/Table/ui/HeadCell/ui/Filter/Filter.css +1 -1
  21. package/cjs/components/TextArea/TextArea.js +2 -5
  22. package/cjs/components/TextArea/TextArea.js.map +1 -1
  23. package/cjs/components/TextArea/TextArea.tokens.js +1 -2
  24. package/cjs/components/TextArea/TextArea.tokens.js.map +1 -1
  25. package/cjs/components/TextArea/variations/_size/base.js +1 -1
  26. package/cjs/components/TextArea/variations/_size/base.js.map +1 -1
  27. package/cjs/components/TextField/TextField.js +2 -10
  28. package/cjs/components/TextField/TextField.js.map +1 -1
  29. package/cjs/components/TextField/TextField.tokens.js +1 -2
  30. package/cjs/components/TextField/TextField.tokens.js.map +1 -1
  31. package/cjs/components/TextField/variations/_size/base.js +1 -1
  32. package/cjs/components/TextField/variations/_size/base.js.map +1 -1
  33. package/cjs/components/TextField/variations/_size/base_uulqii.css +1 -0
  34. package/cjs/index.css +1 -8
  35. package/cjs/index.js +0 -6
  36. package/cjs/index.js.map +1 -1
  37. package/emotion/cjs/components/Mask/Mask.js +3 -3
  38. package/emotion/cjs/components/TextArea/TextArea.js +3 -6
  39. package/emotion/cjs/components/TextArea/TextArea.tokens.js +1 -2
  40. package/emotion/cjs/components/TextArea/variations/_size/base.js +1 -2
  41. package/emotion/cjs/components/TextField/TextField.js +3 -11
  42. package/emotion/cjs/components/TextField/TextField.tokens.js +1 -2
  43. package/emotion/cjs/components/TextField/variations/_size/base.js +1 -1
  44. package/emotion/cjs/index.js +0 -11
  45. package/emotion/es/components/Mask/Mask.js +3 -3
  46. package/emotion/es/components/TextArea/TextArea.js +3 -6
  47. package/emotion/es/components/TextArea/TextArea.tokens.js +1 -2
  48. package/emotion/es/components/TextArea/variations/_size/base.js +1 -2
  49. package/emotion/es/components/TextField/TextField.js +3 -11
  50. package/emotion/es/components/TextField/TextField.tokens.js +1 -2
  51. package/emotion/es/components/TextField/variations/_size/base.js +1 -1
  52. package/emotion/es/index.js +1 -2
  53. package/es/components/Autocomplete/Autocomplete.css +1 -1
  54. package/es/components/Combobox/ComboboxNew/Combobox.css +1 -1
  55. package/es/components/DatePicker/RangeDate/RangeDate.css +1 -1
  56. package/es/components/DatePicker/RangeDate/RangeDatePopover/RangeDatePopover.css +1 -1
  57. package/es/components/DatePicker/SingleDate/SingleDate.css +1 -1
  58. package/es/components/Mask/Mask.js +3 -3
  59. package/es/components/Mask/Mask.js.map +1 -1
  60. package/es/components/Pagination/Pagination.css +1 -1
  61. package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +1 -1
  62. package/es/components/Range/Range.css +1 -1
  63. package/es/components/Select/Select.css +1 -1
  64. package/es/components/Select/ui/Target/Target.css +1 -1
  65. package/es/components/Select/ui/Target/ui/Textfield/Textfield.css +1 -1
  66. package/es/components/Slider/Slider.css +1 -1
  67. package/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +1 -1
  68. package/es/components/Table/Table.css +1 -1
  69. package/es/components/Table/ui/Cell/Cell.css +1 -1
  70. package/es/components/Table/ui/EditableCell/EditableCell.css +1 -1
  71. package/es/components/Table/ui/HeadCell/HeadCell.css +1 -1
  72. package/es/components/Table/ui/HeadCell/ui/Filter/Filter.css +1 -1
  73. package/es/components/TextArea/TextArea.js +2 -5
  74. package/es/components/TextArea/TextArea.js.map +1 -1
  75. package/es/components/TextArea/TextArea.tokens.js +1 -2
  76. package/es/components/TextArea/TextArea.tokens.js.map +1 -1
  77. package/es/components/TextArea/variations/_size/base.js +1 -1
  78. package/es/components/TextArea/variations/_size/base.js.map +1 -1
  79. package/es/components/TextField/TextField.js +2 -10
  80. package/es/components/TextField/TextField.js.map +1 -1
  81. package/es/components/TextField/TextField.tokens.js +1 -2
  82. package/es/components/TextField/TextField.tokens.js.map +1 -1
  83. package/es/components/TextField/variations/_size/base.js +1 -1
  84. package/es/components/TextField/variations/_size/base.js.map +1 -1
  85. package/es/components/TextField/variations/_size/base_uulqii.css +1 -0
  86. package/es/index.css +1 -8
  87. package/es/index.js +0 -2
  88. package/es/index.js.map +1 -1
  89. package/package.json +2 -2
  90. package/styled-components/cjs/components/Mask/Mask.js +3 -3
  91. package/styled-components/cjs/components/TextArea/TextArea.js +2 -5
  92. package/styled-components/cjs/components/TextArea/TextArea.tokens.js +1 -2
  93. package/styled-components/cjs/components/TextArea/variations/_size/base.js +1 -2
  94. package/styled-components/cjs/components/TextField/TextField.js +2 -10
  95. package/styled-components/cjs/components/TextField/TextField.tokens.js +1 -2
  96. package/styled-components/cjs/components/TextField/variations/_size/base.js +1 -1
  97. package/styled-components/cjs/index.js +0 -11
  98. package/styled-components/es/components/Mask/Mask.js +3 -3
  99. package/styled-components/es/components/TextArea/TextArea.js +2 -5
  100. package/styled-components/es/components/TextArea/TextArea.tokens.js +1 -2
  101. package/styled-components/es/components/TextArea/variations/_size/base.js +1 -2
  102. package/styled-components/es/components/TextField/TextField.js +2 -10
  103. package/styled-components/es/components/TextField/TextField.tokens.js +1 -2
  104. package/styled-components/es/components/TextField/variations/_size/base.js +1 -1
  105. package/styled-components/es/index.js +1 -2
  106. package/types/components/TextArea/TextArea.d.ts.map +1 -1
  107. package/types/components/TextArea/TextArea.tokens.d.ts +0 -1
  108. package/types/components/TextArea/TextArea.tokens.d.ts.map +1 -1
  109. package/types/components/TextArea/variations/_size/base.d.ts.map +1 -1
  110. package/types/components/TextField/TextField.d.ts.map +1 -1
  111. package/types/components/TextField/TextField.tokens.d.ts +0 -1
  112. package/types/components/TextField/TextField.tokens.d.ts.map +1 -1
  113. package/types/components/TextField/variations/_size/base.d.ts.map +1 -1
  114. package/types/index.d.ts +0 -1
  115. package/types/index.d.ts.map +1 -1
  116. package/cjs/components/TextArea/variations/_size/base_1mq4sb2.css +0 -1
  117. package/cjs/components/TextField/variations/_size/base_ryad12.css +0 -1
  118. package/cjs/components/Tour/Tour.css +0 -4
  119. package/cjs/components/Tour/Tour.js +0 -231
  120. package/cjs/components/Tour/Tour.js.map +0 -1
  121. package/cjs/components/Tour/Tour.styles.js +0 -58
  122. package/cjs/components/Tour/Tour.styles.js.map +0 -1
  123. package/cjs/components/Tour/Tour.styles_hmd79i.css +0 -4
  124. package/cjs/components/Tour/Tour.tokens.js +0 -21
  125. package/cjs/components/Tour/Tour.tokens.js.map +0 -1
  126. package/cjs/components/Tour/utils/index.js +0 -113
  127. package/cjs/components/Tour/utils/index.js.map +0 -1
  128. package/cjs/components/Tour/variatoins/_size/base.js +0 -9
  129. package/cjs/components/Tour/variatoins/_size/base.js.map +0 -1
  130. package/cjs/components/Tour/variatoins/_view/base.js +0 -9
  131. package/cjs/components/Tour/variatoins/_view/base.js.map +0 -1
  132. package/emotion/cjs/components/Tour/Tour.js +0 -240
  133. package/emotion/cjs/components/Tour/Tour.styles.js +0 -50
  134. package/emotion/cjs/components/Tour/Tour.tokens.js +0 -19
  135. package/emotion/cjs/components/Tour/Tour.types.js +0 -5
  136. package/emotion/cjs/components/Tour/index.js +0 -31
  137. package/emotion/cjs/components/Tour/utils/index.js +0 -110
  138. package/emotion/cjs/components/Tour/variatoins/_size/base.js +0 -8
  139. package/emotion/cjs/components/Tour/variatoins/_size/tokens.json +0 -1
  140. package/emotion/cjs/components/Tour/variatoins/_view/base.js +0 -8
  141. package/emotion/cjs/components/Tour/variatoins/_view/tokens.json +0 -1
  142. package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.config.js +0 -22
  143. package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.js +0 -11
  144. package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
  145. package/emotion/cjs/examples/plasma_web/components/Tour/Tour.config.js +0 -22
  146. package/emotion/cjs/examples/plasma_web/components/Tour/Tour.js +0 -11
  147. package/emotion/cjs/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
  148. package/emotion/es/components/Tour/Tour.js +0 -232
  149. package/emotion/es/components/Tour/Tour.styles.js +0 -43
  150. package/emotion/es/components/Tour/Tour.tokens.js +0 -13
  151. package/emotion/es/components/Tour/Tour.types.js +0 -1
  152. package/emotion/es/components/Tour/index.js +0 -2
  153. package/emotion/es/components/Tour/utils/index.js +0 -104
  154. package/emotion/es/components/Tour/variatoins/_size/base.js +0 -2
  155. package/emotion/es/components/Tour/variatoins/_size/tokens.json +0 -1
  156. package/emotion/es/components/Tour/variatoins/_view/base.js +0 -2
  157. package/emotion/es/components/Tour/variatoins/_view/tokens.json +0 -1
  158. package/emotion/es/examples/plasma_b2c/components/Tour/Tour.config.js +0 -16
  159. package/emotion/es/examples/plasma_b2c/components/Tour/Tour.js +0 -5
  160. package/emotion/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
  161. package/emotion/es/examples/plasma_web/components/Tour/Tour.config.js +0 -16
  162. package/emotion/es/examples/plasma_web/components/Tour/Tour.js +0 -5
  163. package/emotion/es/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
  164. package/es/components/TextArea/variations/_size/base_1mq4sb2.css +0 -1
  165. package/es/components/TextField/variations/_size/base_ryad12.css +0 -1
  166. package/es/components/Tour/Tour.css +0 -4
  167. package/es/components/Tour/Tour.js +0 -222
  168. package/es/components/Tour/Tour.js.map +0 -1
  169. package/es/components/Tour/Tour.styles.js +0 -51
  170. package/es/components/Tour/Tour.styles.js.map +0 -1
  171. package/es/components/Tour/Tour.styles_hmd79i.css +0 -4
  172. package/es/components/Tour/Tour.tokens.js +0 -16
  173. package/es/components/Tour/Tour.tokens.js.map +0 -1
  174. package/es/components/Tour/utils/index.js +0 -107
  175. package/es/components/Tour/utils/index.js.map +0 -1
  176. package/es/components/Tour/variatoins/_size/base.js +0 -5
  177. package/es/components/Tour/variatoins/_size/base.js.map +0 -1
  178. package/es/components/Tour/variatoins/_size/base_x642ct.css +0 -1
  179. package/es/components/Tour/variatoins/_view/base.js +0 -5
  180. package/es/components/Tour/variatoins/_view/base.js.map +0 -1
  181. package/es/components/Tour/variatoins/_view/base_x642ct.css +0 -1
  182. package/styled-components/cjs/components/Tour/Tour.js +0 -240
  183. package/styled-components/cjs/components/Tour/Tour.styles.js +0 -29
  184. package/styled-components/cjs/components/Tour/Tour.tokens.js +0 -19
  185. package/styled-components/cjs/components/Tour/Tour.types.js +0 -5
  186. package/styled-components/cjs/components/Tour/index.js +0 -31
  187. package/styled-components/cjs/components/Tour/utils/index.js +0 -110
  188. package/styled-components/cjs/components/Tour/variatoins/_size/base.js +0 -8
  189. package/styled-components/cjs/components/Tour/variatoins/_size/tokens.json +0 -1
  190. package/styled-components/cjs/components/Tour/variatoins/_view/base.js +0 -8
  191. package/styled-components/cjs/components/Tour/variatoins/_view/tokens.json +0 -1
  192. package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.config.js +0 -22
  193. package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.js +0 -11
  194. package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
  195. package/styled-components/cjs/examples/plasma_web/components/Tour/Tour.config.js +0 -22
  196. package/styled-components/cjs/examples/plasma_web/components/Tour/Tour.js +0 -11
  197. package/styled-components/cjs/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
  198. package/styled-components/es/components/Tour/Tour.js +0 -232
  199. package/styled-components/es/components/Tour/Tour.styles.js +0 -22
  200. package/styled-components/es/components/Tour/Tour.tokens.js +0 -13
  201. package/styled-components/es/components/Tour/Tour.types.js +0 -1
  202. package/styled-components/es/components/Tour/index.js +0 -2
  203. package/styled-components/es/components/Tour/utils/index.js +0 -104
  204. package/styled-components/es/components/Tour/variatoins/_size/base.js +0 -2
  205. package/styled-components/es/components/Tour/variatoins/_size/tokens.json +0 -1
  206. package/styled-components/es/components/Tour/variatoins/_view/base.js +0 -2
  207. package/styled-components/es/components/Tour/variatoins/_view/tokens.json +0 -1
  208. package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.config.js +0 -16
  209. package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.js +0 -5
  210. package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
  211. package/styled-components/es/examples/plasma_web/components/Tour/Tour.config.js +0 -16
  212. package/styled-components/es/examples/plasma_web/components/Tour/Tour.js +0 -5
  213. package/styled-components/es/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
  214. package/types/components/Tour/Tour.d.ts +0 -23
  215. package/types/components/Tour/Tour.d.ts.map +0 -1
  216. package/types/components/Tour/Tour.styles.d.ts +0 -10
  217. package/types/components/Tour/Tour.styles.d.ts.map +0 -1
  218. package/types/components/Tour/Tour.tokens.d.ts +0 -14
  219. package/types/components/Tour/Tour.tokens.d.ts.map +0 -1
  220. package/types/components/Tour/Tour.types.d.ts +0 -86
  221. package/types/components/Tour/Tour.types.d.ts.map +0 -1
  222. package/types/components/Tour/index.d.ts +0 -4
  223. package/types/components/Tour/index.d.ts.map +0 -1
  224. package/types/components/Tour/utils/index.d.ts +0 -4
  225. package/types/components/Tour/utils/index.d.ts.map +0 -1
  226. package/types/components/Tour/variatoins/_size/base.d.ts +0 -2
  227. package/types/components/Tour/variatoins/_size/base.d.ts.map +0 -1
  228. package/types/components/Tour/variatoins/_view/base.d.ts +0 -2
  229. package/types/components/Tour/variatoins/_view/base.d.ts.map +0 -1
  230. /package/cjs/components/{Tour/variatoins → TextArea/variations}/_size/base_x642ct.css +0 -0
  231. /package/{cjs/components/Tour/variatoins/_view → es/components/TextArea/variations/_size}/base_x642ct.css +0 -0
package/cjs/index.js CHANGED
@@ -248,8 +248,6 @@ var PaginationDot = require('./components/PaginationDots/PaginationDot.js');
248
248
  var CodeField = require('./components/CodeField/CodeField.js');
249
249
  var CodeField_tokens = require('./components/CodeField/CodeField.tokens.js');
250
250
  var constants$1 = require('./components/CodeField/utils/constants.js');
251
- var Tour = require('./components/Tour/Tour.js');
252
- var Tour_tokens = require('./components/Tour/Tour.tokens.js');
253
251
 
254
252
 
255
253
 
@@ -709,8 +707,4 @@ exports.codeFieldTokens = CodeField_tokens.tokens;
709
707
  exports.ONLY_CHARS_PATTERN = constants$1.ONLY_CHARS_PATTERN;
710
708
  exports.ONLY_DIGITS_AND_CHARS_PATTERN = constants$1.ONLY_DIGITS_AND_CHARS_PATTERN;
711
709
  exports.ONLY_DIGITS_PATTERN = constants$1.ONLY_DIGITS_PATTERN;
712
- exports.tourConfig = Tour.tourConfig;
713
- exports.tourRoot = Tour.tourRoot;
714
- exports.tourClasses = Tour_tokens.classes;
715
- exports.tourTokens = Tour_tokens.tokens;
716
710
  //# sourceMappingURL=index.js.map
package/cjs/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -21,11 +21,11 @@ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
21
21
  function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
22
22
  function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
23
23
  var defaultFormatChars = [{
24
- str: '0',
25
- regexp: /[0-9]/
26
- }, {
27
24
  str: '*',
28
25
  regexp: /./
26
+ }, {
27
+ str: '0',
28
+ regexp: /[0-9]/
29
29
  }, {
30
30
  str: 'a',
31
31
  regexp: /[a-zA-Z]/
@@ -52,7 +52,7 @@ var innerPlaceholderUp = _TextArea2.classes.innerPlaceholderUp,
52
52
  styledPlaceholder = _TextArea2.classes.styledPlaceholder,
53
53
  styledHelpers = _TextArea2.classes.styledHelpers;
54
54
  var optionalText = 'optional';
55
- var base = /*#__PURE__*/(0, _react2.css)(_mixins.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":"AAqDgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback, useRef, MouseEventHandler, useLayoutEffect } 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    StyledOutsideHelpersWrapper,\n    StyledHiddenTextArea,\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 readOnlyCSS } from './variations/_read-only/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            leftHelperPlacement = 'inner',\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            hasRequiredIndicator = true,\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        // TODO: перенести в общую переменную для value снаружи и внутри\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n        const hiddenRef = useRef<HTMLTextAreaElement | null>(null);\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 isInnerLeftHelperPlacement = leftHelperPlacement === 'inner';\n        const leftHelperText = leftHelper || helperText;\n        const innerOptional = required ? false : optional;\n        const hasLeftHelper = Boolean(leftHelper || helperText);\n        const hasRightHelper = Boolean(rightHelper);\n        const hasHelper = !isInnerLeftHelperPlacement ? hasRightHelper : hasLeftHelper || hasRightHelper;\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        const applyAutoResize = autoResize || Boolean(clear);\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        useLayoutEffect(() => {\n            if (outerRef.current) {\n                setUncontrolledValue(outerRef.current.value);\n            }\n        }, [outerRef]);\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(applyAutoResize, outerRef, value || uncontrolledValue, minAuto, maxAuto, resize, hiddenRef);\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.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                style={{ width: helperWidth, ...style }}\n                className={cx(clearClass, hasDividerClass, hasHintClass, className)}\n                onClick={handleTextAreaFocus}\n                data-root\n                {...(hintText && {\n                    hintView,\n                    hintSize,\n                })}\n            >\n                {(hasOuterLabel || titleCaption) && (\n                    <OuterLabelWrapper width={helperWidth} 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 && hasRequiredIndicator && (\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 && hasRequiredIndicator && (\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                                        size={size}\n                                        handleHintShow={handleHintShow}\n                                        handleHintHide={handleHintHide}\n                                        handleHintClick={handleHintClick}\n                                        isInnerLabel\n                                    />\n                                </StyledHintWrapper>\n                            )}\n                        </>\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={cx(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                            required={required}\n                            height={applyAutoResize ? 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                        {applyAutoResize && (\n                            <StyledHiddenTextArea\n                                aria-hidden\n                                ref={hiddenRef}\n                                hasContentRight={Boolean(contentRight)}\n                                value={value || uncontrolledValue || ' '}\n                                defaultValue={defaultValue}\n                            />\n                        )}\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {isInnerLeftHelperPlacement && (leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper data-root>{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                {hasLeftHelper && !isInnerLeftHelperPlacement && (\n                    <StyledOutsideHelpersWrapper id={textareaHelperId}>\n                        <StyledLeftHelper>{leftHelperText}</StyledLeftHelper>\n                    </StyledOutsideHelpersWrapper>\n                )}\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        readOnly: {\n            css: readOnlyCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\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"]} */"));
55
+ var base = /*#__PURE__*/(0, _react2.css)(_mixins.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":"AAqDgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback, useRef, MouseEventHandler, useLayoutEffect } 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    StyledOutsideHelpersWrapper,\n    StyledHiddenTextArea,\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 readOnlyCSS } from './variations/_read-only/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            leftHelperPlacement = 'inner',\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            hasRequiredIndicator = true,\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        // TODO: перенести в общую переменную для value снаружи и внутри\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n        const hiddenRef = useRef<HTMLTextAreaElement | null>(null);\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 isInnerLeftHelperPlacement = leftHelperPlacement === 'inner';\n        const leftHelperText = leftHelper || helperText;\n        const innerOptional = required ? false : optional;\n        const hasLeftHelper = Boolean(leftHelper || helperText);\n        const hasRightHelper = Boolean(rightHelper);\n        const hasHelper = !isInnerLeftHelperPlacement ? hasRightHelper : hasLeftHelper || hasRightHelper;\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        const applyAutoResize = autoResize || Boolean(clear);\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        useLayoutEffect(() => {\n            if (outerRef.current) {\n                setUncontrolledValue(outerRef.current.value);\n            }\n        }, [outerRef]);\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(applyAutoResize, outerRef, value || uncontrolledValue, minAuto, maxAuto, resize, hiddenRef);\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.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                style={{ width: helperWidth, ...style }}\n                className={cx(clearClass, hasDividerClass, hasHintClass, className)}\n                onClick={handleTextAreaFocus}\n                {...(hintText && {\n                    hintView,\n                    hintSize,\n                })}\n            >\n                {(hasOuterLabel || titleCaption) && (\n                    <OuterLabelWrapper width={helperWidth} 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 && hasRequiredIndicator && (\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 && hasRequiredIndicator && (\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                                        size={size}\n                                        handleHintShow={handleHintShow}\n                                        handleHintHide={handleHintHide}\n                                        handleHintClick={handleHintClick}\n                                        isInnerLabel\n                                    />\n                                </StyledHintWrapper>\n                            )}\n                        </>\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={cx(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                            required={required}\n                            height={applyAutoResize ? 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                        {applyAutoResize && (\n                            <StyledHiddenTextArea\n                                aria-hidden\n                                ref={hiddenRef}\n                                hasContentRight={Boolean(contentRight)}\n                                value={value || uncontrolledValue || ' '}\n                                defaultValue={defaultValue}\n                            />\n                        )}\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {isInnerLeftHelperPlacement && (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                {hasLeftHelper && !isInnerLeftHelperPlacement && (\n                    <StyledOutsideHelpersWrapper id={textareaHelperId}>\n                        <StyledLeftHelper>{leftHelperText}</StyledLeftHelper>\n                    </StyledOutsideHelpersWrapper>\n                )}\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        readOnly: {\n            css: readOnlyCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\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"]} */"));
56
56
 
57
57
  // TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c
58
58
  var fallbackStatusMap = {
@@ -256,8 +256,7 @@ var textAreaRoot = exports.textAreaRoot = function textAreaRoot(Root) {
256
256
  width: helperWidth
257
257
  }, style),
258
258
  className: (0, _utils.cx)(clearClass, hasDividerClass, hasHintClass, className),
259
- onClick: handleTextAreaFocus,
260
- "data-root": true
259
+ onClick: handleTextAreaFocus
261
260
  }, hintText && {
262
261
  hintView: hintView,
263
262
  hintSize: hintSize
@@ -337,9 +336,7 @@ var textAreaRoot = exports.textAreaRoot = function textAreaRoot(Root) {
337
336
  })), hasHelper && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledHelpers, {
338
337
  className: styledHelpers,
339
338
  id: textareaHelperId
340
- }, isInnerLeftHelperPlacement && (leftHelper || helperText) && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledLeftHelper, null, leftHelper || helperText), rightHelper && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledRightHelper, {
341
- "data-root": true
342
- }, rightHelper)), placeholderLabel && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledPlaceholder, {
339
+ }, isInnerLeftHelperPlacement && (leftHelper || helperText) && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledLeftHelper, null, leftHelper || helperText), rightHelper && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledRightHelper, null, rightHelper)), placeholderLabel && /*#__PURE__*/_react["default"].createElement(_TextArea.StyledPlaceholder, {
343
340
  hasContentRight: Boolean(contentRight),
344
341
  className: styledPlaceholder,
345
342
  htmlFor: id
@@ -260,6 +260,5 @@ var tokens = exports.tokens = {
260
260
  tooltipArrowMaskImage: '--plasma-textarea__tooltip-arrow-mask-image',
261
261
  tooltipArrowHeight: '--plasma-textarea__tooltip-arrow-height',
262
262
  tooltipArrowEdgeMargin: '--plasma-textarea__tooltip-arrow-edge-margin',
263
- tooltipArrowBackground: '--plasma-textarea__tooltip-arrow-background',
264
- tourBorderRadius: '--plasma-tour__border-radius'
263
+ tooltipArrowBackground: '--plasma-textarea__tooltip-arrow-background'
265
264
  };
@@ -5,5 +5,4 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.base = void 0;
7
7
  var _react = /*#__PURE__*/require("@emotion/react");
8
- var _TextArea = /*#__PURE__*/require("../../TextArea.tokens");
9
- var base = exports.base = /*#__PURE__*/(0, _react.css)(_TextArea.tokens.tourBorderRadius, ":var(", _TextArea.tokens.borderRadius, ");;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEFyZWEvdmFyaWF0aW9ucy9fc2l6ZS9iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl1QiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi8uLi9zcmMtZW1vdGlvbi9jb21wb25lbnRzL1RleHRBcmVhL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuaW1wb3J0IHsgdG9rZW5zIH0gZnJvbSAnLi4vLi4vVGV4dEFyZWEudG9rZW5zJztcblxuZXhwb3J0IGNvbnN0IGJhc2UgPSBjc3NgXG4gICAgJHt0b2tlbnMudG91ckJvcmRlclJhZGl1c306IHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KTtcbmA7XG4iXX0= */"));
8
+ var base = exports.base = /*#__PURE__*/(0, _react.css)(";label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEFyZWEvdmFyaWF0aW9ucy9fc2l6ZS9iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV1QiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi8uLi9zcmMtZW1vdGlvbi9jb21wb25lbnRzL1RleHRBcmVhL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IGJhc2UgPSBjc3NgYDtcbiJdfQ== */"));
@@ -45,7 +45,7 @@ var base = exports.base = process.env.NODE_ENV === "production" ? {
45
45
  } : {
46
46
  name: "121o0v2-plasma-new-hope__base",
47
47
  styles: "display:block;label:plasma-new-hope__base;",
48
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextField/TextField.tsx"],"names":[],"mappings":"AAgDuB","file":"../../../../src-emotion/components/TextField/TextField.tsx","sourcesContent":["import React, { forwardRef, useEffect, useRef, useState } from 'react';\nimport type { FormEventHandler, ChangeEventHandler, KeyboardEvent, ChangeEvent, MouseEventHandler } from 'react';\nimport { safeUseId, useForkRef } from '@salutejs/plasma-core';\nimport { css } from '@emotion/react';\n\nimport type { RootProps } from '../../engines';\nimport { cx } from '../../utils';\nimport { useOutsideClick } from '../../hooks';\n\nimport type { ChipValues, TextFieldPrimitiveValue, TextFieldProps, TextFieldRootProps } from './TextField.types';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as clearCSS } from './variations/_clear/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as readOnlyCSS } from './variations/_read-only/base';\nimport { base as labelPlacementCSS } from './variations/_label-placement/base';\nimport { base as hintViewCSS } from './variations/_hint-view/base';\nimport { base as hintSizeCSS } from './variations/_hint-size/base';\nimport { base as chipViewCSS } from './variations/_chip-view/base';\nimport {\n    Input,\n    InputContainer,\n    LeftHelper,\n    Label,\n    InputWrapper,\n    InputLabelWrapper,\n    StyledContentLeft,\n    StyledContentRight,\n    StyledChips,\n    StyledTextBefore,\n    StyledTextAfter,\n    StyledIndicator,\n    StyledOptionalText,\n    InputPlaceholder,\n    OuterLabelWrapper,\n    TitleCaption,\n    StyledHintWrapper,\n    StyledIndicatorWrapper,\n    StyledContentRightWrapper,\n} from './TextField.styles';\nimport { classes } from './TextField.tokens';\nimport { TextFieldChip } from './ui';\nimport { useKeyNavigation } from './hooks';\nimport { HintComponent } from './ui/Hint/Hint';\nimport { getInputWidth } from './getInputWidth';\n\nconst optionalText = 'optional';\n\nexport const base = css`\n    /* NOTE: Webkit не применяет opacity к inline тегам */\n    display: block;\n`;\n\nconst HINT_DEFAULT_OFFSET: [number, number] = [0, 0];\n\nexport const textFieldRoot = (Root: RootProps<HTMLDivElement, TextFieldRootProps>) =>\n    forwardRef<HTMLInputElement, TextFieldProps>(\n        (\n            {\n                id,\n                className,\n                style,\n\n                // layout\n                contentLeft,\n                contentRight,\n                label,\n                labelPlacement,\n                keepPlaceholder,\n                textBefore,\n                textAfter,\n                placeholder,\n                leftHelper,\n                enumerationType = 'plain',\n                requiredPlacement = 'right',\n                hasRequiredIndicator = true,\n                titleCaption,\n                chipView = 'default',\n                chipValidator,\n\n                // hint\n                hintTrigger = 'hover',\n                hintText,\n                hintView = 'default',\n                hintSize = 'm',\n                hintTargetIcon,\n                hintTargetPlacement = 'outer',\n                hintPlacement = 'auto',\n                hintHasArrow,\n                hintOffset = HINT_DEFAULT_OFFSET,\n                hintWidth,\n                hintContentLeft,\n\n                // variations\n                view,\n                size,\n                readOnly = false,\n                disabled = false,\n                required = false,\n                clear = false,\n                optional,\n                hasDivider,\n\n                // controlled\n                value: outerValue,\n                chips: values,\n                chipType = 'default',\n\n                // events\n                onChange,\n                onChangeChips,\n                onSearch,\n                onKeyDown,\n                onFocus,\n                onBlur,\n\n                // Пропсы для внутреннего использования, не отдается наружу.\n                // @ts-ignore\n                _onEnterDisabled,\n                // @ts-ignore\n                _forceChipManipulationWithReadonly,\n\n                ...rest\n            },\n            ref,\n        ) => {\n            const contentRef = useRef<HTMLDivElement>(null);\n            const inputContainerRef = useRef<HTMLDivElement>(null);\n            const inputRef = useRef<HTMLInputElement>(null);\n            const inputForkRef = useForkRef(inputRef, ref);\n            const chipsRefs = useRef<Array<HTMLButtonElement>>([]);\n\n            const controlledRefs = { contentRef, inputRef, chipsRefs };\n\n            const [hasValue, setHasValue] = useState(\n                Boolean(outerValue) || Boolean(inputRef?.current?.value) || Boolean(rest?.defaultValue),\n            );\n            const [hasFocus, setHasFocus] = useState(false);\n\n            const [chips, setChips] = useState<Array<ChipValues>>([]);\n            const [isHintVisible, setIsHintVisible] = useState(false);\n\n            const uniqId = safeUseId();\n            const innerId = id || uniqId;\n            const labelId = safeUseId();\n            const helperTextId = safeUseId();\n\n            const isDefaultView = view === 'default' || readOnly || disabled;\n\n            const isChipEnumeration = enumerationType === 'chip';\n            const isChipsVisible = isChipEnumeration && Boolean(chips?.length);\n            const withHasChips = isChipsVisible ? classes.hasChips : undefined;\n\n            const hasLabelValue = Boolean(label);\n            const hasInnerLabel = size !== 'xs' && labelPlacement === 'inner' && !isChipsVisible && hasLabelValue;\n            const hasOuterLabel = labelPlacement === 'outer' && hasLabelValue;\n            const innerKeepPlaceholder = keepPlaceholder && labelPlacement === 'inner';\n            const hasPlaceholder = Boolean(placeholder) && (innerKeepPlaceholder || !hasInnerLabel);\n            let hasTextAfter = Boolean(textAfter);\n            let hasTextBefore = textBefore && !isChipEnumeration;\n            if (labelPlacement === 'inner') {\n                if (!hasValue && !hasPlaceholder && !hasFocus) {\n                    hasTextAfter = false;\n                    hasTextBefore = false;\n                }\n            }\n\n            const hasPlaceholderPadding = hasInnerLabel && keepPlaceholder && size !== 'xs';\n\n            const innerLabelValue = hasInnerLabel || hasOuterLabel ? label : undefined;\n            const innerLabelPlacementValue = labelPlacement === 'inner' && !hasInnerLabel ? undefined : labelPlacement;\n\n            const innerPlaceholderValue = hasPlaceholder ? placeholder : undefined;\n            const placeholderShown = Boolean(innerPlaceholderValue) && !hasValue;\n\n            const clearClass = clear ? classes.clear : undefined;\n            const hasDividerClass = hasDivider ? classes.hasDivider : undefined;\n            const hasInnerHintClass = hintText && hintTargetPlacement === 'outer' ? classes.hasHint : undefined;\n            const hasHintClass = hintText ? classes.hasHint : undefined;\n            const requiredPlacementClass = requiredPlacement === 'right' ? classes.requiredAlignRight : undefined;\n            const labelPlacementClass = innerLabelPlacementValue\n                ? classes[`${innerLabelPlacementValue}LabelPlacement` as keyof typeof classes]\n                : undefined;\n            const hasValueClass = hasValue ? classes.hasValue : undefined;\n            const keepPlaceholderClass = hasPlaceholder && placeholderShown && classes.keepPlaceholder;\n\n            const wrapperWithoutLeftContent =\n                !contentLeft && isChipsVisible && chipType === 'default' ? classes.hasEmptyContentLeft : undefined;\n            const wrapperWithoutRightContent =\n                !contentRight && isChipsVisible && chipType === 'default' ? classes.hasEmptyContentRight : undefined;\n\n            const contentRightCompensationMargin =\n                !hasOuterLabel && hintText && hintTargetPlacement === 'inner'\n                    ? classes.contentRightCompensationMargin\n                    : undefined;\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 handleInput: FormEventHandler<HTMLInputElement> = (event) => {\n                const { value } = event.target as HTMLInputElement;\n\n                setHasValue(Boolean(value));\n            };\n\n            useEffect(() => {\n                if (hasTextAfter && inputRef.current) {\n                    const textWidth = getInputWidth(inputRef.current, inputContainerRef.current);\n                    inputRef.current.style.width = `${textWidth}px`;\n                } else {\n                    inputRef.current?.style.removeProperty('width');\n                }\n            }, [hasTextAfter]);\n\n            const handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n                setHasFocus(true);\n                onFocus?.(event);\n            };\n\n            const handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n                setHasFocus(false);\n                onBlur?.(event);\n            };\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            const handleChange: ChangeEventHandler<HTMLInputElement> = (event) => {\n                if (disabled || readOnly) {\n                    return;\n                }\n\n                const { maxLength, value } = event.target;\n\n                if (maxLength !== -1 && value.length > maxLength) {\n                    return;\n                }\n\n                onChange?.(event);\n\n                if (hasTextAfter) {\n                    const textWidth = getInputWidth(event.currentTarget, inputContainerRef.current);\n                    event.currentTarget.style.width = `${textWidth}px`;\n                }\n            };\n\n            const updateChips = (newChips: Array<ChipValues>, newValues: Array<TextFieldPrimitiveValue>) => {\n                setChips(newChips);\n                onChangeChips?.(newValues);\n            };\n\n            const { handleInputKeydown, handleChipKeyDown, onChipClear, handleContentKeyDown } = useKeyNavigation({\n                controlledRefs,\n                disabled,\n                readOnly,\n                chips,\n                enumerationType,\n                updateChips,\n                onSearch,\n                onChange,\n                onEnterDisabled: _onEnterDisabled,\n            });\n\n            const onChipClick = (event: React.MouseEvent<HTMLButtonElement>) => event.stopPropagation();\n\n            const handleInputFocus = () => {\n                if (readOnly || disabled || !inputRef?.current) {\n                    return;\n                }\n\n                inputRef.current.scrollTo({\n                    top: 0,\n                    left: inputRef.current.offsetLeft,\n                    behavior: 'smooth',\n                });\n\n                inputRef.current.focus();\n            };\n\n            const getRef = (element: HTMLButtonElement | null, index: number) => {\n                if (element && chipsRefs?.current) {\n                    chipsRefs.current[index] = element;\n                }\n            };\n\n            const handleOnKeyDown = (event: ChangeEvent<HTMLInputElement> & KeyboardEvent<HTMLInputElement>) => {\n                handleInputKeydown(event);\n\n                if (onKeyDown) {\n                    onKeyDown(event);\n                }\n            };\n\n            useEffect(() => {\n                if (!isChipEnumeration && !values?.length) {\n                    return;\n                }\n\n                const newChips =\n                    values?.map((value, index) => ({\n                        id: `${index}_${value}`,\n                        text: value,\n                    })) || [];\n\n                setChips(newChips);\n            }, [isChipEnumeration, values]);\n\n            useEffect(() => {\n                setHasValue(Boolean(rest?.defaultValue));\n            }, [rest.defaultValue]);\n\n            useEffect(() => {\n                setHasValue(Boolean(outerValue) || Boolean(inputRef?.current?.value));\n            }, [outerValue, inputRef?.current?.value]);\n\n            const innerOptional = Boolean(required ? false : optional);\n            const hasPlaceholderOptional = innerOptional && !innerLabelValue && !hasOuterLabel;\n            const optionalTextNode = innerOptional ? (\n                <StyledOptionalText>\n                    {Boolean(hasPlaceholderOptional ? innerPlaceholderValue : innerLabelValue) && '\\xa0'}\n                    {optionalText}\n                </StyledOptionalText>\n            ) : null;\n\n            const classTextEllipsis =\n                // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n                // @ts-ignore\n                // eslint-disable-next-line no-underscore-dangle\n                !(rest as any)._textEllipsisDisable && !textAfter ? classes.inputTextEllipsis : undefined;\n\n            return (\n                <Root\n                    view={view}\n                    size={size}\n                    disabled={disabled}\n                    readOnly={!disabled && readOnly}\n                    labelPlacement={innerLabelPlacementValue}\n                    onClick={handleInputFocus}\n                    data-root\n                    className={cx(\n                        labelPlacementClass,\n                        clearClass,\n                        hasDividerClass,\n                        hasInnerHintClass,\n                        classes.textFieldGroupItem,\n                        className,\n                    )}\n                    style={style}\n                    {...(hintText && { hintView, hintSize })}\n                >\n                    {(hasOuterLabel || titleCaption) && (\n                        <OuterLabelWrapper isInnerLabel={labelPlacement === 'inner'}>\n                            {hasOuterLabel && (\n                                <StyledIndicatorWrapper>\n                                    <Label id={labelId} htmlFor={id}>\n                                        {innerLabelValue}\n                                    </Label>\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 && hasRequiredIndicator && (\n                                        <StyledIndicator\n                                            className={cx(\n                                                classes.outerLabelPlacement,\n                                                requiredPlacementClass,\n                                                hasHintClass,\n                                            )}\n                                        />\n                                    )}\n                                    {optionalTextNode}\n                                </StyledIndicatorWrapper>\n                            )}\n                            {titleCaption && <TitleCaption data-root>{titleCaption}</TitleCaption>}\n                        </OuterLabelWrapper>\n                    )}\n                    <InputWrapper\n                        // Ref для внутреннего использования. Не отдается наружу.\n                        ref={(rest as any).inputWrapperRef}\n                        // TODO: #1544, и после убрать classes.inputWrapper\n                        className={cx(\n                            withHasChips,\n                            wrapperWithoutLeftContent,\n                            wrapperWithoutRightContent,\n                            classes.inputWrapper,\n                        )}\n                    >\n                        {!hasOuterLabel && (\n                            <>\n                                {required && hasRequiredIndicator && (\n                                    <StyledIndicator\n                                        className={cx(classes.innerLabelPlacement, requiredPlacementClass)}\n                                    />\n                                )}\n                                {hintText && hintTargetPlacement === 'outer' && (\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                                            size={size}\n                                            handleHintShow={handleHintShow}\n                                            handleHintHide={handleHintHide}\n                                            handleHintClick={handleHintClick}\n                                            isInnerLabel\n                                        />\n                                    </StyledHintWrapper>\n                                )}\n                            </>\n                        )}\n                        {contentLeft && (\n                            <StyledContentLeft data-root isClear={clear} isDefaultView={isDefaultView}>\n                                {contentLeft}\n                            </StyledContentLeft>\n                        )}\n                        <InputLabelWrapper\n                            tabIndex={-1}\n                            ref={contentRef}\n                            onKeyDown={handleContentKeyDown}\n                            className={withHasChips}\n                        >\n                            {Boolean(textBefore && isChipEnumeration) && (\n                                <StyledTextBefore>{textBefore}</StyledTextBefore>\n                            )}\n                            {isChipEnumeration && Boolean(chips?.length) && (\n                                <StyledChips className={classes.chipsWrapper}>\n                                    {chips?.map(({ id: chipId, text }, index) => {\n                                        const validationView = chipValidator?.(String(text));\n                                        const resView = validationView?.view || chipView;\n\n                                        return (\n                                            <TextFieldChip\n                                                id={chipId}\n                                                ref={(element) => getRef(element, index)}\n                                                key={`${chipId}_${index}`}\n                                                disabled={disabled}\n                                                readOnly={readOnly}\n                                                value={text}\n                                                text={text}\n                                                onKeyDown={(event) => handleChipKeyDown(event, chipId, index)}\n                                                onClear={() => onChipClear(chipId, index)}\n                                                onClick={onChipClick}\n                                                chipType={chipType}\n                                                view={resView}\n                                                rootWrapper={Root}\n                                                // TODO: #1547\n                                                // @ts-ignore\n                                                _forceChipManipulationWithReadonly={_forceChipManipulationWithReadonly}\n                                            />\n                                        );\n                                    })}\n                                </StyledChips>\n                            )}\n                            <InputContainer ref={inputContainerRef} hasDynamicWidth={hasTextAfter}>\n                                {hasTextBefore && <StyledTextBefore>{textBefore}</StyledTextBefore>}\n                                <Input\n                                    ref={inputForkRef}\n                                    id={innerId}\n                                    value={outerValue}\n                                    required={enumerationType === 'chip' ? chips.length === 0 && required : required}\n                                    aria-labelledby={labelId}\n                                    aria-describedby={helperTextId}\n                                    placeholder={innerPlaceholderValue}\n                                    className={cx(\n                                        hasValueClass,\n                                        keepPlaceholderClass,\n                                        classTextEllipsis,\n                                        readOnly && classes.readOnlyInput,\n                                    )}\n                                    disabled={disabled}\n                                    readOnly={!disabled && readOnly}\n                                    onInput={handleInput}\n                                    onChange={handleChange}\n                                    onKeyDown={handleOnKeyDown}\n                                    onFocus={handleFocus}\n                                    onBlur={handleBlur}\n                                    {...rest}\n                                />\n                                {hasInnerLabel && (\n                                    <Label data-root id={labelId} htmlFor={innerId}>\n                                        {innerLabelValue}\n                                        {optionalTextNode}\n                                    </Label>\n                                )}\n                                {placeholderShown && !hasValue && (\n                                    <InputPlaceholder hasPadding={hasPlaceholderPadding}>\n                                        {hasTextBefore && <StyledTextBefore isHidden>{textBefore}</StyledTextBefore>}\n                                        {innerPlaceholderValue}\n                                        {hasPlaceholderOptional && optionalTextNode}\n                                    </InputPlaceholder>\n                                )}\n                                {hasTextAfter && <StyledTextAfter>{textAfter}</StyledTextAfter>}\n                            </InputContainer>\n                        </InputLabelWrapper>\n                        <StyledContentRightWrapper className={cx(contentRightCompensationMargin)}>\n                            {contentRight && <StyledContentRight data-root>{contentRight}</StyledContentRight>}\n\n                            {!hasOuterLabel && hintText && hintTargetPlacement === 'inner' && (\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                                    size={size}\n                                    handleHintShow={handleHintShow}\n                                    handleHintHide={handleHintHide}\n                                    handleHintClick={handleHintClick}\n                                    isInnerLabel\n                                />\n                            )}\n                        </StyledContentRightWrapper>\n                    </InputWrapper>\n                    {leftHelper && (\n                        <LeftHelper data-root id={helperTextId}>\n                            {leftHelper}\n                        </LeftHelper>\n                    )}\n                </Root>\n            );\n        },\n    );\n\nexport const textFieldConfig = {\n    name: 'TextField',\n    tag: 'div',\n    layout: textFieldRoot,\n    base,\n    variations: {\n        view: {\n            css: viewCSS,\n        },\n        size: {\n            css: sizeCSS,\n        },\n        clear: {\n            css: clearCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        readOnly: {\n            css: readOnlyCSS,\n            attrs: true,\n        },\n        labelPlacement: {\n            css: labelPlacementCSS,\n        },\n        hintView: {\n            css: hintViewCSS,\n        },\n        hintSize: {\n            css: hintSizeCSS,\n        },\n        chipView: {\n            css: chipViewCSS,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'default',\n    },\n};\n"]} */",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextField/TextField.tsx"],"names":[],"mappings":"AAgDuB","file":"../../../../src-emotion/components/TextField/TextField.tsx","sourcesContent":["import React, { forwardRef, useEffect, useRef, useState } from 'react';\nimport type { FormEventHandler, ChangeEventHandler, KeyboardEvent, ChangeEvent, MouseEventHandler } from 'react';\nimport { safeUseId, useForkRef } from '@salutejs/plasma-core';\nimport { css } from '@emotion/react';\n\nimport type { RootProps } from '../../engines';\nimport { cx } from '../../utils';\nimport { useOutsideClick } from '../../hooks';\n\nimport type { ChipValues, TextFieldPrimitiveValue, TextFieldProps, TextFieldRootProps } from './TextField.types';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as clearCSS } from './variations/_clear/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as readOnlyCSS } from './variations/_read-only/base';\nimport { base as labelPlacementCSS } from './variations/_label-placement/base';\nimport { base as hintViewCSS } from './variations/_hint-view/base';\nimport { base as hintSizeCSS } from './variations/_hint-size/base';\nimport { base as chipViewCSS } from './variations/_chip-view/base';\nimport {\n    Input,\n    InputContainer,\n    LeftHelper,\n    Label,\n    InputWrapper,\n    InputLabelWrapper,\n    StyledContentLeft,\n    StyledContentRight,\n    StyledChips,\n    StyledTextBefore,\n    StyledTextAfter,\n    StyledIndicator,\n    StyledOptionalText,\n    InputPlaceholder,\n    OuterLabelWrapper,\n    TitleCaption,\n    StyledHintWrapper,\n    StyledIndicatorWrapper,\n    StyledContentRightWrapper,\n} from './TextField.styles';\nimport { classes } from './TextField.tokens';\nimport { TextFieldChip } from './ui';\nimport { useKeyNavigation } from './hooks';\nimport { HintComponent } from './ui/Hint/Hint';\nimport { getInputWidth } from './getInputWidth';\n\nconst optionalText = 'optional';\n\nexport const base = css`\n    /* NOTE: Webkit не применяет opacity к inline тегам */\n    display: block;\n`;\n\nconst HINT_DEFAULT_OFFSET: [number, number] = [0, 0];\n\nexport const textFieldRoot = (Root: RootProps<HTMLDivElement, TextFieldRootProps>) =>\n    forwardRef<HTMLInputElement, TextFieldProps>(\n        (\n            {\n                id,\n                className,\n                style,\n\n                // layout\n                contentLeft,\n                contentRight,\n                label,\n                labelPlacement,\n                keepPlaceholder,\n                textBefore,\n                textAfter,\n                placeholder,\n                leftHelper,\n                enumerationType = 'plain',\n                requiredPlacement = 'right',\n                hasRequiredIndicator = true,\n                titleCaption,\n                chipView = 'default',\n                chipValidator,\n\n                // hint\n                hintTrigger = 'hover',\n                hintText,\n                hintView = 'default',\n                hintSize = 'm',\n                hintTargetIcon,\n                hintTargetPlacement = 'outer',\n                hintPlacement = 'auto',\n                hintHasArrow,\n                hintOffset = HINT_DEFAULT_OFFSET,\n                hintWidth,\n                hintContentLeft,\n\n                // variations\n                view,\n                size,\n                readOnly = false,\n                disabled = false,\n                required = false,\n                clear = false,\n                optional,\n                hasDivider,\n\n                // controlled\n                value: outerValue,\n                chips: values,\n                chipType = 'default',\n\n                // events\n                onChange,\n                onChangeChips,\n                onSearch,\n                onKeyDown,\n                onFocus,\n                onBlur,\n\n                // Пропсы для внутреннего использования, не отдается наружу.\n                // @ts-ignore\n                _onEnterDisabled,\n                // @ts-ignore\n                _forceChipManipulationWithReadonly,\n\n                ...rest\n            },\n            ref,\n        ) => {\n            const contentRef = useRef<HTMLDivElement>(null);\n            const inputContainerRef = useRef<HTMLDivElement>(null);\n            const inputRef = useRef<HTMLInputElement>(null);\n            const inputForkRef = useForkRef(inputRef, ref);\n            const chipsRefs = useRef<Array<HTMLButtonElement>>([]);\n\n            const controlledRefs = { contentRef, inputRef, chipsRefs };\n\n            const [hasValue, setHasValue] = useState(\n                Boolean(outerValue) || Boolean(inputRef?.current?.value) || Boolean(rest?.defaultValue),\n            );\n            const [hasFocus, setHasFocus] = useState(false);\n\n            const [chips, setChips] = useState<Array<ChipValues>>([]);\n            const [isHintVisible, setIsHintVisible] = useState(false);\n\n            const uniqId = safeUseId();\n            const innerId = id || uniqId;\n            const labelId = safeUseId();\n            const helperTextId = safeUseId();\n\n            const isDefaultView = view === 'default' || readOnly || disabled;\n\n            const isChipEnumeration = enumerationType === 'chip';\n            const isChipsVisible = isChipEnumeration && Boolean(chips?.length);\n            const withHasChips = isChipsVisible ? classes.hasChips : undefined;\n\n            const hasLabelValue = Boolean(label);\n            const hasInnerLabel = size !== 'xs' && labelPlacement === 'inner' && !isChipsVisible && hasLabelValue;\n            const hasOuterLabel = labelPlacement === 'outer' && hasLabelValue;\n            const innerKeepPlaceholder = keepPlaceholder && labelPlacement === 'inner';\n            const hasPlaceholder = Boolean(placeholder) && (innerKeepPlaceholder || !hasInnerLabel);\n            let hasTextAfter = Boolean(textAfter);\n            let hasTextBefore = textBefore && !isChipEnumeration;\n            if (labelPlacement === 'inner') {\n                if (!hasValue && !hasPlaceholder && !hasFocus) {\n                    hasTextAfter = false;\n                    hasTextBefore = false;\n                }\n            }\n\n            const hasPlaceholderPadding = hasInnerLabel && keepPlaceholder && size !== 'xs';\n\n            const innerLabelValue = hasInnerLabel || hasOuterLabel ? label : undefined;\n            const innerLabelPlacementValue = labelPlacement === 'inner' && !hasInnerLabel ? undefined : labelPlacement;\n\n            const innerPlaceholderValue = hasPlaceholder ? placeholder : undefined;\n            const placeholderShown = Boolean(innerPlaceholderValue) && !hasValue;\n\n            const clearClass = clear ? classes.clear : undefined;\n            const hasDividerClass = hasDivider ? classes.hasDivider : undefined;\n            const hasInnerHintClass = hintText && hintTargetPlacement === 'outer' ? classes.hasHint : undefined;\n            const hasHintClass = hintText ? classes.hasHint : undefined;\n            const requiredPlacementClass = requiredPlacement === 'right' ? classes.requiredAlignRight : undefined;\n            const labelPlacementClass = innerLabelPlacementValue\n                ? classes[`${innerLabelPlacementValue}LabelPlacement` as keyof typeof classes]\n                : undefined;\n            const hasValueClass = hasValue ? classes.hasValue : undefined;\n            const keepPlaceholderClass = hasPlaceholder && placeholderShown && classes.keepPlaceholder;\n\n            const wrapperWithoutLeftContent =\n                !contentLeft && isChipsVisible && chipType === 'default' ? classes.hasEmptyContentLeft : undefined;\n            const wrapperWithoutRightContent =\n                !contentRight && isChipsVisible && chipType === 'default' ? classes.hasEmptyContentRight : undefined;\n\n            const contentRightCompensationMargin =\n                !hasOuterLabel && hintText && hintTargetPlacement === 'inner'\n                    ? classes.contentRightCompensationMargin\n                    : undefined;\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 handleInput: FormEventHandler<HTMLInputElement> = (event) => {\n                const { value } = event.target as HTMLInputElement;\n\n                setHasValue(Boolean(value));\n            };\n\n            useEffect(() => {\n                if (hasTextAfter && inputRef.current) {\n                    const textWidth = getInputWidth(inputRef.current, inputContainerRef.current);\n                    inputRef.current.style.width = `${textWidth}px`;\n                } else {\n                    inputRef.current?.style.removeProperty('width');\n                }\n            }, [hasTextAfter]);\n\n            const handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n                setHasFocus(true);\n                onFocus?.(event);\n            };\n\n            const handleBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n                setHasFocus(false);\n                onBlur?.(event);\n            };\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            const handleChange: ChangeEventHandler<HTMLInputElement> = (event) => {\n                if (disabled || readOnly) {\n                    return;\n                }\n\n                const { maxLength, value } = event.target;\n\n                if (maxLength !== -1 && value.length > maxLength) {\n                    return;\n                }\n\n                onChange?.(event);\n\n                if (hasTextAfter) {\n                    const textWidth = getInputWidth(event.currentTarget, inputContainerRef.current);\n                    event.currentTarget.style.width = `${textWidth}px`;\n                }\n            };\n\n            const updateChips = (newChips: Array<ChipValues>, newValues: Array<TextFieldPrimitiveValue>) => {\n                setChips(newChips);\n                onChangeChips?.(newValues);\n            };\n\n            const { handleInputKeydown, handleChipKeyDown, onChipClear, handleContentKeyDown } = useKeyNavigation({\n                controlledRefs,\n                disabled,\n                readOnly,\n                chips,\n                enumerationType,\n                updateChips,\n                onSearch,\n                onChange,\n                onEnterDisabled: _onEnterDisabled,\n            });\n\n            const onChipClick = (event: React.MouseEvent<HTMLButtonElement>) => event.stopPropagation();\n\n            const handleInputFocus = () => {\n                if (readOnly || disabled || !inputRef?.current) {\n                    return;\n                }\n\n                inputRef.current.scrollTo({\n                    top: 0,\n                    left: inputRef.current.offsetLeft,\n                    behavior: 'smooth',\n                });\n\n                inputRef.current.focus();\n            };\n\n            const getRef = (element: HTMLButtonElement | null, index: number) => {\n                if (element && chipsRefs?.current) {\n                    chipsRefs.current[index] = element;\n                }\n            };\n\n            const handleOnKeyDown = (event: ChangeEvent<HTMLInputElement> & KeyboardEvent<HTMLInputElement>) => {\n                handleInputKeydown(event);\n\n                if (onKeyDown) {\n                    onKeyDown(event);\n                }\n            };\n\n            useEffect(() => {\n                if (!isChipEnumeration && !values?.length) {\n                    return;\n                }\n\n                const newChips =\n                    values?.map((value, index) => ({\n                        id: `${index}_${value}`,\n                        text: value,\n                    })) || [];\n\n                setChips(newChips);\n            }, [isChipEnumeration, values]);\n\n            useEffect(() => {\n                setHasValue(Boolean(rest?.defaultValue));\n            }, [rest.defaultValue]);\n\n            useEffect(() => {\n                setHasValue(Boolean(outerValue) || Boolean(inputRef?.current?.value));\n            }, [outerValue, inputRef?.current?.value]);\n\n            const innerOptional = Boolean(required ? false : optional);\n            const hasPlaceholderOptional = innerOptional && !innerLabelValue && !hasOuterLabel;\n            const optionalTextNode = innerOptional ? (\n                <StyledOptionalText>\n                    {Boolean(hasPlaceholderOptional ? innerPlaceholderValue : innerLabelValue) && '\\xa0'}\n                    {optionalText}\n                </StyledOptionalText>\n            ) : null;\n\n            const classTextEllipsis =\n                // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n                // @ts-ignore\n                // eslint-disable-next-line no-underscore-dangle\n                !(rest as any)._textEllipsisDisable && !textAfter ? classes.inputTextEllipsis : undefined;\n\n            return (\n                <Root\n                    view={view}\n                    size={size}\n                    disabled={disabled}\n                    readOnly={!disabled && readOnly}\n                    labelPlacement={innerLabelPlacementValue}\n                    onClick={handleInputFocus}\n                    className={cx(\n                        labelPlacementClass,\n                        clearClass,\n                        hasDividerClass,\n                        hasInnerHintClass,\n                        classes.textFieldGroupItem,\n                        className,\n                    )}\n                    style={style}\n                    {...(hintText && { hintView, hintSize })}\n                >\n                    {(hasOuterLabel || titleCaption) && (\n                        <OuterLabelWrapper isInnerLabel={labelPlacement === 'inner'}>\n                            {hasOuterLabel && (\n                                <StyledIndicatorWrapper>\n                                    <Label id={labelId} htmlFor={id}>\n                                        {innerLabelValue}\n                                    </Label>\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 && hasRequiredIndicator && (\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                    <InputWrapper\n                        // Ref для внутреннего использования. Не отдается наружу.\n                        ref={(rest as any).inputWrapperRef}\n                        // TODO: #1544, и после убрать classes.inputWrapper\n                        className={cx(\n                            withHasChips,\n                            wrapperWithoutLeftContent,\n                            wrapperWithoutRightContent,\n                            classes.inputWrapper,\n                        )}\n                    >\n                        {!hasOuterLabel && (\n                            <>\n                                {required && hasRequiredIndicator && (\n                                    <StyledIndicator\n                                        className={cx(classes.innerLabelPlacement, requiredPlacementClass)}\n                                    />\n                                )}\n                                {hintText && hintTargetPlacement === 'outer' && (\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                                            size={size}\n                                            handleHintShow={handleHintShow}\n                                            handleHintHide={handleHintHide}\n                                            handleHintClick={handleHintClick}\n                                            isInnerLabel\n                                        />\n                                    </StyledHintWrapper>\n                                )}\n                            </>\n                        )}\n                        {contentLeft && (\n                            <StyledContentLeft isClear={clear} isDefaultView={isDefaultView}>\n                                {contentLeft}\n                            </StyledContentLeft>\n                        )}\n                        <InputLabelWrapper\n                            tabIndex={-1}\n                            ref={contentRef}\n                            onKeyDown={handleContentKeyDown}\n                            className={withHasChips}\n                        >\n                            {Boolean(textBefore && isChipEnumeration) && (\n                                <StyledTextBefore>{textBefore}</StyledTextBefore>\n                            )}\n                            {isChipEnumeration && Boolean(chips?.length) && (\n                                <StyledChips className={classes.chipsWrapper}>\n                                    {chips?.map(({ id: chipId, text }, index) => {\n                                        const validationView = chipValidator?.(String(text));\n                                        const resView = validationView?.view || chipView;\n\n                                        return (\n                                            <TextFieldChip\n                                                id={chipId}\n                                                ref={(element) => getRef(element, index)}\n                                                key={`${chipId}_${index}`}\n                                                disabled={disabled}\n                                                readOnly={readOnly}\n                                                value={text}\n                                                text={text}\n                                                onKeyDown={(event) => handleChipKeyDown(event, chipId, index)}\n                                                onClear={() => onChipClear(chipId, index)}\n                                                onClick={onChipClick}\n                                                chipType={chipType}\n                                                view={resView}\n                                                rootWrapper={Root}\n                                                // TODO: #1547\n                                                // @ts-ignore\n                                                _forceChipManipulationWithReadonly={_forceChipManipulationWithReadonly}\n                                            />\n                                        );\n                                    })}\n                                </StyledChips>\n                            )}\n                            <InputContainer ref={inputContainerRef} hasDynamicWidth={hasTextAfter}>\n                                {hasTextBefore && <StyledTextBefore>{textBefore}</StyledTextBefore>}\n                                <Input\n                                    ref={inputForkRef}\n                                    id={innerId}\n                                    value={outerValue}\n                                    required={enumerationType === 'chip' ? chips.length === 0 && required : required}\n                                    aria-labelledby={labelId}\n                                    aria-describedby={helperTextId}\n                                    placeholder={innerPlaceholderValue}\n                                    className={cx(\n                                        hasValueClass,\n                                        keepPlaceholderClass,\n                                        classTextEllipsis,\n                                        readOnly && classes.readOnlyInput,\n                                    )}\n                                    disabled={disabled}\n                                    readOnly={!disabled && readOnly}\n                                    onInput={handleInput}\n                                    onChange={handleChange}\n                                    onKeyDown={handleOnKeyDown}\n                                    onFocus={handleFocus}\n                                    onBlur={handleBlur}\n                                    {...rest}\n                                />\n                                {hasInnerLabel && (\n                                    <Label id={labelId} htmlFor={innerId}>\n                                        {innerLabelValue}\n                                        {optionalTextNode}\n                                    </Label>\n                                )}\n                                {placeholderShown && !hasValue && (\n                                    <InputPlaceholder hasPadding={hasPlaceholderPadding}>\n                                        {hasTextBefore && <StyledTextBefore isHidden>{textBefore}</StyledTextBefore>}\n                                        {innerPlaceholderValue}\n                                        {hasPlaceholderOptional && optionalTextNode}\n                                    </InputPlaceholder>\n                                )}\n                                {hasTextAfter && <StyledTextAfter>{textAfter}</StyledTextAfter>}\n                            </InputContainer>\n                        </InputLabelWrapper>\n                        <StyledContentRightWrapper className={cx(contentRightCompensationMargin)}>\n                            {contentRight && <StyledContentRight>{contentRight}</StyledContentRight>}\n\n                            {!hasOuterLabel && hintText && hintTargetPlacement === 'inner' && (\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                                    size={size}\n                                    handleHintShow={handleHintShow}\n                                    handleHintHide={handleHintHide}\n                                    handleHintClick={handleHintClick}\n                                    isInnerLabel\n                                />\n                            )}\n                        </StyledContentRightWrapper>\n                    </InputWrapper>\n                    {leftHelper && <LeftHelper id={helperTextId}>{leftHelper}</LeftHelper>}\n                </Root>\n            );\n        },\n    );\n\nexport const textFieldConfig = {\n    name: 'TextField',\n    tag: 'div',\n    layout: textFieldRoot,\n    base,\n    variations: {\n        view: {\n            css: viewCSS,\n        },\n        size: {\n            css: sizeCSS,\n        },\n        clear: {\n            css: clearCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        readOnly: {\n            css: readOnlyCSS,\n            attrs: true,\n        },\n        labelPlacement: {\n            css: labelPlacementCSS,\n        },\n        hintView: {\n            css: hintViewCSS,\n        },\n        hintSize: {\n            css: hintSizeCSS,\n        },\n        chipView: {\n            css: chipViewCSS,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'default',\n    },\n};\n"]} */",
49
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
50
  };
51
51
  var HINT_DEFAULT_OFFSET = [0, 0];
@@ -318,7 +318,6 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
318
318
  readOnly: !disabled && readOnly,
319
319
  labelPlacement: innerLabelPlacementValue,
320
320
  onClick: handleInputFocus,
321
- "data-root": true,
322
321
  className: (0, _utils.cx)(labelPlacementClass, clearClass, hasDividerClass, hasInnerHintClass, _TextField2.classes.textFieldGroupItem, className),
323
322
  style: style
324
323
  }, hintText && {
@@ -345,9 +344,7 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
345
344
  handleHintClick: handleHintClick
346
345
  })), required && hasRequiredIndicator && /*#__PURE__*/_react["default"].createElement(_TextField.StyledIndicator, {
347
346
  className: (0, _utils.cx)(_TextField2.classes.outerLabelPlacement, requiredPlacementClass, hasHintClass)
348
- }), optionalTextNode), titleCaption && /*#__PURE__*/_react["default"].createElement(_TextField.TitleCaption, {
349
- "data-root": true
350
- }, titleCaption)), /*#__PURE__*/_react["default"].createElement(_TextField.InputWrapper
347
+ }), optionalTextNode), titleCaption && /*#__PURE__*/_react["default"].createElement(_TextField.TitleCaption, null, titleCaption)), /*#__PURE__*/_react["default"].createElement(_TextField.InputWrapper
351
348
  // Ref для внутреннего использования. Не отдается наружу.
352
349
  , {
353
350
  ref: rest.inputWrapperRef
@@ -375,7 +372,6 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
375
372
  handleHintClick: handleHintClick,
376
373
  isInnerLabel: true
377
374
  }))), contentLeft && /*#__PURE__*/_react["default"].createElement(_TextField.StyledContentLeft, {
378
- "data-root": true,
379
375
  isClear: clear,
380
376
  isDefaultView: isDefaultView
381
377
  }, contentLeft), /*#__PURE__*/_react["default"].createElement(_TextField.InputLabelWrapper, {
@@ -435,7 +431,6 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
435
431
  onFocus: handleFocus,
436
432
  onBlur: handleBlur
437
433
  }, rest)), hasInnerLabel && /*#__PURE__*/_react["default"].createElement(_TextField.Label, {
438
- "data-root": true,
439
434
  id: labelId,
440
435
  htmlFor: innerId
441
436
  }, innerLabelValue, optionalTextNode), placeholderShown && !hasValue && /*#__PURE__*/_react["default"].createElement(_TextField.InputPlaceholder, {
@@ -444,9 +439,7 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
444
439
  isHidden: true
445
440
  }, textBefore), innerPlaceholderValue, hasPlaceholderOptional && optionalTextNode), hasTextAfter && /*#__PURE__*/_react["default"].createElement(_TextField.StyledTextAfter, null, textAfter))), /*#__PURE__*/_react["default"].createElement(_TextField.StyledContentRightWrapper, {
446
441
  className: (0, _utils.cx)(contentRightCompensationMargin)
447
- }, contentRight && /*#__PURE__*/_react["default"].createElement(_TextField.StyledContentRight, {
448
- "data-root": true
449
- }, contentRight), !hasOuterLabel && hintText && hintTargetPlacement === 'inner' && /*#__PURE__*/_react["default"].createElement(_Hint.HintComponent, {
442
+ }, contentRight && /*#__PURE__*/_react["default"].createElement(_TextField.StyledContentRight, null, contentRight), !hasOuterLabel && hintText && hintTargetPlacement === 'inner' && /*#__PURE__*/_react["default"].createElement(_Hint.HintComponent, {
450
443
  ref: hintForkRef,
451
444
  hintText: hintText,
452
445
  hintTrigger: hintTrigger,
@@ -463,7 +456,6 @@ var textFieldRoot = exports.textFieldRoot = function textFieldRoot(Root) {
463
456
  handleHintClick: handleHintClick,
464
457
  isInnerLabel: true
465
458
  }))), leftHelper && /*#__PURE__*/_react["default"].createElement(_TextField.LeftHelper, {
466
- "data-root": true,
467
459
  id: helperTextId
468
460
  }, leftHelper));
469
461
  });
@@ -193,6 +193,5 @@ var tokens = exports.tokens = {
193
193
  indicatorLabelPlacementHintOuterRight: '--plasma-textfield__indicator-hint-placement-outer-right',
194
194
  clearIndicatorLabelPlacementInner: '--plasma-textfield__clear-indicator-placement-inner',
195
195
  clearIndicatorLabelPlacementInnerRight: '--plasma-textfield__clear-indicator-placement-inner-right',
196
- clearIndicatorHintInnerRight: '--plasma-textfield__clear-indicator-hint-placement-inner-right',
197
- tourBorderRadius: '--plasma-textfield-tour-border-radius'
196
+ clearIndicatorHintInnerRight: '--plasma-textfield__clear-indicator-hint-placement-inner-right'
198
197
  };
@@ -7,4 +7,4 @@ exports.base = void 0;
7
7
  var _react = /*#__PURE__*/require("@emotion/react");
8
8
  var _TextField = /*#__PURE__*/require("../../TextField.tokens");
9
9
  var _TextField2 = /*#__PURE__*/require("../../TextField.styles");
10
- var base = exports.base = /*#__PURE__*/(0, _react.css)(_TextField.tokens.tourBorderRadius, ":var(", _TextField.tokens.borderRadius, ");", _TextField2.Input, "{width:100%;font:inherit;letter-spacing:inherit;line-height:inherit;}", _TextField2.InputContainer, "{width:100%;font-family:var(", _TextField.tokens.fontFamily, ");font-size:var(", _TextField.tokens.fontSize, ");font-style:var(", _TextField.tokens.fontStyle, ");font-weight:var(", _TextField.tokens.fontWeight, ");letter-spacing:var(", _TextField.tokens.letterSpacing, ");line-height:var(", _TextField.tokens.lineHeight, ");}", _TextField2.InputWrapper, "{height:var(", _TextField.tokens.height, ");border-radius:var(", _TextField.tokens.borderRadius, ");padding:var(", _TextField.tokens.padding, ");&.", _TextField.classes.hasChips, "{padding-top:var(", _TextField.tokens.paddingWithChips, ");padding-bottom:var(", _TextField.tokens.paddingWithChips, ");}&.", _TextField.classes.hasEmptyContentLeft, "{padding-left:var(", _TextField.tokens.paddingWithChips, ");}&.", _TextField.classes.hasEmptyContentRight, "{padding-right:var(", _TextField.tokens.paddingWithChips, ");}}", _TextField2.Label, ",&:not(.", _TextField.classes.innerLabelPlacement, ") ", _TextField2.StyledOptionalText, "{font-family:var(", _TextField.tokens.labelFontFamily, ");font-size:var(", _TextField.tokens.labelFontSize, ");font-style:var(", _TextField.tokens.labelFontStyle, ");font-weight:var(", _TextField.tokens.labelFontWeight, ");letter-spacing:var(", _TextField.tokens.labelLetterSpacing, ");line-height:var(", _TextField.tokens.labelLineHeight, ");}", _TextField2.StyledHintWrapper, "{margin:var(", _TextField.tokens.hintMargin, ");width:var(", _TextField.tokens.hintTargetSize, ");height:var(", _TextField.tokens.hintTargetSize, ");}", _TextField2.HintTargetWrapper, "{width:var(", _TextField.tokens.hintTargetSize, ");height:var(", _TextField.tokens.hintTargetSize, ");}", _TextField2.TitleCaption, "{font-family:var(", _TextField.tokens.titleCaptionFontFamily, ");font-size:var(", _TextField.tokens.titleCaptionFontSize, ");font-style:var(", _TextField.tokens.titleCaptionFontStyle, ");font-weight:var(", _TextField.tokens.titleCaptionFontWeight, ");letter-spacing:var(", _TextField.tokens.titleCaptionLetterSpacing, ");line-height:var(", _TextField.tokens.titleCaptionLineHeight, ");}", _TextField2.LeftHelper, "{margin-top:var(", _TextField.tokens.leftHelperOffset, ");font-family:var(", _TextField.tokens.leftHelperFontFamily, ");font-size:var(", _TextField.tokens.leftHelperFontSize, ");font-style:var(", _TextField.tokens.leftHelperFontStyle, ");font-weight:var(", _TextField.tokens.leftHelperFontWeight, ");letter-spacing:var(", _TextField.tokens.leftHelperLetterSpacing, ");line-height:var(", _TextField.tokens.leftHelperLineHeight, ");}", _TextField2.StyledTextBefore, ",", _TextField2.StyledTextAfter, "{font-family:var(", _TextField.tokens.fontFamily, ");font-size:var(", _TextField.tokens.fontSize, ");font-style:var(", _TextField.tokens.fontStyle, ");font-weight:var(", _TextField.tokens.fontWeight, ");letter-spacing:var(", _TextField.tokens.letterSpacing, ");line-height:var(", _TextField.tokens.lineHeight, ");}", _TextField2.StyledTextBefore, "{margin:var(", _TextField.tokens.textBeforeMargin, ");}", _TextField2.StyledTextAfter, "{margin:var(", _TextField.tokens.textAfterMargin, ");}", _TextField2.StyledContentRightWrapper, ".", _TextField.classes.contentRightCompensationMargin, "{gap:var(", _TextField.tokens.contentRightWrapperGap, ");margin:var(", _TextField.tokens.contentRightWrapperMargin, ");", _TextField2.StyledContentRight, "{margin:var(", _TextField.tokens.rightContentWithHintMargin, ");}};label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEZpZWxkL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQnVCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEZpZWxkL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuaW1wb3J0IHsgY2xhc3NlcywgdG9rZW5zIH0gZnJvbSAnLi4vLi4vVGV4dEZpZWxkLnRva2Vucyc7XG5pbXBvcnQge1xuICAgIEhpbnRUYXJnZXRXcmFwcGVyLFxuICAgIElucHV0LFxuICAgIElucHV0Q29udGFpbmVyLFxuICAgIElucHV0V3JhcHBlcixcbiAgICBMYWJlbCxcbiAgICBMZWZ0SGVscGVyLFxuICAgIFN0eWxlZENvbnRlbnRSaWdodCxcbiAgICBTdHlsZWRDb250ZW50UmlnaHRXcmFwcGVyLFxuICAgIFN0eWxlZEhpbnRXcmFwcGVyLFxuICAgIFN0eWxlZE9wdGlvbmFsVGV4dCxcbiAgICBTdHlsZWRUZXh0QWZ0ZXIsXG4gICAgU3R5bGVkVGV4dEJlZm9yZSxcbiAgICBUaXRsZUNhcHRpb24sXG59IGZyb20gJy4uLy4uL1RleHRGaWVsZC5zdHlsZXMnO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BcbiAgICAke3Rva2Vucy50b3VyQm9yZGVyUmFkaXVzfTogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuXG4gICAgJHtJbnB1dH0ge1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgZm9udDogaW5oZXJpdDtcbiAgICAgICAgbGV0dGVyLXNwYWNpbmc6IGluaGVyaXQ7XG4gICAgICAgIGxpbmUtaGVpZ2h0OiBpbmhlcml0O1xuICAgIH1cblxuICAgICR7SW5wdXRDb250YWluZXJ9IHtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGZvbnQtZmFtaWx5OiB2YXIoJHt0b2tlbnMuZm9udEZhbWlseX0pO1xuICAgICAgICBmb250LXNpemU6IHZhcigke3Rva2Vucy5mb250U2l6ZX0pO1xuICAgICAgICBmb250LXN0eWxlOiB2YXIoJHt0b2tlbnMuZm9udFN0eWxlfSk7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiB2YXIoJHt0b2tlbnMuZm9udFdlaWdodH0pO1xuICAgICAgICBsZXR0ZXItc3BhY2luZzogdmFyKCR7dG9rZW5zLmxldHRlclNwYWNpbmd9KTtcbiAgICAgICAgbGluZS1oZWlnaHQ6IHZhcigke3Rva2Vucy5saW5lSGVpZ2h0fSk7XG4gICAgfVxuXG4gICAgJHtJbnB1dFdyYXBwZXJ9IHtcbiAgICAgICAgaGVpZ2h0OiB2YXIoJHt0b2tlbnMuaGVpZ2h0fSk7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IHZhcigke3Rva2Vucy5ib3JkZXJSYWRpdXN9KTtcbiAgICAgICAgcGFkZGluZzogdmFyKCR7dG9rZW5zLnBhZGRpbmd9KTtcblxuICAgICAgICAmLiR7Y2xhc3Nlcy5oYXNDaGlwc30ge1xuICAgICAgICAgICAgcGFkZGluZy10b3A6IHZhcigke3Rva2Vucy5wYWRkaW5nV2l0aENoaXBzfSk7XG4gICAgICAgICAgICBwYWRkaW5nLWJvdHRvbTogdmFyKCR7dG9rZW5zLnBhZGRpbmdXaXRoQ2hpcHN9KTtcbiAgICAgICAgfVxuXG4gICAgICAgICYuJHtjbGFzc2VzLmhhc0VtcHR5Q29udGVudExlZnR9IHtcbiAgICAgICAgICAgIHBhZGRpbmctbGVmdDogdmFyKCR7dG9rZW5zLnBhZGRpbmdXaXRoQ2hpcHN9KTtcbiAgICAgICAgfVxuXG4gICAgICAgICYuJHtjbGFzc2VzLmhhc0VtcHR5Q29udGVudFJpZ2h0fSB7XG4gICAgICAgICAgICBwYWRkaW5nLXJpZ2h0OiB2YXIoJHt0b2tlbnMucGFkZGluZ1dpdGhDaGlwc30pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgJHtMYWJlbH0sICY6bm90KC4ke2NsYXNzZXMuaW5uZXJMYWJlbFBsYWNlbWVudH0pICR7U3R5bGVkT3B0aW9uYWxUZXh0fSB7XG4gICAgICAgIGZvbnQtZmFtaWx5OiB2YXIoJHt0b2tlbnMubGFiZWxGb250RmFtaWx5fSk7XG4gICAgICAgIGZvbnQtc2l6ZTogdmFyKCR7dG9rZW5zLmxhYmVsRm9udFNpemV9KTtcbiAgICAgICAgZm9udC1zdHlsZTogdmFyKCR7dG9rZW5zLmxhYmVsRm9udFN0eWxlfSk7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiB2YXIoJHt0b2tlbnMubGFiZWxGb250V2VpZ2h0fSk7XG4gICAgICAgIGxldHRlci1zcGFjaW5nOiB2YXIoJHt0b2tlbnMubGFiZWxMZXR0ZXJTcGFjaW5nfSk7XG4gICAgICAgIGxpbmUtaGVpZ2h0OiB2YXIoJHt0b2tlbnMubGFiZWxMaW5lSGVpZ2h0fSk7XG4gICAgfVxuXG4gICAgJHtTdHlsZWRIaW50V3JhcHBlcn0ge1xuICAgICAgICBtYXJnaW46IHZhcigke3Rva2Vucy5oaW50TWFyZ2lufSk7XG4gICAgICAgIHdpZHRoOiB2YXIoJHt0b2tlbnMuaGludFRhcmdldFNpemV9KTtcbiAgICAgICAgaGVpZ2h0OiB2YXIoJHt0b2tlbnMuaGludFRhcmdldFNpemV9KTtcbiAgICB9XG5cbiAgICAke0hpbnRUYXJnZXRXcmFwcGVyfSB7XG4gICAgICAgIHdpZHRoOiB2YXIoJHt0b2tlbnMuaGludFRhcmdldFNpemV9KTtcbiAgICAgICAgaGVpZ2h0OiB2YXIoJHt0b2tlbnMuaGludFRhcmdldFNpemV9KTtcbiAgICB9XG5cbiAgICAke1RpdGxlQ2FwdGlvbn0ge1xuICAgICAgICBmb250LWZhbWlseTogdmFyKCR7dG9rZW5zLnRpdGxlQ2FwdGlvbkZvbnRGYW1pbHl9KTtcbiAgICAgICAgZm9udC1zaXplOiB2YXIoJHt0b2tlbnMudGl0bGVDYXB0aW9uRm9udFNpemV9KTtcbiAgICAgICAgZm9udC1zdHlsZTogdmFyKCR7dG9rZW5zLnRpdGxlQ2FwdGlvbkZvbnRTdHlsZX0pO1xuICAgICAgICBmb250LXdlaWdodDogdmFyKCR7dG9rZW5zLnRpdGxlQ2FwdGlvbkZvbnRXZWlnaHR9KTtcbiAgICAgICAgbGV0dGVyLXNwYWNpbmc6IHZhcigke3Rva2Vucy50aXRsZUNhcHRpb25MZXR0ZXJTcGFjaW5nfSk7XG4gICAgICAgIGxpbmUtaGVpZ2h0OiB2YXIoJHt0b2tlbnMudGl0bGVDYXB0aW9uTGluZUhlaWdodH0pO1xuICAgIH1cblxuICAgICR7TGVmdEhlbHBlcn0ge1xuICAgICAgICBtYXJnaW4tdG9wOiB2YXIoJHt0b2tlbnMubGVmdEhlbHBlck9mZnNldH0pO1xuXG4gICAgICAgIGZvbnQtZmFtaWx5OiB2YXIoJHt0b2tlbnMubGVmdEhlbHBlckZvbnRGYW1pbHl9KTtcbiAgICAgICAgZm9udC1zaXplOiB2YXIoJHt0b2tlbnMubGVmdEhlbHBlckZvbnRTaXplfSk7XG4gICAgICAgIGZvbnQtc3R5bGU6IHZhcigke3Rva2Vucy5sZWZ0SGVscGVyRm9udFN0eWxlfSk7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiB2YXIoJHt0b2tlbnMubGVmdEhlbHBlckZvbnRXZWlnaHR9KTtcbiAgICAgICAgbGV0dGVyLXNwYWNpbmc6IHZhcigke3Rva2Vucy5sZWZ0SGVscGVyTGV0dGVyU3BhY2luZ30pO1xuICAgICAgICBsaW5lLWhlaWdodDogdmFyKCR7dG9rZW5zLmxlZnRIZWxwZXJMaW5lSGVpZ2h0fSk7XG4gICAgfVxuXG4gICAgJHtTdHlsZWRUZXh0QmVmb3JlfSwgJHtTdHlsZWRUZXh0QWZ0ZXJ9IHtcbiAgICAgICAgZm9udC1mYW1pbHk6IHZhcigke3Rva2Vucy5mb250RmFtaWx5fSk7XG4gICAgICAgIGZvbnQtc2l6ZTogdmFyKCR7dG9rZW5zLmZvbnRTaXplfSk7XG4gICAgICAgIGZvbnQtc3R5bGU6IHZhcigke3Rva2Vucy5mb250U3R5bGV9KTtcbiAgICAgICAgZm9udC13ZWlnaHQ6IHZhcigke3Rva2Vucy5mb250V2VpZ2h0fSk7XG4gICAgICAgIGxldHRlci1zcGFjaW5nOiB2YXIoJHt0b2tlbnMubGV0dGVyU3BhY2luZ30pO1xuICAgICAgICBsaW5lLWhlaWdodDogdmFyKCR7dG9rZW5zLmxpbmVIZWlnaHR9KTtcbiAgICB9XG5cbiAgICAke1N0eWxlZFRleHRCZWZvcmV9IHtcbiAgICAgICAgbWFyZ2luOiB2YXIoJHt0b2tlbnMudGV4dEJlZm9yZU1hcmdpbn0pO1xuICAgIH1cblxuICAgICR7U3R5bGVkVGV4dEFmdGVyfSB7XG4gICAgICAgIG1hcmdpbjogdmFyKCR7dG9rZW5zLnRleHRBZnRlck1hcmdpbn0pO1xuICAgIH1cblxuICAgICR7U3R5bGVkQ29udGVudFJpZ2h0V3JhcHBlcn0uJHtjbGFzc2VzLmNvbnRlbnRSaWdodENvbXBlbnNhdGlvbk1hcmdpbn0ge1xuICAgICAgICBnYXA6IHZhcigke3Rva2Vucy5jb250ZW50UmlnaHRXcmFwcGVyR2FwfSk7XG4gICAgICAgIG1hcmdpbjogdmFyKCR7dG9rZW5zLmNvbnRlbnRSaWdodFdyYXBwZXJNYXJnaW59KTtcblxuICAgICAgICAke1N0eWxlZENvbnRlbnRSaWdodH0ge1xuICAgICAgICAgICAgbWFyZ2luOiB2YXIoJHt0b2tlbnMucmlnaHRDb250ZW50V2l0aEhpbnRNYXJnaW59KTtcbiAgICAgICAgfVxuICAgIH1cbmA7XG4iXX0= */"));
10
+ var base = exports.base = /*#__PURE__*/(0, _react.css)(_TextField2.Input, "{width:100%;font:inherit;letter-spacing:inherit;line-height:inherit;}", _TextField2.InputContainer, "{width:100%;font-family:var(", _TextField.tokens.fontFamily, ");font-size:var(", _TextField.tokens.fontSize, ");font-style:var(", _TextField.tokens.fontStyle, ");font-weight:var(", _TextField.tokens.fontWeight, ");letter-spacing:var(", _TextField.tokens.letterSpacing, ");line-height:var(", _TextField.tokens.lineHeight, ");}", _TextField2.InputWrapper, "{height:var(", _TextField.tokens.height, ");border-radius:var(", _TextField.tokens.borderRadius, ");padding:var(", _TextField.tokens.padding, ");&.", _TextField.classes.hasChips, "{padding-top:var(", _TextField.tokens.paddingWithChips, ");padding-bottom:var(", _TextField.tokens.paddingWithChips, ");}&.", _TextField.classes.hasEmptyContentLeft, "{padding-left:var(", _TextField.tokens.paddingWithChips, ");}&.", _TextField.classes.hasEmptyContentRight, "{padding-right:var(", _TextField.tokens.paddingWithChips, ");}}", _TextField2.Label, ",&:not(.", _TextField.classes.innerLabelPlacement, ") ", _TextField2.StyledOptionalText, "{font-family:var(", _TextField.tokens.labelFontFamily, ");font-size:var(", _TextField.tokens.labelFontSize, ");font-style:var(", _TextField.tokens.labelFontStyle, ");font-weight:var(", _TextField.tokens.labelFontWeight, ");letter-spacing:var(", _TextField.tokens.labelLetterSpacing, ");line-height:var(", _TextField.tokens.labelLineHeight, ");}", _TextField2.StyledHintWrapper, "{margin:var(", _TextField.tokens.hintMargin, ");width:var(", _TextField.tokens.hintTargetSize, ");height:var(", _TextField.tokens.hintTargetSize, ");}", _TextField2.HintTargetWrapper, "{width:var(", _TextField.tokens.hintTargetSize, ");height:var(", _TextField.tokens.hintTargetSize, ");}", _TextField2.TitleCaption, "{font-family:var(", _TextField.tokens.titleCaptionFontFamily, ");font-size:var(", _TextField.tokens.titleCaptionFontSize, ");font-style:var(", _TextField.tokens.titleCaptionFontStyle, ");font-weight:var(", _TextField.tokens.titleCaptionFontWeight, ");letter-spacing:var(", _TextField.tokens.titleCaptionLetterSpacing, ");line-height:var(", _TextField.tokens.titleCaptionLineHeight, ");}", _TextField2.LeftHelper, "{margin-top:var(", _TextField.tokens.leftHelperOffset, ");font-family:var(", _TextField.tokens.leftHelperFontFamily, ");font-size:var(", _TextField.tokens.leftHelperFontSize, ");font-style:var(", _TextField.tokens.leftHelperFontStyle, ");font-weight:var(", _TextField.tokens.leftHelperFontWeight, ");letter-spacing:var(", _TextField.tokens.leftHelperLetterSpacing, ");line-height:var(", _TextField.tokens.leftHelperLineHeight, ");}", _TextField2.StyledTextBefore, ",", _TextField2.StyledTextAfter, "{font-family:var(", _TextField.tokens.fontFamily, ");font-size:var(", _TextField.tokens.fontSize, ");font-style:var(", _TextField.tokens.fontStyle, ");font-weight:var(", _TextField.tokens.fontWeight, ");letter-spacing:var(", _TextField.tokens.letterSpacing, ");line-height:var(", _TextField.tokens.lineHeight, ");}", _TextField2.StyledTextBefore, "{margin:var(", _TextField.tokens.textBeforeMargin, ");}", _TextField2.StyledTextAfter, "{margin:var(", _TextField.tokens.textAfterMargin, ");}", _TextField2.StyledContentRightWrapper, ".", _TextField.classes.contentRightCompensationMargin, "{gap:var(", _TextField.tokens.contentRightWrapperGap, ");margin:var(", _TextField.tokens.contentRightWrapperMargin, ");", _TextField2.StyledContentRight, "{margin:var(", _TextField.tokens.rightContentWithHintMargin, ");}};label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEZpZWxkL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQnVCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEZpZWxkL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuaW1wb3J0IHsgY2xhc3NlcywgdG9rZW5zIH0gZnJvbSAnLi4vLi4vVGV4dEZpZWxkLnRva2Vucyc7XG5pbXBvcnQge1xuICAgIEhpbnRUYXJnZXRXcmFwcGVyLFxuICAgIElucHV0LFxuICAgIElucHV0Q29udGFpbmVyLFxuICAgIElucHV0V3JhcHBlcixcbiAgICBMYWJlbCxcbiAgICBMZWZ0SGVscGVyLFxuICAgIFN0eWxlZENvbnRlbnRSaWdodCxcbiAgICBTdHlsZWRDb250ZW50UmlnaHRXcmFwcGVyLFxuICAgIFN0eWxlZEhpbnRXcmFwcGVyLFxuICAgIFN0eWxlZE9wdGlvbmFsVGV4dCxcbiAgICBTdHlsZWRUZXh0QWZ0ZXIsXG4gICAgU3R5bGVkVGV4dEJlZm9yZSxcbiAgICBUaXRsZUNhcHRpb24sXG59IGZyb20gJy4uLy4uL1RleHRGaWVsZC5zdHlsZXMnO1xuXG5leHBvcnQgY29uc3QgYmFzZSA9IGNzc2BcbiAgICAke0lucHV0fSB7XG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICBmb250OiBpbmhlcml0O1xuICAgICAgICBsZXR0ZXItc3BhY2luZzogaW5oZXJpdDtcbiAgICAgICAgbGluZS1oZWlnaHQ6IGluaGVyaXQ7XG4gICAgfVxuXG4gICAgJHtJbnB1dENvbnRhaW5lcn0ge1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgZm9udC1mYW1pbHk6IHZhcigke3Rva2Vucy5mb250RmFtaWx5fSk7XG4gICAgICAgIGZvbnQtc2l6ZTogdmFyKCR7dG9rZW5zLmZvbnRTaXplfSk7XG4gICAgICAgIGZvbnQtc3R5bGU6IHZhcigke3Rva2Vucy5mb250U3R5bGV9KTtcbiAgICAgICAgZm9udC13ZWlnaHQ6IHZhcigke3Rva2Vucy5mb250V2VpZ2h0fSk7XG4gICAgICAgIGxldHRlci1zcGFjaW5nOiB2YXIoJHt0b2tlbnMubGV0dGVyU3BhY2luZ30pO1xuICAgICAgICBsaW5lLWhlaWdodDogdmFyKCR7dG9rZW5zLmxpbmVIZWlnaHR9KTtcbiAgICB9XG5cbiAgICAke0lucHV0V3JhcHBlcn0ge1xuICAgICAgICBoZWlnaHQ6IHZhcigke3Rva2Vucy5oZWlnaHR9KTtcbiAgICAgICAgYm9yZGVyLXJhZGl1czogdmFyKCR7dG9rZW5zLmJvcmRlclJhZGl1c30pO1xuICAgICAgICBwYWRkaW5nOiB2YXIoJHt0b2tlbnMucGFkZGluZ30pO1xuXG4gICAgICAgICYuJHtjbGFzc2VzLmhhc0NoaXBzfSB7XG4gICAgICAgICAgICBwYWRkaW5nLXRvcDogdmFyKCR7dG9rZW5zLnBhZGRpbmdXaXRoQ2hpcHN9KTtcbiAgICAgICAgICAgIHBhZGRpbmctYm90dG9tOiB2YXIoJHt0b2tlbnMucGFkZGluZ1dpdGhDaGlwc30pO1xuICAgICAgICB9XG5cbiAgICAgICAgJi4ke2NsYXNzZXMuaGFzRW1wdHlDb250ZW50TGVmdH0ge1xuICAgICAgICAgICAgcGFkZGluZy1sZWZ0OiB2YXIoJHt0b2tlbnMucGFkZGluZ1dpdGhDaGlwc30pO1xuICAgICAgICB9XG5cbiAgICAgICAgJi4ke2NsYXNzZXMuaGFzRW1wdHlDb250ZW50UmlnaHR9IHtcbiAgICAgICAgICAgIHBhZGRpbmctcmlnaHQ6IHZhcigke3Rva2Vucy5wYWRkaW5nV2l0aENoaXBzfSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAke0xhYmVsfSwgJjpub3QoLiR7Y2xhc3Nlcy5pbm5lckxhYmVsUGxhY2VtZW50fSkgJHtTdHlsZWRPcHRpb25hbFRleHR9IHtcbiAgICAgICAgZm9udC1mYW1pbHk6IHZhcigke3Rva2Vucy5sYWJlbEZvbnRGYW1pbHl9KTtcbiAgICAgICAgZm9udC1zaXplOiB2YXIoJHt0b2tlbnMubGFiZWxGb250U2l6ZX0pO1xuICAgICAgICBmb250LXN0eWxlOiB2YXIoJHt0b2tlbnMubGFiZWxGb250U3R5bGV9KTtcbiAgICAgICAgZm9udC13ZWlnaHQ6IHZhcigke3Rva2Vucy5sYWJlbEZvbnRXZWlnaHR9KTtcbiAgICAgICAgbGV0dGVyLXNwYWNpbmc6IHZhcigke3Rva2Vucy5sYWJlbExldHRlclNwYWNpbmd9KTtcbiAgICAgICAgbGluZS1oZWlnaHQ6IHZhcigke3Rva2Vucy5sYWJlbExpbmVIZWlnaHR9KTtcbiAgICB9XG5cbiAgICAke1N0eWxlZEhpbnRXcmFwcGVyfSB7XG4gICAgICAgIG1hcmdpbjogdmFyKCR7dG9rZW5zLmhpbnRNYXJnaW59KTtcbiAgICAgICAgd2lkdGg6IHZhcigke3Rva2Vucy5oaW50VGFyZ2V0U2l6ZX0pO1xuICAgICAgICBoZWlnaHQ6IHZhcigke3Rva2Vucy5oaW50VGFyZ2V0U2l6ZX0pO1xuICAgIH1cblxuICAgICR7SGludFRhcmdldFdyYXBwZXJ9IHtcbiAgICAgICAgd2lkdGg6IHZhcigke3Rva2Vucy5oaW50VGFyZ2V0U2l6ZX0pO1xuICAgICAgICBoZWlnaHQ6IHZhcigke3Rva2Vucy5oaW50VGFyZ2V0U2l6ZX0pO1xuICAgIH1cblxuICAgICR7VGl0bGVDYXB0aW9ufSB7XG4gICAgICAgIGZvbnQtZmFtaWx5OiB2YXIoJHt0b2tlbnMudGl0bGVDYXB0aW9uRm9udEZhbWlseX0pO1xuICAgICAgICBmb250LXNpemU6IHZhcigke3Rva2Vucy50aXRsZUNhcHRpb25Gb250U2l6ZX0pO1xuICAgICAgICBmb250LXN0eWxlOiB2YXIoJHt0b2tlbnMudGl0bGVDYXB0aW9uRm9udFN0eWxlfSk7XG4gICAgICAgIGZvbnQtd2VpZ2h0OiB2YXIoJHt0b2tlbnMudGl0bGVDYXB0aW9uRm9udFdlaWdodH0pO1xuICAgICAgICBsZXR0ZXItc3BhY2luZzogdmFyKCR7dG9rZW5zLnRpdGxlQ2FwdGlvbkxldHRlclNwYWNpbmd9KTtcbiAgICAgICAgbGluZS1oZWlnaHQ6IHZhcigke3Rva2Vucy50aXRsZUNhcHRpb25MaW5lSGVpZ2h0fSk7XG4gICAgfVxuXG4gICAgJHtMZWZ0SGVscGVyfSB7XG4gICAgICAgIG1hcmdpbi10b3A6IHZhcigke3Rva2Vucy5sZWZ0SGVscGVyT2Zmc2V0fSk7XG5cbiAgICAgICAgZm9udC1mYW1pbHk6IHZhcigke3Rva2Vucy5sZWZ0SGVscGVyRm9udEZhbWlseX0pO1xuICAgICAgICBmb250LXNpemU6IHZhcigke3Rva2Vucy5sZWZ0SGVscGVyRm9udFNpemV9KTtcbiAgICAgICAgZm9udC1zdHlsZTogdmFyKCR7dG9rZW5zLmxlZnRIZWxwZXJGb250U3R5bGV9KTtcbiAgICAgICAgZm9udC13ZWlnaHQ6IHZhcigke3Rva2Vucy5sZWZ0SGVscGVyRm9udFdlaWdodH0pO1xuICAgICAgICBsZXR0ZXItc3BhY2luZzogdmFyKCR7dG9rZW5zLmxlZnRIZWxwZXJMZXR0ZXJTcGFjaW5nfSk7XG4gICAgICAgIGxpbmUtaGVpZ2h0OiB2YXIoJHt0b2tlbnMubGVmdEhlbHBlckxpbmVIZWlnaHR9KTtcbiAgICB9XG5cbiAgICAke1N0eWxlZFRleHRCZWZvcmV9LCAke1N0eWxlZFRleHRBZnRlcn0ge1xuICAgICAgICBmb250LWZhbWlseTogdmFyKCR7dG9rZW5zLmZvbnRGYW1pbHl9KTtcbiAgICAgICAgZm9udC1zaXplOiB2YXIoJHt0b2tlbnMuZm9udFNpemV9KTtcbiAgICAgICAgZm9udC1zdHlsZTogdmFyKCR7dG9rZW5zLmZvbnRTdHlsZX0pO1xuICAgICAgICBmb250LXdlaWdodDogdmFyKCR7dG9rZW5zLmZvbnRXZWlnaHR9KTtcbiAgICAgICAgbGV0dGVyLXNwYWNpbmc6IHZhcigke3Rva2Vucy5sZXR0ZXJTcGFjaW5nfSk7XG4gICAgICAgIGxpbmUtaGVpZ2h0OiB2YXIoJHt0b2tlbnMubGluZUhlaWdodH0pO1xuICAgIH1cblxuICAgICR7U3R5bGVkVGV4dEJlZm9yZX0ge1xuICAgICAgICBtYXJnaW46IHZhcigke3Rva2Vucy50ZXh0QmVmb3JlTWFyZ2lufSk7XG4gICAgfVxuXG4gICAgJHtTdHlsZWRUZXh0QWZ0ZXJ9IHtcbiAgICAgICAgbWFyZ2luOiB2YXIoJHt0b2tlbnMudGV4dEFmdGVyTWFyZ2lufSk7XG4gICAgfVxuXG4gICAgJHtTdHlsZWRDb250ZW50UmlnaHRXcmFwcGVyfS4ke2NsYXNzZXMuY29udGVudFJpZ2h0Q29tcGVuc2F0aW9uTWFyZ2lufSB7XG4gICAgICAgIGdhcDogdmFyKCR7dG9rZW5zLmNvbnRlbnRSaWdodFdyYXBwZXJHYXB9KTtcbiAgICAgICAgbWFyZ2luOiB2YXIoJHt0b2tlbnMuY29udGVudFJpZ2h0V3JhcHBlck1hcmdpbn0pO1xuXG4gICAgICAgICR7U3R5bGVkQ29udGVudFJpZ2h0fSB7XG4gICAgICAgICAgICBtYXJnaW46IHZhcigke3Rva2Vucy5yaWdodENvbnRlbnRXaXRoSGludE1hcmdpbn0pO1xuICAgICAgICB9XG4gICAgfVxuYDtcbiJdfQ== */"));
@@ -860,15 +860,4 @@ Object.keys(_CodeField).forEach(function (key) {
860
860
  return _CodeField[key];
861
861
  }
862
862
  });
863
- });
864
- var _Tour = /*#__PURE__*/require("./components/Tour");
865
- Object.keys(_Tour).forEach(function (key) {
866
- if (key === "default" || key === "__esModule") return;
867
- if (key in exports && exports[key] === _Tour[key]) return;
868
- Object.defineProperty(exports, key, {
869
- enumerable: true,
870
- get: function get() {
871
- return _Tour[key];
872
- }
873
- });
874
863
  });
@@ -11,11 +11,11 @@ function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t =
11
11
  import React, { forwardRef, useImperativeHandle, useState } from 'react';
12
12
  import maskInputCompose from '@salutejs/react-maskinput';
13
13
  var defaultFormatChars = [{
14
- str: '0',
15
- regexp: /[0-9]/
16
- }, {
17
14
  str: '*',
18
15
  regexp: /./
16
+ }, {
17
+ str: '0',
18
+ regexp: /[0-9]/
19
19
  }, {
20
20
  str: 'a',
21
21
  regexp: /[a-zA-Z]/