@true-engineering/true-react-common-ui-kit 3.18.0 → 3.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (89) hide show
  1. package/LICENSE +201 -201
  2. package/README.md +12 -0
  3. package/dist/components/TextArea/TextArea.d.ts +2 -0
  4. package/dist/true-react-common-ui-kit.js +62 -60
  5. package/dist/true-react-common-ui-kit.js.map +1 -1
  6. package/dist/true-react-common-ui-kit.umd.cjs +62 -60
  7. package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
  8. package/package.json +1 -1
  9. package/src/components/AccountInfo/AccountInfo.stories.tsx +32 -32
  10. package/src/components/AccountInfo/AccountInfo.tsx +80 -80
  11. package/src/components/AddButton/AddButton.stories.tsx +21 -21
  12. package/src/components/AddButton/AddButton.tsx +52 -52
  13. package/src/components/Button/Button.tsx +129 -129
  14. package/src/components/Colors/Colors.stories.tsx +7 -7
  15. package/src/components/DateInput/DateInput.tsx +90 -90
  16. package/src/components/DateInput/constants.ts +2 -2
  17. package/src/components/DatePicker/DatePicker.tsx +308 -308
  18. package/src/components/Description/Description.stories.tsx +27 -27
  19. package/src/components/Description/Description.tsx +61 -61
  20. package/src/components/FiltersPane/components/FilterValueView/FilterValueView.tsx +166 -166
  21. package/src/components/FiltersPane/components/FilterWithDates/FilterWithDates.tsx +210 -210
  22. package/src/components/FiltersPane/components/FilterWithPeriod/FilterWithPeriod.tsx +177 -177
  23. package/src/components/Flag/Flag.stories.tsx +29 -29
  24. package/src/components/Flag/Flag.tsx +26 -26
  25. package/src/components/Flag/augment.d.ts +1 -1
  26. package/src/components/FlexibleTable/components/FlexibleTableCell/FlexibleTableCell.styles.ts +38 -38
  27. package/src/components/FlexibleTable/components/FlexibleTableRow/FlexibleTableRow.styles.ts +25 -25
  28. package/src/components/FlexibleTable/components/FlexibleTableRow/FlexibleTableRow.tsx +196 -196
  29. package/src/components/FlexibleTable/helpers.ts +13 -13
  30. package/src/components/Icon/Icon.stories.tsx +86 -86
  31. package/src/components/Icon/complexIcons/augment.d.ts +1 -1
  32. package/src/components/Icon/complexIcons/avatarGreen.svg +57 -57
  33. package/src/components/Icon/complexIcons/index.ts +1 -1
  34. package/src/components/IncrementInput/IncrementInput.tsx +105 -105
  35. package/src/components/Input/Input.tsx +297 -297
  36. package/src/components/Input/types.ts +32 -32
  37. package/src/components/List/List.stories.tsx +70 -70
  38. package/src/components/List/List.tsx +33 -33
  39. package/src/components/List/components/ListItem/ListItem.tsx +57 -57
  40. package/src/components/Modal/Modal.stories.tsx +105 -105
  41. package/src/components/MultiSelect/MultiSelect.stories.tsx +46 -46
  42. package/src/components/MultiSelect/MultiSelect.tsx +106 -106
  43. package/src/components/MultiSelect/components/MultiSelectInput/MultiSelectInput.tsx +53 -53
  44. package/src/components/Notification/Notification.stories.tsx +46 -46
  45. package/src/components/Notification/Notification.tsx +69 -69
  46. package/src/components/NumberInput/NumberInput.tsx +137 -137
  47. package/src/components/NumberInput/index.ts +1 -1
  48. package/src/components/PhoneInput/PhoneInput.tsx +214 -214
  49. package/src/components/PhoneInput/components/PhoneInputCountryList/PhoneInputCountryList.tsx +155 -155
  50. package/src/components/PhoneInput/types.ts +16 -16
  51. package/src/components/RadioButton/RadioButton.stories.tsx +46 -46
  52. package/src/components/RadioButton/RadioButton.tsx +57 -57
  53. package/src/components/ScrollIntoViewIfNeeded/index.ts +1 -1
  54. package/src/components/Select/MultiSelect.stories.tsx +240 -240
  55. package/src/components/Select/Select.stories.tsx +235 -235
  56. package/src/components/Select/Select.tsx +1 -1
  57. package/src/components/Select/constants.ts +2 -2
  58. package/src/components/Select/types.ts +1 -1
  59. package/src/components/Selector/Selector.stories.tsx +62 -62
  60. package/src/components/Selector/Selector.tsx +115 -115
  61. package/src/components/Selector/index.ts +2 -2
  62. package/src/components/Selector/types.ts +12 -12
  63. package/src/components/Skeleton/Skeleton.stories.tsx +19 -19
  64. package/src/components/SmartInput/SmartInput.tsx +134 -134
  65. package/src/components/Status/Status.stories.tsx +73 -73
  66. package/src/components/Status/Status.styles.ts +143 -143
  67. package/src/components/Status/Status.tsx +49 -49
  68. package/src/components/Status/constants.ts +11 -11
  69. package/src/components/Status/index.ts +3 -3
  70. package/src/components/Status/types.ts +5 -5
  71. package/src/components/Switch/Switch.stories.tsx +40 -40
  72. package/src/components/Switch/Switch.tsx +75 -75
  73. package/src/components/TextArea/TextArea.stories.tsx +1 -0
  74. package/src/components/TextArea/TextArea.tsx +5 -1
  75. package/src/components/TextWithInfo/TextWithInfo.stories.tsx +53 -53
  76. package/src/components/TextWithInfo/TextWithInfo.tsx +62 -62
  77. package/src/components/TextWithTooltip/TextWithTooltip.stories.tsx +58 -58
  78. package/src/components/ThemedPreloader/ThemedPreloader.stories.tsx +41 -41
  79. package/src/components/ThemedPreloader/ThemedPreloader.tsx +54 -54
  80. package/src/components/ThemedPreloader/components/DefaultPreloader/index.ts +1 -1
  81. package/src/components/Toaster/Toaster.stories.tsx +30 -30
  82. package/src/components/Tooltip/Tooltip.stories.tsx +19 -19
  83. package/src/components/Tooltip/Tooltip.tsx +35 -35
  84. package/src/components/Tooltip/types.ts +1 -1
  85. package/src/helpers/popper-helpers.ts +17 -17
  86. package/src/hooks/use-dropdown.ts +84 -84
  87. package/src/hooks/use-is-mounted.ts +15 -15
  88. package/src/theme/helpers.ts +76 -76
  89. 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
