@true-engineering/true-react-common-ui-kit 3.31.0 → 3.32.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/LICENSE +201 -201
- package/README.md +7 -0
- package/dist/components/Notification/Notification.d.ts +2 -0
- package/dist/components/Notification/Notification.styles.d.ts +1 -1
- package/dist/components/Notification/types.d.ts +1 -1
- package/dist/true-react-common-ui-kit.js +64 -61
- package/dist/true-react-common-ui-kit.js.map +1 -1
- package/dist/true-react-common-ui-kit.umd.cjs +64 -61
- package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
- package/package.json +98 -98
- package/src/components/AccountInfo/AccountInfo.stories.tsx +32 -32
- package/src/components/AccountInfo/AccountInfo.tsx +80 -80
- package/src/components/AddButton/AddButton.stories.tsx +21 -21
- package/src/components/AddButton/AddButton.tsx +52 -52
- package/src/components/Colors/Colors.stories.tsx +7 -7
- package/src/components/DateInput/DateInput.tsx +90 -90
- package/src/components/DateInput/constants.ts +2 -2
- package/src/components/Description/Description.stories.tsx +27 -27
- package/src/components/Description/Description.tsx +61 -61
- package/src/components/FiltersPane/components/FilterValueView/FilterValueView.tsx +166 -166
- package/src/components/FiltersPane/components/FilterWithDates/FilterWithDates.tsx +210 -210
- package/src/components/FiltersPane/components/FilterWithPeriod/FilterWithPeriod.tsx +177 -177
- package/src/components/Flag/Flag.stories.tsx +29 -29
- package/src/components/Flag/Flag.tsx +26 -26
- package/src/components/Flag/augment.d.ts +1 -1
- package/src/components/FlexibleTable/components/FlexibleTableCell/FlexibleTableCell.styles.ts +38 -38
- package/src/components/FlexibleTable/components/FlexibleTableRow/FlexibleTableRow.styles.ts +25 -25
- package/src/components/FlexibleTable/types.ts +70 -70
- package/src/components/Icon/Icon.stories.tsx +86 -86
- package/src/components/Icon/complexIcons/augment.d.ts +1 -1
- package/src/components/Icon/complexIcons/avatarGreen.svg +57 -57
- package/src/components/Icon/complexIcons/index.ts +1 -1
- package/src/components/Icon/icons-list.ts +856 -856
- package/src/components/IncrementInput/IncrementInput.tsx +105 -105
- package/src/components/Input/types.ts +32 -32
- package/src/components/Modal/Modal.stories.tsx +105 -105
- package/src/components/MultiSelect/MultiSelect.stories.tsx +46 -46
- package/src/components/MultiSelect/MultiSelect.tsx +106 -106
- package/src/components/MultiSelect/components/MultiSelectInput/MultiSelectInput.tsx +53 -53
- package/src/components/Notification/Notification.stories.tsx +55 -46
- package/src/components/Notification/Notification.styles.ts +57 -55
- package/src/components/Notification/Notification.tsx +77 -69
- package/src/components/Notification/types.ts +1 -1
- package/src/components/NumberInput/NumberInput.tsx +137 -137
- package/src/components/NumberInput/index.ts +1 -1
- package/src/components/PhoneInput/PhoneInput.tsx +214 -214
- package/src/components/PhoneInput/components/PhoneInputCountryList/PhoneInputCountryList.tsx +155 -155
- package/src/components/PhoneInput/types.ts +16 -16
- package/src/components/RadioButton/RadioButton.stories.tsx +46 -46
- package/src/components/RadioButton/RadioButton.tsx +57 -57
- package/src/components/ScrollIntoViewIfNeeded/index.ts +1 -1
- package/src/components/Select/Select.stories.tsx +235 -235
- package/src/components/Select/constants.ts +2 -2
- package/src/components/Select/types.ts +1 -1
- package/src/components/Selector/Selector.stories.tsx +62 -62
- package/src/components/Selector/Selector.tsx +115 -115
- package/src/components/Selector/index.ts +2 -2
- package/src/components/Selector/types.ts +12 -12
- package/src/components/Skeleton/Skeleton.stories.tsx +19 -19
- package/src/components/SmartInput/SmartInput.tsx +134 -134
- package/src/components/Status/Status.stories.tsx +73 -73
- package/src/components/Status/Status.styles.ts +143 -143
- package/src/components/Status/Status.tsx +49 -49
- package/src/components/Status/constants.ts +11 -11
- package/src/components/Status/index.ts +3 -3
- package/src/components/Status/types.ts +5 -5
- package/src/components/Switch/Switch.stories.tsx +40 -40
- package/src/components/Switch/Switch.tsx +75 -75
- package/src/components/TextWithInfo/TextWithInfo.stories.tsx +53 -53
- package/src/components/TextWithInfo/TextWithInfo.tsx +62 -62
- package/src/components/TextWithTooltip/TextWithTooltip.stories.tsx +58 -58
- package/src/components/ThemedPreloader/ThemedPreloader.stories.tsx +41 -41
- package/src/components/ThemedPreloader/ThemedPreloader.tsx +54 -54
- package/src/components/ThemedPreloader/components/DefaultPreloader/index.ts +1 -1
- package/src/components/Toaster/Toaster.stories.tsx +30 -30
- package/src/components/Tooltip/Tooltip.stories.tsx +19 -19
- package/src/components/Tooltip/Tooltip.tsx +35 -35
- package/src/components/Tooltip/types.ts +1 -1
- package/src/helpers/popper-helpers.ts +17 -17
- package/src/hooks/use-dropdown.ts +84 -84
- package/src/hooks/use-is-mounted.ts +15 -15
- package/src/theme/helpers.ts +76 -76
- package/src/vite-env.d.ts +1 -1
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
import { ReactNode } from 'react';
|
|
2
|
-
import clsx from 'clsx';
|
|
3
|
-
import { addDataTestId, isReactNodeNotEmpty } from '@true-engineering/true-react-platform-helpers';
|
|
4
|
-
import { addDataAttributes } from '../../helpers';
|
|
5
|
-
import { ICommonProps } from '../../types';
|
|
6
|
-
import { ISwitchState } from './types';
|
|
7
|
-
import { useStyles, ISwitchStyles } from './Switch.styles';
|
|
8
|
-
|
|
9
|
-
export interface ISwitchProps<V extends string> extends ICommonProps<ISwitchStyles> {
|
|
10
|
-
children?: ReactNode;
|
|
11
|
-
value: V;
|
|
12
|
-
/** @default false */
|
|
13
|
-
isChecked: boolean | undefined;
|
|
14
|
-
/** @default false */
|
|
15
|
-
isDisabled?: boolean;
|
|
16
|
-
/** @default false */
|
|
17
|
-
isInvalid?: boolean;
|
|
18
|
-
/** @default 'right' */
|
|
19
|
-
labelPosition?: 'left' | 'right';
|
|
20
|
-
/** @default 'primary' */
|
|
21
|
-
color?: 'primary' | 'secondary';
|
|
22
|
-
onChange: (state: ISwitchState<V>) => void;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export const Switch = <V extends string>({
|
|
26
|
-
isDisabled = false,
|
|
27
|
-
isChecked = false,
|
|
28
|
-
isInvalid = false,
|
|
29
|
-
value,
|
|
30
|
-
children,
|
|
31
|
-
labelPosition = 'right',
|
|
32
|
-
color = 'primary',
|
|
33
|
-
data,
|
|
34
|
-
tweakStyles,
|
|
35
|
-
testId,
|
|
36
|
-
onChange,
|
|
37
|
-
}: ISwitchProps<V>): JSX.Element => {
|
|
38
|
-
const classes = useStyles({ theme: tweakStyles });
|
|
39
|
-
|
|
40
|
-
const handleChange = () => onChange({ name: value, isEnabled: !isChecked });
|
|
41
|
-
|
|
42
|
-
return (
|
|
43
|
-
<label
|
|
44
|
-
className={clsx(classes.root, classes[color], {
|
|
45
|
-
[classes.disabled]: isDisabled,
|
|
46
|
-
[classes.checked]: isChecked,
|
|
47
|
-
[classes.invalid]: isInvalid,
|
|
48
|
-
})}
|
|
49
|
-
{...addDataTestId(testId)}
|
|
50
|
-
{...addDataAttributes(data)}
|
|
51
|
-
>
|
|
52
|
-
<span className={classes.switch}>
|
|
53
|
-
<input
|
|
54
|
-
type="checkbox"
|
|
55
|
-
name={value}
|
|
56
|
-
className={classes.input}
|
|
57
|
-
onChange={isDisabled ? undefined : handleChange}
|
|
58
|
-
checked={isChecked}
|
|
59
|
-
disabled={isDisabled}
|
|
60
|
-
{...addDataTestId(testId, 'input')}
|
|
61
|
-
/>
|
|
62
|
-
</span>
|
|
63
|
-
{isReactNodeNotEmpty(children) && (
|
|
64
|
-
<span
|
|
65
|
-
className={clsx(
|
|
66
|
-
classes.label,
|
|
67
|
-
classes[labelPosition === 'left' ? 'labelLeft' : 'labelRight'],
|
|
68
|
-
)}
|
|
69
|
-
>
|
|
70
|
-
{children}
|
|
71
|
-
</span>
|
|
72
|
-
)}
|
|
73
|
-
</label>
|
|
74
|
-
);
|
|
75
|
-
};
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import clsx from 'clsx';
|
|
3
|
+
import { addDataTestId, isReactNodeNotEmpty } from '@true-engineering/true-react-platform-helpers';
|
|
4
|
+
import { addDataAttributes } from '../../helpers';
|
|
5
|
+
import { ICommonProps } from '../../types';
|
|
6
|
+
import { ISwitchState } from './types';
|
|
7
|
+
import { useStyles, ISwitchStyles } from './Switch.styles';
|
|
8
|
+
|
|
9
|
+
export interface ISwitchProps<V extends string> extends ICommonProps<ISwitchStyles> {
|
|
10
|
+
children?: ReactNode;
|
|
11
|
+
value: V;
|
|
12
|
+
/** @default false */
|
|
13
|
+
isChecked: boolean | undefined;
|
|
14
|
+
/** @default false */
|
|
15
|
+
isDisabled?: boolean;
|
|
16
|
+
/** @default false */
|
|
17
|
+
isInvalid?: boolean;
|
|
18
|
+
/** @default 'right' */
|
|
19
|
+
labelPosition?: 'left' | 'right';
|
|
20
|
+
/** @default 'primary' */
|
|
21
|
+
color?: 'primary' | 'secondary';
|
|
22
|
+
onChange: (state: ISwitchState<V>) => void;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export const Switch = <V extends string>({
|
|
26
|
+
isDisabled = false,
|
|
27
|
+
isChecked = false,
|
|
28
|
+
isInvalid = false,
|
|
29
|
+
value,
|
|
30
|
+
children,
|
|
31
|
+
labelPosition = 'right',
|
|
32
|
+
color = 'primary',
|
|
33
|
+
data,
|
|
34
|
+
tweakStyles,
|
|
35
|
+
testId,
|
|
36
|
+
onChange,
|
|
37
|
+
}: ISwitchProps<V>): JSX.Element => {
|
|
38
|
+
const classes = useStyles({ theme: tweakStyles });
|
|
39
|
+
|
|
40
|
+
const handleChange = () => onChange({ name: value, isEnabled: !isChecked });
|
|
41
|
+
|
|
42
|
+
return (
|
|
43
|
+
<label
|
|
44
|
+
className={clsx(classes.root, classes[color], {
|
|
45
|
+
[classes.disabled]: isDisabled,
|
|
46
|
+
[classes.checked]: isChecked,
|
|
47
|
+
[classes.invalid]: isInvalid,
|
|
48
|
+
})}
|
|
49
|
+
{...addDataTestId(testId)}
|
|
50
|
+
{...addDataAttributes(data)}
|
|
51
|
+
>
|
|
52
|
+
<span className={classes.switch}>
|
|
53
|
+
<input
|
|
54
|
+
type="checkbox"
|
|
55
|
+
name={value}
|
|
56
|
+
className={classes.input}
|
|
57
|
+
onChange={isDisabled ? undefined : handleChange}
|
|
58
|
+
checked={isChecked}
|
|
59
|
+
disabled={isDisabled}
|
|
60
|
+
{...addDataTestId(testId, 'input')}
|
|
61
|
+
/>
|
|
62
|
+
</span>
|
|
63
|
+
{isReactNodeNotEmpty(children) && (
|
|
64
|
+
<span
|
|
65
|
+
className={clsx(
|
|
66
|
+
classes.label,
|
|
67
|
+
classes[labelPosition === 'left' ? 'labelLeft' : 'labelRight'],
|
|
68
|
+
)}
|
|
69
|
+
>
|
|
70
|
+
{children}
|
|
71
|
+
</span>
|
|
72
|
+
)}
|
|
73
|
+
</label>
|
|
74
|
+
);
|
|
75
|
+
};
|
|
@@ -1,53 +1,53 @@
|
|
|
1
|
-
import { FC, useState } from 'react';
|
|
2
|
-
import { ComponentStory } from '@storybook/react';
|
|
3
|
-
import { ITextWithInfoProps, TextWithInfo } from './TextWithInfo';
|
|
4
|
-
|
|
5
|
-
interface ITextWithInfoWithCustomProps extends ITextWithInfoProps {
|
|
6
|
-
infoTooltip: string;
|
|
7
|
-
link: string;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const TextWithInfoWithCustomProps: FC<ITextWithInfoWithCustomProps> = ({
|
|
11
|
-
infoTooltip,
|
|
12
|
-
link,
|
|
13
|
-
...args
|
|
14
|
-
}) => {
|
|
15
|
-
const [isSelected, setIsSelected] = useState(false);
|
|
16
|
-
|
|
17
|
-
return (
|
|
18
|
-
<div
|
|
19
|
-
style={{
|
|
20
|
-
display: 'flex',
|
|
21
|
-
alignItems: 'center',
|
|
22
|
-
justifyContent: 'center',
|
|
23
|
-
width: 600,
|
|
24
|
-
height: 400,
|
|
25
|
-
}}
|
|
26
|
-
>
|
|
27
|
-
<TextWithInfo
|
|
28
|
-
{...args}
|
|
29
|
-
info={{ infoTooltip, link }}
|
|
30
|
-
isSelected={isSelected}
|
|
31
|
-
onClick={() => setIsSelected(true)}
|
|
32
|
-
/>
|
|
33
|
-
</div>
|
|
34
|
-
);
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
export default {
|
|
38
|
-
title: 'Data Display/TextWithInfo',
|
|
39
|
-
component: TextWithInfoWithCustomProps,
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
const Template: ComponentStory<typeof TextWithInfoWithCustomProps> = (args) => (
|
|
43
|
-
<TextWithInfoWithCustomProps {...args} />
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
export const Default = Template.bind({});
|
|
47
|
-
|
|
48
|
-
Default.args = {
|
|
49
|
-
text: 'Обычная перевозка',
|
|
50
|
-
textTooltip: 'Tултип для самой обычной перевозки',
|
|
51
|
-
infoTooltip: 'Читать подробную информацию',
|
|
52
|
-
link: 'https://ya.ru/',
|
|
53
|
-
};
|
|
1
|
+
import { FC, useState } from 'react';
|
|
2
|
+
import { ComponentStory } from '@storybook/react';
|
|
3
|
+
import { ITextWithInfoProps, TextWithInfo } from './TextWithInfo';
|
|
4
|
+
|
|
5
|
+
interface ITextWithInfoWithCustomProps extends ITextWithInfoProps {
|
|
6
|
+
infoTooltip: string;
|
|
7
|
+
link: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
const TextWithInfoWithCustomProps: FC<ITextWithInfoWithCustomProps> = ({
|
|
11
|
+
infoTooltip,
|
|
12
|
+
link,
|
|
13
|
+
...args
|
|
14
|
+
}) => {
|
|
15
|
+
const [isSelected, setIsSelected] = useState(false);
|
|
16
|
+
|
|
17
|
+
return (
|
|
18
|
+
<div
|
|
19
|
+
style={{
|
|
20
|
+
display: 'flex',
|
|
21
|
+
alignItems: 'center',
|
|
22
|
+
justifyContent: 'center',
|
|
23
|
+
width: 600,
|
|
24
|
+
height: 400,
|
|
25
|
+
}}
|
|
26
|
+
>
|
|
27
|
+
<TextWithInfo
|
|
28
|
+
{...args}
|
|
29
|
+
info={{ infoTooltip, link }}
|
|
30
|
+
isSelected={isSelected}
|
|
31
|
+
onClick={() => setIsSelected(true)}
|
|
32
|
+
/>
|
|
33
|
+
</div>
|
|
34
|
+
);
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
export default {
|
|
38
|
+
title: 'Data Display/TextWithInfo',
|
|
39
|
+
component: TextWithInfoWithCustomProps,
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
const Template: ComponentStory<typeof TextWithInfoWithCustomProps> = (args) => (
|
|
43
|
+
<TextWithInfoWithCustomProps {...args} />
|
|
44
|
+
);
|
|
45
|
+
|
|
46
|
+
export const Default = Template.bind({});
|
|
47
|
+
|
|
48
|
+
Default.args = {
|
|
49
|
+
text: 'Обычная перевозка',
|
|
50
|
+
textTooltip: 'Tултип для самой обычной перевозки',
|
|
51
|
+
infoTooltip: 'Читать подробную информацию',
|
|
52
|
+
link: 'https://ya.ru/',
|
|
53
|
+
};
|
|
@@ -1,62 +1,62 @@
|
|
|
1
|
-
import { FC } from 'react';
|
|
2
|
-
import clsx from 'clsx';
|
|
3
|
-
import { addDataTestId } from '@true-engineering/true-react-platform-helpers';
|
|
4
|
-
import { addDataAttributes } from '../../helpers';
|
|
5
|
-
import { ICommonProps } from '../../types';
|
|
6
|
-
import { Icon } from '../Icon';
|
|
7
|
-
import { TextWithTooltip } from '../TextWithTooltip';
|
|
8
|
-
import { useStyles, ITextWithInfoStyles } from './TextWithInfo.styles';
|
|
9
|
-
|
|
10
|
-
export interface ITextWithInfoProps extends ICommonProps<ITextWithInfoStyles> {
|
|
11
|
-
text: string;
|
|
12
|
-
/** @default false */
|
|
13
|
-
isSelected?: boolean;
|
|
14
|
-
textTooltip?: string;
|
|
15
|
-
info?: {
|
|
16
|
-
infoTooltip?: string;
|
|
17
|
-
link?: string;
|
|
18
|
-
};
|
|
19
|
-
onClick: () => void;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export const TextWithInfo: FC<ITextWithInfoProps> = ({
|
|
23
|
-
text,
|
|
24
|
-
isSelected = false,
|
|
25
|
-
info,
|
|
26
|
-
textTooltip,
|
|
27
|
-
onClick,
|
|
28
|
-
testId,
|
|
29
|
-
data,
|
|
30
|
-
tweakStyles,
|
|
31
|
-
}) => {
|
|
32
|
-
const classes = useStyles({ theme: tweakStyles });
|
|
33
|
-
|
|
34
|
-
return (
|
|
35
|
-
<div
|
|
36
|
-
className={clsx(classes.root, isSelected && classes.selected)}
|
|
37
|
-
{...addDataTestId(testId)}
|
|
38
|
-
{...addDataAttributes(data)}
|
|
39
|
-
>
|
|
40
|
-
<div className={classes.container}>
|
|
41
|
-
<div className={classes.text} onClick={onClick}>
|
|
42
|
-
{textTooltip !== undefined ? (
|
|
43
|
-
<TextWithTooltip tooltipText={textTooltip}>{text}</TextWithTooltip>
|
|
44
|
-
) : (
|
|
45
|
-
text
|
|
46
|
-
)}
|
|
47
|
-
</div>
|
|
48
|
-
{info && (
|
|
49
|
-
<a className={classes.info} href={info.link} target="_blank" rel="noopener noreferrer">
|
|
50
|
-
{info.infoTooltip !== undefined ? (
|
|
51
|
-
<TextWithTooltip tooltipText={info.infoTooltip}>
|
|
52
|
-
<Icon type="information" />
|
|
53
|
-
</TextWithTooltip>
|
|
54
|
-
) : (
|
|
55
|
-
<Icon type="information" />
|
|
56
|
-
)}
|
|
57
|
-
</a>
|
|
58
|
-
)}
|
|
59
|
-
</div>
|
|
60
|
-
</div>
|
|
61
|
-
);
|
|
62
|
-
};
|
|
1
|
+
import { FC } from 'react';
|
|
2
|
+
import clsx from 'clsx';
|
|
3
|
+
import { addDataTestId } from '@true-engineering/true-react-platform-helpers';
|
|
4
|
+
import { addDataAttributes } from '../../helpers';
|
|
5
|
+
import { ICommonProps } from '../../types';
|
|
6
|
+
import { Icon } from '../Icon';
|
|
7
|
+
import { TextWithTooltip } from '../TextWithTooltip';
|
|
8
|
+
import { useStyles, ITextWithInfoStyles } from './TextWithInfo.styles';
|
|
9
|
+
|
|
10
|
+
export interface ITextWithInfoProps extends ICommonProps<ITextWithInfoStyles> {
|
|
11
|
+
text: string;
|
|
12
|
+
/** @default false */
|
|
13
|
+
isSelected?: boolean;
|
|
14
|
+
textTooltip?: string;
|
|
15
|
+
info?: {
|
|
16
|
+
infoTooltip?: string;
|
|
17
|
+
link?: string;
|
|
18
|
+
};
|
|
19
|
+
onClick: () => void;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const TextWithInfo: FC<ITextWithInfoProps> = ({
|
|
23
|
+
text,
|
|
24
|
+
isSelected = false,
|
|
25
|
+
info,
|
|
26
|
+
textTooltip,
|
|
27
|
+
onClick,
|
|
28
|
+
testId,
|
|
29
|
+
data,
|
|
30
|
+
tweakStyles,
|
|
31
|
+
}) => {
|
|
32
|
+
const classes = useStyles({ theme: tweakStyles });
|
|
33
|
+
|
|
34
|
+
return (
|
|
35
|
+
<div
|
|
36
|
+
className={clsx(classes.root, isSelected && classes.selected)}
|
|
37
|
+
{...addDataTestId(testId)}
|
|
38
|
+
{...addDataAttributes(data)}
|
|
39
|
+
>
|
|
40
|
+
<div className={classes.container}>
|
|
41
|
+
<div className={classes.text} onClick={onClick}>
|
|
42
|
+
{textTooltip !== undefined ? (
|
|
43
|
+
<TextWithTooltip tooltipText={textTooltip}>{text}</TextWithTooltip>
|
|
44
|
+
) : (
|
|
45
|
+
text
|
|
46
|
+
)}
|
|
47
|
+
</div>
|
|
48
|
+
{info && (
|
|
49
|
+
<a className={classes.info} href={info.link} target="_blank" rel="noopener noreferrer">
|
|
50
|
+
{info.infoTooltip !== undefined ? (
|
|
51
|
+
<TextWithTooltip tooltipText={info.infoTooltip}>
|
|
52
|
+
<Icon type="information" />
|
|
53
|
+
</TextWithTooltip>
|
|
54
|
+
) : (
|
|
55
|
+
<Icon type="information" />
|
|
56
|
+
)}
|
|
57
|
+
</a>
|
|
58
|
+
)}
|
|
59
|
+
</div>
|
|
60
|
+
</div>
|
|
61
|
+
);
|
|
62
|
+
};
|
|
@@ -1,58 +1,58 @@
|
|
|
1
|
-
import { ComponentStory } from '@storybook/react';
|
|
2
|
-
import { TextWithTooltip } from './TextWithTooltip';
|
|
3
|
-
|
|
4
|
-
const positions = [
|
|
5
|
-
'top',
|
|
6
|
-
'bottom',
|
|
7
|
-
'right',
|
|
8
|
-
'left',
|
|
9
|
-
'top-start',
|
|
10
|
-
'top-end',
|
|
11
|
-
'bottom-start',
|
|
12
|
-
'bottom-end',
|
|
13
|
-
'right-start',
|
|
14
|
-
'right-end',
|
|
15
|
-
'left-start',
|
|
16
|
-
'left-end',
|
|
17
|
-
'auto',
|
|
18
|
-
'auto-start',
|
|
19
|
-
'auto-end',
|
|
20
|
-
];
|
|
21
|
-
|
|
22
|
-
export default {
|
|
23
|
-
title: 'Data Display/TextWithTooltip',
|
|
24
|
-
component: TextWithTooltip,
|
|
25
|
-
argTypes: {
|
|
26
|
-
tooltipPosition: { control: 'select', options: positions },
|
|
27
|
-
tooltipView: { control: 'inline-radio', options: ['tooltip', 'hint'] },
|
|
28
|
-
tooltipType: { control: 'inline-radio', options: ['info', 'error'] },
|
|
29
|
-
mouseEventType: { control: 'inline-radio', options: ['hover', 'click'] },
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
const Template: ComponentStory<typeof TextWithTooltip> = (args) => (
|
|
34
|
-
<div
|
|
35
|
-
style={{
|
|
36
|
-
display: 'flex',
|
|
37
|
-
alignItems: 'center',
|
|
38
|
-
justifyContent: 'center',
|
|
39
|
-
width: 600,
|
|
40
|
-
height: 400,
|
|
41
|
-
}}
|
|
42
|
-
>
|
|
43
|
-
<TextWithTooltip {...args} />
|
|
44
|
-
</div>
|
|
45
|
-
);
|
|
46
|
-
|
|
47
|
-
export const Default = Template.bind({});
|
|
48
|
-
|
|
49
|
-
Default.args = {
|
|
50
|
-
children: 'Наведи на меня - появится тултип',
|
|
51
|
-
tooltipText: 'Текст тултипа',
|
|
52
|
-
tooltipPosition: 'top',
|
|
53
|
-
tooltipView: 'tooltip',
|
|
54
|
-
tooltipType: 'info',
|
|
55
|
-
isDisabled: false,
|
|
56
|
-
mouseEventType: 'hover',
|
|
57
|
-
shouldRenderInBody: true,
|
|
58
|
-
};
|
|
1
|
+
import { ComponentStory } from '@storybook/react';
|
|
2
|
+
import { TextWithTooltip } from './TextWithTooltip';
|
|
3
|
+
|
|
4
|
+
const positions = [
|
|
5
|
+
'top',
|
|
6
|
+
'bottom',
|
|
7
|
+
'right',
|
|
8
|
+
'left',
|
|
9
|
+
'top-start',
|
|
10
|
+
'top-end',
|
|
11
|
+
'bottom-start',
|
|
12
|
+
'bottom-end',
|
|
13
|
+
'right-start',
|
|
14
|
+
'right-end',
|
|
15
|
+
'left-start',
|
|
16
|
+
'left-end',
|
|
17
|
+
'auto',
|
|
18
|
+
'auto-start',
|
|
19
|
+
'auto-end',
|
|
20
|
+
];
|
|
21
|
+
|
|
22
|
+
export default {
|
|
23
|
+
title: 'Data Display/TextWithTooltip',
|
|
24
|
+
component: TextWithTooltip,
|
|
25
|
+
argTypes: {
|
|
26
|
+
tooltipPosition: { control: 'select', options: positions },
|
|
27
|
+
tooltipView: { control: 'inline-radio', options: ['tooltip', 'hint'] },
|
|
28
|
+
tooltipType: { control: 'inline-radio', options: ['info', 'error'] },
|
|
29
|
+
mouseEventType: { control: 'inline-radio', options: ['hover', 'click'] },
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const Template: ComponentStory<typeof TextWithTooltip> = (args) => (
|
|
34
|
+
<div
|
|
35
|
+
style={{
|
|
36
|
+
display: 'flex',
|
|
37
|
+
alignItems: 'center',
|
|
38
|
+
justifyContent: 'center',
|
|
39
|
+
width: 600,
|
|
40
|
+
height: 400,
|
|
41
|
+
}}
|
|
42
|
+
>
|
|
43
|
+
<TextWithTooltip {...args} />
|
|
44
|
+
</div>
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
export const Default = Template.bind({});
|
|
48
|
+
|
|
49
|
+
Default.args = {
|
|
50
|
+
children: 'Наведи на меня - появится тултип',
|
|
51
|
+
tooltipText: 'Текст тултипа',
|
|
52
|
+
tooltipPosition: 'top',
|
|
53
|
+
tooltipView: 'tooltip',
|
|
54
|
+
tooltipType: 'info',
|
|
55
|
+
isDisabled: false,
|
|
56
|
+
mouseEventType: 'hover',
|
|
57
|
+
shouldRenderInBody: true,
|
|
58
|
+
};
|
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
import { FC } from 'react';
|
|
2
|
-
import { ComponentStory } from '@storybook/react';
|
|
3
|
-
import { colors } from '../../theme';
|
|
4
|
-
import { IThemedPreloaderProps, ThemedPreloader } from './ThemedPreloader';
|
|
5
|
-
|
|
6
|
-
interface IThemedPreloaderWithCustomProps extends IThemedPreloaderProps {
|
|
7
|
-
currentColor: string;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const ThemedPreloaderWithCustomProps: FC<IThemedPreloaderWithCustomProps> = ({
|
|
11
|
-
currentColor,
|
|
12
|
-
...args
|
|
13
|
-
}) => (
|
|
14
|
-
<div style={{ color: currentColor }}>
|
|
15
|
-
<ThemedPreloader {...args} />
|
|
16
|
-
</div>
|
|
17
|
-
);
|
|
18
|
-
|
|
19
|
-
export default {
|
|
20
|
-
title: 'Feedback/ThemedPreloader',
|
|
21
|
-
component: ThemedPreloaderWithCustomProps,
|
|
22
|
-
argTypes: {
|
|
23
|
-
type: { options: ['default', 'logo', 'dots'], control: 'inline-radio' },
|
|
24
|
-
},
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
const Template: ComponentStory<typeof ThemedPreloaderWithCustomProps> = (args) => (
|
|
28
|
-
<ThemedPreloaderWithCustomProps {...args} />
|
|
29
|
-
);
|
|
30
|
-
|
|
31
|
-
export const Default = Template.bind({});
|
|
32
|
-
Default.args = {
|
|
33
|
-
type: 'dots',
|
|
34
|
-
useCurrentColor: false,
|
|
35
|
-
currentColor: colors.GREEN_FOCUS,
|
|
36
|
-
};
|
|
37
|
-
Default.parameters = {
|
|
38
|
-
controls: {
|
|
39
|
-
exclude: ['data'],
|
|
40
|
-
},
|
|
41
|
-
};
|
|
1
|
+
import { FC } from 'react';
|
|
2
|
+
import { ComponentStory } from '@storybook/react';
|
|
3
|
+
import { colors } from '../../theme';
|
|
4
|
+
import { IThemedPreloaderProps, ThemedPreloader } from './ThemedPreloader';
|
|
5
|
+
|
|
6
|
+
interface IThemedPreloaderWithCustomProps extends IThemedPreloaderProps {
|
|
7
|
+
currentColor: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
const ThemedPreloaderWithCustomProps: FC<IThemedPreloaderWithCustomProps> = ({
|
|
11
|
+
currentColor,
|
|
12
|
+
...args
|
|
13
|
+
}) => (
|
|
14
|
+
<div style={{ color: currentColor }}>
|
|
15
|
+
<ThemedPreloader {...args} />
|
|
16
|
+
</div>
|
|
17
|
+
);
|
|
18
|
+
|
|
19
|
+
export default {
|
|
20
|
+
title: 'Feedback/ThemedPreloader',
|
|
21
|
+
component: ThemedPreloaderWithCustomProps,
|
|
22
|
+
argTypes: {
|
|
23
|
+
type: { options: ['default', 'logo', 'dots'], control: 'inline-radio' },
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
const Template: ComponentStory<typeof ThemedPreloaderWithCustomProps> = (args) => (
|
|
28
|
+
<ThemedPreloaderWithCustomProps {...args} />
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
export const Default = Template.bind({});
|
|
32
|
+
Default.args = {
|
|
33
|
+
type: 'dots',
|
|
34
|
+
useCurrentColor: false,
|
|
35
|
+
currentColor: colors.GREEN_FOCUS,
|
|
36
|
+
};
|
|
37
|
+
Default.parameters = {
|
|
38
|
+
controls: {
|
|
39
|
+
exclude: ['data'],
|
|
40
|
+
},
|
|
41
|
+
};
|