@true-engineering/true-react-common-ui-kit 3.24.1 → 3.25.1
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 +21 -0
- package/dist/components/Select/CustomSelect.stories.d.ts +1 -1
- package/dist/components/Select/MultiSelect.stories.d.ts +2 -2
- package/dist/components/Select/Select.d.ts +14 -9
- package/dist/components/Select/Select.styles.d.ts +5 -5
- package/dist/components/Select/components/SelectList/SelectList.d.ts +7 -6
- package/dist/components/Select/components/SelectList/SelectList.styles.d.ts +1 -1
- package/dist/components/Select/components/SelectListItem/SelectListItem.d.ts +4 -3
- package/dist/components/Select/helpers.d.ts +0 -3
- package/dist/true-react-common-ui-kit.js +176 -142
- package/dist/true-react-common-ui-kit.js.map +1 -1
- package/dist/true-react-common-ui-kit.umd.cjs +175 -141
- package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
- package/package.json +1 -1
- 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/Button/Button.tsx +129 -129
- 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/helpers.ts +13 -13
- 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/IncrementInput/IncrementInput.tsx +105 -105
- package/src/components/Input/Input.tsx +297 -297
- package/src/components/Input/types.ts +32 -32
- package/src/components/List/List.stories.tsx +70 -70
- package/src/components/List/List.tsx +33 -33
- package/src/components/List/components/ListItem/ListItem.tsx +57 -57
- 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 +46 -46
- package/src/components/Notification/Notification.tsx +69 -69
- package/src/components/NumberInput/NumberInput.tsx +137 -137
- package/src/components/NumberInput/helpers.ts +4 -6
- 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/CustomSelect.stories.tsx +52 -16
- package/src/components/Select/MultiSelect.stories.tsx +3 -3
- package/src/components/Select/Select.stories.tsx +235 -235
- package/src/components/Select/Select.styles.ts +8 -7
- package/src/components/Select/Select.tsx +106 -62
- package/src/components/Select/components/SelectList/SelectList.styles.ts +6 -4
- package/src/components/Select/components/SelectList/SelectList.tsx +25 -29
- package/src/components/Select/components/SelectListItem/SelectListItem.tsx +23 -19
- package/src/components/Select/constants.ts +2 -2
- package/src/components/Select/helpers.ts +0 -7
- 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/TextWithTooltip/TextWithTooltip.tsx +2 -3
- 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,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,5 +1,4 @@
|
|
|
1
|
-
import { FC, ReactNode, useEffect, useRef, useState } from 'react';
|
|
2
|
-
import { Styles } from 'react-jss';
|
|
1
|
+
import { CSSProperties, FC, ReactNode, useEffect, useRef, useState } from 'react';
|
|
3
2
|
import { Portal } from 'react-overlays';
|
|
4
3
|
import usePopper, { Modifier, Placement } from 'react-overlays/usePopper';
|
|
5
4
|
import clsx from 'clsx';
|
|
@@ -137,7 +136,7 @@ export const TextWithTooltip: FC<ITextWithTooltipProps> = ({
|
|
|
137
136
|
<Portal container={shouldRenderInBody ? document.body : root.current}>
|
|
138
137
|
<div
|
|
139
138
|
className={classes.tooltip}
|
|
140
|
-
style={popperStyles.popper as
|
|
139
|
+
style={popperStyles.popper as CSSProperties}
|
|
141
140
|
{...attributes.popper}
|
|
142
141
|
ref={tooltip}
|
|
143
142
|
>
|
|
@@ -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
|
+
};
|
|
@@ -1,54 +1,54 @@
|
|
|
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 { useTweakStyles } from '../../hooks';
|
|
6
|
-
import { ICommonProps } from '../../types';
|
|
7
|
-
import { SvgPreloader, DotsPreloader } from './components';
|
|
8
|
-
import { IPreloaderSvgType } from './types';
|
|
9
|
-
import { useStyles, IThemedPreloaderStyles } from './ThemedPreloader.styles';
|
|
10
|
-
|
|
11
|
-
export interface IThemedPreloaderProps extends ICommonProps<IThemedPreloaderStyles> {
|
|
12
|
-
/** @default 'default' */
|
|
13
|
-
type?: 'dots' | IPreloaderSvgType;
|
|
14
|
-
/** @default false */
|
|
15
|
-
useCurrentColor?: boolean;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export const ThemedPreloader: FC<IThemedPreloaderProps> = ({
|
|
19
|
-
type = 'default',
|
|
20
|
-
useCurrentColor = false,
|
|
21
|
-
data,
|
|
22
|
-
testId,
|
|
23
|
-
tweakStyles,
|
|
24
|
-
}) => {
|
|
25
|
-
const classes = useStyles({ theme: tweakStyles });
|
|
26
|
-
|
|
27
|
-
const tweakDotsPreloaderStyles = useTweakStyles({
|
|
28
|
-
tweakStyles,
|
|
29
|
-
className: 'tweakDotsPreloader',
|
|
30
|
-
currentComponentName: 'ThemedPreloader',
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
const tweakSvgPreloaderStyles = useTweakStyles({
|
|
34
|
-
tweakStyles,
|
|
35
|
-
className: 'tweakSvgPreloader',
|
|
36
|
-
currentComponentName: 'ThemedPreloader',
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
return (
|
|
40
|
-
<div
|
|
41
|
-
className={clsx(classes.root, classes[type], {
|
|
42
|
-
[classes.currentColor]: useCurrentColor,
|
|
43
|
-
})}
|
|
44
|
-
{...addDataTestId(testId)}
|
|
45
|
-
{...addDataAttributes(data)}
|
|
46
|
-
>
|
|
47
|
-
{type === 'dots' ? (
|
|
48
|
-
<DotsPreloader tweakStyles={tweakDotsPreloaderStyles} />
|
|
49
|
-
) : (
|
|
50
|
-
<SvgPreloader type={type} tweakStyles={tweakSvgPreloaderStyles} />
|
|
51
|
-
)}
|
|
52
|
-
</div>
|
|
53
|
-
);
|
|
54
|
-
};
|
|
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 { useTweakStyles } from '../../hooks';
|
|
6
|
+
import { ICommonProps } from '../../types';
|
|
7
|
+
import { SvgPreloader, DotsPreloader } from './components';
|
|
8
|
+
import { IPreloaderSvgType } from './types';
|
|
9
|
+
import { useStyles, IThemedPreloaderStyles } from './ThemedPreloader.styles';
|
|
10
|
+
|
|
11
|
+
export interface IThemedPreloaderProps extends ICommonProps<IThemedPreloaderStyles> {
|
|
12
|
+
/** @default 'default' */
|
|
13
|
+
type?: 'dots' | IPreloaderSvgType;
|
|
14
|
+
/** @default false */
|
|
15
|
+
useCurrentColor?: boolean;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export const ThemedPreloader: FC<IThemedPreloaderProps> = ({
|
|
19
|
+
type = 'default',
|
|
20
|
+
useCurrentColor = false,
|
|
21
|
+
data,
|
|
22
|
+
testId,
|
|
23
|
+
tweakStyles,
|
|
24
|
+
}) => {
|
|
25
|
+
const classes = useStyles({ theme: tweakStyles });
|
|
26
|
+
|
|
27
|
+
const tweakDotsPreloaderStyles = useTweakStyles({
|
|
28
|
+
tweakStyles,
|
|
29
|
+
className: 'tweakDotsPreloader',
|
|
30
|
+
currentComponentName: 'ThemedPreloader',
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
const tweakSvgPreloaderStyles = useTweakStyles({
|
|
34
|
+
tweakStyles,
|
|
35
|
+
className: 'tweakSvgPreloader',
|
|
36
|
+
currentComponentName: 'ThemedPreloader',
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
return (
|
|
40
|
+
<div
|
|
41
|
+
className={clsx(classes.root, classes[type], {
|
|
42
|
+
[classes.currentColor]: useCurrentColor,
|
|
43
|
+
})}
|
|
44
|
+
{...addDataTestId(testId)}
|
|
45
|
+
{...addDataAttributes(data)}
|
|
46
|
+
>
|
|
47
|
+
{type === 'dots' ? (
|
|
48
|
+
<DotsPreloader tweakStyles={tweakDotsPreloaderStyles} />
|
|
49
|
+
) : (
|
|
50
|
+
<SvgPreloader type={type} tweakStyles={tweakSvgPreloaderStyles} />
|
|
51
|
+
)}
|
|
52
|
+
</div>
|
|
53
|
+
);
|
|
54
|
+
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './DefaultPreloader';
|
|
1
|
+
export * from './DefaultPreloader';
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
|
2
|
-
import { Button } from '../Button';
|
|
3
|
-
import { Toaster } from './Toaster';
|
|
4
|
-
|
|
5
|
-
const types = ['error', 'info', 'warning', 'ok', 'not-ok'];
|
|
6
|
-
|
|
7
|
-
export default {
|
|
8
|
-
title: 'Feedback/Toaster',
|
|
9
|
-
component: Toaster,
|
|
10
|
-
args: {
|
|
11
|
-
title: 'Произошла очень страшная ошибка',
|
|
12
|
-
text: 'Мы даже не знаем, чем вам помочь!',
|
|
13
|
-
type: types[0],
|
|
14
|
-
timeout: 7000,
|
|
15
|
-
hasCloseButton: false,
|
|
16
|
-
shouldCloseOnClick: false,
|
|
17
|
-
},
|
|
18
|
-
argTypes: {
|
|
19
|
-
type: { control: 'inline-radio', options: types },
|
|
20
|
-
},
|
|
21
|
-
parameters: {
|
|
22
|
-
controls: { exclude: ['onTimeEnd', 'onClose', 'data', 'tweakStyles'] },
|
|
23
|
-
},
|
|
24
|
-
} as ComponentMeta<typeof Toaster>;
|
|
25
|
-
|
|
26
|
-
export const Default: ComponentStory<typeof Toaster> = (args) => (
|
|
27
|
-
<Toaster {...args} onTimeEnd={() => console.log(1)} onClose={() => alert('closed')}>
|
|
28
|
-
<Button size="m">Нажмите</Button>
|
|
29
|
-
</Toaster>
|
|
30
|
-
);
|
|
1
|
+
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
|
2
|
+
import { Button } from '../Button';
|
|
3
|
+
import { Toaster } from './Toaster';
|
|
4
|
+
|
|
5
|
+
const types = ['error', 'info', 'warning', 'ok', 'not-ok'];
|
|
6
|
+
|
|
7
|
+
export default {
|
|
8
|
+
title: 'Feedback/Toaster',
|
|
9
|
+
component: Toaster,
|
|
10
|
+
args: {
|
|
11
|
+
title: 'Произошла очень страшная ошибка',
|
|
12
|
+
text: 'Мы даже не знаем, чем вам помочь!',
|
|
13
|
+
type: types[0],
|
|
14
|
+
timeout: 7000,
|
|
15
|
+
hasCloseButton: false,
|
|
16
|
+
shouldCloseOnClick: false,
|
|
17
|
+
},
|
|
18
|
+
argTypes: {
|
|
19
|
+
type: { control: 'inline-radio', options: types },
|
|
20
|
+
},
|
|
21
|
+
parameters: {
|
|
22
|
+
controls: { exclude: ['onTimeEnd', 'onClose', 'data', 'tweakStyles'] },
|
|
23
|
+
},
|
|
24
|
+
} as ComponentMeta<typeof Toaster>;
|
|
25
|
+
|
|
26
|
+
export const Default: ComponentStory<typeof Toaster> = (args) => (
|
|
27
|
+
<Toaster {...args} onTimeEnd={() => console.log(1)} onClose={() => alert('closed')}>
|
|
28
|
+
<Button size="m">Нажмите</Button>
|
|
29
|
+
</Toaster>
|
|
30
|
+
);
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
|
2
|
-
import { Tooltip } from './Tooltip';
|
|
3
|
-
|
|
4
|
-
export default {
|
|
5
|
-
title: 'Data Display/Tooltip',
|
|
6
|
-
component: Tooltip,
|
|
7
|
-
args: {
|
|
8
|
-
text: 'Tooltip Text',
|
|
9
|
-
view: 'tooltip',
|
|
10
|
-
type: 'info',
|
|
11
|
-
},
|
|
12
|
-
argTypes: {
|
|
13
|
-
text: { control: 'text' },
|
|
14
|
-
view: { control: 'inline-radio', options: ['tooltip', 'hint'] },
|
|
15
|
-
type: { control: 'inline-radio', options: ['info', 'error'] },
|
|
16
|
-
},
|
|
17
|
-
} as ComponentMeta<typeof Tooltip>;
|
|
18
|
-
|
|
19
|
-
export const Default: ComponentStory<typeof Tooltip> = (args) => <Tooltip {...args} />;
|
|
1
|
+
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
|
2
|
+
import { Tooltip } from './Tooltip';
|
|
3
|
+
|
|
4
|
+
export default {
|
|
5
|
+
title: 'Data Display/Tooltip',
|
|
6
|
+
component: Tooltip,
|
|
7
|
+
args: {
|
|
8
|
+
text: 'Tooltip Text',
|
|
9
|
+
view: 'tooltip',
|
|
10
|
+
type: 'info',
|
|
11
|
+
},
|
|
12
|
+
argTypes: {
|
|
13
|
+
text: { control: 'text' },
|
|
14
|
+
view: { control: 'inline-radio', options: ['tooltip', 'hint'] },
|
|
15
|
+
type: { control: 'inline-radio', options: ['info', 'error'] },
|
|
16
|
+
},
|
|
17
|
+
} as ComponentMeta<typeof Tooltip>;
|
|
18
|
+
|
|
19
|
+
export const Default: ComponentStory<typeof Tooltip> = (args) => <Tooltip {...args} />;
|