@salutejs/plasma-new-hope 0.327.0-canary.2010.15679377511.0 → 0.327.0-canary.2010.15733259332.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/components/TextArea/TextArea.js +5 -2
- package/cjs/components/TextArea/TextArea.js.map +1 -1
- package/cjs/components/TextArea/TextArea.tokens.js +2 -1
- package/cjs/components/TextArea/TextArea.tokens.js.map +1 -1
- package/cjs/components/TextArea/variations/_size/base.js +1 -1
- package/cjs/components/TextArea/variations/_size/base.js.map +1 -1
- package/cjs/components/TextArea/variations/_size/base_vftquy.css +1 -0
- package/cjs/components/Tour/Tour.css +4 -4
- package/cjs/components/Tour/Tour.js +15 -8
- package/cjs/components/Tour/Tour.js.map +1 -1
- package/cjs/components/Tour/Tour.styles.js +9 -2
- package/cjs/components/Tour/Tour.styles.js.map +1 -1
- package/cjs/components/Tour/Tour.styles_hmd79i.css +4 -0
- package/cjs/components/Tour/utils/index.js +94 -0
- package/cjs/components/Tour/utils/index.js.map +1 -1
- package/cjs/index.css +6 -4
- package/emotion/cjs/components/TextArea/TextArea.js +6 -3
- package/emotion/cjs/components/TextArea/TextArea.tokens.js +2 -1
- package/emotion/cjs/components/TextArea/variations/_size/base.js +2 -1
- package/emotion/cjs/components/Tour/Tour.js +16 -9
- package/emotion/cjs/components/Tour/Tour.styles.js +7 -5
- package/emotion/cjs/components/Tour/utils/index.js +93 -1
- package/emotion/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +57 -8
- package/emotion/es/components/TextArea/TextArea.js +6 -3
- package/emotion/es/components/TextArea/TextArea.tokens.js +2 -1
- package/emotion/es/components/TextArea/variations/_size/base.js +2 -1
- package/emotion/es/components/Tour/Tour.js +17 -11
- package/emotion/es/components/Tour/Tour.styles.js +7 -5
- package/emotion/es/components/Tour/utils/index.js +92 -0
- package/emotion/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +57 -8
- package/es/components/TextArea/TextArea.js +5 -2
- package/es/components/TextArea/TextArea.js.map +1 -1
- package/es/components/TextArea/TextArea.tokens.js +2 -1
- package/es/components/TextArea/TextArea.tokens.js.map +1 -1
- package/es/components/TextArea/variations/_size/base.js +1 -1
- package/es/components/TextArea/variations/_size/base.js.map +1 -1
- package/es/components/TextArea/variations/_size/base_vftquy.css +1 -0
- package/es/components/Tour/Tour.css +4 -4
- package/es/components/Tour/Tour.js +17 -10
- package/es/components/Tour/Tour.js.map +1 -1
- package/es/components/Tour/Tour.styles.js +9 -2
- package/es/components/Tour/Tour.styles.js.map +1 -1
- package/es/components/Tour/Tour.styles_hmd79i.css +4 -0
- package/es/components/Tour/utils/index.js +93 -1
- package/es/components/Tour/utils/index.js.map +1 -1
- package/es/index.css +6 -4
- package/package.json +2 -2
- package/styled-components/cjs/components/TextArea/TextArea.js +5 -2
- package/styled-components/cjs/components/TextArea/TextArea.tokens.js +2 -1
- package/styled-components/cjs/components/TextArea/variations/_size/base.js +2 -1
- package/styled-components/cjs/components/Tour/Tour.js +16 -9
- package/styled-components/cjs/components/Tour/Tour.styles.js +5 -3
- package/styled-components/cjs/components/Tour/utils/index.js +93 -1
- package/styled-components/cjs/examples/plasma_b2c/components/Tour/Tour.stories.tsx +57 -8
- package/styled-components/es/components/TextArea/TextArea.js +5 -2
- package/styled-components/es/components/TextArea/TextArea.tokens.js +2 -1
- package/styled-components/es/components/TextArea/variations/_size/base.js +2 -1
- package/styled-components/es/components/Tour/Tour.js +17 -11
- package/styled-components/es/components/Tour/Tour.styles.js +5 -3
- package/styled-components/es/components/Tour/utils/index.js +92 -0
- package/styled-components/es/examples/plasma_b2c/components/Tour/Tour.stories.tsx +57 -8
- package/types/components/TextArea/TextArea.d.ts.map +1 -1
- package/types/components/TextArea/TextArea.tokens.d.ts +1 -0
- package/types/components/TextArea/TextArea.tokens.d.ts.map +1 -1
- package/types/components/TextArea/variations/_size/base.d.ts.map +1 -1
- package/types/components/Tour/Tour.d.ts.map +1 -1
- package/types/components/Tour/Tour.styles.d.ts +1 -0
- package/types/components/Tour/Tour.styles.d.ts.map +1 -1
- package/types/components/Tour/Tour.types.d.ts +8 -0
- package/types/components/Tour/Tour.types.d.ts.map +1 -1
- package/types/components/Tour/utils/index.d.ts +2 -0
- package/types/components/Tour/utils/index.d.ts.map +1 -1
- package/cjs/components/TextArea/variations/_size/base_x642ct.css +0 -1
- package/cjs/components/Tour/Tour.styles_1ks2isn.css +0 -4
- package/es/components/TextArea/variations/_size/base_x642ct.css +0 -1
- 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<
|
118
|
+
const ref1 = useRef<HTMLTextAreaElement>(null);
|
117
119
|
const ref2 = useRef<HTMLButtonElement>(null);
|
118
|
-
const ref3 = useRef<
|
119
|
-
const ref4 = useRef<
|
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: '
|
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: '
|
216
|
+
height: '100vh',
|
197
217
|
display: 'flex',
|
198
218
|
justifyContent: 'space-between',
|
199
219
|
flexDirection: 'column',
|
@@ -207,7 +227,19 @@ const StoryDefault = (args) => {
|
|
207
227
|
justifyContent: 'space-between',
|
208
228
|
}}
|
209
229
|
>
|
210
|
-
<
|
230
|
+
<TextArea
|
231
|
+
ref={ref1}
|
232
|
+
label="Textarea"
|
233
|
+
placeholder="Напиши что нибудь"
|
234
|
+
leftHelper="Helper Text"
|
235
|
+
rightHelper={
|
236
|
+
<div ref={ref5} style={{ cursor: 'pointer', transform: 'rotate(-90deg)' }}>
|
237
|
+
<IconArrowDown />
|
238
|
+
</div>
|
239
|
+
}
|
240
|
+
rows={10}
|
241
|
+
cols={20}
|
242
|
+
/>
|
211
243
|
<Button ref={ref2}>Блок 2</Button>
|
212
244
|
</div>
|
213
245
|
<Button onClick={() => setOpen(true)}>Запуск тура</Button>
|
@@ -219,8 +251,25 @@ const StoryDefault = (args) => {
|
|
219
251
|
justifyContent: 'space-between',
|
220
252
|
}}
|
221
253
|
>
|
222
|
-
<
|
223
|
-
|
254
|
+
<div
|
255
|
+
style={{
|
256
|
+
background: 'black',
|
257
|
+
width: '100px',
|
258
|
+
height: '100px',
|
259
|
+
borderRadius: '50%',
|
260
|
+
}}
|
261
|
+
ref={ref3}
|
262
|
+
/>
|
263
|
+
<div
|
264
|
+
style={{
|
265
|
+
background: 'black',
|
266
|
+
width: '100px',
|
267
|
+
height: '100px',
|
268
|
+
}}
|
269
|
+
ref={ref4}
|
270
|
+
>
|
271
|
+
Блок 4
|
272
|
+
</div>
|
224
273
|
</div>
|
225
274
|
|
226
275
|
<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,
|
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
|
-
|
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
|
-
|
71
|
-
|
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
|
119
|
-
|
120
|
-
|
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(
|
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;
|
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,
|
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,
|
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:
|
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,
|
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<
|
118
|
+
const ref1 = useRef<HTMLTextAreaElement>(null);
|
117
119
|
const ref2 = useRef<HTMLButtonElement>(null);
|
118
|
-
const ref3 = useRef<
|
119
|
-
const ref4 = useRef<
|
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: '
|
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: '
|
216
|
+
height: '100vh',
|
197
217
|
display: 'flex',
|
198
218
|
justifyContent: 'space-between',
|
199
219
|
flexDirection: 'column',
|
@@ -207,7 +227,19 @@ const StoryDefault = (args) => {
|
|
207
227
|
justifyContent: 'space-between',
|
208
228
|
}}
|
209
229
|
>
|
210
|
-
<
|
230
|
+
<TextArea
|
231
|
+
ref={ref1}
|
232
|
+
label="Textarea"
|
233
|
+
placeholder="Напиши что нибудь"
|
234
|
+
leftHelper="Helper Text"
|
235
|
+
rightHelper={
|
236
|
+
<div ref={ref5} style={{ cursor: 'pointer', transform: 'rotate(-90deg)' }}>
|
237
|
+
<IconArrowDown />
|
238
|
+
</div>
|
239
|
+
}
|
240
|
+
rows={10}
|
241
|
+
cols={20}
|
242
|
+
/>
|
211
243
|
<Button ref={ref2}>Блок 2</Button>
|
212
244
|
</div>
|
213
245
|
<Button onClick={() => setOpen(true)}>Запуск тура</Button>
|
@@ -219,8 +251,25 @@ const StoryDefault = (args) => {
|
|
219
251
|
justifyContent: 'space-between',
|
220
252
|
}}
|
221
253
|
>
|
222
|
-
<
|
223
|
-
|
254
|
+
<div
|
255
|
+
style={{
|
256
|
+
background: 'black',
|
257
|
+
width: '100px',
|
258
|
+
height: '100px',
|
259
|
+
borderRadius: '50%',
|
260
|
+
}}
|
261
|
+
ref={ref3}
|
262
|
+
/>
|
263
|
+
<div
|
264
|
+
style={{
|
265
|
+
background: 'black',
|
266
|
+
width: '100px',
|
267
|
+
height: '100px',
|
268
|
+
}}
|
269
|
+
ref={ref4}
|
270
|
+
>
|
271
|
+
Блок 4
|
272
|
+
</div>
|
224
273
|
</div>
|
225
274
|
|
226
275
|
<Tour
|