@salutejs/plasma-new-hope 0.327.0-canary.2010.15679377511.0 → 0.327.0-canary.2010.15694111005.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/cjs/components/TextArea/TextArea.js +5 -2
  2. package/cjs/components/TextArea/TextArea.js.map +1 -1
  3. package/cjs/components/TextArea/TextArea.tokens.js +2 -1
  4. package/cjs/components/TextArea/TextArea.tokens.js.map +1 -1
  5. package/cjs/components/TextArea/variations/_size/base.js +1 -1
  6. package/cjs/components/TextArea/variations/_size/base.js.map +1 -1
  7. package/cjs/components/TextArea/variations/_size/base_vftquy.css +1 -0
  8. package/cjs/components/Tour/Tour.css +4 -4
  9. package/cjs/components/Tour/Tour.js +15 -8
  10. package/cjs/components/Tour/Tour.js.map +1 -1
  11. package/cjs/components/Tour/Tour.styles.js +9 -2
  12. package/cjs/components/Tour/Tour.styles.js.map +1 -1
  13. package/cjs/components/Tour/Tour.styles_hmd79i.css +4 -0
  14. package/cjs/components/Tour/utils/index.js +94 -0
  15. package/cjs/components/Tour/utils/index.js.map +1 -1
  16. package/cjs/index.css +6 -4
  17. package/emotion/cjs/components/TextArea/TextArea.js +6 -3
  18. package/emotion/cjs/components/TextArea/TextArea.tokens.js +2 -1
  19. package/emotion/cjs/components/TextArea/variations/_size/base.js +2 -1
  20. package/emotion/cjs/components/Tour/Tour.js +16 -9
  21. package/emotion/cjs/components/Tour/Tour.styles.js +7 -5
  22. package/emotion/cjs/components/Tour/utils/index.js +93 -1
  23. package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +54 -8
  24. package/emotion/es/components/TextArea/TextArea.js +6 -3
  25. package/emotion/es/components/TextArea/TextArea.tokens.js +2 -1
  26. package/emotion/es/components/TextArea/variations/_size/base.js +2 -1
  27. package/emotion/es/components/Tour/Tour.js +17 -11
  28. package/emotion/es/components/Tour/Tour.styles.js +7 -5
  29. package/emotion/es/components/Tour/utils/index.js +92 -0
  30. package/emotion/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +54 -8
  31. package/es/components/TextArea/TextArea.js +5 -2
  32. package/es/components/TextArea/TextArea.js.map +1 -1
  33. package/es/components/TextArea/TextArea.tokens.js +2 -1
  34. package/es/components/TextArea/TextArea.tokens.js.map +1 -1
  35. package/es/components/TextArea/variations/_size/base.js +1 -1
  36. package/es/components/TextArea/variations/_size/base.js.map +1 -1
  37. package/es/components/TextArea/variations/_size/base_vftquy.css +1 -0
  38. package/es/components/Tour/Tour.css +4 -4
  39. package/es/components/Tour/Tour.js +17 -10
  40. package/es/components/Tour/Tour.js.map +1 -1
  41. package/es/components/Tour/Tour.styles.js +9 -2
  42. package/es/components/Tour/Tour.styles.js.map +1 -1
  43. package/es/components/Tour/Tour.styles_hmd79i.css +4 -0
  44. package/es/components/Tour/utils/index.js +93 -1
  45. package/es/components/Tour/utils/index.js.map +1 -1
  46. package/es/index.css +6 -4
  47. package/package.json +2 -2
  48. package/styled-components/cjs/components/TextArea/TextArea.js +5 -2
  49. package/styled-components/cjs/components/TextArea/TextArea.tokens.js +2 -1
  50. package/styled-components/cjs/components/TextArea/variations/_size/base.js +2 -1
  51. package/styled-components/cjs/components/Tour/Tour.js +16 -9
  52. package/styled-components/cjs/components/Tour/Tour.styles.js +5 -3
  53. package/styled-components/cjs/components/Tour/utils/index.js +93 -1
  54. package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +54 -8
  55. package/styled-components/es/components/TextArea/TextArea.js +5 -2
  56. package/styled-components/es/components/TextArea/TextArea.tokens.js +2 -1
  57. package/styled-components/es/components/TextArea/variations/_size/base.js +2 -1
  58. package/styled-components/es/components/Tour/Tour.js +17 -11
  59. package/styled-components/es/components/Tour/Tour.styles.js +5 -3
  60. package/styled-components/es/components/Tour/utils/index.js +92 -0
  61. package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +54 -8
  62. package/types/components/TextArea/TextArea.d.ts.map +1 -1
  63. package/types/components/TextArea/TextArea.tokens.d.ts +1 -0
  64. package/types/components/TextArea/TextArea.tokens.d.ts.map +1 -1
  65. package/types/components/TextArea/variations/_size/base.d.ts.map +1 -1
  66. package/types/components/Tour/Tour.d.ts.map +1 -1
  67. package/types/components/Tour/Tour.styles.d.ts +1 -0
  68. package/types/components/Tour/Tour.styles.d.ts.map +1 -1
  69. package/types/components/Tour/Tour.types.d.ts +8 -0
  70. package/types/components/Tour/Tour.types.d.ts.map +1 -1
  71. package/types/components/Tour/utils/index.d.ts +2 -0
  72. package/types/components/Tour/utils/index.d.ts.map +1 -1
  73. package/cjs/components/TextArea/variations/_size/base_x642ct.css +0 -1
  74. package/cjs/components/Tour/Tour.styles_1ks2isn.css +0 -4
  75. package/es/components/TextArea/variations/_size/base_x642ct.css +0 -1
  76. package/es/components/Tour/Tour.styles_1ks2isn.css +0 -4
@@ -2,10 +2,12 @@ import React, { useRef, useState } from 'react';
2
2
  import type { StoryObj, Meta } from '@storybook/react';
3
3
  import styled from '@emotion/styled';
4
4
 
5
+ import { IconArrowDown } from '../../../../components/_Icon';
5
6
  import { linkConfig } from '../../../../components/Link';
6
7
  import { mergeConfig } from '../../../../engines';
7
8
  import { WithTheme, argTypesFromConfig } from '../../../_helpers';
8
9
  import { Button } from '../Button/Button';
10
+ import { TextArea } from '../TextArea/TextArea';
9
11
 
10
12
  import { config } from './Tour.config';
11
13
  import { Tour } from './Tour';
@@ -113,10 +115,11 @@ const TourCard: React.FC<{
113
115
  };
114
116
 
115
117
  const StoryDefault = (args) => {
116
- const ref1 = useRef<HTMLButtonElement>(null);
118
+ const ref1 = useRef<HTMLTextAreaElement>(null);
117
119
  const ref2 = useRef<HTMLButtonElement>(null);
118
- const ref3 = useRef<HTMLButtonElement>(null);
119
- const ref4 = useRef<HTMLButtonElement>(null);
120
+ const ref3 = useRef<HTMLDivElement>(null);
121
+ const ref4 = useRef<HTMLDivElement>(null);
122
+ const ref5 = useRef<HTMLDivElement>(null);
120
123
  const [open, setOpen] = useState(false);
121
124
  const [current, setCurrent] = useState(0);
122
125
 
@@ -139,7 +142,7 @@ const StoryDefault = (args) => {
139
142
  onClose={onClose}
140
143
  />
141
144
  ),
142
- placement: 'right',
145
+ placement: 'bottom',
143
146
  },
144
147
  {
145
148
  target: ref2,
@@ -187,13 +190,30 @@ const StoryDefault = (args) => {
187
190
  ),
188
191
  placement: 'left',
189
192
  },
193
+ {
194
+ target: ref5,
195
+ renderItem: () => (
196
+ <TourCard
197
+ title="Первый шаг"
198
+ description="Нажмите кнопку, чтобы продолжить"
199
+ index={4}
200
+ last={current === steps.length - 1}
201
+ total={steps.length}
202
+ onNext={onNext}
203
+ onPrev={onPrev}
204
+ onClose={onClose}
205
+ />
206
+ ),
207
+ placement: 'left',
208
+ borderRadius: 'fixed',
209
+ },
190
210
  ];
191
211
 
