@true-engineering/true-react-common-ui-kit 2.3.1 → 2.3.2

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 (251) hide show
  1. package/LICENSE +201 -201
  2. package/README.md +12 -0
  3. package/dist/components/DatePicker/DatePicker.d.ts +1 -1
  4. package/dist/components/FiltersPane/FilterSelect/FilterSelect.d.ts +1 -1
  5. package/dist/components/FiltersPane/FiltersPane.d.ts +1 -1
  6. package/dist/components/Flag/augment.d.ts +1 -1
  7. package/dist/components/FlexibleTable/FlexibleTable.d.ts +1 -1
  8. package/dist/components/Icon/Icon.d.ts +1 -1
  9. package/dist/components/Icon/complexIcons/augment.d.ts +1 -1
  10. package/dist/components/MultiSelectList/MultiSelectList.d.ts +1 -1
  11. package/dist/components/PhoneInput/PhoneInput.d.ts +1 -1
  12. package/dist/components/Select/Select.d.ts +1 -1
  13. package/dist/true-react-common-ui-kit.js +577 -577
  14. package/dist/true-react-common-ui-kit.js.map +1 -1
  15. package/dist/true-react-common-ui-kit.umd.cjs +577 -577
  16. package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
  17. package/dist/vite-env.d.ts +1 -1
  18. package/package.json +93 -93
  19. package/src/components/AccountInfo/AccountInfo.stories.tsx +32 -32
  20. package/src/components/AccountInfo/AccountInfo.styles.ts +55 -55
  21. package/src/components/AccountInfo/AccountInfo.tsx +77 -77
  22. package/src/components/AccountInfo/index.ts +2 -2
  23. package/src/components/AddButton/AddButton.stories.tsx +21 -21
  24. package/src/components/AddButton/AddButton.styles.ts +34 -34
  25. package/src/components/AddButton/AddButton.tsx +48 -48
  26. package/src/components/AddButton/index.ts +2 -2
  27. package/src/components/Button/Button.stories.tsx +52 -52
  28. package/src/components/Button/Button.styles.ts +196 -196
  29. package/src/components/Button/Button.tsx +167 -167
  30. package/src/components/Button/index.ts +2 -2
  31. package/src/components/Checkbox/Checkbox.stories.tsx +32 -32
  32. package/src/components/Checkbox/Checkbox.styles.ts +62 -62
  33. package/src/components/Checkbox/Checkbox.tsx +105 -105
  34. package/src/components/Checkbox/index.ts +2 -2
  35. package/src/components/CloseButton/CloseButton.styles.ts +34 -34
  36. package/src/components/CloseButton/CloseButton.tsx +35 -35
  37. package/src/components/CloseButton/index.ts +2 -2
  38. package/src/components/Colors/Colors.stories.tsx +7 -7
  39. package/src/components/Colors/Colors.styles.ts +38 -38
  40. package/src/components/Colors/Colors.tsx +26 -26
  41. package/src/components/Colors/index.ts +2 -2
  42. package/src/components/CssBaseline/CssBaseline.styles.ts +15 -15
  43. package/src/components/CssBaseline/CssBaseline.tsx +15 -15
  44. package/src/components/CssBaseline/index.ts +2 -2
  45. package/src/components/DateInput/DateInput.stories.tsx +61 -61
  46. package/src/components/DateInput/DateInput.styles.ts +14 -14
  47. package/src/components/DateInput/DateInput.tsx +82 -82
  48. package/src/components/DateInput/constants.ts +2 -2
  49. package/src/components/DateInput/index.ts +3 -3
  50. package/src/components/DatePicker/DatePicker.stories.tsx +87 -87
  51. package/src/components/DatePicker/DatePicker.styles.ts +44 -44
  52. package/src/components/DatePicker/DatePicker.tsx +327 -327
  53. package/src/components/DatePicker/DatePickerHeader/DatePickerHeader.styles.ts +84 -84
  54. package/src/components/DatePicker/DatePickerHeader/DatePickerHeader.tsx +79 -79
  55. package/src/components/DatePicker/DatePickerHeader/index.ts +2 -2
  56. package/src/components/DatePicker/constants.ts +1 -1
  57. package/src/components/DatePicker/helpers.ts +23 -23
  58. package/src/components/DatePicker/index.ts +3 -3
  59. package/src/components/DatePicker/types.ts +45 -45
  60. package/src/components/Description/Description.stories.tsx +27 -27
  61. package/src/components/Description/Description.styles.ts +31 -31
  62. package/src/components/Description/Description.tsx +60 -60
  63. package/src/components/Description/index.ts +2 -2
  64. package/src/components/FiltersPane/FilterInterval/FilterInterval.styles.ts +64 -64
  65. package/src/components/FiltersPane/FilterInterval/FilterInterval.tsx +143 -143
  66. package/src/components/FiltersPane/FilterInterval/index.ts +1 -1
  67. package/src/components/FiltersPane/FilterMultiSelect/FilterMultiSelect.tsx +10 -10
  68. package/src/components/FiltersPane/FilterMultiSelect/index.ts +1 -1
  69. package/src/components/FiltersPane/FilterSelect/FilterSelect.styles.ts +143 -143
  70. package/src/components/FiltersPane/FilterSelect/FilterSelect.tsx +348 -348
  71. package/src/components/FiltersPane/FilterSelect/index.ts +1 -1
  72. package/src/components/FiltersPane/FilterSelect/locales.ts +37 -37
  73. package/src/components/FiltersPane/FilterValueView/FilterValueView.styles.tsx +15 -15
  74. package/src/components/FiltersPane/FilterValueView/FilterValueView.tsx +166 -166
  75. package/src/components/FiltersPane/FilterValueView/index.tsx +1 -1
  76. package/src/components/FiltersPane/FilterWithDates/FilterWithDates.styles.ts +60 -60
  77. package/src/components/FiltersPane/FilterWithDates/FilterWithDates.tsx +184 -184
  78. package/src/components/FiltersPane/FilterWithDates/index.ts +1 -1
  79. package/src/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.styles.ts +17 -17
  80. package/src/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.tsx +198 -198
  81. package/src/components/FiltersPane/FilterWithPeriod/index.ts +1 -1
  82. package/src/components/FiltersPane/FilterWrapper/FilterWrapper.styles.ts +110 -110
  83. package/src/components/FiltersPane/FilterWrapper/FilterWrapper.tsx +346 -346
  84. package/src/components/FiltersPane/FilterWrapper/index.ts +1 -1
  85. package/src/components/FiltersPane/FiltersPane.stories.tsx +295 -295
  86. package/src/components/FiltersPane/FiltersPane.styles.ts +71 -71
  87. package/src/components/FiltersPane/FiltersPane.tsx +151 -151
  88. package/src/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.styles.ts +109 -109
  89. package/src/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.tsx +155 -155
  90. package/src/components/FiltersPane/FiltersPaneSearch/index.ts +1 -1
  91. package/src/components/FiltersPane/index.ts +20 -20
  92. package/src/components/FiltersPane/locales.ts +107 -107
  93. package/src/components/FiltersPane/types.ts +112 -112
  94. package/src/components/Flag/Flag.stories.tsx +29 -29
  95. package/src/components/Flag/Flag.styles.ts +18 -18
  96. package/src/components/Flag/Flag.tsx +27 -27
  97. package/src/components/Flag/augment.d.ts +1 -1
  98. package/src/components/Flag/index.ts +2 -2
  99. package/src/components/FlexibleTable/FlexibleTable.stories.tsx +84 -84
  100. package/src/components/FlexibleTable/FlexibleTable.styles.ts +131 -131
  101. package/src/components/FlexibleTable/FlexibleTable.tsx +205 -205
  102. package/src/components/FlexibleTable/TableRow.tsx +152 -152
  103. package/src/components/FlexibleTable/TableValue.tsx +75 -75
  104. package/src/components/FlexibleTable/fixture-test.ts +254 -254
  105. package/src/components/FlexibleTable/index.ts +3 -3
  106. package/src/components/FlexibleTable/types.ts +52 -52
  107. package/src/components/Icon/ComplexIconBoilerplate.tsx +17 -17
  108. package/src/components/Icon/Icon.stories.tsx +85 -85
  109. package/src/components/Icon/Icon.styles.ts +10 -10
  110. package/src/components/Icon/Icon.tsx +32 -32
  111. package/src/components/Icon/IconBoilerplate.tsx +42 -42
  112. package/src/components/Icon/complexIcons/augment.d.ts +1 -1
  113. package/src/components/Icon/complexIcons/avatarGreen.svg +57 -57
  114. package/src/components/Icon/complexIcons/icons.ts +7 -7
  115. package/src/components/Icon/complexIcons/index.ts +1 -1
  116. package/src/components/Icon/icons/icons.ts +838 -838
  117. package/src/components/Icon/icons/index.ts +1 -1
  118. package/src/components/Icon/index.ts +4 -4
  119. package/src/components/IncrementInput/ChangeButton.tsx +33 -33
  120. package/src/components/IncrementInput/IncrementInput.stories.tsx +31 -31
  121. package/src/components/IncrementInput/IncrementInput.styles.ts +77 -77
  122. package/src/components/IncrementInput/IncrementInput.tsx +80 -80
  123. package/src/components/IncrementInput/index.ts +2 -2
  124. package/src/components/Input/Input.stories.tsx +86 -86
  125. package/src/components/Input/Input.styles.ts +307 -307
  126. package/src/components/Input/Input.tsx +311 -311
  127. package/src/components/Input/index.ts +2 -2
  128. package/src/components/List/List.stories.tsx +62 -62
  129. package/src/components/List/List.styles.ts +52 -52
  130. package/src/components/List/List.tsx +64 -64
  131. package/src/components/List/index.ts +2 -2
  132. package/src/components/Modal/Modal.stories.tsx +105 -105
  133. package/src/components/Modal/Modal.styles.ts +305 -305
  134. package/src/components/Modal/Modal.tsx +200 -200
  135. package/src/components/Modal/index.ts +2 -2
  136. package/src/components/MoreMenu/MoreMenu.stories.tsx +46 -46
  137. package/src/components/MoreMenu/MoreMenu.styles.ts +70 -70
  138. package/src/components/MoreMenu/MoreMenu.tsx +90 -90
  139. package/src/components/MoreMenu/index.ts +2 -2
  140. package/src/components/MultiSelect/MultiSelect.stories.tsx +46 -46
  141. package/src/components/MultiSelect/MultiSelect.styles.ts +55 -55
  142. package/src/components/MultiSelect/MultiSelect.tsx +89 -89
  143. package/src/components/MultiSelect/MultiSelectInput/MultiSelectInput.styles.ts +73 -73
  144. package/src/components/MultiSelect/MultiSelectInput/MultiSelectInput.tsx +51 -51
  145. package/src/components/MultiSelect/MultiSelectInput/index.ts +1 -1
  146. package/src/components/MultiSelect/index.ts +3 -3
  147. package/src/components/MultiSelectList/MultiSelectList.styles.ts +124 -124
  148. package/src/components/MultiSelectList/MultiSelectList.tsx +451 -451
  149. package/src/components/MultiSelectList/index.ts +2 -2
  150. package/src/components/MultiSelectList/locales.ts +37 -37
  151. package/src/components/Notification/Notification.stories.tsx +46 -46
  152. package/src/components/Notification/Notification.styles.ts +50 -50
  153. package/src/components/Notification/Notification.tsx +79 -79
  154. package/src/components/Notification/index.ts +2 -2
  155. package/src/components/NumberInput/NumberInput.stories.tsx +35 -35
  156. package/src/components/NumberInput/NumberInput.tsx +133 -133
  157. package/src/components/NumberInput/helpers.ts +86 -86
  158. package/src/components/NumberInput/index.ts +1 -1
  159. package/src/components/PhoneInput/PhoneInput.stories.tsx +70 -70
  160. package/src/components/PhoneInput/PhoneInput.styles.ts +84 -84
  161. package/src/components/PhoneInput/PhoneInput.tsx +194 -194
  162. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.stories.tsx +21 -21
  163. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.styles.ts +100 -100
  164. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.tsx +147 -147
  165. package/src/components/PhoneInput/PhoneInputCountryList/index.ts +2 -2
  166. package/src/components/PhoneInput/index.ts +6 -6
  167. package/src/components/PhoneInput/phone-info.ts +2147 -2147
  168. package/src/components/PhoneInput/types.ts +16 -16
  169. package/src/components/RadioButton/RadioButton.stories.tsx +46 -46
  170. package/src/components/RadioButton/RadioButton.styles.ts +37 -37
  171. package/src/components/RadioButton/RadioButton.tsx +55 -55
  172. package/src/components/RadioButton/index.ts +2 -2
  173. package/src/components/ScrollIntoViewIfNeeded/ScrollIntoViewIfNeeded.ts +61 -61
  174. package/src/components/ScrollIntoViewIfNeeded/index.ts +1 -1
  175. package/src/components/SearchInput/SearchInput.stories.tsx +23 -23
  176. package/src/components/SearchInput/SearchInput.styles.ts +50 -50
  177. package/src/components/SearchInput/SearchInput.tsx +50 -50
  178. package/src/components/SearchInput/index.ts +2 -2
  179. package/src/components/Select/MultiSelect.stories.tsx +240 -240
  180. package/src/components/Select/Select.stories.tsx +235 -235
  181. package/src/components/Select/Select.styles.ts +96 -96
  182. package/src/components/Select/Select.tsx +575 -575
  183. package/src/components/Select/SelectList/SelectList.styles.ts +72 -72
  184. package/src/components/Select/SelectList/SelectList.tsx +158 -158
  185. package/src/components/Select/SelectList/index.ts +1 -1
  186. package/src/components/Select/SelectListItem/SelectListItem.styles.ts +14 -14
  187. package/src/components/Select/SelectListItem/SelectListItem.tsx +68 -68
  188. package/src/components/Select/constants.ts +2 -2
  189. package/src/components/Select/helpers.ts +26 -26
  190. package/src/components/Select/index.ts +4 -4
  191. package/src/components/Select/types.ts +1 -1
  192. package/src/components/SmartInput/SmartInput.stories.tsx +50 -50
  193. package/src/components/SmartInput/SmartInput.tsx +147 -147
  194. package/src/components/SmartInput/helpers.ts +85 -85
  195. package/src/components/SmartInput/index.ts +1 -1
  196. package/src/components/Switch/Switch.stories.tsx +40 -40
  197. package/src/components/Switch/Switch.styles.ts +75 -75
  198. package/src/components/Switch/Switch.tsx +83 -83
  199. package/src/components/Switch/index.ts +2 -2
  200. package/src/components/TextArea/TextArea.stories.tsx +35 -35
  201. package/src/components/TextArea/TextArea.styles.ts +153 -153
  202. package/src/components/TextArea/TextArea.tsx +165 -165
  203. package/src/components/TextArea/index.ts +2 -2
  204. package/src/components/TextWithInfo/TextWithInfo.stories.tsx +53 -53
  205. package/src/components/TextWithInfo/TextWithInfo.styles.ts +60 -60
  206. package/src/components/TextWithInfo/TextWithInfo.tsx +60 -60
  207. package/src/components/TextWithInfo/index.ts +2 -2
  208. package/src/components/TextWithTooltip/TextWithTooltip.stories.tsx +58 -58
  209. package/src/components/TextWithTooltip/TextWithTooltip.styles.ts +19 -19
  210. package/src/components/TextWithTooltip/TextWithTooltip.tsx +143 -143
  211. package/src/components/TextWithTooltip/index.ts +2 -2
  212. package/src/components/ThemedPreloader/ThemedPreloader.stories.tsx +41 -41
  213. package/src/components/ThemedPreloader/ThemedPreloader.styles.ts +21 -21
  214. package/src/components/ThemedPreloader/ThemedPreloader.tsx +50 -50
  215. package/src/components/ThemedPreloader/components/DefaultPreloader/DefaultPreloader.tsx +29 -29
  216. package/src/components/ThemedPreloader/components/DefaultPreloader/index.ts +1 -1
  217. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.styles.ts +54 -54
  218. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.tsx +18 -18
  219. package/src/components/ThemedPreloader/components/DotsPreloader/index.ts +2 -2
  220. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.styles.ts +11 -11
  221. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.tsx +25 -25
  222. package/src/components/ThemedPreloader/components/SvgPreloader/index.ts +2 -2
  223. package/src/components/ThemedPreloader/components/index.ts +2 -2
  224. package/src/components/ThemedPreloader/index.ts +2 -2
  225. package/src/components/Toaster/Toaster.stories.tsx +30 -30
  226. package/src/components/Toaster/Toaster.styles.ts +59 -59
  227. package/src/components/Toaster/Toaster.tsx +110 -110
  228. package/src/components/Toaster/index.ts +2 -2
  229. package/src/components/Tooltip/Tooltip.stories.tsx +19 -19
  230. package/src/components/Tooltip/Tooltip.styles.ts +45 -45
  231. package/src/components/Tooltip/Tooltip.tsx +35 -35
  232. package/src/components/Tooltip/index.ts +3 -3
  233. package/src/components/Tooltip/types.ts +1 -1
  234. package/src/components/index.ts +36 -36
  235. package/src/helpers/deprecated.ts +23 -23
  236. package/src/helpers/index.ts +4 -4
  237. package/src/helpers/misc.ts +158 -158
  238. package/src/helpers/phone.ts +87 -87
  239. package/src/helpers/popper-helpers.ts +17 -17
  240. package/src/helpers/snippets.tsx +6 -6
  241. package/src/hooks/index.ts +6 -6
  242. package/src/hooks/use-did-mount-effect.ts +18 -18
  243. package/src/hooks/use-dropdown.ts +82 -82
  244. package/src/hooks/use-is-mounted.ts +15 -15
  245. package/src/hooks/use-on-click-outside.ts +77 -77
  246. package/src/hooks/use-theme.ts +32 -32
  247. package/src/hooks/use-tweak-styles.ts +13 -13
  248. package/src/index.ts +6 -6
  249. package/src/theme.ts +149 -149
  250. package/src/types.ts +107 -107
  251. package/src/vite-env.d.ts +1 -1
