@true-engineering/true-react-common-ui-kit 2.1.0 → 2.1.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.
Files changed (264) hide show
  1. package/LICENSE +201 -201
  2. package/dist/components/Button/Button.d.ts +1 -1
  3. package/dist/components/DatePicker/DatePicker.d.ts +1 -1
  4. package/dist/components/FiltersPane/FilterMultiSelect/FilterMultiSelect.d.ts +1 -1
  5. package/dist/components/FiltersPane/FilterSelect/FilterSelect.d.ts +1 -1
  6. package/dist/components/FiltersPane/FilterWithDates/FilterWithDates.d.ts +1 -1
  7. package/dist/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.d.ts +1 -1
  8. package/dist/components/FiltersPane/FilterWrapper/FilterWrapper.d.ts +1 -1
  9. package/dist/components/FiltersPane/FiltersPane.d.ts +2 -2
  10. package/dist/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.d.ts +1 -1
  11. package/dist/components/FiltersPane/types.d.ts +1 -1
  12. package/dist/components/Flag/augment.d.ts +1 -1
  13. package/dist/components/FlexibleTable/FlexibleTable.d.ts +1 -1
  14. package/dist/components/FlexibleTable/TableRow.d.ts +1 -1
  15. package/dist/components/Icon/Icon.d.ts +2 -2
  16. package/dist/components/Icon/complexIcons/augment.d.ts +1 -1
  17. package/dist/components/Input/Input.d.ts +1 -1
  18. package/dist/components/MultiSelect/MultiSelectInput/MultiSelectInput.d.ts +1 -1
  19. package/dist/components/MultiSelectList/MultiSelectList.d.ts +1 -1
  20. package/dist/components/PhoneInput/PhoneInput.d.ts +1 -1
  21. package/dist/components/Select/Select.d.ts +3 -3
  22. package/dist/components/TextWithTooltip/TextWithTooltip.d.ts +1 -1
  23. package/dist/helpers/snippets.d.ts +1 -1
  24. package/dist/helpers/utils.d.ts +1 -1
  25. package/dist/true-react-common-ui-kit.js +3875 -3875
  26. package/dist/true-react-common-ui-kit.js.map +1 -1
  27. package/dist/true-react-common-ui-kit.umd.cjs +3875 -3875
  28. package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
  29. package/dist/vite-env.d.ts +1 -1
  30. package/package.json +92 -91
  31. package/src/components/AccountInfo/AccountInfo.stories.tsx +32 -35
  32. package/src/components/AccountInfo/AccountInfo.styles.ts +55 -55
  33. package/src/components/AccountInfo/AccountInfo.tsx +77 -106
  34. package/src/components/AccountInfo/index.ts +2 -2
  35. package/src/components/AddButton/AddButton.stories.tsx +21 -21
  36. package/src/components/AddButton/AddButton.styles.ts +34 -34
  37. package/src/components/AddButton/AddButton.tsx +48 -49
  38. package/src/components/AddButton/index.ts +2 -2
  39. package/src/components/Button/Button.stories.tsx +52 -61
  40. package/src/components/Button/Button.styles.ts +196 -196
  41. package/src/components/Button/Button.tsx +187 -207
  42. package/src/components/Button/index.ts +2 -2
  43. package/src/components/Checkbox/Checkbox.stories.tsx +32 -35
  44. package/src/components/Checkbox/Checkbox.styles.ts +62 -62
  45. package/src/components/Checkbox/Checkbox.tsx +100 -107
  46. package/src/components/Checkbox/index.ts +2 -2
  47. package/src/components/CloseButton/CloseButton.styles.ts +34 -34
  48. package/src/components/CloseButton/CloseButton.tsx +35 -37
  49. package/src/components/CloseButton/index.ts +2 -2
  50. package/src/components/Colors/Colors.stories.tsx +7 -7
  51. package/src/components/Colors/Colors.styles.ts +38 -38
  52. package/src/components/Colors/Colors.tsx +26 -34
  53. package/src/components/Colors/index.ts +2 -2
  54. package/src/components/CssBaseline/CssBaseline.styles.ts +15 -15
  55. package/src/components/CssBaseline/CssBaseline.tsx +15 -17
  56. package/src/components/CssBaseline/index.ts +2 -2
  57. package/src/components/DateInput/DateInput.stories.tsx +61 -67
  58. package/src/components/DateInput/DateInput.styles.ts +14 -14
  59. package/src/components/DateInput/DateInput.tsx +82 -101
  60. package/src/components/DateInput/constants.ts +2 -2
  61. package/src/components/DateInput/index.ts +3 -3
  62. package/src/components/DatePicker/DatePicker.stories.tsx +87 -90
  63. package/src/components/DatePicker/DatePicker.styles.ts +44 -44
  64. package/src/components/DatePicker/DatePicker.tsx +322 -352
  65. package/src/components/DatePicker/DatePickerHeader/DatePickerHeader.styles.ts +84 -84
  66. package/src/components/DatePicker/DatePickerHeader/DatePickerHeader.tsx +79 -80
  67. package/src/components/DatePicker/DatePickerHeader/index.ts +2 -2
  68. package/src/components/DatePicker/constants.ts +1 -1
  69. package/src/components/DatePicker/helpers.ts +19 -24
  70. package/src/components/DatePicker/index.ts +3 -3
  71. package/src/components/DatePicker/types.ts +45 -45
  72. package/src/components/Description/Description.stories.tsx +27 -29
  73. package/src/components/Description/Description.styles.ts +31 -31
  74. package/src/components/Description/Description.tsx +60 -69
  75. package/src/components/Description/index.ts +2 -2
  76. package/src/components/FiltersPane/FilterInterval/FilterInterval.styles.ts +64 -64
  77. package/src/components/FiltersPane/FilterInterval/FilterInterval.tsx +143 -162
  78. package/src/components/FiltersPane/FilterInterval/index.ts +1 -1
  79. package/src/components/FiltersPane/FilterMultiSelect/FilterMultiSelect.tsx +10 -14
  80. package/src/components/FiltersPane/FilterMultiSelect/index.ts +1 -1
  81. package/src/components/FiltersPane/FilterSelect/FilterSelect.styles.ts +143 -144
  82. package/src/components/FiltersPane/FilterSelect/FilterSelect.tsx +347 -397
  83. package/src/components/FiltersPane/FilterSelect/index.ts +1 -1
  84. package/src/components/FiltersPane/FilterSelect/locales.ts +37 -37
  85. package/src/components/FiltersPane/FilterValueView/FilterValueView.styles.tsx +15 -15
  86. package/src/components/FiltersPane/FilterValueView/FilterValueView.tsx +166 -186
  87. package/src/components/FiltersPane/FilterValueView/index.tsx +1 -1
  88. package/src/components/FiltersPane/FilterWithDates/FilterWithDates.styles.ts +60 -60
  89. package/src/components/FiltersPane/FilterWithDates/FilterWithDates.tsx +183 -210
  90. package/src/components/FiltersPane/FilterWithDates/index.ts +1 -1
  91. package/src/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.styles.ts +17 -17
  92. package/src/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.tsx +198 -231
  93. package/src/components/FiltersPane/FilterWithPeriod/index.ts +1 -1
  94. package/src/components/FiltersPane/FilterWrapper/FilterWrapper.styles.ts +110 -110
  95. package/src/components/FiltersPane/FilterWrapper/FilterWrapper.tsx +346 -360
  96. package/src/components/FiltersPane/FilterWrapper/index.ts +1 -1
  97. package/src/components/FiltersPane/FiltersPane.stories.tsx +295 -308
  98. package/src/components/FiltersPane/FiltersPane.styles.ts +71 -71
  99. package/src/components/FiltersPane/FiltersPane.tsx +151 -193
  100. package/src/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.styles.ts +109 -109
  101. package/src/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.tsx +155 -175
  102. package/src/components/FiltersPane/FiltersPaneSearch/index.ts +1 -1
  103. package/src/components/FiltersPane/index.ts +20 -20
  104. package/src/components/FiltersPane/locales.ts +107 -107
  105. package/src/components/FiltersPane/types.ts +112 -126
  106. package/src/components/Flag/Flag.stories.tsx +29 -29
  107. package/src/components/Flag/Flag.styles.ts +18 -18
  108. package/src/components/Flag/Flag.tsx +27 -28
  109. package/src/components/Flag/augment.d.ts +1 -1
  110. package/src/components/Flag/index.ts +2 -2
  111. package/src/components/FlexibleTable/FlexibleTable.stories.tsx +84 -86
  112. package/src/components/FlexibleTable/FlexibleTable.styles.ts +131 -131
  113. package/src/components/FlexibleTable/FlexibleTable.tsx +205 -243
  114. package/src/components/FlexibleTable/TableRow.tsx +152 -171
  115. package/src/components/FlexibleTable/TableValue.tsx +75 -81
  116. package/src/components/FlexibleTable/fixture-test.ts +254 -254
  117. package/src/components/FlexibleTable/index.ts +3 -3
  118. package/src/components/FlexibleTable/types.ts +52 -58
  119. package/src/components/Icon/ComplexIconBoilerplate.tsx +17 -17
  120. package/src/components/Icon/Icon.stories.tsx +85 -88
  121. package/src/components/Icon/Icon.styles.ts +10 -10
  122. package/src/components/Icon/Icon.tsx +32 -34
  123. package/src/components/Icon/IconBoilerplate.tsx +42 -42
  124. package/src/components/Icon/complexIcons/augment.d.ts +1 -1
  125. package/src/components/Icon/complexIcons/avatarGreen.svg +57 -57
  126. package/src/components/Icon/complexIcons/icons.ts +7 -7
  127. package/src/components/Icon/complexIcons/index.ts +1 -1
  128. package/src/components/Icon/icons/icons.ts +838 -838
  129. package/src/components/Icon/icons/index.ts +1 -1
  130. package/src/components/Icon/index.ts +4 -4
  131. package/src/components/IncrementInput/ChangeButton.tsx +33 -34
  132. package/src/components/IncrementInput/IncrementInput.stories.tsx +31 -34
  133. package/src/components/IncrementInput/IncrementInput.styles.ts +77 -77
  134. package/src/components/IncrementInput/IncrementInput.tsx +79 -95
  135. package/src/components/IncrementInput/index.ts +2 -2
  136. package/src/components/Input/Input.stories.tsx +86 -92
  137. package/src/components/Input/Input.styles.ts +307 -307
  138. package/src/components/Input/Input.tsx +306 -321
  139. package/src/components/Input/index.ts +2 -2
  140. package/src/components/List/List.stories.tsx +62 -62
  141. package/src/components/List/List.styles.ts +52 -52
  142. package/src/components/List/List.tsx +61 -82
  143. package/src/components/List/index.ts +2 -2
  144. package/src/components/Modal/Modal.stories.tsx +105 -113
  145. package/src/components/Modal/Modal.styles.ts +305 -308
  146. package/src/components/Modal/Modal.tsx +181 -210
  147. package/src/components/Modal/index.ts +2 -2
  148. package/src/components/MoreMenu/MoreMenu.stories.tsx +46 -46
  149. package/src/components/MoreMenu/MoreMenu.styles.ts +70 -70
  150. package/src/components/MoreMenu/MoreMenu.tsx +89 -102
  151. package/src/components/MoreMenu/index.ts +2 -2
  152. package/src/components/MultiSelect/MultiSelect.stories.tsx +46 -46
  153. package/src/components/MultiSelect/MultiSelect.styles.ts +55 -55
  154. package/src/components/MultiSelect/MultiSelect.tsx +89 -98
  155. package/src/components/MultiSelect/MultiSelectInput/MultiSelectInput.styles.ts +73 -73
  156. package/src/components/MultiSelect/MultiSelectInput/MultiSelectInput.tsx +51 -62
  157. package/src/components/MultiSelect/MultiSelectInput/index.ts +1 -1
  158. package/src/components/MultiSelect/index.ts +3 -3
  159. package/src/components/MultiSelectList/MultiSelectList.styles.ts +124 -125
  160. package/src/components/MultiSelectList/MultiSelectList.tsx +451 -519
  161. package/src/components/MultiSelectList/index.ts +2 -2
  162. package/src/components/MultiSelectList/locales.ts +37 -37
  163. package/src/components/Notification/Notification.stories.tsx +46 -51
  164. package/src/components/Notification/Notification.styles.ts +50 -50
  165. package/src/components/Notification/Notification.tsx +75 -84
  166. package/src/components/Notification/index.ts +2 -2
  167. package/src/components/NumberInput/NumberInput.stories.tsx +35 -36
  168. package/src/components/NumberInput/NumberInput.tsx +133 -154
  169. package/src/components/NumberInput/helpers.ts +85 -87
  170. package/src/components/NumberInput/index.ts +1 -1
  171. package/src/components/PhoneInput/PhoneInput.stories.tsx +70 -71
  172. package/src/components/PhoneInput/PhoneInput.styles.ts +84 -84
  173. package/src/components/PhoneInput/PhoneInput.tsx +194 -223
  174. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.stories.tsx +21 -21
  175. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.styles.ts +100 -100
  176. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.tsx +147 -171
  177. package/src/components/PhoneInput/PhoneInputCountryList/index.ts +2 -2
  178. package/src/components/PhoneInput/index.ts +6 -6
  179. package/src/components/PhoneInput/phone-info.ts +2147 -2167
  180. package/src/components/PhoneInput/types.ts +16 -16
  181. package/src/components/RadioButton/RadioButton.stories.tsx +46 -46
  182. package/src/components/RadioButton/RadioButton.styles.ts +37 -37
  183. package/src/components/RadioButton/RadioButton.tsx +54 -57
  184. package/src/components/RadioButton/index.ts +2 -2
  185. package/src/components/ScrollIntoViewIfNeeded/ScrollIntoViewIfNeeded.ts +61 -66
  186. package/src/components/ScrollIntoViewIfNeeded/index.ts +1 -1
  187. package/src/components/SearchInput/SearchInput.stories.tsx +23 -24
  188. package/src/components/SearchInput/SearchInput.styles.ts +50 -50
  189. package/src/components/SearchInput/SearchInput.tsx +49 -63
  190. package/src/components/SearchInput/index.ts +2 -2
  191. package/src/components/Select/MultiSelect.stories.tsx +240 -263
  192. package/src/components/Select/Select.stories.tsx +235 -258
  193. package/src/components/Select/Select.styles.ts +96 -96
  194. package/src/components/Select/Select.tsx +575 -634
  195. package/src/components/Select/SelectList/SelectList.styles.ts +72 -72
  196. package/src/components/Select/SelectList/SelectList.tsx +152 -165
  197. package/src/components/Select/SelectList/index.ts +1 -1
  198. package/src/components/Select/SelectListItem/SelectListItem.styles.ts +14 -14
  199. package/src/components/Select/SelectListItem/SelectListItem.tsx +67 -73
  200. package/src/components/Select/constants.ts +2 -2
  201. package/src/components/Select/helpers.ts +26 -29
  202. package/src/components/Select/index.ts +4 -4
  203. package/src/components/Select/types.ts +1 -1
  204. package/src/components/SmartInput/SmartInput.stories.tsx +50 -63
  205. package/src/components/SmartInput/SmartInput.tsx +147 -180
  206. package/src/components/SmartInput/helpers.ts +85 -85
  207. package/src/components/SmartInput/index.ts +1 -1
  208. package/src/components/Switch/Switch.stories.tsx +40 -40
  209. package/src/components/Switch/Switch.styles.ts +75 -75
  210. package/src/components/Switch/Switch.tsx +82 -83
  211. package/src/components/Switch/index.ts +2 -2
  212. package/src/components/TextArea/TextArea.stories.tsx +35 -35
  213. package/src/components/TextArea/TextArea.styles.ts +153 -153
  214. package/src/components/TextArea/TextArea.tsx +165 -178
  215. package/src/components/TextArea/index.ts +2 -2
  216. package/src/components/TextWithInfo/TextWithInfo.stories.tsx +53 -53
  217. package/src/components/TextWithInfo/TextWithInfo.styles.ts +60 -60
  218. package/src/components/TextWithInfo/TextWithInfo.tsx +60 -67
  219. package/src/components/TextWithInfo/index.ts +2 -2
  220. package/src/components/TextWithTooltip/TextWithTooltip.stories.tsx +58 -58
  221. package/src/components/TextWithTooltip/TextWithTooltip.styles.ts +19 -19
  222. package/src/components/TextWithTooltip/TextWithTooltip.tsx +143 -163
  223. package/src/components/TextWithTooltip/index.ts +2 -2
  224. package/src/components/ThemedPreloader/ThemedPreloader.stories.tsx +41 -41
  225. package/src/components/ThemedPreloader/ThemedPreloader.styles.ts +21 -21
  226. package/src/components/ThemedPreloader/ThemedPreloader.tsx +50 -56
  227. package/src/components/ThemedPreloader/components/DefaultPreloader/DefaultPreloader.tsx +29 -34
  228. package/src/components/ThemedPreloader/components/DefaultPreloader/index.ts +1 -1
  229. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.styles.ts +54 -54
  230. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.tsx +18 -18
  231. package/src/components/ThemedPreloader/components/DotsPreloader/index.ts +2 -2
  232. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.styles.ts +11 -11
  233. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.tsx +25 -32
  234. package/src/components/ThemedPreloader/components/SvgPreloader/index.ts +2 -2
  235. package/src/components/ThemedPreloader/components/index.ts +2 -2
  236. package/src/components/ThemedPreloader/index.ts +2 -2
  237. package/src/components/Toaster/Toaster.stories.tsx +30 -34
  238. package/src/components/Toaster/Toaster.styles.ts +59 -59
  239. package/src/components/Toaster/Toaster.tsx +105 -113
  240. package/src/components/Toaster/index.ts +2 -2
  241. package/src/components/Tooltip/Tooltip.stories.tsx +19 -21
  242. package/src/components/Tooltip/Tooltip.styles.ts +45 -45
  243. package/src/components/Tooltip/Tooltip.tsx +35 -40
  244. package/src/components/Tooltip/index.ts +3 -3
  245. package/src/components/Tooltip/types.ts +1 -1
  246. package/src/components/index.ts +36 -36
  247. package/src/helpers/colors.ts +3 -2
  248. package/src/helpers/dateHelpers/date-helpers.ts +9 -9
  249. package/src/helpers/index.ts +4 -4
  250. package/src/helpers/phone.ts +87 -106
  251. package/src/helpers/popper-helpers.ts +17 -17
  252. package/src/helpers/snippets.tsx +5 -5
  253. package/src/helpers/utils.ts +231 -261
  254. package/src/hooks/index.ts +6 -6
  255. package/src/hooks/use-did-mount-effect.ts +18 -21
  256. package/src/hooks/use-dropdown.ts +82 -85
  257. package/src/hooks/use-is-mounted.ts +15 -15
  258. package/src/hooks/use-on-click-outside.ts +77 -92
  259. package/src/hooks/use-theme.ts +32 -36
  260. package/src/hooks/use-tweak-styles.ts +13 -14
  261. package/src/index.ts +6 -6
  262. package/src/theme.ts +149 -155
  263. package/src/types.ts +98 -105
  264. package/src/vite-env.d.ts +1 -1