192
212
  return (
193
213
  <div
194
214
  style={{
195
215
  width: '100%',
196
- height: '110vh',
216
+ height: '100vh',
197
217
  display: 'flex',
198
218
  justifyContent: 'space-between',
199
219
  flexDirection: 'column',
@@ -207,7 +227,16 @@ const StoryDefault = (args) => {
207
227
  justifyContent: 'space-between',
208
228
  }}
209
229
  >
210
- <Button ref={ref1}>Блок 1</Button>
230
+ <TextArea
231
+ ref={ref1}
232
+ rightHelper={
233
+ <div ref={ref5} style={{ cursor: 'pointer', transform: 'rotate(-90deg)' }}>
234
+ <IconArrowDown />
235
+ </div>
236
+ }
237
+ rows={10}
238
+ cols={20}
239
+ />
211
240
  <Button ref={ref2}>Блок 2</Button>
212
241
  </div>
213
242
  <Button onClick={() => setOpen(true)}>Запуск тура</Button>
@@ -219,8 +248,25 @@ const StoryDefault = (args) => {
219
248
  justifyContent: 'space-between',
220
249
  }}
221
250
  >
222
- <Button ref={ref3}>Блок 3</Button>
223
- <Button ref={ref4}>Блок 4</Button>
251
+ <div
252
+ style={{
253
+ background: 'black',
254
+ width: '100px',
255
+ height: '100px',
256
+ borderRadius: '50%',
257
+ }}
258
+ ref={ref3}
259
+ />
260
+ <div
261
+ style={{
262
+ background: 'black',
263
+ width: '100px',
264
+ height: '100px',
265
+ }}
266
+ ref={ref4}
267
+ >
268
+ Блок 4
269
+ </div>
224
270
  </div>
225
271
 
226
272
  <Tour
@@ -44,7 +44,7 @@ var innerPlaceholderUp = classes.innerPlaceholderUp,
44
44
  styledPlaceholder = classes.styledPlaceholder,
45
45
  styledHelpers = classes.styledHelpers;
46
46
  var optionalText = 'optional';
47
- var base = /*#__PURE__*/css(applyDynamicLabel, ";position:relative;box-sizing:border-box;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextArea/TextArea.tsx"],"names":[],"mappings":"AAqDgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback, useRef, MouseEventHandler, useLayoutEffect } from 'react';\nimport { css } from '@emotion/react';\nimport { useForkRef, useResizeObserver } from '@salutejs/plasma-core';\n\nimport { cx, mergeRefs } from '../../utils';\nimport type { RootProps } from '../../engines/types';\nimport { useOutsideClick } from '../../hooks';\n\nimport { applyDynamicLabel } from './mixins';\nimport { useAutoResize, ROOT_FONT_SIZE } from './hooks';\nimport {\n    StyledContent,\n    StyledHelpers,\n    StyledLeftHelper,\n    StyledRightHelper,\n    StyledLabel,\n    StyledPlaceholder,\n    StyledTextArea,\n    StyledTextAreaWrapper,\n    StyledContainer,\n    StyledIndicator,\n    StyledOptionalText,\n    OuterLabelWrapper,\n    StyledIndicatorWrapper,\n    StyledHintWrapper,\n    TitleCaption,\n    StyledOutsideHelpersWrapper,\n    StyledHiddenTextArea,\n} from './TextArea.styles';\nimport { classes } from './TextArea.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as clearCSS } from './variations/_clear/base';\nimport { base as readOnlyCSS } from './variations/_read-only/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as hintViewCSS } from './variations/_hint-view/base';\nimport { base as hintSizeCSS } from './variations/_hint-size/base';\nimport type { TextAreaProps, TextAreaRootProps } from './TextArea.types';\nimport { HintComponent } from './ui/Hint/Hint';\n\nconst {\n    innerPlaceholderUp,\n    focusedOuterPlaceholderColor,\n    hidePlaceHolder,\n    styledContainer,\n    styledTextArea,\n    styledTextAreaWrapper,\n    styledPlaceholder,\n    styledHelpers,\n} = classes;\n\nconst optionalText = 'optional';\n\nconst base = css`\n    ${applyDynamicLabel};\n\n    position: relative;\n    box-sizing: border-box;\n`;\n\n// TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c\nconst fallbackStatusMap = {\n    '': 'primary',\n    success: 'positive',\n    warning: 'warning',\n    error: 'negative',\n};\n\nconst HINT_DEFAULT_OFFSET: [number, number] = [0, 0];\n\n// TODO: Перенести этот метод в файл applyDynamicLabel.ts\nexport const getDynamicLabelClasses = (props: TextAreaProps, focused: boolean) => {\n    const { readOnly, label, labelPlacement, rows, value, size } = props;\n\n    // Добавить класс отвечающий за изменение цвета плейсхолдера при фокусе\n    const withFocusedOuterUpPlaceholder =\n        !readOnly && focused && (!label || labelPlacement === 'outer') ? focusedOuterPlaceholderColor : undefined;\n\n    // Добавить класс отвечающий за поднятие и уменьшение плейсхолдера\n    const withInnerPlaceholderUp =\n        labelPlacement === 'inner' &&\n        label &&\n        !rows &&\n        size !== 'xs' &&\n        ((!readOnly && (value || focused)) || (readOnly && value))\n            ? innerPlaceholderUp\n            : undefined;\n\n    // Добавить класс отвечающий за скрытие плейсхолдера\n    const withHidePlaceholder =\n        (value && !label) ||\n        (labelPlacement === 'inner' && ((focused && !readOnly) || value) && label && rows) ||\n        (labelPlacement === 'outer' && value) ||\n        (labelPlacement === 'inner' && size === 'xs' && value)\n            ? hidePlaceHolder\n            : undefined;\n\n    return [withFocusedOuterUpPlaceholder, withInnerPlaceholderUp, withHidePlaceholder];\n};\n\nexport const textAreaRoot = (Root: RootProps<HTMLTextAreaElement, TextAreaRootProps>) =>\n    forwardRef<HTMLTextAreaElement, TextAreaProps>((props, innerRef) => {\n        const {\n            helperText,\n            status,\n            resize,\n            rightHelper,\n            leftHelper,\n            leftHelperPlacement = 'inner',\n            contentRight,\n            autoResize = false,\n            minAuto = 0,\n            maxAuto,\n            label,\n            labelPlacement = 'inner',\n            titleCaption,\n            placeholder,\n            defaultValue,\n            height,\n            width,\n            value,\n            disabled,\n            required = false,\n            requiredPlacement = 'right',\n            hasRequiredIndicator = true,\n            optional = false,\n            clear,\n            hasDivider,\n            size,\n            view,\n            id,\n            style,\n            className,\n            readOnly,\n            rows,\n            cols,\n            hintTrigger = 'hover',\n            hintText,\n            hintView = 'default',\n            hintSize = 'm',\n            hintTargetIcon,\n            hintPlacement = 'auto',\n            hintHasArrow,\n            hintOffset = HINT_DEFAULT_OFFSET,\n            hintWidth,\n            hintContentLeft,\n            onChange,\n            ...rest\n        } = props;\n\n        const [isHintVisible, setIsHintVisible] = useState(false);\n        const [helperWidth, setHelperWidth] = useState<string>(width ? `${width}rem` : '100%');\n        const [focused, setFocused] = useState(false);\n        // TODO: перенести в общую переменную для value снаружи и внутри\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n        const hiddenRef = useRef<HTMLTextAreaElement | null>(null);\n\n        const hintRef = useOutsideClick<HTMLDivElement>(() => {\n            setIsHintVisible(false);\n        });\n        const hintInnerRef = useRef<HTMLDivElement>(null);\n        const hintForkRef = useForkRef(hintRef, hintInnerRef);\n\n        const isInnerLeftHelperPlacement = leftHelperPlacement === 'inner';\n        const leftHelperText = leftHelper || helperText;\n        const innerOptional = required ? false : optional;\n        const hasLeftHelper = Boolean(leftHelper || helperText);\n        const hasRightHelper = Boolean(rightHelper);\n        const hasHelper = !isInnerLeftHelperPlacement ? hasRightHelper : hasLeftHelper || hasRightHelper;\n        const hasOuterLabel = Boolean(label && labelPlacement === 'outer');\n        const hasInnerLabel = Boolean(label && labelPlacement === 'inner' && size !== 'xs');\n        const hasPlaceholderOptional = innerOptional && !hasOuterLabel;\n\n        const overriddenView = status !== undefined ? fallbackStatusMap[status] : view;\n        const textareaHelperId = id ? `${id}-helper` : undefined;\n        const applyCustomWidth = resize !== 'horizontal' && resize !== 'both' && !cols;\n        const placeholderLabel = hasInnerLabel ? label : placeholder;\n        const applyAutoResize = autoResize || Boolean(clear);\n\n        const clearClass = clear ? classes.clear : undefined;\n        const hasHintClass = hintText ? classes.hasHint : undefined;\n        const hasRightContentClass = contentRight ? classes.hasRightContent : undefined;\n        const hasDividerClass = hasDivider ? classes.hasDivider : undefined;\n        const requiredPlacementClass = requiredPlacement === 'right' ? classes.requiredAlignRight : undefined;\n\n        const handleHintShow = () => setIsHintVisible(true);\n        const handleHintHide = () => setIsHintVisible(false);\n        const handleHintClick: MouseEventHandler = (event) => {\n            if (!hintText || hintTrigger !== 'click') {\n                return;\n            }\n\n            event.stopPropagation();\n            const targetIsPopover = event.target === hintInnerRef.current;\n            const rootHasTarget = hintInnerRef.current?.contains(event.target as Element);\n\n            if (!targetIsPopover && !rootHasTarget) {\n                setIsHintVisible(true);\n            }\n        };\n\n        useLayoutEffect(() => {\n            if (outerRef.current) {\n                setUncontrolledValue(outerRef.current.value);\n            }\n        }, [outerRef]);\n\n        useResizeObserver(outerRef, (currentElement) => {\n            const { width: inlineWidth } = currentElement.style;\n\n            if (inlineWidth || cols) {\n                const { width: elementWidth } = currentElement.getBoundingClientRect();\n                setHelperWidth(`${elementWidth / ROOT_FONT_SIZE}rem`);\n            }\n        });\n\n        useAutoResize(applyAutoResize, outerRef, value || uncontrolledValue, minAuto, maxAuto, resize, hiddenRef);\n\n        const onFocusHandler = useCallback(() => {\n            setFocused(true);\n        }, []);\n\n        const onBlurHandler = useCallback(() => {\n            setFocused(false);\n        }, []);\n\n        const onChangeHandler = useCallback(\n            (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n                // INFO: Для крайне редких кейсов, когда value снаружи не контролируется\n                if (value === undefined) {\n                    setUncontrolledValue(event?.target.value);\n                }\n\n                onChange?.(event);\n            },\n            [value, onChange],\n        );\n\n        const handleTextAreaFocus = () => {\n            if (readOnly || disabled || !outerRef?.current) {\n                return;\n            }\n\n            outerRef.current.focus();\n        };\n\n        const dynamicLabelClasses = getDynamicLabelClasses(\n            {\n                size,\n                readOnly,\n                label,\n                labelPlacement,\n                value: value || uncontrolledValue || defaultValue,\n                rows,\n            },\n            focused,\n        );\n\n        const optionalTextNode = innerOptional ? (\n            <StyledOptionalText inheritFont={!hasOuterLabel}>\n                {Boolean(hasPlaceholderOptional ? placeholderLabel : label) && '\\xa0'}\n                {optionalText}\n            </StyledOptionalText>\n        ) : null;\n\n        return (\n            <Root\n                view={overriddenView}\n                size={size}\n                disabled={disabled}\n                readOnly={readOnly}\n                style={{ width: helperWidth, ...style }}\n                className={cx(clearClass, hasDividerClass, hasHintClass, className)}\n                onClick={handleTextAreaFocus}\n                {...(hintText && {\n                    hintView,\n                    hintSize,\n                })}\n            >\n                {(hasOuterLabel || titleCaption) && (\n                    <OuterLabelWrapper width={helperWidth} isInnerLabel={labelPlacement === 'inner'}>\n                        {hasOuterLabel && (\n                            <StyledIndicatorWrapper>\n                                <StyledLabel>{label}</StyledLabel>\n\n                                {hintText && (\n                                    <StyledHintWrapper>\n                                        <HintComponent\n                                            ref={hintForkRef}\n                                            hintText={hintText}\n                                            hintTrigger={hintTrigger}\n                                            isHintVisible={isHintVisible}\n                                            hintTargetIcon={hintTargetIcon}\n                                            hintPlacement={hintPlacement}\n                                            hintHasArrow={hintHasArrow}\n                                            hintOffset={hintOffset}\n                                            hintWidth={hintWidth}\n                                            hintContentLeft={hintContentLeft}\n                                            handleHintShow={handleHintShow}\n                                            handleHintHide={handleHintHide}\n                                            handleHintClick={handleHintClick}\n                                        />\n                                    </StyledHintWrapper>\n                                )}\n                                {required && hasRequiredIndicator && (\n                                    <StyledIndicator\n                                        className={cx(\n                                            classes.outerLabelPlacement,\n                                            requiredPlacementClass,\n                                            hasHintClass,\n                                        )}\n                                    />\n                                )}\n                                {optionalTextNode}\n                            </StyledIndicatorWrapper>\n                        )}\n                        {titleCaption && <TitleCaption>{titleCaption}</TitleCaption>}\n                    </OuterLabelWrapper>\n                )}\n                <StyledContainer\n                    className={cx(styledContainer, ...dynamicLabelClasses)}\n                    width={helperWidth}\n                    onFocus={onFocusHandler}\n                    onBlur={onBlurHandler}\n                >\n                    {!hasOuterLabel && (\n                        <>\n                            {required && hasRequiredIndicator && (\n                                <StyledIndicator className={cx(classes.innerLabelPlacement, requiredPlacementClass)} />\n                            )}\n                            {hintText && (\n                                <StyledHintWrapper className={classes.innerLabelPlacement}>\n                                    <HintComponent\n                                        ref={hintForkRef}\n                                        hintText={hintText}\n                                        hintTrigger={hintTrigger}\n                                        isHintVisible={isHintVisible}\n                                        hintTargetIcon={hintTargetIcon}\n                                        hintPlacement={hintPlacement}\n                                        hintHasArrow={hintHasArrow}\n                                        hintOffset={hintOffset}\n                                        hintWidth={hintWidth}\n                                        hintContentLeft={hintContentLeft}\n                                        size={size}\n                                        handleHintShow={handleHintShow}\n                                        handleHintHide={handleHintHide}\n                                        handleHintClick={handleHintClick}\n                                        isInnerLabel\n                                    />\n                                </StyledHintWrapper>\n                            )}\n                        </>\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={cx(styledTextAreaWrapper)} hasHelper={hasHelper}>\n                        <StyledTextArea\n                            className={cx(styledTextArea, hasRightContentClass)}\n                            id={id}\n                            hasContentRight={Boolean(contentRight)}\n                            hasHelper={hasHelper}\n                            applyCustomWidth={applyCustomWidth}\n                            ref={mergeRefs(outerRef, innerRef)}\n                            disabled={disabled}\n                            required={required}\n                            height={applyAutoResize ? minAuto : height}\n                            width={width}\n                            placeholder={placeholderLabel}\n                            aria-describedby={textareaHelperId}\n                            value={value}\n                            readOnly={readOnly}\n                            rows={rows}\n                            cols={cols}\n                            resize={resize}\n                            defaultValue={defaultValue}\n                            onChange={onChangeHandler}\n                            {...rest}\n                        />\n                        {applyAutoResize && (\n                            <StyledHiddenTextArea\n                                aria-hidden\n                                ref={hiddenRef}\n                                hasContentRight={Boolean(contentRight)}\n                                value={value || uncontrolledValue || ' '}\n                                defaultValue={defaultValue}\n                            />\n                        )}\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {isInnerLeftHelperPlacement && (leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper>{rightHelper}</StyledRightHelper>}\n                        </StyledHelpers>\n                    )}\n                    {placeholderLabel && (\n                        <StyledPlaceholder\n                            hasContentRight={Boolean(contentRight)}\n                            className={styledPlaceholder}\n                            htmlFor={id}\n                        >\n                            {placeholderLabel}\n                            {!hasOuterLabel && optionalTextNode}\n                        </StyledPlaceholder>\n                    )}\n                </StyledContainer>\n                {hasLeftHelper && !isInnerLeftHelperPlacement && (\n                    <StyledOutsideHelpersWrapper id={textareaHelperId}>\n                        <StyledLeftHelper>{leftHelperText}</StyledLeftHelper>\n                    </StyledOutsideHelpersWrapper>\n                )}\n            </Root>\n        );\n    });\n\nexport const textAreaConfig = {\n    name: 'TextArea',\n    tag: 'div',\n    layout: textAreaRoot,\n    base,\n    variations: {\n        size: {\n            css: sizeCSS,\n        },\n        view: {\n            css: viewCSS,\n        },\n        clear: {\n            css: clearCSS,\n            attrs: true,\n        },\n        readOnly: {\n            css: readOnlyCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        hintView: {\n            css: hintViewCSS,\n        },\n        hintSize: {\n            css: hintSizeCSS,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'primary',\n    },\n};\n"]} */"));
47
+ var base = /*#__PURE__*/css(applyDynamicLabel, ";position:relative;box-sizing:border-box;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src-emotion/components/TextArea/TextArea.tsx"],"names":[],"mappings":"AAqDgB","file":"../../../../src-emotion/components/TextArea/TextArea.tsx","sourcesContent":["import React, { forwardRef, useState, createRef, useCallback, useRef, MouseEventHandler, useLayoutEffect } from 'react';\nimport { css } from '@emotion/react';\nimport { useForkRef, useResizeObserver } from '@salutejs/plasma-core';\n\nimport { cx, mergeRefs } from '../../utils';\nimport type { RootProps } from '../../engines/types';\nimport { useOutsideClick } from '../../hooks';\n\nimport { applyDynamicLabel } from './mixins';\nimport { useAutoResize, ROOT_FONT_SIZE } from './hooks';\nimport {\n    StyledContent,\n    StyledHelpers,\n    StyledLeftHelper,\n    StyledRightHelper,\n    StyledLabel,\n    StyledPlaceholder,\n    StyledTextArea,\n    StyledTextAreaWrapper,\n    StyledContainer,\n    StyledIndicator,\n    StyledOptionalText,\n    OuterLabelWrapper,\n    StyledIndicatorWrapper,\n    StyledHintWrapper,\n    TitleCaption,\n    StyledOutsideHelpersWrapper,\n    StyledHiddenTextArea,\n} from './TextArea.styles';\nimport { classes } from './TextArea.tokens';\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as clearCSS } from './variations/_clear/base';\nimport { base as readOnlyCSS } from './variations/_read-only/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as hintViewCSS } from './variations/_hint-view/base';\nimport { base as hintSizeCSS } from './variations/_hint-size/base';\nimport type { TextAreaProps, TextAreaRootProps } from './TextArea.types';\nimport { HintComponent } from './ui/Hint/Hint';\n\nconst {\n    innerPlaceholderUp,\n    focusedOuterPlaceholderColor,\n    hidePlaceHolder,\n    styledContainer,\n    styledTextArea,\n    styledTextAreaWrapper,\n    styledPlaceholder,\n    styledHelpers,\n} = classes;\n\nconst optionalText = 'optional';\n\nconst base = css`\n    ${applyDynamicLabel};\n\n    position: relative;\n    box-sizing: border-box;\n`;\n\n// TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c\nconst fallbackStatusMap = {\n    '': 'primary',\n    success: 'positive',\n    warning: 'warning',\n    error: 'negative',\n};\n\nconst HINT_DEFAULT_OFFSET: [number, number] = [0, 0];\n\n// TODO: Перенести этот метод в файл applyDynamicLabel.ts\nexport const getDynamicLabelClasses = (props: TextAreaProps, focused: boolean) => {\n    const { readOnly, label, labelPlacement, rows, value, size } = props;\n\n    // Добавить класс отвечающий за изменение цвета плейсхолдера при фокусе\n    const withFocusedOuterUpPlaceholder =\n        !readOnly && focused && (!label || labelPlacement === 'outer') ? focusedOuterPlaceholderColor : undefined;\n\n    // Добавить класс отвечающий за поднятие и уменьшение плейсхолдера\n    const withInnerPlaceholderUp =\n        labelPlacement === 'inner' &&\n        label &&\n        !rows &&\n        size !== 'xs' &&\n        ((!readOnly && (value || focused)) || (readOnly && value))\n            ? innerPlaceholderUp\n            : undefined;\n\n    // Добавить класс отвечающий за скрытие плейсхолдера\n    const withHidePlaceholder =\n        (value && !label) ||\n        (labelPlacement === 'inner' && ((focused && !readOnly) || value) && label && rows) ||\n        (labelPlacement === 'outer' && value) ||\n        (labelPlacement === 'inner' && size === 'xs' && value)\n            ? hidePlaceHolder\n            : undefined;\n\n    return [withFocusedOuterUpPlaceholder, withInnerPlaceholderUp, withHidePlaceholder];\n};\n\nexport const textAreaRoot = (Root: RootProps<HTMLTextAreaElement, TextAreaRootProps>) =>\n    forwardRef<HTMLTextAreaElement, TextAreaProps>((props, innerRef) => {\n        const {\n            helperText,\n            status,\n            resize,\n            rightHelper,\n            leftHelper,\n            leftHelperPlacement = 'inner',\n            contentRight,\n            autoResize = false,\n            minAuto = 0,\n            maxAuto,\n            label,\n            labelPlacement = 'inner',\n            titleCaption,\n            placeholder,\n            defaultValue,\n            height,\n            width,\n            value,\n            disabled,\n            required = false,\n            requiredPlacement = 'right',\n            hasRequiredIndicator = true,\n            optional = false,\n            clear,\n            hasDivider,\n            size,\n            view,\n            id,\n            style,\n            className,\n            readOnly,\n            rows,\n            cols,\n            hintTrigger = 'hover',\n            hintText,\n            hintView = 'default',\n            hintSize = 'm',\n            hintTargetIcon,\n            hintPlacement = 'auto',\n            hintHasArrow,\n            hintOffset = HINT_DEFAULT_OFFSET,\n            hintWidth,\n            hintContentLeft,\n            onChange,\n            ...rest\n        } = props;\n\n        const [isHintVisible, setIsHintVisible] = useState(false);\n        const [helperWidth, setHelperWidth] = useState<string>(width ? `${width}rem` : '100%');\n        const [focused, setFocused] = useState(false);\n        // TODO: перенести в общую переменную для value снаружи и внутри\n        const [uncontrolledValue, setUncontrolledValue] = useState<string | undefined>();\n\n        const outerRef = createRef<HTMLTextAreaElement>();\n        const hiddenRef = useRef<HTMLTextAreaElement | null>(null);\n\n        const hintRef = useOutsideClick<HTMLDivElement>(() => {\n            setIsHintVisible(false);\n        });\n        const hintInnerRef = useRef<HTMLDivElement>(null);\n        const hintForkRef = useForkRef(hintRef, hintInnerRef);\n\n        const isInnerLeftHelperPlacement = leftHelperPlacement === 'inner';\n        const leftHelperText = leftHelper || helperText;\n        const innerOptional = required ? false : optional;\n        const hasLeftHelper = Boolean(leftHelper || helperText);\n        const hasRightHelper = Boolean(rightHelper);\n        const hasHelper = !isInnerLeftHelperPlacement ? hasRightHelper : hasLeftHelper || hasRightHelper;\n        const hasOuterLabel = Boolean(label && labelPlacement === 'outer');\n        const hasInnerLabel = Boolean(label && labelPlacement === 'inner' && size !== 'xs');\n        const hasPlaceholderOptional = innerOptional && !hasOuterLabel;\n\n        const overriddenView = status !== undefined ? fallbackStatusMap[status] : view;\n        const textareaHelperId = id ? `${id}-helper` : undefined;\n        const applyCustomWidth = resize !== 'horizontal' && resize !== 'both' && !cols;\n        const placeholderLabel = hasInnerLabel ? label : placeholder;\n        const applyAutoResize = autoResize || Boolean(clear);\n\n        const clearClass = clear ? classes.clear : undefined;\n        const hasHintClass = hintText ? classes.hasHint : undefined;\n        const hasRightContentClass = contentRight ? classes.hasRightContent : undefined;\n        const hasDividerClass = hasDivider ? classes.hasDivider : undefined;\n        const requiredPlacementClass = requiredPlacement === 'right' ? classes.requiredAlignRight : undefined;\n\n        const handleHintShow = () => setIsHintVisible(true);\n        const handleHintHide = () => setIsHintVisible(false);\n        const handleHintClick: MouseEventHandler = (event) => {\n            if (!hintText || hintTrigger !== 'click') {\n                return;\n            }\n\n            event.stopPropagation();\n            const targetIsPopover = event.target === hintInnerRef.current;\n            const rootHasTarget = hintInnerRef.current?.contains(event.target as Element);\n\n            if (!targetIsPopover && !rootHasTarget) {\n                setIsHintVisible(true);\n            }\n        };\n\n        useLayoutEffect(() => {\n            if (outerRef.current) {\n                setUncontrolledValue(outerRef.current.value);\n            }\n        }, [outerRef]);\n\n        useResizeObserver(outerRef, (currentElement) => {\n            const { width: inlineWidth } = currentElement.style;\n\n            if (inlineWidth || cols) {\n                const { width: elementWidth } = currentElement.getBoundingClientRect();\n                setHelperWidth(`${elementWidth / ROOT_FONT_SIZE}rem`);\n            }\n        });\n\n        useAutoResize(applyAutoResize, outerRef, value || uncontrolledValue, minAuto, maxAuto, resize, hiddenRef);\n\n        const onFocusHandler = useCallback(() => {\n            setFocused(true);\n        }, []);\n\n        const onBlurHandler = useCallback(() => {\n            setFocused(false);\n        }, []);\n\n        const onChangeHandler = useCallback(\n            (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n                // INFO: Для крайне редких кейсов, когда value снаружи не контролируется\n                if (value === undefined) {\n                    setUncontrolledValue(event?.target.value);\n                }\n\n                onChange?.(event);\n            },\n            [value, onChange],\n        );\n\n        const handleTextAreaFocus = () => {\n            if (readOnly || disabled || !outerRef?.current) {\n                return;\n            }\n\n            outerRef.current.focus();\n        };\n\n        const dynamicLabelClasses = getDynamicLabelClasses(\n            {\n                size,\n                readOnly,\n                label,\n                labelPlacement,\n                value: value || uncontrolledValue || defaultValue,\n                rows,\n            },\n            focused,\n        );\n\n        const optionalTextNode = innerOptional ? (\n            <StyledOptionalText inheritFont={!hasOuterLabel}>\n                {Boolean(hasPlaceholderOptional ? placeholderLabel : label) && '\\xa0'}\n                {optionalText}\n            </StyledOptionalText>\n        ) : null;\n\n        return (\n            <Root\n                view={overriddenView}\n                size={size}\n                disabled={disabled}\n                readOnly={readOnly}\n                style={{ width: helperWidth, ...style }}\n                className={cx(clearClass, hasDividerClass, hasHintClass, className)}\n                onClick={handleTextAreaFocus}\n                data-root\n                {...(hintText && {\n                    hintView,\n                    hintSize,\n                })}\n            >\n                {(hasOuterLabel || titleCaption) && (\n                    <OuterLabelWrapper width={helperWidth} isInnerLabel={labelPlacement === 'inner'}>\n                        {hasOuterLabel && (\n                            <StyledIndicatorWrapper>\n                                <StyledLabel>{label}</StyledLabel>\n\n                                {hintText && (\n                                    <StyledHintWrapper>\n                                        <HintComponent\n                                            ref={hintForkRef}\n                                            hintText={hintText}\n                                            hintTrigger={hintTrigger}\n                                            isHintVisible={isHintVisible}\n                                            hintTargetIcon={hintTargetIcon}\n                                            hintPlacement={hintPlacement}\n                                            hintHasArrow={hintHasArrow}\n                                            hintOffset={hintOffset}\n                                            hintWidth={hintWidth}\n                                            hintContentLeft={hintContentLeft}\n                                            handleHintShow={handleHintShow}\n                                            handleHintHide={handleHintHide}\n                                            handleHintClick={handleHintClick}\n                                        />\n                                    </StyledHintWrapper>\n                                )}\n                                {required && hasRequiredIndicator && (\n                                    <StyledIndicator\n                                        className={cx(\n                                            classes.outerLabelPlacement,\n                                            requiredPlacementClass,\n                                            hasHintClass,\n                                        )}\n                                    />\n                                )}\n                                {optionalTextNode}\n                            </StyledIndicatorWrapper>\n                        )}\n                        {titleCaption && <TitleCaption>{titleCaption}</TitleCaption>}\n                    </OuterLabelWrapper>\n                )}\n                <StyledContainer\n                    className={cx(styledContainer, ...dynamicLabelClasses)}\n                    width={helperWidth}\n                    onFocus={onFocusHandler}\n                    onBlur={onBlurHandler}\n                >\n                    {!hasOuterLabel && (\n                        <>\n                            {required && hasRequiredIndicator && (\n                                <StyledIndicator className={cx(classes.innerLabelPlacement, requiredPlacementClass)} />\n                            )}\n                            {hintText && (\n                                <StyledHintWrapper className={classes.innerLabelPlacement}>\n                                    <HintComponent\n                                        ref={hintForkRef}\n                                        hintText={hintText}\n                                        hintTrigger={hintTrigger}\n                                        isHintVisible={isHintVisible}\n                                        hintTargetIcon={hintTargetIcon}\n                                        hintPlacement={hintPlacement}\n                                        hintHasArrow={hintHasArrow}\n                                        hintOffset={hintOffset}\n                                        hintWidth={hintWidth}\n                                        hintContentLeft={hintContentLeft}\n                                        size={size}\n                                        handleHintShow={handleHintShow}\n                                        handleHintHide={handleHintHide}\n                                        handleHintClick={handleHintClick}\n                                        isInnerLabel\n                                    />\n                                </StyledHintWrapper>\n                            )}\n                        </>\n                    )}\n                    {contentRight && <StyledContent>{contentRight}</StyledContent>}\n                    <StyledTextAreaWrapper className={cx(styledTextAreaWrapper)} hasHelper={hasHelper}>\n                        <StyledTextArea\n                            className={cx(styledTextArea, hasRightContentClass)}\n                            id={id}\n                            hasContentRight={Boolean(contentRight)}\n                            hasHelper={hasHelper}\n                            applyCustomWidth={applyCustomWidth}\n                            ref={mergeRefs(outerRef, innerRef)}\n                            disabled={disabled}\n                            required={required}\n                            height={applyAutoResize ? minAuto : height}\n                            width={width}\n                            placeholder={placeholderLabel}\n                            aria-describedby={textareaHelperId}\n                            value={value}\n                            readOnly={readOnly}\n                            rows={rows}\n                            cols={cols}\n                            resize={resize}\n                            defaultValue={defaultValue}\n                            onChange={onChangeHandler}\n                            {...rest}\n                        />\n                        {applyAutoResize && (\n                            <StyledHiddenTextArea\n                                aria-hidden\n                                ref={hiddenRef}\n                                hasContentRight={Boolean(contentRight)}\n                                value={value || uncontrolledValue || ' '}\n                                defaultValue={defaultValue}\n                            />\n                        )}\n                    </StyledTextAreaWrapper>\n                    {hasHelper && (\n                        <StyledHelpers className={styledHelpers} id={textareaHelperId}>\n                            {isInnerLeftHelperPlacement && (leftHelper || helperText) && (\n                                <StyledLeftHelper>{leftHelper || helperText}</StyledLeftHelper>\n                            )}\n                            {rightHelper && <StyledRightHelper data-root>{rightHelper}</StyledRightHelper>}\n                        </StyledHelpers>\n                    )}\n                    {placeholderLabel && (\n                        <StyledPlaceholder\n                            hasContentRight={Boolean(contentRight)}\n                            className={styledPlaceholder}\n                            htmlFor={id}\n                        >\n                            {placeholderLabel}\n                            {!hasOuterLabel && optionalTextNode}\n                        </StyledPlaceholder>\n                    )}\n                </StyledContainer>\n                {hasLeftHelper && !isInnerLeftHelperPlacement && (\n                    <StyledOutsideHelpersWrapper id={textareaHelperId}>\n                        <StyledLeftHelper>{leftHelperText}</StyledLeftHelper>\n                    </StyledOutsideHelpersWrapper>\n                )}\n            </Root>\n        );\n    });\n\nexport const textAreaConfig = {\n    name: 'TextArea',\n    tag: 'div',\n    layout: textAreaRoot,\n    base,\n    variations: {\n        size: {\n            css: sizeCSS,\n        },\n        view: {\n            css: viewCSS,\n        },\n        clear: {\n            css: clearCSS,\n            attrs: true,\n        },\n        readOnly: {\n            css: readOnlyCSS,\n            attrs: true,\n        },\n        disabled: {\n            css: disabledCSS,\n            attrs: true,\n        },\n        hintView: {\n            css: hintViewCSS,\n        },\n        hintSize: {\n            css: hintSizeCSS,\n        },\n    },\n    defaults: {\n        size: 'm',\n        view: 'primary',\n    },\n};\n"]} */"));
48
48
 