+ };
@@ -33,4 +33,5 @@ Default.args = {
33
33
  isDisabled: false,
34
34
  isRequired: false,
35
35
  isAutoSizeable: true,
36
+ shouldAlwaysShowPlaceholder: false,
36
37
  };
@@ -40,6 +40,8 @@ export interface ITextAreaProps extends ICommonProps<ITextAreaStyles>, ITextArea
40
40
  hasCounter?: boolean;
41
41
  /** @default false */
42
42
  shouldTrimAfterMaxLength?: boolean;
43
+ /** @default false */
44
+ shouldAlwaysShowPlaceholder?: boolean;
43
45
  onChange: (value: string, event?: FormEvent<HTMLTextAreaElement>) => void;
44
46
  }
45
47
 
@@ -64,6 +66,7 @@ export const TextArea = forwardRef<HTMLTextAreaElement, ITextAreaProps>(
64
66
  hasCounter = true,
65
67
  shouldTrimAfterMaxLength = false,
66
68
  isAutoSizeable = true,
69
+ shouldAlwaysShowPlaceholder = false,
67
70
  maxLength,
68
71
  rows,
69
72
  testId,
@@ -108,7 +111,8 @@ export const TextArea = forwardRef<HTMLTextAreaElement, ITextAreaProps>(
108
111
  // в hasValue нельзя использовать isStringNotEmpty из-за того что isStringNotEmpty делает trim
109
112
  const hasValue = value !== undefined && value !== '';
110
113
  const hasLabel = isReactNodeNotEmpty(label);
111
- const hasPlaceholder = (!hasLabel || hasFocus) && isStringNotEmpty(placeholder);
114
+ const hasPlaceholder =
115
+ (!hasLabel || hasFocus || shouldAlwaysShowPlaceholder) && isStringNotEmpty(placeholder);
112
116
 
113
117
  const props = {
114
118
  className: classes.textarea,
@@ -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
+ };