@salutejs/plasma-new-hope 0.328.0-canary.2048.15925099045.0 → 0.328.0-canary.2050.15924604410.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/NumberFormat/NumberFormat.js +38 -3
- package/cjs/components/NumberFormat/NumberFormat.js.map +1 -1
- package/cjs/components/TextField/TextField.js +20 -1
- package/cjs/components/TextField/TextField.js.map +1 -1
- package/emotion/cjs/components/NumberFormat/NumberFormat.js +82 -4
- package/emotion/cjs/components/TextField/TextField.js +21 -2
- package/emotion/es/components/NumberFormat/NumberFormat.js +83 -5
- package/emotion/es/components/TextField/TextField.js +21 -2
- package/es/components/NumberFormat/NumberFormat.js +40 -5
- package/es/components/NumberFormat/NumberFormat.js.map +1 -1
- package/es/components/TextField/TextField.js +20 -1
- package/es/components/TextField/TextField.js.map +1 -1
- package/package.json +4 -4
- package/styled-components/cjs/components/NumberFormat/NumberFormat.js +82 -4
- package/styled-components/cjs/components/TextField/TextField.js +20 -1
- package/styled-components/es/components/NumberFormat/NumberFormat.js +83 -5
- package/styled-components/es/components/TextField/TextField.js +20 -1
- package/types/components/NumberFormat/NumberFormat.d.ts.map +1 -1
- package/types/components/TextField/TextField.d.ts.map +1 -1
@@ -182,7 +182,7 @@ function _unsupported_iterable_to_array(o, minLen) {
|
|
182
182
|
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
183
183
|
}
|
184
184
|
var optionalText = 'optional';
|
185
|
-
var base = (0, /*#__PURE__*/ _react1.css)("display:block;", "base", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src-emotion/components/TextField/TextField.tsx","sources":["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 { useForkRef } from '@salutejs/plasma-core';\nimport { css } from '@emotion/react';\nimport { cx, safeUseId } from 'src/utils';\nimport type { RootProps } from 'src/engines';\nimport { useOutsideClick } from 'src/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                                    data-tour\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"],"names":[],"mappings":"AA+CoB"} */");
|
185
|
+
var base = (0, /*#__PURE__*/ _react1.css)("display:block;", "base", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src-emotion/components/TextField/TextField.tsx","sources":["src-emotion/components/TextField/TextField.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useRef, useState } from 'react';\nimport type {\n    FormEventHandler,\n    ChangeEventHandler,\n    KeyboardEvent,\n    ChangeEvent,\n    MouseEventHandler,\n    ClipboardEventHandler,\n} from 'react';\nimport { useForkRef } from '@salutejs/plasma-core';\nimport { css } from '@emotion/react';\nimport { cx, safeUseId } from 'src/utils';\nimport type { RootProps } from 'src/engines';\nimport { useOutsideClick } from 'src/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                onPaste,\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 handlePaste: ClipboardEventHandler<HTMLInputElement> = (event) => {\n                if (disabled || readOnly) {\n                    return;\n                }\n\n                if (onPaste) {\n                    onPaste(event);\n                }\n\n                if (hasTextAfter) {\n                    setTimeout(() => {\n                        if (!inputRef.current) {\n                            return;\n                        }\n\n                        const textWidth = getInputWidth(inputRef.current, inputContainerRef.current);\n                        inputRef.current.style.width = `${textWidth}px`;\n                    });\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                                    onPaste={handlePaste}\n                                    data-tour\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"],"names":[],"mappings":"AAsDoB"} */");
|
186
186
|
var HINT_DEFAULT_OFFSET = [
|
187
187
|
0,
|
188
188
|
0
|
@@ -194,7 +194,7 @@ var textFieldRoot = function(Root) {
|
|
194
194
|
hintTrigger, hintTrigger = _param_hintTrigger === void 0 ? 'hover' : _param_hintTrigger, hintText = _param.hintText, _param_hintView = _param.hintView, hintView = _param_hintView === void 0 ? 'default' : _param_hintView, _param_hintSize = _param.hintSize, hintSize = _param_hintSize === void 0 ? 'm' : _param_hintSize, hintTargetIcon = _param.hintTargetIcon, _param_hintTargetPlacement = _param.hintTargetPlacement, hintTargetPlacement = _param_hintTargetPlacement === void 0 ? 'outer' : _param_hintTargetPlacement, _param_hintPlacement = _param.hintPlacement, hintPlacement = _param_hintPlacement === void 0 ? 'auto' : _param_hintPlacement, hintHasArrow = _param.hintHasArrow, _param_hintOffset = _param.hintOffset, hintOffset = _param_hintOffset === void 0 ? HINT_DEFAULT_OFFSET : _param_hintOffset, hintWidth = _param.hintWidth, hintContentLeft = _param.hintContentLeft, // variations
|
195
195
|
view = _param.view, size = _param.size, _param_readOnly = _param.readOnly, readOnly = _param_readOnly === void 0 ? false : _param_readOnly, _param_disabled = _param.disabled, disabled = _param_disabled === void 0 ? false : _param_disabled, _param_required = _param.required, required = _param_required === void 0 ? false : _param_required, _param_clear = _param.clear, clear = _param_clear === void 0 ? false : _param_clear, optional = _param.optional, hasDivider = _param.hasDivider, // controlled
|
196
196
|
outerValue = _param.value, values = _param.chips, _param_chipType = _param.chipType, chipType = _param_chipType === void 0 ? 'default' : _param_chipType, // events
|
197
|
-
onChange = _param.onChange, onChangeChips = _param.onChangeChips, onSearch = _param.onSearch, onKeyDown = _param.onKeyDown, onFocus = _param.onFocus, onBlur = _param.onBlur, // Пропсы для внутреннего использования, не отдается наружу.
|
197
|
+
onChange = _param.onChange, onChangeChips = _param.onChangeChips, onSearch = _param.onSearch, onKeyDown = _param.onKeyDown, onFocus = _param.onFocus, onBlur = _param.onBlur, onPaste = _param.onPaste, // Пропсы для внутреннего использования, не отдается наружу.
|
198
198
|
// @ts-ignore
|
199
199
|
_onEnterDisabled = _param._onEnterDisabled, // @ts-ignore
|
200
200
|
_forceChipManipulationWithReadonly = _param._forceChipManipulationWithReadonly, rest = _object_without_properties(_param, [
|
@@ -244,6 +244,7 @@ var textFieldRoot = function(Root) {
|
|
244
244
|
"onKeyDown",
|
245
245
|
"onFocus",
|
246
246
|
"onBlur",
|
247
|
+
"onPaste",
|
247
248
|
"_onEnterDisabled",
|
248
249
|
"_forceChipManipulationWithReadonly"
|
249
250
|
]);
|
@@ -359,6 +360,23 @@ var textFieldRoot = function(Root) {
|
|
359
360
|
event.currentTarget.style.width = "".concat(textWidth, "px");
|
360
361
|
}
|
361
362
|
};
|
363
|
+
var handlePaste = function(event) {
|
364
|
+
if (disabled || readOnly) {
|
365
|
+
return;
|
366
|
+
}
|
367
|
+
if (onPaste) {
|
368
|
+
onPaste(event);
|
369
|
+
}
|
370
|
+
if (hasTextAfter) {
|
371
|
+
setTimeout(function() {
|
372
|
+
if (!inputRef.current) {
|
373
|
+
return;
|
374
|
+
}
|
375
|
+
var textWidth = (0, _getInputWidth.getInputWidth)(inputRef.current, inputContainerRef.current);
|
376
|
+
inputRef.current.style.width = "".concat(textWidth, "px");
|
377
|
+
});
|
378
|
+
}
|
379
|
+
};
|
362
380
|
var updateChips = function(newChips, newValues) {
|
363
381
|
setChips(newChips);
|
364
382
|
onChangeChips === null || onChangeChips === void 0 ? void 0 : onChangeChips(newValues);
|
@@ -552,6 +570,7 @@ var textFieldRoot = function(Root) {
|
|
552
570
|
onKeyDown: handleOnKeyDown,
|
553
571
|
onFocus: handleFocus,
|
554
572
|
onBlur: handleBlur,
|
573
|
+
onPaste: handlePaste,
|
555
574
|
"data-tour": true
|
556
575
|
}, rest)), hasInnerLabel && /*#__PURE__*/ _react.default.createElement(_TextFieldstyles.Label, {
|
557
576
|
"data-root": true,
|
@@ -1,3 +1,11 @@
|
|
1
|
+
function _array_like_to_array(arr, len) {
|
2
|
+
if (len == null || len > arr.length) len = arr.length;
|
3
|
+
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
4
|
+
return arr2;
|
5
|
+
}
|
6
|
+
function _array_with_holes(arr) {
|
7
|
+
if (Array.isArray(arr)) return arr;
|
8
|
+
}
|
1
9
|
function _define_property(obj, key, value) {
|
2
10
|
if (key in obj) {
|
3
11
|
Object.defineProperty(obj, key, {
|
@@ -11,6 +19,33 @@ function _define_property(obj, key, value) {
|
|
11
19
|
}
|
12
20
|
return obj;
|
13
21
|
}
|
22
|
+
function _iterable_to_array_limit(arr, i) {
|
23
|
+
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
|
24
|
+
if (_i == null) return;
|
25
|
+
var _arr = [];
|
26
|
+
var _n = true;
|
27
|
+
var _d = false;
|
28
|
+
var _s, _e;
|
29
|
+
try {
|
30
|
+
for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
|
31
|
+
_arr.push(_s.value);
|
32
|
+
if (i && _arr.length === i) break;
|
33
|
+
}
|
34
|
+
} catch (err) {
|
35
|
+
_d = true;
|
36
|
+
_e = err;
|
37
|
+
} finally{
|
38
|
+
try {
|
39
|
+
if (!_n && _i["return"] != null) _i["return"]();
|
40
|
+
} finally{
|
41
|
+
if (_d) throw _e;
|
42
|
+
}
|
43
|
+
}
|
44
|
+
return _arr;
|
45
|
+
}
|
46
|
+
function _non_iterable_rest() {
|
47
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
48
|
+
}
|
14
49
|
function _object_spread(target) {
|
15
50
|
for(var i = 1; i < arguments.length; i++){
|
16
51
|
var source = arguments[i] != null ? arguments[i] : {};
|
@@ -53,30 +88,73 @@ function _object_without_properties_loose(source, excluded) {
|
|
53
88
|
}
|
54
89
|
return target;
|
55
90
|
}
|
56
|
-
|
91
|
+
function _sliced_to_array(arr, i) {
|
92
|
+
return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
|
93
|
+
}
|
94
|
+
function _unsupported_iterable_to_array(o, minLen) {
|
95
|
+
if (!o) return;
|
96
|
+
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
97
|
+
var n = Object.prototype.toString.call(o).slice(8, -1);
|
98
|
+
if (n === "Object" && o.constructor) n = o.constructor.name;
|
99
|
+
if (n === "Map" || n === "Set") return Array.from(n);
|
100
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
101
|
+
}
|
102
|
+
import React, { forwardRef, useRef, useState } from "react";
|
57
103
|
import { NumericFormat } from "react-number-format";
|
104
|
+
import { useForkRef } from "@salutejs/plasma-core";
|
58
105
|
export var composeNumberFormat = function(InputComponent) {
|
59
106
|
return /*#__PURE__*/ forwardRef(function(_param, outerRef) {
|
60
|
-
var _param_thousandSeparator = _param.thousandSeparator, thousandSeparator = _param_thousandSeparator === void 0 ? ' ' : _param_thousandSeparator, _param_decimalScale = _param.decimalScale, decimalScale = _param_decimalScale === void 0 ? 3 : _param_decimalScale, _param_decimalSeparator = _param.decimalSeparator, decimalSeparator = _param_decimalSeparator === void 0 ? '.' : _param_decimalSeparator, onChange = _param.onChange, rest = _object_without_properties(_param, [
|
107
|
+
var _param_thousandSeparator = _param.thousandSeparator, thousandSeparator = _param_thousandSeparator === void 0 ? ' ' : _param_thousandSeparator, _param_decimalScale = _param.decimalScale, decimalScale = _param_decimalScale === void 0 ? 3 : _param_decimalScale, _param_decimalSeparator = _param.decimalSeparator, decimalSeparator = _param_decimalSeparator === void 0 ? '.' : _param_decimalSeparator, disabled = _param.disabled, value = _param.value, onChange = _param.onChange, onPaste = _param.onPaste, rest = _object_without_properties(_param, [
|
61
108
|
"thousandSeparator",
|
62
109
|
"decimalScale",
|
63
110
|
"decimalSeparator",
|
64
|
-
"
|
111
|
+
"disabled",
|
112
|
+
"value",
|
113
|
+
"onChange",
|
114
|
+
"onPaste"
|
65
115
|
]);
|
116
|
+
var inputRef = useRef(null);
|
117
|
+
var inputForkRef = useForkRef(inputRef, outerRef);
|
118
|
+
var _useState = _sliced_to_array(useState(value), 2), innerValue = _useState[0], setInnerValue = _useState[1];
|
66
119
|
var handleChangeValue = function(values, sourceInfo) {
|
67
120
|
if (onChange) {
|
68
121
|
var changeEvent = sourceInfo.event;
|
122
|
+
setInnerValue(values.value);
|
69
123
|
onChange(changeEvent, values);
|
70
124
|
}
|
71
125
|
};
|
126
|
+
var handlePaste = function(event) {
|
127
|
+
if (disabled) {
|
128
|
+
return;
|
129
|
+
}
|
130
|
+
if (decimalSeparator !== '.' && inputRef.current) {
|
131
|
+
if (!Number.isNaN(Number(event.clipboardData.getData('text/plain')))) {
|
132
|
+
event.preventDefault();
|
133
|
+
var pastedValue = event.clipboardData.getData('text/plain').replace('.', decimalSeparator);
|
134
|
+
var input = event.target;
|
135
|
+
var startPos = input.selectionStart || 0;
|
136
|
+
var newCursorPos = startPos + pastedValue.length;
|
137
|
+
setInnerValue(pastedValue);
|
138
|
+
setTimeout(function() {
|
139
|
+
var _inputRef_current;
|
140
|
+
(_inputRef_current = inputRef.current) === null || _inputRef_current === void 0 ? void 0 : _inputRef_current.setSelectionRange(newCursorPos, newCursorPos);
|
141
|
+
}, 10);
|
142
|
+
}
|
143
|
+
}
|
144
|
+
if (onPaste) {
|
145
|
+
onPaste(event);
|
146
|
+
}
|
147
|
+
};
|
72
148
|
return /*#__PURE__*/ React.createElement(NumericFormat, _object_spread({
|
149
|
+
value: innerValue,
|
73
150
|
thousandSeparator: thousandSeparator,
|
74
151
|
decimalScale: decimalScale,
|
75
152
|
decimalSeparator: decimalSeparator,
|
76
153
|
customInput: InputComponent,
|
77
|
-
getInputRef:
|
154
|
+
getInputRef: inputForkRef,
|
78
155
|
_textEllipsisDisable: true,
|
79
|
-
onValueChange: handleChangeValue
|
156
|
+
onValueChange: handleChangeValue,
|
157
|
+
onPaste: handlePaste
|
80
158
|
}, rest));
|
81
159
|
});
|
82
160
|
};
|
@@ -120,7 +120,7 @@ import { useKeyNavigation } from "./hooks";
|
|
120
120
|
import { HintComponent } from "./ui/Hint/Hint";
|
121
121
|
import { getInputWidth } from "./getInputWidth";
|
122
122
|
var optionalText = 'optional';
|
123
|
-
export var base = /*#__PURE__*/ css("display:block;", "base", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src-emotion/components/TextField/TextField.tsx","sources":["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 { useForkRef } from '@salutejs/plasma-core';\nimport { css } from '@emotion/react';\nimport { cx, safeUseId } from 'src/utils';\nimport type { RootProps } from 'src/engines';\nimport { useOutsideClick } from 'src/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                                    data-tour\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"],"names":[],"mappings":"AA+CoB"} */");
|
123
|
+
export var base = /*#__PURE__*/ css("display:block;", "base", "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src-emotion/components/TextField/TextField.tsx","sources":["src-emotion/components/TextField/TextField.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useRef, useState } from 'react';\nimport type {\n    FormEventHandler,\n    ChangeEventHandler,\n    KeyboardEvent,\n    ChangeEvent,\n    MouseEventHandler,\n    ClipboardEventHandler,\n} from 'react';\nimport { useForkRef } from '@salutejs/plasma-core';\nimport { css } from '@emotion/react';\nimport { cx, safeUseId } from 'src/utils';\nimport type { RootProps } from 'src/engines';\nimport { useOutsideClick } from 'src/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                onPaste,\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 handlePaste: ClipboardEventHandler<HTMLInputElement> = (event) => {\n                if (disabled || readOnly) {\n                    return;\n                }\n\n                if (onPaste) {\n                    onPaste(event);\n                }\n\n                if (hasTextAfter) {\n                    setTimeout(() => {\n                        if (!inputRef.current) {\n                            return;\n                        }\n\n                        const textWidth = getInputWidth(inputRef.current, inputContainerRef.current);\n                        inputRef.current.style.width = `${textWidth}px`;\n                    });\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                                    onPaste={handlePaste}\n                                    data-tour\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"],"names":[],"mappings":"AAsDoB"} */");
|
124
124
|
var HINT_DEFAULT_OFFSET = [
|
125
125
|
0,
|
126
126
|
0
|
@@ -132,7 +132,7 @@ export var textFieldRoot = function(Root) {
|
|
132
132
|
hintTrigger, hintTrigger = _param_hintTrigger === void 0 ? 'hover' : _param_hintTrigger, hintText = _param.hintText, _param_hintView = _param.hintView, hintView = _param_hintView === void 0 ? 'default' : _param_hintView, _param_hintSize = _param.hintSize, hintSize = _param_hintSize === void 0 ? 'm' : _param_hintSize, hintTargetIcon = _param.hintTargetIcon, _param_hintTargetPlacement = _param.hintTargetPlacement, hintTargetPlacement = _param_hintTargetPlacement === void 0 ? 'outer' : _param_hintTargetPlacement, _param_hintPlacement = _param.hintPlacement, hintPlacement = _param_hintPlacement === void 0 ? 'auto' : _param_hintPlacement, hintHasArrow = _param.hintHasArrow, _param_hintOffset = _param.hintOffset, hintOffset = _param_hintOffset === void 0 ? HINT_DEFAULT_OFFSET : _param_hintOffset, hintWidth = _param.hintWidth, hintContentLeft = _param.hintContentLeft, // variations
|
133
133
|
view = _param.view, size = _param.size, _param_readOnly = _param.readOnly, readOnly = _param_readOnly === void 0 ? false : _param_readOnly, _param_disabled = _param.disabled, disabled = _param_disabled === void 0 ? false : _param_disabled, _param_required = _param.required, required = _param_required === void 0 ? false : _param_required, _param_clear = _param.clear, clear = _param_clear === void 0 ? false : _param_clear, optional = _param.optional, hasDivider = _param.hasDivider, // controlled
|
134
134
|
outerValue = _param.value, values = _param.chips, _param_chipType = _param.chipType, chipType = _param_chipType === void 0 ? 'default' : _param_chipType, // events
|
135
|
-
onChange = _param.onChange, onChangeChips = _param.onChangeChips, onSearch = _param.onSearch, onKeyDown = _param.onKeyDown, onFocus = _param.onFocus, onBlur = _param.onBlur, // Пропсы для внутреннего использования, не отдается наружу.
|
135
|
+
onChange = _param.onChange, onChangeChips = _param.onChangeChips, onSearch = _param.onSearch, onKeyDown = _param.onKeyDown, onFocus = _param.onFocus, onBlur = _param.onBlur, onPaste = _param.onPaste, // Пропсы для внутреннего использования, не отдается наружу.
|
136
136
|
// @ts-ignore
|
137
137
|
_onEnterDisabled = _param._onEnterDisabled, // @ts-ignore
|
138
138
|
_forceChipManipulationWithReadonly = _param._forceChipManipulationWithReadonly, rest = _object_without_properties(_param, [
|
@@ -182,6 +182,7 @@ export var textFieldRoot = function(Root) {
|
|
182
182
|
"onKeyDown",
|
183
183
|
"onFocus",
|
184
184
|
"onBlur",
|
185
|
+
"onPaste",
|
185
186
|
"_onEnterDisabled",
|
186
187
|
"_forceChipManipulationWithReadonly"
|
187
188
|
]);
|
@@ -297,6 +298,23 @@ export var textFieldRoot = function(Root) {
|
|
297
298
|
event.currentTarget.style.width = "".concat(textWidth, "px");
|
298
299
|
}
|
299
300
|
};
|
301
|
+
var handlePaste = function(event) {
|
302
|
+
if (disabled || readOnly) {
|
303
|
+
return;
|
304
|
+
}
|
305
|
+
if (onPaste) {
|
306
|
+
onPaste(event);
|
307
|
+
}
|
308
|
+
if (hasTextAfter) {
|
309
|
+
setTimeout(function() {
|
310
|
+
if (!inputRef.current) {
|
311
|
+
return;
|
312
|
+
}
|
313
|
+
var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
|
314
|
+
inputRef.current.style.width = "".concat(textWidth, "px");
|
315
|
+
});
|
316
|
+
}
|
317
|
+
};
|
300
318
|
var updateChips = function(newChips, newValues) {
|
301
319
|
setChips(newChips);
|
302
320
|
onChangeChips === null || onChangeChips === void 0 ? void 0 : onChangeChips(newValues);
|
@@ -490,6 +508,7 @@ export var textFieldRoot = function(Root) {
|
|
490
508
|
onKeyDown: handleOnKeyDown,
|
491
509
|
onFocus: handleFocus,
|
492
510
|
onBlur: handleBlur,
|
511
|
+
onPaste: handlePaste,
|
493
512
|
"data-tour": true
|
494
513
|
}, rest)), hasInnerLabel && /*#__PURE__*/ React.createElement(Label, {
|
495
514
|
"data-root": true,
|