49
49
  // TODO: Удалить после отказа от старых библиотек plasma-web / plasma-b2c
50
50
  var fallbackStatusMap = {
@@ -248,7 +248,8 @@ export var textAreaRoot = function textAreaRoot(Root) {
248
248
  width: helperWidth
249
249
  }, style),
250
250
  className: cx(clearClass, hasDividerClass, hasHintClass, className),
251
- onClick: handleTextAreaFocus
251
+ onClick: handleTextAreaFocus,
252
+ "data-root": true
252
253
  }, hintText && {
253
254
  hintView: hintView,
254
255
  hintSize: hintSize
@@ -328,7 +329,9 @@ export var textAreaRoot = function textAreaRoot(Root) {
328
329
  })), hasHelper && /*#__PURE__*/React.createElement(StyledHelpers, {
329
330
  className: styledHelpers,
330
331
  id: textareaHelperId
331
- }, isInnerLeftHelperPlacement && (leftHelper || helperText) && /*#__PURE__*/React.createElement(StyledLeftHelper, null, leftHelper || helperText), rightHelper && /*#__PURE__*/React.createElement(StyledRightHelper, null, rightHelper)), placeholderLabel && /*#__PURE__*/React.createElement(StyledPlaceholder, {
332
+ }, isInnerLeftHelperPlacement && (leftHelper || helperText) && /*#__PURE__*/React.createElement(StyledLeftHelper, null, leftHelper || helperText), rightHelper && /*#__PURE__*/React.createElement(StyledRightHelper, {
333
+ "data-root": true
334
+ }, rightHelper)), placeholderLabel && /*#__PURE__*/React.createElement(StyledPlaceholder, {
332
335
  hasContentRight: Boolean(contentRight),
333
336
  className: styledPlaceholder,
334
337
  htmlFor: id
@@ -254,5 +254,6 @@ export var tokens = {
254
254
  tooltipArrowMaskImage: '--plasma-textarea__tooltip-arrow-mask-image',
255
255
  tooltipArrowHeight: '--plasma-textarea__tooltip-arrow-height',
256
256
  tooltipArrowEdgeMargin: '--plasma-textarea__tooltip-arrow-edge-margin',
257
- tooltipArrowBackground: '--plasma-textarea__tooltip-arrow-background'
257
+ tooltipArrowBackground: '--plasma-textarea__tooltip-arrow-background',
258
+ tourBorderRadius: '--plasma-tour__border-radius'
258
259
  };
@@ -1,2 +1,3 @@
1
1
  import { css } from '@emotion/react';
2
- export var base = /*#__PURE__*/css(";label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEFyZWEvdmFyaWF0aW9ucy9fc2l6ZS9iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV1QiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi8uLi9zcmMtZW1vdGlvbi9jb21wb25lbnRzL1RleHRBcmVhL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IGJhc2UgPSBjc3NgYDtcbiJdfQ== */"));
2
+ import { tokens } from "../../TextArea.tokens";
3
+ export var base = /*#__PURE__*/css(tokens.tourBorderRadius, ":0.75rem;;label:plasma-new-hope__base;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVGV4dEFyZWEvdmFyaWF0aW9ucy9fc2l6ZS9iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl1QiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi8uLi9zcmMtZW1vdGlvbi9jb21wb25lbnRzL1RleHRBcmVhL3ZhcmlhdGlvbnMvX3NpemUvYmFzZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuaW1wb3J0IHsgdG9rZW5zIH0gZnJvbSAnLi4vLi4vVGV4dEFyZWEudG9rZW5zJztcblxuZXhwb3J0IGNvbnN0IGJhc2UgPSBjc3NgXG4gICAgJHt0b2tlbnMudG91ckJvcmRlclJhZGl1c306IDAuNzVyZW07XG5gO1xuIl19 */"));
@@ -15,16 +15,15 @@ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" !=
15
15
  function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
