@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.
- package/cjs/components/Autocomplete/Autocomplete.css +1 -1
- package/cjs/components/Combobox/ComboboxNew/Combobox.css +1 -1
- package/cjs/components/DatePicker/RangeDate/RangeDate.css +1 -1
- package/cjs/components/DatePicker/RangeDate/RangeDatePopover/RangeDatePopover.css +1 -1
- package/cjs/components/DatePicker/SingleDate/SingleDate.css +1 -1
- package/cjs/components/Mask/Mask.js +3 -3
- package/cjs/components/Mask/Mask.js.map +1 -1
- package/cjs/components/Pagination/Pagination.css +1 -1
- package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +1 -1
- package/cjs/components/Range/Range.css +1 -1
- package/cjs/components/Select/Select.css +1 -1
- package/cjs/components/Select/ui/Target/Target.css +1 -1
- package/cjs/components/Select/ui/Target/ui/Textfield/Textfield.css +1 -1
- package/cjs/components/Slider/Slider.css +1 -1
- package/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +1 -1
- package/cjs/components/Table/Table.css +1 -1
- package/cjs/components/Table/ui/Cell/Cell.css +1 -1
- package/cjs/components/Table/ui/EditableCell/EditableCell.css +1 -1
- package/cjs/components/Table/ui/HeadCell/HeadCell.css +1 -1
- package/cjs/components/Table/ui/HeadCell/ui/Filter/Filter.css +1 -1
- package/cjs/components/TextArea/TextArea.js +2 -5
- package/cjs/components/TextArea/TextArea.js.map +1 -1
- package/cjs/components/TextArea/TextArea.tokens.js +1 -2
- package/cjs/components/TextArea/TextArea.tokens.js.map +1 -1
- package/cjs/components/TextArea/variations/_size/base.js +1 -1
- package/cjs/components/TextArea/variations/_size/base.js.map +1 -1
- package/cjs/components/TextField/TextField.js +2 -10
- package/cjs/components/TextField/TextField.js.map +1 -1
- package/cjs/components/TextField/TextField.tokens.js +1 -2
- package/cjs/components/TextField/TextField.tokens.js.map +1 -1
- package/cjs/components/TextField/variations/_size/base.js +1 -1
- package/cjs/components/TextField/variations/_size/base.js.map +1 -1
- package/cjs/components/TextField/variations/_size/base_uulqii.css +1 -0
- package/cjs/index.css +1 -8
- package/cjs/index.js +0 -6
- package/cjs/index.js.map +1 -1
- package/emotion/cjs/components/Mask/Mask.js +3 -3
- package/emotion/cjs/components/TextArea/TextArea.js +3 -6
- package/emotion/cjs/components/TextArea/TextArea.tokens.js +1 -2
- package/emotion/cjs/components/TextArea/variations/_size/base.js +1 -2
- package/emotion/cjs/components/TextField/TextField.js +3 -11
- package/emotion/cjs/components/TextField/TextField.tokens.js +1 -2
- package/emotion/cjs/components/TextField/variations/_size/base.js +1 -1
- package/emotion/cjs/index.js +0 -11
- package/emotion/es/components/Mask/Mask.js +3 -3
- package/emotion/es/components/TextArea/TextArea.js +3 -6
- package/emotion/es/components/TextArea/TextArea.tokens.js +1 -2
- package/emotion/es/components/TextArea/variations/_size/base.js +1 -2
- package/emotion/es/components/TextField/TextField.js +3 -11
- package/emotion/es/components/TextField/TextField.tokens.js +1 -2
- package/emotion/es/components/TextField/variations/_size/base.js +1 -1
- package/emotion/es/index.js +1 -2
- package/es/components/Autocomplete/Autocomplete.css +1 -1
- package/es/components/Combobox/ComboboxNew/Combobox.css +1 -1
- package/es/components/DatePicker/RangeDate/RangeDate.css +1 -1
- package/es/components/DatePicker/RangeDate/RangeDatePopover/RangeDatePopover.css +1 -1
- package/es/components/DatePicker/SingleDate/SingleDate.css +1 -1
- package/es/components/Mask/Mask.js +3 -3
- package/es/components/Mask/Mask.js.map +1 -1
- package/es/components/Pagination/Pagination.css +1 -1
- package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +1 -1
- package/es/components/Range/Range.css +1 -1
- package/es/components/Select/Select.css +1 -1
- package/es/components/Select/ui/Target/Target.css +1 -1
- package/es/components/Select/ui/Target/ui/Textfield/Textfield.css +1 -1
- package/es/components/Slider/Slider.css +1 -1
- package/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +1 -1
- package/es/components/Table/Table.css +1 -1
- package/es/components/Table/ui/Cell/Cell.css +1 -1
- package/es/components/Table/ui/EditableCell/EditableCell.css +1 -1
- package/es/components/Table/ui/HeadCell/HeadCell.css +1 -1
- package/es/components/Table/ui/HeadCell/ui/Filter/Filter.css +1 -1
- package/es/components/TextArea/TextArea.js +2 -5
- package/es/components/TextArea/TextArea.js.map +1 -1
- package/es/components/TextArea/TextArea.tokens.js +1 -2
- package/es/components/TextArea/TextArea.tokens.js.map +1 -1
- package/es/components/TextArea/variations/_size/base.js +1 -1
- package/es/components/TextArea/variations/_size/base.js.map +1 -1
- package/es/components/TextField/TextField.js +2 -10
- package/es/components/TextField/TextField.js.map +1 -1
- package/es/components/TextField/TextField.tokens.js +1 -2
- package/es/components/TextField/TextField.tokens.js.map +1 -1
- package/es/components/TextField/variations/_size/base.js +1 -1
- package/es/components/TextField/variations/_size/base.js.map +1 -1
- package/es/components/TextField/variations/_size/base_uulqii.css +1 -0
- package/es/index.css +1 -8
- package/es/index.js +0 -2
- package/es/index.js.map +1 -1
- package/package.json +2 -2
- package/styled-components/cjs/components/Mask/Mask.js +3 -3
- package/styled-components/cjs/components/TextArea/TextArea.js +2 -5
- package/styled-components/cjs/components/TextArea/TextArea.tokens.js +1 -2
- package/styled-components/cjs/components/TextArea/variations/_size/base.js +1 -2
- package/styled-components/cjs/components/TextField/TextField.js +2 -10
- package/styled-components/cjs/components/TextField/TextField.tokens.js +1 -2
- package/styled-components/cjs/components/TextField/variations/_size/base.js +1 -1
- package/styled-components/cjs/index.js +0 -11
- package/styled-components/es/components/Mask/Mask.js +3 -3
- package/styled-components/es/components/TextArea/TextArea.js +2 -5
- package/styled-components/es/components/TextArea/TextArea.tokens.js +1 -2
- package/styled-components/es/components/TextArea/variations/_size/base.js +1 -2
- package/styled-components/es/components/TextField/TextField.js +2 -10
- package/styled-components/es/components/TextField/TextField.tokens.js +1 -2
- package/styled-components/es/components/TextField/variations/_size/base.js +1 -1
- package/styled-components/es/index.js +1 -2
- package/types/components/TextArea/TextArea.d.ts.map +1 -1
- package/types/components/TextArea/TextArea.tokens.d.ts +0 -1
- package/types/components/TextArea/TextArea.tokens.d.ts.map +1 -1
- package/types/components/TextArea/variations/_size/base.d.ts.map +1 -1
- package/types/components/TextField/TextField.d.ts.map +1 -1
- package/types/components/TextField/TextField.tokens.d.ts +0 -1
- package/types/components/TextField/TextField.tokens.d.ts.map +1 -1
- package/types/components/TextField/variations/_size/base.d.ts.map +1 -1
- package/types/index.d.ts +0 -1
- package/types/index.d.ts.map +1 -1
- package/cjs/components/TextArea/variations/_size/base_1mq4sb2.css +0 -1
- package/cjs/components/TextField/variations/_size/base_ryad12.css +0 -1
- package/cjs/components/Tour/Tour.css +0 -4
- package/cjs/components/Tour/Tour.js +0 -231
- package/cjs/components/Tour/Tour.js.map +0 -1
- package/cjs/components/Tour/Tour.styles.js +0 -58
- package/cjs/components/Tour/Tour.styles.js.map +0 -1
- package/cjs/components/Tour/Tour.styles_hmd79i.css +0 -4
- package/cjs/components/Tour/Tour.tokens.js +0 -21
- package/cjs/components/Tour/Tour.tokens.js.map +0 -1
- package/cjs/components/Tour/utils/index.js +0 -113
- package/cjs/components/Tour/utils/index.js.map +0 -1
- package/cjs/components/Tour/variatoins/_size/base.js +0 -9
- package/cjs/components/Tour/variatoins/_size/base.js.map +0 -1
- package/cjs/components/Tour/variatoins/_view/base.js +0 -9
- package/cjs/components/Tour/variatoins/_view/base.js.map +0 -1
- package/emotion/cjs/components/Tour/Tour.js +0 -240
- package/emotion/cjs/components/Tour/Tour.styles.js +0 -50
- package/emotion/cjs/components/Tour/Tour.tokens.js +0 -19
- package/emotion/cjs/components/Tour/Tour.types.js +0 -5
- package/emotion/cjs/components/Tour/index.js +0 -31
- package/emotion/cjs/components/Tour/utils/index.js +0 -110
- package/emotion/cjs/components/Tour/variatoins/_size/base.js +0 -8
- package/emotion/cjs/components/Tour/variatoins/_size/tokens.json +0 -1
- package/emotion/cjs/components/Tour/variatoins/_view/base.js +0 -8
- package/emotion/cjs/components/Tour/variatoins/_view/tokens.json +0 -1
- package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.config.js +0 -22
- package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.js +0 -11
- package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
- package/emotion/cjs/examples/plasma_web/components/Tour/Tour.config.js +0 -22
- package/emotion/cjs/examples/plasma_web/components/Tour/Tour.js +0 -11
- package/emotion/cjs/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
- package/emotion/es/components/Tour/Tour.js +0 -232
- package/emotion/es/components/Tour/Tour.styles.js +0 -43
- package/emotion/es/components/Tour/Tour.tokens.js +0 -13
- package/emotion/es/components/Tour/Tour.types.js +0 -1
- package/emotion/es/components/Tour/index.js +0 -2
- package/emotion/es/components/Tour/utils/index.js +0 -104
- package/emotion/es/components/Tour/variatoins/_size/base.js +0 -2
- package/emotion/es/components/Tour/variatoins/_size/tokens.json +0 -1
- package/emotion/es/components/Tour/variatoins/_view/base.js +0 -2
- package/emotion/es/components/Tour/variatoins/_view/tokens.json +0 -1
- package/emotion/es/examples/plasma_b2c/components/Tour/Tour.config.js +0 -16
- package/emotion/es/examples/plasma_b2c/components/Tour/Tour.js +0 -5
- package/emotion/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
- package/emotion/es/examples/plasma_web/components/Tour/Tour.config.js +0 -16
- package/emotion/es/examples/plasma_web/components/Tour/Tour.js +0 -5
- package/emotion/es/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
- package/es/components/TextArea/variations/_size/base_1mq4sb2.css +0 -1
- package/es/components/TextField/variations/_size/base_ryad12.css +0 -1
- package/es/components/Tour/Tour.css +0 -4
- package/es/components/Tour/Tour.js +0 -222
- package/es/components/Tour/Tour.js.map +0 -1
- package/es/components/Tour/Tour.styles.js +0 -51
- package/es/components/Tour/Tour.styles.js.map +0 -1
- package/es/components/Tour/Tour.styles_hmd79i.css +0 -4
- package/es/components/Tour/Tour.tokens.js +0 -16
- package/es/components/Tour/Tour.tokens.js.map +0 -1
- package/es/components/Tour/utils/index.js +0 -107
- package/es/components/Tour/utils/index.js.map +0 -1
- package/es/components/Tour/variatoins/_size/base.js +0 -5
- package/es/components/Tour/variatoins/_size/base.js.map +0 -1
- package/es/components/Tour/variatoins/_size/base_x642ct.css +0 -1
- package/es/components/Tour/variatoins/_view/base.js +0 -5
- package/es/components/Tour/variatoins/_view/base.js.map +0 -1
- package/es/components/Tour/variatoins/_view/base_x642ct.css +0 -1
- package/styled-components/cjs/components/Tour/Tour.js +0 -240
- package/styled-components/cjs/components/Tour/Tour.styles.js +0 -29
- package/styled-components/cjs/components/Tour/Tour.tokens.js +0 -19
- package/styled-components/cjs/components/Tour/Tour.types.js +0 -5
- package/styled-components/cjs/components/Tour/index.js +0 -31
- package/styled-components/cjs/components/Tour/utils/index.js +0 -110
- package/styled-components/cjs/components/Tour/variatoins/_size/base.js +0 -8
- package/styled-components/cjs/components/Tour/variatoins/_size/tokens.json +0 -1
- package/styled-components/cjs/components/Tour/variatoins/_view/base.js +0 -8
- package/styled-components/cjs/components/Tour/variatoins/_view/tokens.json +0 -1
- package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.config.js +0 -22
- package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.js +0 -11
- package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
- package/styled-components/cjs/examples/plasma_web/components/Tour/Tour.config.js +0 -22
- package/styled-components/cjs/examples/plasma_web/components/Tour/Tour.js +0 -11
- package/styled-components/cjs/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
- package/styled-components/es/components/Tour/Tour.js +0 -232
- package/styled-components/es/components/Tour/Tour.styles.js +0 -22
- package/styled-components/es/components/Tour/Tour.tokens.js +0 -13
- package/styled-components/es/components/Tour/Tour.types.js +0 -1
- package/styled-components/es/components/Tour/index.js +0 -2
- package/styled-components/es/components/Tour/utils/index.js +0 -104
- package/styled-components/es/components/Tour/variatoins/_size/base.js +0 -2
- package/styled-components/es/components/Tour/variatoins/_size/tokens.json +0 -1
- package/styled-components/es/components/Tour/variatoins/_view/base.js +0 -2
- package/styled-components/es/components/Tour/variatoins/_view/tokens.json +0 -1
- package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.config.js +0 -16
- package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.js +0 -5
- package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +0 -299
- package/styled-components/es/examples/plasma_web/components/Tour/Tour.config.js +0 -16
- package/styled-components/es/examples/plasma_web/components/Tour/Tour.js +0 -5
- package/styled-components/es/examples/plasma_web/components/Tour/Tour.stories.tsx +0 -242
- package/types/components/Tour/Tour.d.ts +0 -23
- package/types/components/Tour/Tour.d.ts.map +0 -1
- package/types/components/Tour/Tour.styles.d.ts +0 -10
- package/types/components/Tour/Tour.styles.d.ts.map +0 -1
- package/types/components/Tour/Tour.tokens.d.ts +0 -14
- package/types/components/Tour/Tour.tokens.d.ts.map +0 -1
- package/types/components/Tour/Tour.types.d.ts +0 -86
- package/types/components/Tour/Tour.types.d.ts.map +0 -1
- package/types/components/Tour/index.d.ts +0 -4
- package/types/components/Tour/index.d.ts.map +0 -1
- package/types/components/Tour/utils/index.d.ts +0 -4
- package/types/components/Tour/utils/index.d.ts.map +0 -1
- package/types/components/Tour/variatoins/_size/base.d.ts +0 -2
- package/types/components/Tour/variatoins/_size/base.d.ts.map +0 -1
- package/types/components/Tour/variatoins/_view/base.d.ts +0 -2
- package/types/components/Tour/variatoins/_view/base.d.ts.map +0 -1
- /package/cjs/components/{Tour/variatoins → TextArea/variations}/_size/base_x642ct.css +0 -0
- /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
|
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)(
|
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== */"));
|
package/emotion/cjs/index.js
CHANGED
@@ -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]/
|