@@ -1,63 +1,49 @@
1
- import { FC } from 'react';
2
-
3
- import { useTheme, useTweakStyles } from '../../hooks';
4
- import { getTestId, addDataAttributes, addDataTestId } from '../../helpers';
5
- import { Icon } from '../Icon';
6
- import { IInputProps, Input } from '../Input';
7
-
8
- import { SearchInputStyles, styles } from './SearchInput.styles';
9
-
10
- export type ISearchInputProps = Omit<
11
- IInputProps,
12
- | 'type'
13
- | 'isInvalid'
14
- | 'errorMessage'
15
- | 'label'
16
- | 'isActive'
17
- | 'errorPosition'
18
- | 'hasFloatingLabel'
19
- | 'border'
20
- > & {
21
- tweakStyles?: SearchInputStyles;
22
- };
23
-
24
- export const SearchInput: FC<ISearchInputProps> = ({
25
- isClearable = true,
26
- tweakStyles,
27
- testId,
28
- data,
29
- ...props
30
- }) => {
31
- const { classes, componentStyles } = useTheme(
32
- 'SearchInput',
33
- styles,
34
- tweakStyles,
35
- );
36
-
37
- const tweakInputStyles = useTweakStyles(
38
- componentStyles,
39
- tweakStyles,
40
- 'tweakInput',
41
- );
42
-
43
- return (
44
- <div
45
- className={classes.root}
46
- {...addDataTestId(testId)}
47
- {...addDataAttributes(data)}
48
- >
49
- <div className={classes.icon}>
50
- <Icon type="search" />
51
- </div>
52
- <Input
53
- isClearable={isClearable}
54
- isActive={props.value !== '' && props.value !== undefined}
55
- testId={getTestId(testId, 'input')}
56
- tweakStyles={tweakInputStyles}
57
- hasFloatingLabel={false}
58
- label={props.placeholder}
59
- {...props}
60
- />
61
- </div>
62
- );
63
- };
1
+ import { FC } from 'react';
2
+ import { getTestId, addDataAttributes, addDataTestId } from '../../helpers';
3
+ import { useTheme, useTweakStyles } from '../../hooks';
4
+ import { Icon } from '../Icon';
5
+ import { IInputProps, Input } from '../Input';
6
+ import { SearchInputStyles, styles } from './SearchInput.styles';
7
+
8
+ export type ISearchInputProps = Omit<
9
+ IInputProps,
10
+ | 'type'
11
+ | 'isInvalid'
12
+ | 'errorMessage'
13
+ | 'label'
14
+ | 'isActive'
15
+ | 'errorPosition'
16
+ | 'hasFloatingLabel'
17
+ | 'border'
18
+ > & {
19
+ tweakStyles?: SearchInputStyles;
20
+ };
21
+
22
+ export const SearchInput: FC<ISearchInputProps> = ({
23
+ isClearable = true,
24
+ tweakStyles,
25
+ testId,
26
+ data,
27
+ ...props
28
+ }) => {
29
+ const { classes, componentStyles } = useTheme('SearchInput', styles, tweakStyles);
30
+
31
+ const tweakInputStyles = useTweakStyles(componentStyles, tweakStyles, 'tweakInput');
32
+
33
+ return (
34
+ <div className={classes.root} {...addDataTestId(testId)} {...addDataAttributes(data)}>
35
+ <div className={classes.icon}>
36
+ <Icon type="search" />
37
+ </div>
38
+ <Input
39
+ isClearable={isClearable}
40
+ isActive={props.value !== '' && props.value !== undefined}
41
+ testId={getTestId(testId, 'input')}
42
+ tweakStyles={tweakInputStyles}
43
+ hasFloatingLabel={false}
44
+ label={props.placeholder}
45
+ {...props}
46
+ />
47
+ </div>
48
+ );
49
+ };
@@ -1,2 +1,2 @@
1
- export * from './SearchInput';
2
- export type { SearchInputStyles } from './SearchInput.styles';
1
+ export * from './SearchInput';
2
+ export type { SearchInputStyles } from './SearchInput.styles';
@@ -1,263 +1,240 @@
1
- import { ReactNode, useEffect, useState } from 'react';
2
- import { Select, ISelectProps } from './Select';
3
- import { ComponentMeta, ComponentStory } from '@storybook/react';
4
- import { isNotEmpty } from '../../helpers';
5
-
6
- interface ObjectValue {
7
- name: string;
8
- age: number;
9
- isDisabled?: boolean;
10
- }
11
-
12
- const inlineStyles = [undefined, 'left', 'right', 'middle'];
13
- const borders: Array<ISelectProps<any>['border']> = [
14
- undefined,
15
- 'left',
16
- 'top',
17
- 'right',
18
- 'bottom',
19
- ];
20
- const errorPositions: Array<ISelectProps<any>['errorPosition']> = [
21
- 'bottom',
22
- 'top',
23
- ];
24
-
25
- const genLetters = (qnt = 1): string =>
26
- Math.random()
27
- .toString(36)
28
- .replace(/[^a-z]+/g, '')
29
- .substr(0, qnt);
30
-
31
- const convertObjectToString = (v: ObjectValue): string => v.name;
32
-
33
- const convertObjectToId = (v: ObjectValue): string => `${v.name}${v.age}`;
34
-
35
- const convertObjectToReactNode = (
36
- v: ObjectValue,
37
- isDisabled: boolean,
38
- ): ReactNode => (
39
- <span style={{ color: isDisabled ? 'red' : undefined }}>
40
- <i>{v.name}</i>, {v.age}
41
- </span>
42
- );
43
-
44
- const convertStringToReactNode = (v: string): ReactNode => <i>{v}</i>;
45
-
46
- const isOptionDisabled = (option: string) => option.startsWith('Опция');
47
- const isObjectOptionDisabled = (option: ObjectValue) => option.age > 30;
48
-
49
- const stringOptions = [
50
- 'Опция 1',
51
- 'Опция 11',
52
- 'Еще одна опция',
53
- 'Еще выбор',
54
- 'Очень длинная опция вот такой текст',
55
- '1',
56
- '2',
57
- '3',
58
- '4',
59
- ];
60
-
61
- const objectOptions: ObjectValue[] = [
62
- { name: 'Ivan', age: 34 },
63
- { name: 'Ivan', age: 42 },
64
- { name: 'Konstantin', age: 11 },
65
- { name: 'Mikhail', age: 24 },
66
- { name: 'Maria', age: 45, isDisabled: true },
67
- { name: 'Elena', age: 14 },
68
- { name: 'Artem', age: 23 },
69
- ];
70
-
71
- // Максимум не включается, минимум включается
72
- const getRandomInt = (min: number, max: number) =>
73
- Math.floor(Math.random() * (Math.floor(max) - Math.ceil(min))) +
74
- Math.ceil(min);
75
-
76
- interface ISelectWithCustomProps<T> extends ISelectProps<T> {
77
- valuesType: 'strings' | 'objects';
78
- shouldUseReactNodes?: boolean;
79
- shouldUsePopper?: boolean;
80
- shouldRenderInBody?: boolean;
81
- shouldHideOnScroll?: boolean;
82
- shouldUseCustomIsDisabledFunction?: boolean;
83
- shouldRenderSearchInputInList?: boolean;
84
- canBeFlipped?: boolean;
85
- scrollParent?: 'document' | 'auto';
86
- }
87
-
88
- function SelectWithCustomProps<T>({
89
- valuesType,
90
- optionsMode,
91
- shouldUseReactNodes,
92
- shouldUsePopper,
93
- shouldRenderInBody,
94
- shouldHideOnScroll,
95
- shouldUseCustomIsDisabledFunction,
96
- shouldRenderSearchInputInList,
97
- canBeFlipped,
98
- scrollParent,
99
- noMatchesLabel,
100
- ...rest
101
- }: ISelectWithCustomProps<T>) {
102
- const [stringValue, setStringValue] = useState<string[]>();
103
-
104
- const stringHandler = (newValue?: string[]) => {
105
- console.log('change');
106
- setStringValue(newValue);
107
- };
108
-
109
- const [objectValue, setObjectValue] = useState<ObjectValue[]>();
110
-
111
- const objectHandler = (newValue?: ObjectValue[]) => {
112
- console.log('change');
113
- setObjectValue(newValue);
114
- };
115
-
116
- const selectValuesType = valuesType;
117
- const shouldRenderAsReactNodes = shouldUseReactNodes;
118
-
119
- const getOptions = async (): Promise<Array<string | ObjectValue>> =>
120
- new Promise((resolve) =>
121
- setTimeout(() => {
122
- resolve(
123
- [...Array(10)].map((_) => {
124
- if (selectValuesType === 'strings') {
125
- return genLetters(getRandomInt(3, 10));
126
- }
127
- return {
128
- name: genLetters(getRandomInt(3, 10)),
129
- age: getRandomInt(10, 70),
130
- } as ObjectValue;
131
- }),
132
- );
133
- }, 1000),
134
- );
135
-
136
- const [dynamicOptions, setDynamicOptions] = useState<
137
- Array<string | ObjectValue>
138
- >([]);
139
-
140
- const handleOpen = () => {
141
- console.log('isOpen');
142
- };
143
-
144
- const handleBlur = () => {
145
- console.log('blur');
146
- };
147
-
148
- useEffect(() => {
149
- const api = async () => {
150
- setDynamicOptions(await getOptions());
151
- };
152
-
153
- api();
154
- }, [selectValuesType]);
155
-
156
- const props =
157
- selectValuesType === 'strings'
158
- ? {
159
- onChange: stringHandler,
160
- value: stringValue,
161
- options: optionsMode === 'dynamic' ? dynamicOptions : stringOptions,
162
- convertValueToReactNode: shouldRenderAsReactNodes
163
- ? convertStringToReactNode
164
- : undefined,
165
- isOptionDisabled: shouldUseCustomIsDisabledFunction
166
- ? isOptionDisabled
167
- : undefined,
168
- }
169
- : {
170
- onChange: objectHandler,
171
- value: objectValue,
172
- options: optionsMode === 'dynamic' ? dynamicOptions : objectOptions,
173
- convertValueToString: convertObjectToString,
174
- convertValueToId: convertObjectToId,
175
- convertValueToReactNode: shouldRenderAsReactNodes
176
- ? convertObjectToReactNode
177
- : undefined,
178
- isOptionDisabled: shouldUseCustomIsDisabledFunction
179
- ? isObjectOptionDisabled
180
- : undefined,
181
- };
182
-
183
- return (
184
- <Select
185
- {...rest}
186
- {...(props as unknown as ISelectProps<any>)}
187
- {...(shouldRenderSearchInputInList && {
188
- searchInput: { shouldRenderInList: true },
189
- })}
190
- isMultiSelect
191
- noMatchesLabel={isNotEmpty(noMatchesLabel) ? noMatchesLabel : undefined}
192
- optionsMode={optionsMode}
193
- onType={async () => setDynamicOptions(await getOptions())}
194
- onOpen={handleOpen}
195
- onBlur={handleBlur}
196
- dropdownOptions={{
197
- shouldUsePopper,
198
- shouldRenderInBody,
199
- shouldHideOnScroll,
200
- canBeFlipped,
201
- scrollParent,
202
- }}
203
- />
204
- );
205
- }
206
-
207
- export default {
208
- title: 'Select',
209
- component: SelectWithCustomProps,
210
- argTypes: {
211
- debounceTime: {
212
- control: { type: 'range', min: 0, max: 1000, step: 100 },
213
- },
214
- errorPosition: { control: 'inline-radio', options: errorPositions },
215
- border: { control: 'inline-radio', options: borders },
216
- inlineStyle: { control: 'select', options: inlineStyles },
217
- optionsMode: {
218
- control: 'inline-radio',
219
- options: ['normal', 'search', 'dynamic'],
220
- },
221
- valuesType: {
222
- control: 'inline-radio',
223
- options: ['strings', 'objects'],
224
- },
225
- },
226
- } as ComponentMeta<typeof SelectWithCustomProps>;
227
-
228
- const Template: ComponentStory<typeof SelectWithCustomProps> = (args) => (
229
- <SelectWithCustomProps {...args} />
230
- );
231
-
232
- export const MultiSelect = Template.bind({});
233
-
234
- MultiSelect.args = {
235
- label: 'Dropdown',
236
- noMatchesLabel: 'No matches',
237
- border: undefined,
238
- isInvalid: false,
239
- errorMessage: 'Error Text',
240
- errorPosition: 'bottom',
241
- hasFloatingLabel: true,
242
- hasRequiredLabel: true,
243
- iconType: 'document',
244
- defaultOptionLabel: '',
245
- allOptionsLabel: 'Все опции',
246
- isDisabled: false,
247
- isRequired: false,
248
- isClearable: false,
249
- isLoading: false,
250
- debounceTime: 400,
251
- // custom options
252
- shouldUseReactNodes: false,
253
- valuesType: 'strings',
254
- optionsMode: 'normal',
255
- shouldUsePopper: false,
256
- shouldRenderInBody: false,
257
- shouldHideOnScroll: false,
258
- shouldUseCustomIsDisabledFunction: false,
259
- shouldRenderSearchInputInList: false,
260
- shouldScrollToList: true,
261
- canBeFlipped: false,
262
- scrollParent: 'document',
263
- };
1
+ import { ReactNode, useEffect, useState } from 'react';
2
+ import { ComponentMeta, ComponentStory } from '@storybook/react';
3
+ import { isNotEmpty } from '../../helpers';
4
+ import { Select, ISelectProps } from './Select';
5
+
6
+ interface ObjectValue {
7
+ name: string;
8
+ age: number;
9
+ isDisabled?: boolean;
10
+ }
11
+
12
+ const inlineStyles = [undefined, 'left', 'right', 'middle'];
13
+ const borders: Array<ISelectProps<any>['border']> = [undefined, 'left', 'top', 'right', 'bottom'];
14
+ const errorPositions: Array<ISelectProps<any>['errorPosition']> = ['bottom', 'top'];
15
+
16
+ const genLetters = (qnt = 1): string =>
17
+ Math.random()
18
+ .toString(36)
19
+ .replace(/[^a-z]+/g, '')
20
+ .substr(0, qnt);
21
+
22
+ const convertObjectToString = (v: ObjectValue): string => v.name;
23
+
24
+ const convertObjectToId = (v: ObjectValue): string => `${v.name}${v.age}`;
25
+
26
+ const convertObjectToReactNode = (v: ObjectValue, isDisabled: boolean): ReactNode => (
27
+ <span style={{ color: isDisabled ? 'red' : undefined }}>
28
+ <i>{v.name}</i>, {v.age}
29
+ </span>
30
+ );
31
+
32
+ const convertStringToReactNode = (v: string): ReactNode => <i>{v}</i>;
33
+
34
+ const isOptionDisabled = (option: string) => option.startsWith('Опция');
35
+ const isObjectOptionDisabled = (option: ObjectValue) => option.age > 30;
36
+
37
+ const stringOptions = [
38
+ 'Опция 1',
39
+ 'Опция 11',
40
+ 'Еще одна опция',
41
+ 'Еще выбор',
42
+ 'Очень длинная опция вот такой текст',
43
+ '1',
44
+ '2',
45
+ '3',
46
+ '4',
47
+ ];
48
+
49
+ const objectOptions: ObjectValue[] = [
50
+ { name: 'Ivan', age: 34 },
51
+ { name: 'Ivan', age: 42 },
52
+ { name: 'Konstantin', age: 11 },
53
+ { name: 'Mikhail', age: 24 },
54
+ { name: 'Maria', age: 45, isDisabled: true },
55
+ { name: 'Elena', age: 14 },
56
+ { name: 'Artem', age: 23 },
57
+ ];
58
+
59
+ // Максимум не включается, минимум включается
60
+ const getRandomInt = (min: number, max: number) =>
61
+ Math.floor(Math.random() * (Math.floor(max) - Math.ceil(min))) + Math.ceil(min);
62
+
63
+ interface ISelectWithCustomProps<T> extends ISelectProps<T> {
64
+ valuesType: 'strings' | 'objects';
65
+ shouldUseReactNodes?: boolean;
66
+ shouldUsePopper?: boolean;
67
+ shouldRenderInBody?: boolean;
68
+ shouldHideOnScroll?: boolean;
69
+ shouldUseCustomIsDisabledFunction?: boolean;
70
+ shouldRenderSearchInputInList?: boolean;
71
+ canBeFlipped?: boolean;
72
+ scrollParent?: 'document' | 'auto';
73
+ }
74
+
75
+ function SelectWithCustomProps<T>({
76
+ valuesType,
77
+ optionsMode,
78
+ shouldUseReactNodes,
79
+ shouldUsePopper,
80
+ shouldRenderInBody,
81
+ shouldHideOnScroll,
82
+ shouldUseCustomIsDisabledFunction,
83
+ shouldRenderSearchInputInList,
84
+ canBeFlipped,
85
+ scrollParent,
86
+ noMatchesLabel,
87
+ ...rest
88
+ }: ISelectWithCustomProps<T>) {
89
+ const [stringValue, setStringValue] = useState<string[]>();
90
+
91
+ const stringHandler = (newValue?: string[]) => {
92
+ console.log('change');
93
+ setStringValue(newValue);
94
+ };
95
+
96
+ const [objectValue, setObjectValue] = useState<ObjectValue[]>();
97
+
98
+ const objectHandler = (newValue?: ObjectValue[]) => {
99
+ console.log('change');
100
+ setObjectValue(newValue);
101
+ };
102
+
103
+ const selectValuesType = valuesType;
104
+ const shouldRenderAsReactNodes = shouldUseReactNodes;
105
+
106
+ const getOptions = async (): Promise<Array<string | ObjectValue>> =>
107
+ new Promise((resolve) =>
108
+ setTimeout(() => {
109
+ resolve(
110
+ [...Array(10)].map((_) => {
111
+ if (selectValuesType === 'strings') {
112
+ return genLetters(getRandomInt(3, 10));
113
+ }
114
+ return {
115
+ name: genLetters(getRandomInt(3, 10)),
116
+ age: getRandomInt(10, 70),
117
+ } as ObjectValue;
118
+ }),
119
+ );
120
+ }, 1000),
121
+ );
122
+
123
+ const [dynamicOptions, setDynamicOptions] = useState<Array<string | ObjectValue>>([]);
124
+
125
+ const handleOpen = () => {
126
+ console.log('isOpen');
127
+ };
128
+
129
+ const handleBlur = () => {
130
+ console.log('blur');
131
+ };
132
+
133
+ useEffect(() => {
134
+ const api = async () => {
135
+ setDynamicOptions(await getOptions());
136
+ };
137
+
138
+ api();
139
+ }, [selectValuesType]);
140
+
141
+ const props =
142
+ selectValuesType === 'strings'
143
+ ? {
144
+ onChange: stringHandler,
145
+ value: stringValue,
146
+ options: optionsMode === 'dynamic' ? dynamicOptions : stringOptions,
147
+ convertValueToReactNode: shouldRenderAsReactNodes ? convertStringToReactNode : undefined,
148
+ isOptionDisabled: shouldUseCustomIsDisabledFunction ? isOptionDisabled : undefined,
149
+ }
150
+ : {
151
+ onChange: objectHandler,
152
+ value: objectValue,
153
+ options: optionsMode === 'dynamic' ? dynamicOptions : objectOptions,
154
+ convertValueToString: convertObjectToString,
155
+ convertValueToId: convertObjectToId,
156
+ convertValueToReactNode: shouldRenderAsReactNodes ? convertObjectToReactNode : undefined,
157
+ isOptionDisabled: shouldUseCustomIsDisabledFunction ? isObjectOptionDisabled : undefined,
158
+ };
159
+
160
+ return (
161
+ <Select
162
+ {...rest}
163
+ {...(props as unknown as ISelectProps<any>)}
164
+ {...(shouldRenderSearchInputInList && {
165
+ searchInput: { shouldRenderInList: true },
166
+ })}
167
+ isMultiSelect
168
+ noMatchesLabel={isNotEmpty(noMatchesLabel) ? noMatchesLabel : undefined}
169
+ optionsMode={optionsMode}
170
+ onType={async () => setDynamicOptions(await getOptions())}
171
+ onOpen={handleOpen}
172
+ onBlur={handleBlur}
173
+ dropdownOptions={{
174
+ shouldUsePopper,
175
+ shouldRenderInBody,
176
+ shouldHideOnScroll,
177
+ canBeFlipped,
178
+ scrollParent,
179
+ }}
180
+ />
181
+ );
182
+ }
183
+
184
+ export default {
185
+ title: 'Select',
186
+ component: SelectWithCustomProps,
187
+ argTypes: {
188
+ debounceTime: {
189
+ control: { type: 'range', min: 0, max: 1000, step: 100 },
190
+ },
191
+ errorPosition: { control: 'inline-radio', options: errorPositions },
192
+ border: { control: 'inline-radio', options: borders },
193
+ inlineStyle: { control: 'select', options: inlineStyles },
194
+ optionsMode: {
195
+ control: 'inline-radio',
196
+ options: ['normal', 'search', 'dynamic'],
197
+ },
198
+ valuesType: {
199
+ control: 'inline-radio',
200
+ options: ['strings', 'objects'],
201
+ },
202
+ },
203
+ } as ComponentMeta<typeof SelectWithCustomProps>;
204
+
205
+ const Template: ComponentStory<typeof SelectWithCustomProps> = (args) => (
206
+ <SelectWithCustomProps {...args} />
207
+ );
208
+
209
+ export const MultiSelect = Template.bind({});
210
+
211
+ MultiSelect.args = {
212
+ label: 'Dropdown',
213
+ noMatchesLabel: 'No matches',
214
+ border: undefined,
215
+ isInvalid: false,
216
+ errorMessage: 'Error Text',
217
+ errorPosition: 'bottom',
218
+ hasFloatingLabel: true,
219
+ hasRequiredLabel: true,
220
+ iconType: 'document',
221
+ defaultOptionLabel: '',
222
+ allOptionsLabel: 'Все опции',
223
+ isDisabled: false,
224
+ isRequired: false,
225
+ isClearable: false,
226
+ isLoading: false,
227
+ debounceTime: 400,
228
+ // custom options
229
+ shouldUseReactNodes: false,
230
+ valuesType: 'strings',
231
+ optionsMode: 'normal',
232
+ shouldUsePopper: false,
233
+ shouldRenderInBody: false,
234
+ shouldHideOnScroll: false,
235
+ shouldUseCustomIsDisabledFunction: false,
236
+ shouldRenderSearchInputInList: false,
237
+ shouldScrollToList: true,
238
+ canBeFlipped: false,
239
+ scrollParent: 'document',
240
+ };