@@ -1,62 +1,62 @@
1
- import { ComponentStory, ComponentMeta } from '@storybook/react';
2
- import { colors } from '../../theme';
3
- import { List, IListItem } from './List';
4
-
5
- const listItems: IListItem[] = [
6
- {
7
- item: 'Печатать билет',
8
- onClick: console.log,
9
- icon: 'sign-out',
10
- },
11
- { item: 'Выписать', onClick: console.log, withIconGap: true },
12
- {
13
- item: 'Аннулировать',
14
- onClick: console.log,
15
- icon: <>2</>,
16
- },
17
- {
18
- item: 'Вернуть',
19
- onClick: console.log,
20
- disabled: true,
21
- withIconGap: true,
22
- shouldDrawSpacerBelow: true,
23
- },
24
- {
25
- item: (() => <div style={{ color: colors.RED_ACTIVE }}>Удалить</div>)(),
26
- onClick: console.log,
27
- disabled: true,
28
- withIconGap: true,
29
- },
30
- {
31
- item: (() => <div style={{ color: colors.RED_ACTIVE }}>Удалить</div>)(),
32
- onClick: console.log,
33
- withIconGap: true,
34
- },
35
- ];
36
-
37
- export default {
38
- title: 'List',
39
- component: List,
40
- args: {
41
- items: listItems,
42
- },
43
- parameters: {
44
- controls: {
45
- exclude: ['data', 'tweakStyles', 'testId', 'onClick'],
46
- },
47
- },
48
- } as ComponentMeta<typeof List>;
49
-
50
- export const Default: ComponentStory<typeof List> = (args) => (
51
- <div
52
- style={{
53
- border: '1px dotted rgba(0,0,0,.2)',
54
- display: 'flex',
55
- alignItems: 'center',
56
- justifyContent: 'center',
57
- padding: 40,
58
- }}
59
- >
60
- <List {...args} />
61
- </div>
62
- );
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { colors } from '../../theme';
3
+ import { List, IListItem } from './List';
4
+
5
+ const listItems: IListItem[] = [
6
+ {
7
+ item: 'Печатать билет',
8
+ onClick: console.log,
9
+ icon: 'sign-out',
10
+ },
11
+ { item: 'Выписать', onClick: console.log, withIconGap: true },
12
+ {
13
+ item: 'Аннулировать',
14
+ onClick: console.log,
15
+ icon: <>2</>,
16
+ },
17
+ {
18
+ item: 'Вернуть',
19
+ onClick: console.log,
20
+ disabled: true,
21
+ withIconGap: true,
22
+ shouldDrawSpacerBelow: true,
23
+ },
24
+ {
25
+ item: (() => <div style={{ color: colors.RED_ACTIVE }}>Удалить</div>)(),
26
+ onClick: console.log,
27
+ disabled: true,
28
+ withIconGap: true,
29
+ },
30
+ {
31
+ item: (() => <div style={{ color: colors.RED_ACTIVE }}>Удалить</div>)(),
32
+ onClick: console.log,
33
+ withIconGap: true,
34
+ },
35
+ ];
36
+
37
+ export default {
38
+ title: 'List',
39
+ component: List,
40
+ args: {
41
+ items: listItems,
42
+ },
43
+ parameters: {
44
+ controls: {
45
+ exclude: ['data', 'tweakStyles', 'testId', 'onClick'],
46
+ },
47
+ },
48
+ } as ComponentMeta<typeof List>;
49
+
50
+ export const Default: ComponentStory<typeof List> = (args) => (
51
+ <div
52
+ style={{
53
+ border: '1px dotted rgba(0,0,0,.2)',
54
+ display: 'flex',
55
+ alignItems: 'center',
56
+ justifyContent: 'center',
57
+ padding: 40,
58
+ }}
59
+ >
60
+ <List {...args} />
61
+ </div>
62
+ );
@@ -1,52 +1,52 @@
1
- import { colors } from '../../theme';
2
- import { ComponentStyles } from '../../types';
3
-
4
- const ITEM_HORIZONTAL_PADDING = 16;
5
- const ICON_SIZE = 20;
6
- const ICON_GAP = 12;
7
-
8
- export const styles = {
9
- root: {
10
- minWidth: 180,
11
- backgroundColor: colors.CLASSIC_WHITE,
12
- padding: [8, 0],
13
- listStyle: 'none',
14
- margin: 0,
15
- },
16
-
17
- item: {
18
- display: 'flex',
19
- alignItems: 'center',
20
- boxSizing: 'border-box',
21
- fontSize: 16,
22
- whiteSpace: 'nowrap',
23
- minHeight: 40,
24
- padding: [0, ITEM_HORIZONTAL_PADDING],
25
- transition: 'background-color 0.25s ease-in-out',
26
- cursor: 'pointer',
27
- },
28
-
29
- disabledItem: {
30
- cursor: 'default',
31
- },
32
-
33
- spacer: {
34
- height: 1,
35
- backgroundColor: colors.BORDER_LIGHT,
36
- },
37
-
38
- withIconGap: {
39
- paddingLeft: ITEM_HORIZONTAL_PADDING + ICON_SIZE + ICON_GAP,
40
- },
41
-
42
- icon: {
43
- width: ICON_SIZE,
44
- height: ICON_SIZE,
45
- marginRight: ICON_GAP,
46
- flexShrink: 0,
47
- },
48
-
49
- content: {},
50
- };
51
-
52
- export type ListStyles = ComponentStyles<typeof styles>;
1
+ import { colors } from '../../theme';
2
+ import { ComponentStyles } from '../../types';
3
+
4
+ const ITEM_HORIZONTAL_PADDING = 16;
5
+ const ICON_SIZE = 20;
6
+ const ICON_GAP = 12;
7
+
8
+ export const styles = {
9
+ root: {
10
+ minWidth: 180,
11
+ backgroundColor: colors.CLASSIC_WHITE,
12
+ padding: [8, 0],
13
+ listStyle: 'none',
14
+ margin: 0,
15
+ },
16
+
17
+ item: {
18
+ display: 'flex',
19
+ alignItems: 'center',
20
+ boxSizing: 'border-box',
21
+ fontSize: 16,
22
+ whiteSpace: 'nowrap',
23
+ minHeight: 40,
24
+ padding: [0, ITEM_HORIZONTAL_PADDING],
25
+ transition: 'background-color 0.25s ease-in-out',
26
+ cursor: 'pointer',
27
+ },
28
+
29
+ disabledItem: {
30
+ cursor: 'default',
31
+ },
32
+
33
+ spacer: {
34
+ height: 1,
35
+ backgroundColor: colors.BORDER_LIGHT,
36
+ },
37
+
38
+ withIconGap: {
39
+ paddingLeft: ITEM_HORIZONTAL_PADDING + ICON_SIZE + ICON_GAP,
40
+ },
41
+
42
+ icon: {
43
+ width: ICON_SIZE,
44
+ height: ICON_SIZE,
45
+ marginRight: ICON_GAP,
46
+ flexShrink: 0,
47
+ },
48
+
49
+ content: {},
50
+ };
51
+
52
+ export type ListStyles = ComponentStyles<typeof styles>;
@@ -1,64 +1,64 @@
1
- import { FC, Fragment, ReactNode } from 'react';
2
- import clsx from 'clsx';
3
- import {
4
- addDataTestId,
5
- getTestId,
6
- isReactNodeNotEmpty,
7
- } from '@true-engineering/true-react-platform-helpers';
8
- import { addDataAttributes } from '../../helpers';
9
- import { renderIcon } from '../../helpers/snippets';
10
- import { useTheme } from '../../hooks';
11
- import { ICommonProps, IIcon } from '../../types';
12
- import { ListStyles, styles } from './List.styles';
13
-
14
- export interface IListItem {
15
- item: ReactNode;
16
- icon?: IIcon;
17
- disabled?: boolean;
18
- shouldDrawSpacerAbove?: boolean;
19
- shouldDrawSpacerBelow?: boolean;
20
- withIconGap?: boolean;
21
- testId?: string;
22
- onClick(): void;
23
- }
24
-
25
- export interface IListProps extends ICommonProps {
26
- tweakStyles?: ListStyles;
27
- items: IListItem[];
28
- testId?: string;
29
- onClick?(): void;
30
- }
31
-
32
- export const List: FC<IListProps> = ({ items, testId, data, tweakStyles, onClick }) => {
33
- const { classes } = useTheme('List', styles, tweakStyles);
34
-
35
- const handleItemClick = (item: IListItem) => {
36
- item.onClick();
37
- onClick?.();
38
- };
39
-
40
- return (
41
- <div className={classes.root} {...addDataTestId(testId)} {...addDataAttributes(data)}>
42
- {items.map((item, idx) => (
43
- <Fragment key={idx}>
44
- {item.shouldDrawSpacerAbove && <div className={classes.spacer} />}
45
- <div
46
- className={clsx(classes.item, {
47
- [classes.disabledItem]: item.disabled,
48
- [classes.withIconGap]: item.withIconGap,
49
- })}
50
- onClick={item.disabled ? undefined : () => handleItemClick(item)}
51
- {...addDataTestId(item.testId ?? getTestId(testId, `item-${idx}`))}
52
- {...(item.disabled && addDataAttributes({ disabled: item.disabled }))}
53
- >
54
- {isReactNodeNotEmpty(item.icon) && (
55
- <span className={classes.icon}>{renderIcon(item.icon)}</span>
56
- )}
57
- <span className={classes.content}>{item.item}</span>
58
- </div>
59
- {item.shouldDrawSpacerBelow && <div className={classes.spacer} />}
60
- </Fragment>
61
- ))}
62
- </div>
63
- );
64
- };
1
+ import { FC, Fragment, ReactNode } from 'react';
2
+ import clsx from 'clsx';
3
+ import {
4
+ addDataTestId,
5
+ getTestId,
6
+ isReactNodeNotEmpty,
7
+ } from '@true-engineering/true-react-platform-helpers';
8
+ import { addDataAttributes } from '../../helpers';
9
+ import { renderIcon } from '../../helpers/snippets';
10
+ import { useTheme } from '../../hooks';
11
+ import { ICommonProps, IIcon } from '../../types';
12
+ import { ListStyles, styles } from './List.styles';
13
+
14
+ export interface IListItem {
15
+ item: ReactNode;
16
+ icon?: IIcon;
17
+ disabled?: boolean;
18
+ shouldDrawSpacerAbove?: boolean;
19
+ shouldDrawSpacerBelow?: boolean;
20
+ withIconGap?: boolean;
21
+ testId?: string;
22
+ onClick(): void;
23
+ }
24
+
25
+ export interface IListProps extends ICommonProps {
26
+ tweakStyles?: ListStyles;
27
+ items: IListItem[];
28
+ testId?: string;
29
+ onClick?(): void;
30
+ }
31
+
32
+ export const List: FC<IListProps> = ({ items, testId, data, tweakStyles, onClick }) => {
33
+ const { classes } = useTheme('List', styles, tweakStyles);
34
+
35
+ const handleItemClick = (item: IListItem) => {
36
+ item.onClick();
37
+ onClick?.();
38
+ };
39
+
40
+ return (
41
+ <div className={classes.root} {...addDataTestId(testId)} {...addDataAttributes(data)}>
42
+ {items.map((item, idx) => (
43
+ <Fragment key={idx}>
44
+ {item.shouldDrawSpacerAbove && <div className={classes.spacer} />}
45
+ <div
46
+ className={clsx(classes.item, {
47
+ [classes.disabledItem]: item.disabled,
48
+ [classes.withIconGap]: item.withIconGap,
49
+ })}
50
+ onClick={item.disabled ? undefined : () => handleItemClick(item)}
51
+ {...addDataTestId(item.testId ?? getTestId(testId, `item-${idx}`))}
52
+ {...(item.disabled && addDataAttributes({ disabled: item.disabled }))}
53
+ >
54
+ {isReactNodeNotEmpty(item.icon) && (
55
+ <span className={classes.icon}>{renderIcon(item.icon)}</span>
56
+ )}
57
+ <span className={classes.content}>{item.item}</span>
58
+ </div>
59
+ {item.shouldDrawSpacerBelow && <div className={classes.spacer} />}
60
+ </Fragment>
61
+ ))}
62
+ </div>
63
+ );
64
+ };
@@ -1,2 +1,2 @@
1
- export * from './List';
2
- export type { ListStyles } from './List.styles';
1
+ export * from './List';
2
+ export type { ListStyles } from './List.styles';
@@ -1,105 +1,105 @@
1
- import { FC, useState } from 'react';
2
- import { ComponentStory } from '@storybook/react';
3
- import { Button } from '../Button';
4
- import { IModalProps, Modal } from './Modal';
5
-
6
- const smallText =
7
- 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.';
8
- const text =
9
- 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat.';
10
- const largeText = [...text, ...text, ...text];
11
- const texts = { small: smallText, medium: text, large: largeText };
12
-
13
- export interface IModalWithCustomProps extends IModalProps {
14
- textSize: 'small' | 'medium' | 'large';
15
- }
16
-
17
- const ModalWithCustomProps: FC<IModalWithCustomProps> = ({ size, textSize, ...args }) => {
18
- const [isModalOpen, setIsModalOpen] = useState(false);
19
- const [isSecondModalOpen, setIsSecondModalOpen] = useState(false);
20
-
21
- return (
22
- <div>
23
- <Button onClick={() => setIsModalOpen(true)}>Open</Button>
24
- <Button onClick={() => setIsSecondModalOpen(true)}>Open 2</Button>
25
-
26
- <Modal
27
- {...args}
28
- isOpen={isModalOpen}
29
- onClose={() => setIsModalOpen(false)}
30
- buttons={[
31
- <Button
32
- key="1"
33
- view="secondary"
34
- onClick={() => setIsModalOpen(false)}
35
- size={size === 's' ? 'm' : 'l'}
36
- >
37
- Отмена
38
- </Button>,
39
- <Button
40
- key="2"
41
- size={size === 's' ? 'm' : 'l'}
42
- onClick={() => {
43
- setIsModalOpen(false);
44
- setIsSecondModalOpen(true);
45
- }}
46
- >
47
- Применить
48
- </Button>,
49
- ]}
50
- >
51
- <div style={{ lineHeight: 1.6 }}>{texts[textSize]}</div>
52
- </Modal>
53
-
54
- <Modal {...args} isOpen={isSecondModalOpen} onClose={() => setIsSecondModalOpen(false)}>
55
- Text
56
- </Modal>
57
- </div>
58
- );
59
- };
60
-
61
- export default {
62
- title: 'Modal',
63
- component: Modal,
64
- argTypes: {
65
- buttonsAlign: {
66
- control: 'inline-radio',
67
- options: ['left', 'center', 'right'],
68
- },
69
- textSize: {
70
- control: 'inline-radio',
71
- options: ['small', 'medium', 'large'],
72
- },
73
- size: { control: 'inline-radio', options: ['s', 'm', 'l'] },
74
- position: {
75
- control: 'inline-radio',
76
- options: ['center', 'left', 'right', 'static'],
77
- },
78
- },
79
- };
80
-
81
- const Template: ComponentStory<typeof ModalWithCustomProps> = (args) => (
82
- <div
83
- style={{
84
- border: '1px dotted rgba(0,0,0,.2)',
85
- height: 1000, // чтобы был скролл на странице
86
- }}
87
- >
88
- <ModalWithCustomProps {...args} />
89
- </div>
90
- );
91
-
92
- export const Default = Template.bind({});
93
-
94
- Default.args = {
95
- title: 'Some modal title',
96
- size: 'm',
97
- textSize: 'small',
98
- buttonsAlign: 'right',
99
- shouldCloseOnEsc: true,
100
- hasOverlay: true,
101
- hasCloseButton: true,
102
- shouldCloseOnOverlayClick: true,
103
- shouldBlockScroll: true,
104
- isFooterSticky: false,
105
- };
1
+ import { FC, useState } from 'react';
2
+ import { ComponentStory } from '@storybook/react';
3
+ import { Button } from '../Button';
4
+ import { IModalProps, Modal } from './Modal';
5
+
6
+ const smallText =
7
+ 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.';
8
+ const text =
9
+ 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat.';
10
+ const largeText = [...text, ...text, ...text];
11
+ const texts = { small: smallText, medium: text, large: largeText };
12
+
13
+ export interface IModalWithCustomProps extends IModalProps {
14
+ textSize: 'small' | 'medium' | 'large';
15
+ }
16
+
17
+ const ModalWithCustomProps: FC<IModalWithCustomProps> = ({ size, textSize, ...args }) => {
18
+ const [isModalOpen, setIsModalOpen] = useState(false);
19
+ const [isSecondModalOpen, setIsSecondModalOpen] = useState(false);
20
+
21
+ return (
22
+ <div>
23
+ <Button onClick={() => setIsModalOpen(true)}>Open</Button>
24
+ <Button onClick={() => setIsSecondModalOpen(true)}>Open 2</Button>
25
+
26
+ <Modal
27
+ {...args}
28
+ isOpen={isModalOpen}
29
+ onClose={() => setIsModalOpen(false)}
30
+ buttons={[
31
+ <Button
32
+ key="1"
33
+ view="secondary"
34
+ onClick={() => setIsModalOpen(false)}
35
+ size={size === 's' ? 'm' : 'l'}
36
+ >
37
+ Отмена
38
+ </Button>,
39
+ <Button
40
+ key="2"
41
+ size={size === 's' ? 'm' : 'l'}
42
+ onClick={() => {
43
+ setIsModalOpen(false);
44
+ setIsSecondModalOpen(true);
45
+ }}
46
+ >
47
+ Применить
48
+ </Button>,
49
+ ]}
50
+ >
51
+ <div style={{ lineHeight: 1.6 }}>{texts[textSize]}</div>
52
+ </Modal>
53
+
54
+ <Modal {...args} isOpen={isSecondModalOpen} onClose={() => setIsSecondModalOpen(false)}>
55
+ Text
56
+ </Modal>
57
+ </div>
58
+ );
59
+ };
60
+
61
+ export default {
62
+ title: 'Modal',
63
+ component: Modal,
64
+ argTypes: {
65
+ buttonsAlign: {
66
+ control: 'inline-radio',
67
+ options: ['left', 'center', 'right'],
68
+ },
69
+ textSize: {
70
+ control: 'inline-radio',
71
+ options: ['small', 'medium', 'large'],
72
+ },
73
+ size: { control: 'inline-radio', options: ['s', 'm', 'l'] },
74
+ position: {
75
+ control: 'inline-radio',
76
+ options: ['center', 'left', 'right', 'static'],
77
+ },
78
+ },
79
+ };
80
+
81
+ const Template: ComponentStory<typeof ModalWithCustomProps> = (args) => (
82
+ <div
83
+ style={{
84
+ border: '1px dotted rgba(0,0,0,.2)',
85
+ height: 1000, // чтобы был скролл на странице
86
+ }}
87
+ >
88
+ <ModalWithCustomProps {...args} />
89
+ </div>
90
+ );
91
+
92
+ export const Default = Template.bind({});
93
+
94
+ Default.args = {
95
+ title: 'Some modal title',
96
+ size: 'm',
97
+ textSize: 'small',
98
+ buttonsAlign: 'right',
99
+ shouldCloseOnEsc: true,
100
+ hasOverlay: true,
101
+ hasCloseButton: true,
102
+ shouldCloseOnOverlayClick: true,
103
+ shouldBlockScroll: true,
104
+ isFooterSticky: false,
105
+ };