16
16
  function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
17
17
  function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
18
- // Tour.tsx
19
18
  import React, { forwardRef, useCallback, useEffect, useState, useRef, useMemo } from 'react';
20
19
  import { createPortal } from 'react-dom';
21
20
  import { useFloating, offset, flip, shift, autoUpdate } from '@floating-ui/react-dom';
22
21
  import { canUseDOM } from "../../utils";
23
- import { getHTMLElement } from "./utils";
22
+ import { getHTMLElement, getIncreasedRadius, findRootElement } from "./utils";
24
23
  import { MaskContainer, Mask, Highlight, TourPortal } from "./Tour.styles";
25
24
  import { base as viewCSS } from "./variatoins/_view/base";
26
25
  import { base as sizeCSS } from "./variatoins/_size/base";
27
- import { classes } from "./Tour.tokens";
26
+ import { classes, tokens } from "./Tour.tokens";
28
27
  var TOUR_PORTAL_ID = 'plasma-tour-portal';
29
28
  export var tourRoot = function tourRoot(Root) {
30
29
  return /*#__PURE__*/forwardRef(function (_ref, outerRef) {
@@ -67,8 +66,12 @@ export var tourRoot = function tourRoot(Root) {
67
66
  setHighlightRect = _useState6[1];
68
67
  var _useState7 = useState(null),
69
68
  _useState8 = _slicedToArray(_useState7, 2),
70
- targetElement = _useState8[0],
71
- setTargetElement = _useState8[1];
69
+ highlightBorderRadius = _useState8[0],
70
+ setHighlightBorderRadius = _useState8[1];
71
+ var _useState9 = useState(null),
72
+ _useState10 = _slicedToArray(_useState9, 2),
73
+ targetElement = _useState10[0],
74
+ setTargetElement = _useState10[1];
72
75
  var portalRef = useRef(null);
73
76
  var floatingRef = useRef(null);
74
77
  var active = controlled ? current : innerCurrent;
@@ -115,19 +118,21 @@ export var tourRoot = function tourRoot(Root) {
115
118
  };
116
119
  var updateHighlight = useCallback(function () {
117
120
  if (!isOpen || !currentStep) return;
118
- var element = getHTMLElement(currentStep.target);
119
- if (element) {
120
- var rect = element.getBoundingClientRect();
121
+ var rootItem = findRootElement(currentStep.target);
122
+ var highlightElement = getHTMLElement(rootItem);
123
+ var borderRadius = currentStep.borderRadius === 'fixed' ? "var(".concat(tokens.highlightRadius, ")") : getIncreasedRadius(rootItem, highlightOffset);
124
+ setHighlightBorderRadius(borderRadius);
125
+ if (highlightElement) {
126
+ var rect = highlightElement.getBoundingClientRect();
121
127
  setHighlightRect(rect);
122
- setTargetElement(element);
128
+ setTargetElement(highlightElement);
123
129
  } else {
124
130
  setHighlightRect(null);
125
131
  setTargetElement(null);
126
132
  }
127
133
  }, [isOpen, currentStep]);
128
134
  useEffect(function () {
129
- if (!canUseDOM) return; // No setup needed
130
-
135
+ if (!canUseDOM) return;
131
136
  var portal = document.getElementById(TOUR_PORTAL_ID);
132
137
  if (!portal) {
133
138
  portal = document.createElement('div');
@@ -187,6 +192,7 @@ export var tourRoot = function tourRoot(Root) {
187
192
  "data-plasma-tour-mask": true
188
193
  }, _Mask || (_Mask = /*#__PURE__*/React.createElement(Mask, null)), highlightRect && /*#__PURE__*/React.createElement(Highlight, {
189
194
  overlayColor: overlayColor,
195
+ borderRadius: highlightBorderRadius,
190
196
  style: {
191
197
  left: highlightRect.left - highlightOffset,
192
198
  top: highlightRect.top - highlightOffset,
@@ -1,13 +1,12 @@
1
1
  import _styled from "@emotion/styled/base";
2
2
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
3
- import { tokens } from "./Tour.tokens";
4
3
  export var MaskContainer = /*#__PURE__*/_styled("div", {
5
4
  target: "e1a1dgq93",
6
5
  label: "plasma-new-hope__MaskContainer"
7
6
  })("z-index:", function (_ref) {
8
7
  var zIndex = _ref.zIndex;
9
8
  return zIndex;
10
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSW9FIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IHRva2VucyB9IGZyb20gJy4vVG91ci50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTWFza0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB6SW5kZXg6IHN0cmluZyB8IG51bWJlciB9PmBcbiAgICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuYDtcblxuZXhwb3J0IGNvbnN0IE1hc2sgPSBzdHlsZWQuZGl2YFxuICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICBpbnNldDogMDtcbiAgICBwb2ludGVyLWV2ZW50czogYWxsO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhpZ2hsaWdodCA9IHN0eWxlZC5kaXY8eyBvdmVybGF5Q29sb3I/OiBzdHJpbmcgfT5gXG4gICAgLS1wcml2YXRlLW1hc2stY29sb3I6ICR7KHsgb3ZlcmxheUNvbG9yIH0pID0+IGAke292ZXJsYXlDb2xvciB8fCAncmdiYSgwLCAwLCAwLCAwLjQ1KSd9YH07XG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgIGJvcmRlci1yYWRpdXM6IHZhcigke3Rva2Vucy5oaWdobGlnaHRSYWRpdXN9LCAwLjVyZW0pO1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDk5OTlweCB2YXIoLS1wcml2YXRlLW1hc2stY29sb3IpO1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjNzIGN1YmljLWJlemllcigwLjQsIDAsIDAuMiwgMSk7XG5gO1xuXG5leHBvcnQgY29uc3QgVG91clBvcnRhbCA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuYDtcbiJdfQ== */"));
9
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRW9FIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBNYXNrQ29udGFpbmVyID0gc3R5bGVkLmRpdjx7IHpJbmRleDogc3RyaW5nIHwgbnVtYmVyIH0+YFxuICAgIHotaW5kZXg6ICR7KHsgekluZGV4IH0pID0+IHpJbmRleH07XG5gO1xuXG5leHBvcnQgY29uc3QgTWFzayA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGluc2V0OiAwO1xuICAgIHBvaW50ZXItZXZlbnRzOiBhbGw7XG5gO1xuXG5leHBvcnQgY29uc3QgSGlnaGxpZ2h0ID0gc3R5bGVkLmRpdjx7IG92ZXJsYXlDb2xvcj86IHN0cmluZzsgYm9yZGVyUmFkaXVzPzogc3RyaW5nIHwgbnVsbCB9PmBcbiAgICAtLXByaXZhdGUtbWFzay1jb2xvcjogJHsoeyBvdmVybGF5Q29sb3IgfSkgPT4gYCR7b3ZlcmxheUNvbG9yIHx8ICdyZ2JhKDAsIDAsIDAsIDAuNDUpJ31gfTtcbiAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgYm9yZGVyLXJhZGl1czogJHsoeyBib3JkZXJSYWRpdXMgfSkgPT4gYm9yZGVyUmFkaXVzID8/IDB9O1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDk5OTlweCB2YXIoLS1wcml2YXRlLW1hc2stY29sb3IpO1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjNzIGN1YmljLWJlemllcigwLjQsIDAsIDAuMiwgMSk7XG5gO1xuXG5leHBvcnQgY29uc3QgVG91clBvcnRhbCA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuYDtcbiJdfQ== */"));
11
10
  export var Mask = /*#__PURE__*/_styled("div", {
12
11
  target: "e1a1dgq92",
13
12
  label: "plasma-new-hope__Mask"
@@ -17,7 +16,7 @@ export var Mask = /*#__PURE__*/_styled("div", {
17
16
  } : {
18
17
  name: "xzntb4",
19
18
  styles: "position:fixed;inset:0;pointer-events:all",
20
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUThCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IHRva2VucyB9IGZyb20gJy4vVG91ci50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTWFza0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB6SW5kZXg6IHN0cmluZyB8IG51bWJlciB9PmBcbiAgICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuYDtcblxuZXhwb3J0IGNvbnN0IE1hc2sgPSBzdHlsZWQuZGl2YFxuICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICBpbnNldDogMDtcbiAgICBwb2ludGVyLWV2ZW50czogYWxsO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhpZ2hsaWdodCA9IHN0eWxlZC5kaXY8eyBvdmVybGF5Q29sb3I/OiBzdHJpbmcgfT5gXG4gICAgLS1wcml2YXRlLW1hc2stY29sb3I6ICR7KHsgb3ZlcmxheUNvbG9yIH0pID0+IGAke292ZXJsYXlDb2xvciB8fCAncmdiYSgwLCAwLCAwLCAwLjQ1KSd9YH07XG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgIGJvcmRlci1yYWRpdXM6IHZhcigke3Rva2Vucy5oaWdobGlnaHRSYWRpdXN9LCAwLjVyZW0pO1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDk5OTlweCB2YXIoLS1wcml2YXRlLW1hc2stY29sb3IpO1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjNzIGN1YmljLWJlemllcigwLjQsIDAsIDAuMiwgMSk7XG5gO1xuXG5leHBvcnQgY29uc3QgVG91clBvcnRhbCA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuYDtcbiJdfQ== */",
19
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTThCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBNYXNrQ29udGFpbmVyID0gc3R5bGVkLmRpdjx7IHpJbmRleDogc3RyaW5nIHwgbnVtYmVyIH0+YFxuICAgIHotaW5kZXg6ICR7KHsgekluZGV4IH0pID0+IHpJbmRleH07XG5gO1xuXG5leHBvcnQgY29uc3QgTWFzayA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGluc2V0OiAwO1xuICAgIHBvaW50ZXItZXZlbnRzOiBhbGw7XG5gO1xuXG5leHBvcnQgY29uc3QgSGlnaGxpZ2h0ID0gc3R5bGVkLmRpdjx7IG92ZXJsYXlDb2xvcj86IHN0cmluZzsgYm9yZGVyUmFkaXVzPzogc3RyaW5nIHwgbnVsbCB9PmBcbiAgICAtLXByaXZhdGUtbWFzay1jb2xvcjogJHsoeyBvdmVybGF5Q29sb3IgfSkgPT4gYCR7b3ZlcmxheUNvbG9yIHx8ICdyZ2JhKDAsIDAsIDAsIDAuNDUpJ31gfTtcbiAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgYm9yZGVyLXJhZGl1czogJHsoeyBib3JkZXJSYWRpdXMgfSkgPT4gYm9yZGVyUmFkaXVzID8/IDB9O1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDk5OTlweCB2YXIoLS1wcml2YXRlLW1hc2stY29sb3IpO1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjNzIGN1YmljLWJlemllcigwLjQsIDAsIDAuMiwgMSk7XG5gO1xuXG5leHBvcnQgY29uc3QgVG91clBvcnRhbCA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuYDtcbiJdfQ== */",
21
20
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
21
  });
23
22
  export var Highlight = /*#__PURE__*/_styled("div", {
@@ -26,7 +25,10 @@ export var Highlight = /*#__PURE__*/_styled("div", {
26
25
  })("--private-mask-color:", function (_ref2) {
27
26
  var overlayColor = _ref2.overlayColor;
28
27
  return "".concat(overlayColor || 'rgba(0, 0, 0, 0.45)');
29
- }, ";position:fixed;background:transparent;border-radius:var(", tokens.highlightRadius, ", 0.5rem);box-shadow:0 0 0 9999px var(--private-mask-color);pointer-events:none;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYzhEIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IHRva2VucyB9IGZyb20gJy4vVG91ci50b2tlbnMnO1xuXG5leHBvcnQgY29uc3QgTWFza0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB6SW5kZXg6IHN0cmluZyB8IG51bWJlciB9PmBcbiAgICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuYDtcblxuZXhwb3J0IGNvbnN0IE1hc2sgPSBzdHlsZWQuZGl2YFxuICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICBpbnNldDogMDtcbiAgICBwb2ludGVyLWV2ZW50czogYWxsO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhpZ2hsaWdodCA9IHN0eWxlZC5kaXY8eyBvdmVybGF5Q29sb3I/OiBzdHJpbmcgfT5gXG4gICAgLS1wcml2YXRlLW1hc2stY29sb3I6ICR7KHsgb3ZlcmxheUNvbG9yIH0pID0+IGAke292ZXJsYXlDb2xvciB8fCAncmdiYSgwLCAwLCAwLCAwLjQ1KSd9YH07XG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgIGJvcmRlci1yYWRpdXM6IHZhcigke3Rva2Vucy5oaWdobGlnaHRSYWRpdXN9LCAwLjVyZW0pO1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDk5OTlweCB2YXIoLS1wcml2YXRlLW1hc2stY29sb3IpO1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjNzIGN1YmljLWJlemllcigwLjQsIDAsIDAuMiwgMSk7XG5gO1xuXG5leHBvcnQgY29uc3QgVG91clBvcnRhbCA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuYDtcbiJdfQ== */"));
28
+ }, ";position:fixed;background:transparent;border-radius:", function (_ref3) {
29
+ var borderRadius = _ref3.borderRadius;
30
+ return borderRadius !== null && borderRadius !== void 0 ? borderRadius : 0;
31
+ }, ";box-shadow:0 0 0 9999px var(--private-mask-color);pointer-events:none;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWTRGIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBNYXNrQ29udGFpbmVyID0gc3R5bGVkLmRpdjx7IHpJbmRleDogc3RyaW5nIHwgbnVtYmVyIH0+YFxuICAgIHotaW5kZXg6ICR7KHsgekluZGV4IH0pID0+IHpJbmRleH07XG5gO1xuXG5leHBvcnQgY29uc3QgTWFzayA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGluc2V0OiAwO1xuICAgIHBvaW50ZXItZXZlbnRzOiBhbGw7XG5gO1xuXG5leHBvcnQgY29uc3QgSGlnaGxpZ2h0ID0gc3R5bGVkLmRpdjx7IG92ZXJsYXlDb2xvcj86IHN0cmluZzsgYm9yZGVyUmFkaXVzPzogc3RyaW5nIHwgbnVsbCB9PmBcbiAgICAtLXByaXZhdGUtbWFzay1jb2xvcjogJHsoeyBvdmVybGF5Q29sb3IgfSkgPT4gYCR7b3ZlcmxheUNvbG9yIHx8ICdyZ2JhKDAsIDAsIDAsIDAuNDUpJ31gfTtcbiAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgYm9yZGVyLXJhZGl1czogJHsoeyBib3JkZXJSYWRpdXMgfSkgPT4gYm9yZGVyUmFkaXVzID8/IDB9O1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDk5OTlweCB2YXIoLS1wcml2YXRlLW1hc2stY29sb3IpO1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjNzIGN1YmljLWJlemllcigwLjQsIDAsIDAuMiwgMSk7XG5gO1xuXG5leHBvcnQgY29uc3QgVG91clBvcnRhbCA9IHN0eWxlZC5kaXZgXG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuYDtcbiJdfQ== */"));
30
32
  export var TourPortal = /*#__PURE__*/_styled("div", {
31
33
  target: "e1a1dgq90",
32
34
  label: "plasma-new-hope__TourPortal"
@@ -36,6 +38,6 @@ export var TourPortal = /*#__PURE__*/_styled("div", {
36
38
  } : {
37
39
  name: "a4hmbt",
38
40
  styles: "position:absolute",
39
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JvQyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMtZW1vdGlvbi9jb21wb25lbnRzL1RvdXIvVG91ci5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5pbXBvcnQgeyB0b2tlbnMgfSBmcm9tICcuL1RvdXIudG9rZW5zJztcblxuZXhwb3J0IGNvbnN0IE1hc2tDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgekluZGV4OiBzdHJpbmcgfCBudW1iZXIgfT5gXG4gICAgei1pbmRleDogJHsoeyB6SW5kZXggfSkgPT4gekluZGV4fTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNYXNrID0gc3R5bGVkLmRpdmBcbiAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgaW5zZXQ6IDA7XG4gICAgcG9pbnRlci1ldmVudHM6IGFsbDtcbmA7XG5cbmV4cG9ydCBjb25zdCBIaWdobGlnaHQgPSBzdHlsZWQuZGl2PHsgb3ZlcmxheUNvbG9yPzogc3RyaW5nIH0+YFxuICAgIC0tcHJpdmF0ZS1tYXNrLWNvbG9yOiAkeyh7IG92ZXJsYXlDb2xvciB9KSA9PiBgJHtvdmVybGF5Q29sb3IgfHwgJ3JnYmEoMCwgMCwgMCwgMC40NSknfWB9O1xuICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgICBib3JkZXItcmFkaXVzOiB2YXIoJHt0b2tlbnMuaGlnaGxpZ2h0UmFkaXVzfSwgMC41cmVtKTtcbiAgICBib3gtc2hhZG93OiAwIDAgMCA5OTk5cHggdmFyKC0tcHJpdmF0ZS1tYXNrLWNvbG9yKTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICB0cmFuc2l0aW9uOiBhbGwgMC4zcyBjdWJpYy1iZXppZXIoMC40LCAwLCAwLjIsIDEpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvdXJQb3J0YWwgPSBzdHlsZWQuZGl2YFxuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbmA7XG4iXX0= */",
41
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy1lbW90aW9uL2NvbXBvbmVudHMvVG91ci9Ub3VyLnN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JvQyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMtZW1vdGlvbi9jb21wb25lbnRzL1RvdXIvVG91ci5zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5leHBvcnQgY29uc3QgTWFza0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB6SW5kZXg6IHN0cmluZyB8IG51bWJlciB9PmBcbiAgICB6LWluZGV4OiAkeyh7IHpJbmRleCB9KSA9PiB6SW5kZXh9O1xuYDtcblxuZXhwb3J0IGNvbnN0IE1hc2sgPSBzdHlsZWQuZGl2YFxuICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICBpbnNldDogMDtcbiAgICBwb2ludGVyLWV2ZW50czogYWxsO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhpZ2hsaWdodCA9IHN0eWxlZC5kaXY8eyBvdmVybGF5Q29sb3I/OiBzdHJpbmc7IGJvcmRlclJhZGl1cz86IHN0cmluZyB8IG51bGwgfT5gXG4gICAgLS1wcml2YXRlLW1hc2stY29sb3I6ICR7KHsgb3ZlcmxheUNvbG9yIH0pID0+IGAke292ZXJsYXlDb2xvciB8fCAncmdiYSgwLCAwLCAwLCAwLjQ1KSd9YH07XG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuICAgIGJvcmRlci1yYWRpdXM6ICR7KHsgYm9yZGVyUmFkaXVzIH0pID0+IGJvcmRlclJhZGl1cyA/PyAwfTtcbiAgICBib3gtc2hhZG93OiAwIDAgMCA5OTk5cHggdmFyKC0tcHJpdmF0ZS1tYXNrLWNvbG9yKTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICB0cmFuc2l0aW9uOiBhbGwgMC4zcyBjdWJpYy1iZXppZXIoMC40LCAwLCAwLjIsIDEpO1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvdXJQb3J0YWwgPSBzdHlsZWQuZGl2YFxuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbmA7XG4iXX0= */",
40
42
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
41
43
  });
@@ -9,4 +9,96 @@ export var getHTMLElement = function getHTMLElement(target) {
9
9
  return target.current;
10
10
  }
11
11
  return target;
12
+ };
13
+ export var getIncreasedRadius = function getIncreasedRadius(ref, offset) {
14
+ if (!ref.current) {
15
+ return '';
16
+ }
17
+ var element = ref.current;
18
+ var computedStyle = getComputedStyle(element);
19
+ var borderRadiusComponent = computedStyle.getPropertyValue('--plasma-tour__border-radius');
20
+ var currentRadius = computedStyle.borderRadius !== undefined && computedStyle.borderRadius !== null && computedStyle.borderRadius !== '0px' ? computedStyle.borderRadius : borderRadiusComponent;
21
+ var parseValue = function parseValue(value, context) {
22
+ var num = parseFloat(value);
23
+ if (Number.isNaN(num)) return 0;
24
+ if (value.endsWith('px')) return num;
25
+ if (value.endsWith('%')) return num / 100 * context.width;
26
+ if (value.endsWith('em')) return num * parseFloat(computedStyle.fontSize);
27
+ if (value.endsWith('rem')) {
28
+ return num * parseFloat(getComputedStyle(document.documentElement).fontSize);
29
+ }
30
+ if (value.endsWith('vw')) return num / 100 * window.innerWidth;
31
+ if (value.endsWith('vh')) return num / 100 * window.innerHeight;
32
+ if (value.endsWith('vmin')) return num / 100 * Math.min(window.innerWidth, window.innerHeight);
33
+ if (value.endsWith('vmax')) return num / 100 * Math.max(window.innerWidth, window.innerHeight);
34
+ return num;
35
+ };
36
+ var context = {
37
+ width: element.offsetWidth,
38
+ height: element.offsetHeight
39
+ };
40
+ var parseRadius = function parseRadius(radius) {
41
+ var parts = radius.split('/').map(function (part) {
42
+ return part.trim();
43
+ });
44
+ var horizontal = parts[0].split(/\s+/).map(function (val) {
45
+ return parseValue(val, context);
46
+ });
47
+ var normalize = function normalize(values) {
48
+ if (values.length === 1) return [values[0], values[0], values[0], values[0]];
49
+ if (values.length === 2) return [values[0], values[1], values[0], values[1]];
50
+ if (values.length === 3) return [values[0], values[1], values[2], values[1]];
51
+ return values.slice(0, 4);
52
+ };
53
+ return {
54
+ horizontal: normalize(horizontal),
55
+ vertical: parts[1] ? normalize(parts[1].split(/\s+/).map(function (val) {
56
+ return parseValue(val, context);
57
+ })) : normalize(horizontal)
58
+ };
59
+ };
60
+ try {
61
+ var parsed = parseRadius(currentRadius);
62
+ var newHorizontal = parsed.horizontal.map(function (val) {
63
+ return val !== 0 ? Math.max(0, val + offset) : 0;
64
+ });
65
+ var newVertical = parsed.vertical.map(function (val) {
66
+ return val !== 0 ? Math.max(0, val + offset) : 0;
67
+ });
68
+ var format = function format(values) {
69
+ return values.map(function (v) {
70
+ return "".concat(v, "px");
71
+ }).join(' ');
72
+ };
73
+ var horizontalStr = format(newHorizontal);
74
+ var verticalStr = format(newVertical);
75
+ return horizontalStr === verticalStr ? horizontalStr : "".concat(horizontalStr, " / ").concat(verticalStr);
76
+ } catch (error) {
77
+ return '';
78
+ }
79
+ };
80
+ export var findRootElement = function findRootElement(ref) {
81
+ var _currentElement;
82
+ if (!ref.current) {
83
+ return '';
84
+ }
85
+ var currentElement = ref.current;
86
+ while (currentElement !== null && currentElement !== document.documentElement) {
87
+ if (currentElement.hasAttribute('data-root')) {
88
+ return {
89
+ current: currentElement
90
+ };
91
+ }
92
+ var parent = currentElement.parentElement;
93
+ if (parent === null) {
94
+ break;
95
+ }
96
+ currentElement = parent;
97
+ }
98
+ if ((_currentElement = currentElement) !== null && _currentElement !== void 0 && _currentElement.hasAttribute('data-root')) {
99
+ return {
100
+ current: currentElement
101
+ };
102
+ }
103
+ return ref;
12
104
  };
@@ -2,10 +2,12 @@ import React, { useRef, useState } from 'react';
2
2
  import type { StoryObj, Meta } from '@storybook/react';
3
3
  import styled from '@emotion/styled';
4
4
 
5
+ import { IconArrowDown } from '../../../../components/_Icon';
5
6
  import { linkConfig } from '../../../../components/Link';
6
7
  import { mergeConfig } from '../../../../engines';
7
8
  import { WithTheme, argTypesFromConfig } from '../../../_helpers';
8
9
  import { Button } from '../Button/Button';
10
+ import { TextArea } from '../TextArea/TextArea';
9
11
 
10
12
  import { config } from './Tour.config';
11
13
  import { Tour } from './Tour';
@@ -113,10 +115,11 @@ const TourCard: React.FC<{
113
115
  };
114
116
 
115
117
  const StoryDefault = (args) => {
116
- const ref1 = useRef<HTMLButtonElement>(null);
118
+ const ref1 = useRef<HTMLTextAreaElement>(null);
117
119
  const ref2 = useRef<HTMLButtonElement>(null);
118
- const ref3 = useRef<HTMLButtonElement>(null);
119
- const ref4 = useRef<HTMLButtonElement>(null);
120
+ const ref3 = useRef<HTMLDivElement>(null);
121
+ const ref4 = useRef<HTMLDivElement>(null);
122
+ const ref5 = useRef<HTMLDivElement>(null);
120
123
  const [open, setOpen] = useState(false);
121
124
  const [current, setCurrent] = useState(0);
122
125
 
@@ -139,7 +142,7 @@ const StoryDefault = (args) => {
139
142
  onClose={onClose}
140
143
  />
141
144
  ),
142
- placement: 'right',
145
+ placement: 'bottom',
143
146
  },
144
147
  {
145
148
  target: ref2,
@@ -187,13 +190,30 @@ const StoryDefault = (args) => {
187
190
  ),
188
191
  placement: 'left',
189
192
  },
193
+ {
194
+ target: ref5,
195
+ renderItem: () => (
196
+ <TourCard
197
+ title="Первый шаг"
198
+ description="Нажмите кнопку, чтобы продолжить"
199
+ index={4}
200
+ last={current === steps.length - 1}
201
+ total={steps.length}
202
+ onNext={onNext}
203
+ onPrev={onPrev}
204
+ onClose={onClose}
205
+ />
206
+ ),
207
+ placement: 'left',
208
+ borderRadius: 'fixed',
209
+ },
190
210
  ];
191
211
 
192
212
  return (
193
213
  <div
194
214
  style={{
195
215
  width: '100%',
196
- height: '110vh',
216
+ height: '100vh',
197
217
  display: 'flex',
198
218
  justifyContent: 'space-between',
199
219
  flexDirection: 'column',
@@ -207,7 +227,16 @@ const StoryDefault = (args) => {
207
227
  justifyContent: 'space-between',
208
228
  }}
209
229
  >
210
- <Button ref={ref1}>Блок 1</Button>
230
+ <TextArea
231
+ ref={ref1}
232
+ rightHelper={
233
+ <div ref={ref5} style={{ cursor: 'pointer', transform: 'rotate(-90deg)' }}>
234
+ <IconArrowDown />
235
+ </div>
236
+ }
237
+ rows={10}
238
+ cols={20}
239
+ />
211
240
  <Button ref={ref2}>Блок 2</Button>
212
241
  </div>
213
242
  <Button onClick={() => setOpen(true)}>Запуск тура</Button>
@@ -219,8 +248,25 @@ const StoryDefault = (args) => {
219
248
  justifyContent: 'space-between',
220
249
  }}
221
250
  >
222
- <Button ref={ref3}>Блок 3</Button>
223
- <Button ref={ref4}>Блок 4</Button>
251
+ <div
252
+ style={{
253
+ background: 'black',
254
+ width: '100px',
255
+ height: '100px',
256
+ borderRadius: '50%',
257
+ }}
258
+ ref={ref3}
259
+ />
260
+ <div
261
+ style={{
262
+ background: 'black',
263
+ width: '100px',
264
+ height: '100px',
265
+ }}
266
+ ref={ref4}
267
+ >
268
+ Блок 4
269
+ </div>
224
270
  </div>
225
271
 
226
272
  <Tour