@salutejs/plasma-new-hope 0.330.0-canary.2009.16048670450.0 → 0.330.0-canary.2050.16051901455.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.
@@ -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\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            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                if (onChange) {\n                    onChange(event);\n                }\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 (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, outerValue]);\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
  ]);
@@ -246,17 +247,6 @@ export var textFieldRoot = function(Root) {
246
247
  var value = event.target.value;
247
248
  setHasValue(Boolean(value));
248
249
  };
249
- useEffect(function() {
250
- if (hasTextAfter && inputRef.current) {
251
- var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
252
- inputRef.current.style.width = "".concat(textWidth, "px");
253
- } else {
254
- var _inputRef_current;
255
- (_inputRef_current = inputRef.current) === null || _inputRef_current === void 0 ? void 0 : _inputRef_current.style.removeProperty('width');
256
- }
257
- }, [
258
- hasTextAfter
259
- ]);
260
250
  var handleFocus = function(event) {
261
251
  setHasFocus(true);
262
252
  onFocus === null || onFocus === void 0 ? void 0 : onFocus(event);
@@ -291,12 +281,31 @@ export var textFieldRoot = function(Root) {
291
281
  if (maxLength !== -1 && value.length > maxLength) {
292
282
  return;
293
283
  }
294
- onChange === null || onChange === void 0 ? void 0 : onChange(event);
284
+ if (onChange) {
285
+ onChange(event);
286
+ }
295
287
  if (hasTextAfter) {
296
288
  var textWidth = getInputWidth(event.currentTarget, inputContainerRef.current);
297
289
  event.currentTarget.style.width = "".concat(textWidth, "px");
298
290
  }
299
291
  };
292
+ var handlePaste = function(event) {
293
+ if (disabled || readOnly) {
294
+ return;
295
+ }
296
+ if (onPaste) {
297
+ onPaste(event);
298
+ }
299
+ if (hasTextAfter) {
300
+ setTimeout(function() {
301
+ if (!inputRef.current) {
302
+ return;
303
+ }
304
+ var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
305
+ inputRef.current.style.width = "".concat(textWidth, "px");
306
+ });
307
+ }
308
+ };
300
309
  var updateChips = function(newChips, newValues) {
301
310
  setChips(newChips);
302
311
  onChangeChips === null || onChangeChips === void 0 ? void 0 : onChangeChips(newValues);
@@ -337,6 +346,18 @@ export var textFieldRoot = function(Root) {
337
346
  onKeyDown(event);
338
347
  }
339
348
  };
349
+ useEffect(function() {
350
+ if (hasTextAfter && inputRef.current) {
351
+ var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
352
+ inputRef.current.style.width = "".concat(textWidth, "px");
353
+ } else {
354
+ var _inputRef_current;
355
+ (_inputRef_current = inputRef.current) === null || _inputRef_current === void 0 ? void 0 : _inputRef_current.style.removeProperty('width');
356
+ }
357
+ }, [
358
+ hasTextAfter,
359
+ outerValue
360
+ ]);
340
361
  useEffect(function() {
341
362
  if (!isChipEnumeration && !(values === null || values === void 0 ? void 0 : values.length)) {
342
363
  return;
@@ -490,6 +511,7 @@ export var textFieldRoot = function(Root) {
490
511
  onKeyDown: handleOnKeyDown,
491
512
  onFocus: handleFocus,
492
513
  onBlur: handleBlur,
514
+ onPaste: handlePaste,
493
515
  "data-tour": true
494
516
  }, rest)), hasInnerLabel && /*#__PURE__*/ React.createElement(Label, {
495
517
  "data-root": true,
@@ -1,8 +1,9 @@
1
- import { objectWithoutProperties as _objectWithoutProperties, extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
- import React, { forwardRef } from 'react';
3
- import { NumericFormat } from 'react-number-format';
1
+ import { objectWithoutProperties as _objectWithoutProperties, slicedToArray as _slicedToArray, extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
+ import React, { forwardRef, useRef, useState, useEffect } from 'react';
3
+ import { numericFormatter, NumericFormat } from 'react-number-format';
4
+ import { useForkRef } from '@salutejs/plasma-core';
4
5
 
5
- var _excluded = ["thousandSeparator", "decimalScale", "decimalSeparator", "onChange"];
6
+ var _excluded = ["thousandSeparator", "decimalScale", "decimalSeparator", "disabled", "value", "onChange", "onPaste"];
6
7
  var composeNumberFormat = function composeNumberFormat(InputComponent) {
7
8
  return /*#__PURE__*/forwardRef(function (_ref, outerRef) {
8
9
  var _ref$thousandSeparato = _ref.thousandSeparator,
@@ -11,22 +12,67 @@ var composeNumberFormat = function composeNumberFormat(InputComponent) {
11
12
  decimalScale = _ref$decimalScale === void 0 ? 3 : _ref$decimalScale,
12
13
  _ref$decimalSeparator = _ref.decimalSeparator,
13
14
  decimalSeparator = _ref$decimalSeparator === void 0 ? '.' : _ref$decimalSeparator,
15
+ disabled = _ref.disabled,
16
+ value = _ref.value,
14
17
  onChange = _ref.onChange,
18
+ onPaste = _ref.onPaste,
15
19
  rest = _objectWithoutProperties(_ref, _excluded);
20
+ var inputRef = useRef(null);
21
+ var inputForkRef = useForkRef(inputRef, outerRef);
22
+ var _useState = useState(value ? numericFormatter(String(value), {
23
+ thousandSeparator: thousandSeparator,
24
+ decimalScale: decimalScale,
25
+ decimalSeparator: decimalSeparator
26
+ }) : ''),
27
+ _useState2 = _slicedToArray(_useState, 2),
28
+ innerValue = _useState2[0],
29
+ setInnerValue = _useState2[1];
16
30
  var handleChangeValue = function handleChangeValue(values, sourceInfo) {
17
31
  if (onChange) {
18
32
  var changeEvent = sourceInfo.event;
33
+ setInnerValue(values.value);
19
34
  onChange(changeEvent, values);
20
35
  }
21
36
  };
37
+ var handlePaste = function handlePaste(event) {
38
+ if (disabled) {
39
+ return;
40
+ }
41
+ if (decimalSeparator !== '.' && inputRef.current) {
42
+ if (!Number.isNaN(Number(event.clipboardData.getData('text/plain')))) {
43
+ event.preventDefault();
44
+ var pastedValue = event.clipboardData.getData('text/plain').replace('.', decimalSeparator);
45
+ var input = event.target;
46
+ var startPos = input.selectionStart || 0;
47
+ var newCursorPos = startPos + pastedValue.length;
48
+ setInnerValue(pastedValue);
49
+ setTimeout(function () {
50
+ var _inputRef$current;
51
+ (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 || _inputRef$current.setSelectionRange(newCursorPos, newCursorPos);
52
+ }, 10);
53
+ }
54
+ }
55
+ if (onPaste) {
56
+ onPaste(event);
57
+ }
58
+ };
59
+ useEffect(function () {
60
+ setInnerValue(value ? numericFormatter(String(value), {
61
+ thousandSeparator: thousandSeparator,
62
+ decimalScale: decimalScale,
63
+ decimalSeparator: decimalSeparator
64
+ }) : '');
65
+ }, [value]);
22
66
  return /*#__PURE__*/React.createElement(NumericFormat, _extends({
67
+ value: innerValue,
23
68
  thousandSeparator: thousandSeparator,
24
69
  decimalScale: decimalScale,
25
70
  decimalSeparator: decimalSeparator,
26
71
  customInput: InputComponent,
27
- getInputRef: outerRef,
72
+ getInputRef: inputForkRef,
28
73
  _textEllipsisDisable: true,
29
- onValueChange: handleChangeValue
74
+ onValueChange: handleChangeValue,
75
+ onPaste: handlePaste
30
76
  }, rest));
31
77
  });
32
78
  };
@@ -1 +1 @@
1
- {"version":3,"file":"NumberFormat.js","sources":["../../../src/components/NumberFormat/NumberFormat.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport type { ChangeEvent, FC } from 'react';\nimport { NumericFormat } from 'react-number-format';\nimport type { NumberFormatValues, SourceInfo } from 'react-number-format';\n\nimport type {\n CustomNumberFormatProps,\n CustomNumericFormatProps,\n InputComponentOmittedProps,\n} from './NumberFormat.types';\n\nexport const composeNumberFormat = <T extends InputComponentOmittedProps>(InputComponent: FC<T>) => {\n return forwardRef<HTMLInputElement, T & CustomNumberFormatProps & CustomNumericFormatProps>(\n ({ thousandSeparator = ' ', decimalScale = 3, decimalSeparator = '.', onChange, ...rest }, outerRef) => {\n const handleChangeValue = (values: NumberFormatValues, sourceInfo: SourceInfo) => {\n if (onChange) {\n const changeEvent = sourceInfo.event as ChangeEvent<HTMLInputElement>;\n onChange(changeEvent, values);\n }\n };\n\n return (\n <NumericFormat\n thousandSeparator={thousandSeparator}\n decimalScale={decimalScale}\n decimalSeparator={decimalSeparator}\n customInput={InputComponent}\n getInputRef={outerRef}\n _textEllipsisDisable\n onValueChange={handleChangeValue}\n {...rest}\n />\n );\n },\n );\n};\n"],"names":["composeNumberFormat","InputComponent","forwardRef","_ref","outerRef","_ref$thousandSeparato","thousandSeparator","_ref$decimalScale","decimalScale","_ref$decimalSeparator","decimalSeparator","onChange","rest","_objectWithoutProperties","_excluded","handleChangeValue","values","sourceInfo","changeEvent","event","React","createElement","NumericFormat","_extends","customInput","getInputRef","_textEllipsisDisable","onValueChange"],"mappings":";;;;;IAWaA,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAA0CC,cAAqB,EAAK;AAChG,EAAA,oBAAOC,UAAU,CACb,UAAAC,IAAA,EAA2FC,QAAQ,EAAK;AAAA,IAAA,IAAAC,qBAAA,GAAAF,IAAA,CAArGG,iBAAiB;AAAjBA,MAAAA,iBAAiB,GAAAD,qBAAA,KAAG,KAAA,CAAA,GAAA,GAAG,GAAAA,qBAAA;MAAAE,iBAAA,GAAAJ,IAAA,CAAEK,YAAY;AAAZA,MAAAA,YAAY,GAAAD,iBAAA,KAAG,KAAA,CAAA,GAAA,CAAC,GAAAA,iBAAA;MAAAE,qBAAA,GAAAN,IAAA,CAAEO,gBAAgB;AAAhBA,MAAAA,gBAAgB,GAAAD,qBAAA,KAAG,KAAA,CAAA,GAAA,GAAG,GAAAA,qBAAA;MAAEE,QAAQ,GAAAR,IAAA,CAARQ,QAAQ;AAAKC,MAAAA,IAAI,GAAAC,wBAAA,CAAAV,IAAA,EAAAW,SAAA,CAAA,CAAA;IACnF,IAAMC,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,MAA0B,EAAEC,UAAsB,EAAK;AAC9E,MAAA,IAAIN,QAAQ,EAAE;AACV,QAAA,IAAMO,WAAW,GAAGD,UAAU,CAACE,KAAsC,CAAA;AACrER,QAAAA,QAAQ,CAACO,WAAW,EAAEF,MAAM,CAAC,CAAA;AACjC,OAAA;KACH,CAAA;AAED,IAAA,oBACII,KAAA,CAAAC,aAAA,CAACC,aAAa,EAAAC,QAAA,CAAA;AACVjB,MAAAA,iBAAiB,EAAEA,iBAAkB;AACrCE,MAAAA,YAAY,EAAEA,YAAa;AAC3BE,MAAAA,gBAAgB,EAAEA,gBAAiB;AACnCc,MAAAA,WAAW,EAAEvB,cAAe;AAC5BwB,MAAAA,WAAW,EAAErB,QAAS;MACtBsB,oBAAoB,EAAA,IAAA;AACpBC,MAAAA,aAAa,EAAEZ,iBAAAA;KACXH,EAAAA,IAAI,CACX,CAAC,CAAA;AAEV,GACJ,CAAC,CAAA;AACL;;;;"}
1
+ {"version":3,"file":"NumberFormat.js","sources":["../../../src/components/NumberFormat/NumberFormat.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useRef, useState } from 'react';\nimport type { ChangeEvent, FC, ClipboardEvent } from 'react';\nimport { NumericFormat, numericFormatter } from 'react-number-format';\nimport type { NumberFormatValues, SourceInfo } from 'react-number-format';\nimport { useForkRef } from '@salutejs/plasma-core';\n\nimport type {\n CustomNumberFormatProps,\n CustomNumericFormatProps,\n InputComponentOmittedProps,\n} from './NumberFormat.types';\n\nexport const composeNumberFormat = <T extends InputComponentOmittedProps>(InputComponent: FC<T>) => {\n return forwardRef<HTMLInputElement, T & CustomNumberFormatProps & CustomNumericFormatProps>(\n (\n {\n thousandSeparator = ' ',\n decimalScale = 3,\n decimalSeparator = '.',\n disabled,\n value,\n onChange,\n onPaste,\n ...rest\n },\n outerRef,\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const inputForkRef = useForkRef(inputRef, outerRef);\n\n const [innerValue, setInnerValue] = useState(\n value ? numericFormatter(String(value), { thousandSeparator, decimalScale, decimalSeparator }) : '',\n );\n\n const handleChangeValue = (values: NumberFormatValues, sourceInfo: SourceInfo) => {\n if (onChange) {\n const changeEvent = sourceInfo.event as ChangeEvent<HTMLInputElement>;\n setInnerValue(values.value);\n onChange(changeEvent, values);\n }\n };\n\n const handlePaste = (event: ClipboardEvent<HTMLInputElement>) => {\n if (disabled) {\n return;\n }\n\n if (decimalSeparator !== '.' && inputRef.current) {\n if (!Number.isNaN(Number(event.clipboardData.getData('text/plain')))) {\n event.preventDefault();\n\n const pastedValue = event.clipboardData.getData('text/plain').replace('.', decimalSeparator);\n const input = event.target as HTMLInputElement;\n const startPos = input.selectionStart || 0;\n\n const newCursorPos = startPos + pastedValue.length;\n setInnerValue(pastedValue);\n\n setTimeout(() => {\n inputRef.current?.setSelectionRange(newCursorPos, newCursorPos);\n }, 10);\n }\n }\n\n if (onPaste) {\n onPaste(event);\n }\n };\n\n useEffect(() => {\n setInnerValue(\n value ? numericFormatter(String(value), { thousandSeparator, decimalScale, decimalSeparator }) : '',\n );\n }, [value]);\n\n return (\n <NumericFormat\n value={innerValue}\n thousandSeparator={thousandSeparator}\n decimalScale={decimalScale}\n decimalSeparator={decimalSeparator}\n customInput={InputComponent}\n getInputRef={inputForkRef}\n _textEllipsisDisable\n onValueChange={handleChangeValue}\n onPaste={handlePaste}\n {...rest}\n />\n );\n },\n );\n};\n"],"names":["composeNumberFormat","InputComponent","forwardRef","_ref","outerRef","_ref$thousandSeparato","thousandSeparator","_ref$decimalScale","decimalScale","_ref$decimalSeparator","decimalSeparator","disabled","value","onChange","onPaste","rest","_objectWithoutProperties","_excluded","inputRef","useRef","inputForkRef","useForkRef","_useState","useState","numericFormatter","String","_useState2","_slicedToArray","innerValue","setInnerValue","handleChangeValue","values","sourceInfo","changeEvent","event","handlePaste","current","Number","isNaN","clipboardData","getData","preventDefault","pastedValue","replace","input","target","startPos","selectionStart","newCursorPos","length","setTimeout","_inputRef$current","setSelectionRange","useEffect","React","createElement","NumericFormat","_extends","customInput","getInputRef","_textEllipsisDisable","onValueChange"],"mappings":";;;;;;IAYaA,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAA0CC,cAAqB,EAAK;AAChG,EAAA,oBAAOC,UAAU,CACb,UAAAC,IAAA,EAWIC,QAAQ,EACP;AAAA,IAAA,IAAAC,qBAAA,GAAAF,IAAA,CAVGG,iBAAiB;AAAjBA,MAAAA,iBAAiB,GAAAD,qBAAA,KAAG,KAAA,CAAA,GAAA,GAAG,GAAAA,qBAAA;MAAAE,iBAAA,GAAAJ,IAAA,CACvBK,YAAY;AAAZA,MAAAA,YAAY,GAAAD,iBAAA,KAAG,KAAA,CAAA,GAAA,CAAC,GAAAA,iBAAA;MAAAE,qBAAA,GAAAN,IAAA,CAChBO,gBAAgB;AAAhBA,MAAAA,gBAAgB,GAAAD,qBAAA,KAAG,KAAA,CAAA,GAAA,GAAG,GAAAA,qBAAA;MACtBE,QAAQ,GAAAR,IAAA,CAARQ,QAAQ;MACRC,KAAK,GAAAT,IAAA,CAALS,KAAK;MACLC,QAAQ,GAAAV,IAAA,CAARU,QAAQ;MACRC,OAAO,GAAAX,IAAA,CAAPW,OAAO;AACJC,MAAAA,IAAI,GAAAC,wBAAA,CAAAb,IAAA,EAAAc,SAAA,CAAA,CAAA;AAIX,IAAA,IAAMC,QAAQ,GAAGC,MAAM,CAAmB,IAAI,CAAC,CAAA;AAC/C,IAAA,IAAMC,YAAY,GAAGC,UAAU,CAACH,QAAQ,EAAEd,QAAQ,CAAC,CAAA;AAEnD,IAAA,IAAAkB,SAAA,GAAoCC,QAAQ,CACxCX,KAAK,GAAGY,gBAAgB,CAACC,MAAM,CAACb,KAAK,CAAC,EAAE;AAAEN,QAAAA,iBAAiB,EAAjBA,iBAAiB;AAAEE,QAAAA,YAAY,EAAZA,YAAY;AAAEE,QAAAA,gBAAgB,EAAhBA,gBAAAA;OAAkB,CAAC,GAAG,EACrG,CAAC;MAAAgB,UAAA,GAAAC,cAAA,CAAAL,SAAA,EAAA,CAAA,CAAA;AAFMM,MAAAA,UAAU,GAAAF,UAAA,CAAA,CAAA,CAAA;AAAEG,MAAAA,aAAa,GAAAH,UAAA,CAAA,CAAA,CAAA,CAAA;IAIhC,IAAMI,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,MAA0B,EAAEC,UAAsB,EAAK;AAC9E,MAAA,IAAInB,QAAQ,EAAE;AACV,QAAA,IAAMoB,WAAW,GAAGD,UAAU,CAACE,KAAsC,CAAA;AACrEL,QAAAA,aAAa,CAACE,MAAM,CAACnB,KAAK,CAAC,CAAA;AAC3BC,QAAAA,QAAQ,CAACoB,WAAW,EAAEF,MAAM,CAAC,CAAA;AACjC,OAAA;KACH,CAAA;AAED,IAAA,IAAMI,WAAW,GAAG,SAAdA,WAAWA,CAAID,KAAuC,EAAK;AAC7D,MAAA,IAAIvB,QAAQ,EAAE;AACV,QAAA,OAAA;AACJ,OAAA;AAEA,MAAA,IAAID,gBAAgB,KAAK,GAAG,IAAIQ,QAAQ,CAACkB,OAAO,EAAE;AAC9C,QAAA,IAAI,CAACC,MAAM,CAACC,KAAK,CAACD,MAAM,CAACH,KAAK,CAACK,aAAa,CAACC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;UAClEN,KAAK,CAACO,cAAc,EAAE,CAAA;AAEtB,UAAA,IAAMC,WAAW,GAAGR,KAAK,CAACK,aAAa,CAACC,OAAO,CAAC,YAAY,CAAC,CAACG,OAAO,CAAC,GAAG,EAAEjC,gBAAgB,CAAC,CAAA;AAC5F,UAAA,IAAMkC,KAAK,GAAGV,KAAK,CAACW,MAA0B,CAAA;AAC9C,UAAA,IAAMC,QAAQ,GAAGF,KAAK,CAACG,cAAc,IAAI,CAAC,CAAA;AAE1C,UAAA,IAAMC,YAAY,GAAGF,QAAQ,GAAGJ,WAAW,CAACO,MAAM,CAAA;UAClDpB,aAAa,CAACa,WAAW,CAAC,CAAA;AAE1BQ,UAAAA,UAAU,CAAC,YAAM;AAAA,YAAA,IAAAC,iBAAA,CAAA;AACb,YAAA,CAAAA,iBAAA,GAAAjC,QAAQ,CAACkB,OAAO,MAAAe,IAAAA,IAAAA,iBAAA,KAAhBA,KAAAA,CAAAA,IAAAA,iBAAA,CAAkBC,iBAAiB,CAACJ,YAAY,EAAEA,YAAY,CAAC,CAAA;WAClE,EAAE,EAAE,CAAC,CAAA;AACV,SAAA;AACJ,OAAA;AAEA,MAAA,IAAIlC,OAAO,EAAE;QACTA,OAAO,CAACoB,KAAK,CAAC,CAAA;AAClB,OAAA;KACH,CAAA;AAEDmB,IAAAA,SAAS,CAAC,YAAM;MACZxB,aAAa,CACTjB,KAAK,GAAGY,gBAAgB,CAACC,MAAM,CAACb,KAAK,CAAC,EAAE;AAAEN,QAAAA,iBAAiB,EAAjBA,iBAAiB;AAAEE,QAAAA,YAAY,EAAZA,YAAY;AAAEE,QAAAA,gBAAgB,EAAhBA,gBAAAA;OAAkB,CAAC,GAAG,EACrG,CAAC,CAAA;AACL,KAAC,EAAE,CAACE,KAAK,CAAC,CAAC,CAAA;AAEX,IAAA,oBACI0C,KAAA,CAAAC,aAAA,CAACC,aAAa,EAAAC,QAAA,CAAA;AACV7C,MAAAA,KAAK,EAAEgB,UAAW;AAClBtB,MAAAA,iBAAiB,EAAEA,iBAAkB;AACrCE,MAAAA,YAAY,EAAEA,YAAa;AAC3BE,MAAAA,gBAAgB,EAAEA,gBAAiB;AACnCgD,MAAAA,WAAW,EAAEzD,cAAe;AAC5B0D,MAAAA,WAAW,EAAEvC,YAAa;MAC1BwC,oBAAoB,EAAA,IAAA;AACpBC,MAAAA,aAAa,EAAE/B,iBAAkB;AACjChB,MAAAA,OAAO,EAAEqB,WAAAA;KACLpB,EAAAA,IAAI,CACX,CAAC,CAAA;AAEV,GACJ,CAAC,CAAA;AACL;;;;"}
@@ -21,7 +21,7 @@ import { useOutsideClick } from '../../hooks/useOutsideClick.js';
21
21
  import { useKeyNavigation } from './hooks/useKeyNavigation.js';
22
22
  import { TextFieldChip } from './ui/TextFieldChip/TextFieldChip.js';
23
23
 
24
- var _excluded = ["id", "className", "style", "contentLeft", "contentRight", "label", "labelPlacement", "keepPlaceholder", "textBefore", "textAfter", "placeholder", "leftHelper", "enumerationType", "requiredPlacement", "hasRequiredIndicator", "titleCaption", "chipView", "chipValidator", "hintTrigger", "hintText", "hintView", "hintSize", "hintTargetIcon", "hintTargetPlacement", "hintPlacement", "hintHasArrow", "hintOffset", "hintWidth", "hintContentLeft", "view", "size", "readOnly", "disabled", "required", "clear", "optional", "hasDivider", "value", "chips", "chipType", "onChange", "onChangeChips", "onSearch", "onKeyDown", "onFocus", "onBlur", "_onEnterDisabled", "_forceChipManipulationWithReadonly"];
24
+ var _excluded = ["id", "className", "style", "contentLeft", "contentRight", "label", "labelPlacement", "keepPlaceholder", "textBefore", "textAfter", "placeholder", "leftHelper", "enumerationType", "requiredPlacement", "hasRequiredIndicator", "titleCaption", "chipView", "chipValidator", "hintTrigger", "hintText", "hintView", "hintSize", "hintTargetIcon", "hintTargetPlacement", "hintPlacement", "hintHasArrow", "hintOffset", "hintWidth", "hintContentLeft", "view", "size", "readOnly", "disabled", "required", "clear", "optional", "hasDivider", "value", "chips", "chipType", "onChange", "onChangeChips", "onSearch", "onKeyDown", "onFocus", "onBlur", "onPaste", "_onEnterDisabled", "_forceChipManipulationWithReadonly"];
25
25
  var optionalText = 'optional';
26
26
  var base = "bpunezx";
27
27
  var HINT_DEFAULT_OFFSET = [0, 0];
@@ -89,6 +89,7 @@ var textFieldRoot = function textFieldRoot(Root) {
89
89
  onKeyDown = _ref.onKeyDown,
90
90
  onFocus = _ref.onFocus,
91
91
  onBlur = _ref.onBlur,
92
+ onPaste = _ref.onPaste,
92
93
  _onEnterDisabled = _ref._onEnterDisabled,
93
94
  _forceChipManipulationWithReadonly = _ref._forceChipManipulationWithReadonly,
94
95
  rest = _objectWithoutProperties(_ref, _excluded);
@@ -165,15 +166,6 @@ var textFieldRoot = function textFieldRoot(Root) {
165
166
  value = _ref2.value;
166
167
  setHasValue(Boolean(value));
167
168
  };
168
- useEffect(function () {
169
- if (hasTextAfter && inputRef.current) {
170
- var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
171
- inputRef.current.style.width = "".concat(textWidth, "px");
172
- } else {
173
- var _inputRef$current2;
174
- (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 || _inputRef$current2.style.removeProperty('width');
175
- }
176
- }, [hasTextAfter]);
177
169
  var handleFocus = function handleFocus(event) {
178
170
  setHasFocus(true);
179
171
  onFocus === null || onFocus === void 0 || onFocus(event);
@@ -210,12 +202,31 @@ var textFieldRoot = function textFieldRoot(Root) {
210
202
  if (maxLength !== -1 && value.length > maxLength) {
211
203
  return;
212
204
  }
213
- onChange === null || onChange === void 0 || onChange(event);
205
+ if (onChange) {
206
+ onChange(event);
207
+ }
214
208
  if (hasTextAfter) {
215
209
  var textWidth = getInputWidth(event.currentTarget, inputContainerRef.current);
216
210
  event.currentTarget.style.width = "".concat(textWidth, "px");
217
211
  }
218
212
  };
213
+ var handlePaste = function handlePaste(event) {
214
+ if (disabled || readOnly) {
215
+ return;
216
+ }
217
+ if (onPaste) {
218
+ onPaste(event);
219
+ }
220
+ if (hasTextAfter) {
221
+ setTimeout(function () {
222
+ if (!inputRef.current) {
223
+ return;
224
+ }
225
+ var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
226
+ inputRef.current.style.width = "".concat(textWidth, "px");
227
+ });
228
+ }
229
+ };
219
230
  var updateChips = function updateChips(newChips, newValues) {
220
231
  setChips(newChips);
221
232
  onChangeChips === null || onChangeChips === void 0 || onChangeChips(newValues);
@@ -260,6 +271,15 @@ var textFieldRoot = function textFieldRoot(Root) {
260
271
  onKeyDown(event);
261
272
  }
262
273
  };
274
+ useEffect(function () {
275
+ if (hasTextAfter && inputRef.current) {
276
+ var textWidth = getInputWidth(inputRef.current, inputContainerRef.current);
277
+ inputRef.current.style.width = "".concat(textWidth, "px");
278
+ } else {
279
+ var _inputRef$current2;
280
+ (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 || _inputRef$current2.style.removeProperty('width');
281
+ }
282
+ }, [hasTextAfter, outerValue]);
263
283
  useEffect(function () {
264
284
  if (!isChipEnumeration && !(values !== null && values !== void 0 && values.length)) {
265
285
  return;
@@ -410,6 +430,7 @@ var textFieldRoot = function textFieldRoot(Root) {
410
430
  onKeyDown: handleOnKeyDown,
411
431
  onFocus: handleFocus,
412
432
  onBlur: handleBlur,
433
+ onPaste: handlePaste,
413
434
  "data-tour": true
414
435
  }, rest)), hasInnerLabel && /*#__PURE__*/React.createElement(Label, {
415
436
  "data-root": true,