@true-engineering/true-react-common-ui-kit 1.6.0 → 1.8.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 (239) hide show
  1. package/LICENSE +201 -201
  2. package/dist/components/Flag/augment.d.ts +1 -1
  3. package/dist/components/FlexibleTable/types.d.ts +2 -2
  4. package/dist/components/Icon/complexIcons/augment.d.ts +1 -1
  5. package/dist/components/Select/Select.d.ts +1 -1
  6. package/dist/true-react-common-ui-kit.js +64 -64
  7. package/dist/true-react-common-ui-kit.js.map +1 -1
  8. package/dist/true-react-common-ui-kit.umd.cjs +64 -64
  9. package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
  10. package/dist/vite-env.d.ts +1 -1
  11. package/package.json +91 -91
  12. package/src/components/AccountInfo/AccountInfo.stories.tsx +35 -35
  13. package/src/components/AccountInfo/AccountInfo.styles.ts +55 -55
  14. package/src/components/AccountInfo/AccountInfo.tsx +106 -106
  15. package/src/components/AccountInfo/index.ts +2 -2
  16. package/src/components/AddButton/AddButton.stories.tsx +21 -21
  17. package/src/components/AddButton/AddButton.styles.ts +34 -34
  18. package/src/components/AddButton/AddButton.tsx +49 -49
  19. package/src/components/AddButton/index.ts +2 -2
  20. package/src/components/Button/Button.stories.tsx +61 -61
  21. package/src/components/Button/Button.styles.ts +196 -196
  22. package/src/components/Button/Button.tsx +195 -195
  23. package/src/components/Button/index.ts +2 -2
  24. package/src/components/Checkbox/Checkbox.stories.tsx +35 -35
  25. package/src/components/Checkbox/Checkbox.styles.ts +62 -62
  26. package/src/components/Checkbox/Checkbox.tsx +106 -106
  27. package/src/components/Checkbox/index.ts +2 -2
  28. package/src/components/CloseButton/CloseButton.styles.ts +34 -34
  29. package/src/components/CloseButton/CloseButton.tsx +37 -37
  30. package/src/components/CloseButton/index.ts +2 -2
  31. package/src/components/Colors/Colors.stories.tsx +7 -7
  32. package/src/components/Colors/Colors.styles.ts +38 -38
  33. package/src/components/Colors/Colors.tsx +34 -34
  34. package/src/components/Colors/index.ts +2 -2
  35. package/src/components/CssBaseline/CssBaseline.styles.ts +15 -15
  36. package/src/components/CssBaseline/CssBaseline.tsx +17 -17
  37. package/src/components/CssBaseline/index.ts +2 -2
  38. package/src/components/DateInput/DateInput.stories.tsx +63 -63
  39. package/src/components/DateInput/DateInput.styles.ts +14 -14
  40. package/src/components/DateInput/DateInput.tsx +60 -60
  41. package/src/components/DateInput/index.ts +2 -2
  42. package/src/components/DatePicker/DatePicker.stories.tsx +96 -96
  43. package/src/components/DatePicker/DatePicker.styles.ts +54 -54
  44. package/src/components/DatePicker/DatePicker.tsx +358 -358
  45. package/src/components/DatePicker/DatePickerHeader/DatePickerHeader.styles.ts +84 -84
  46. package/src/components/DatePicker/DatePickerHeader/DatePickerHeader.tsx +94 -94
  47. package/src/components/DatePicker/DatePickerHeader/index.ts +1 -1
  48. package/src/components/DatePicker/DatePickerInput/DatePickerInput.styles.ts +25 -25
  49. package/src/components/DatePicker/DatePickerInput/DatePickerInput.tsx +31 -31
  50. package/src/components/DatePicker/DatePickerInput/index.ts +1 -1
  51. package/src/components/DatePicker/index.ts +4 -4
  52. package/src/components/Description/Description.stories.tsx +29 -29
  53. package/src/components/Description/Description.styles.ts +31 -31
  54. package/src/components/Description/Description.tsx +69 -69
  55. package/src/components/Description/index.ts +2 -2
  56. package/src/components/FiltersPane/FilterInterval/FilterInterval.styles.ts +64 -64
  57. package/src/components/FiltersPane/FilterInterval/FilterInterval.tsx +162 -162
  58. package/src/components/FiltersPane/FilterInterval/index.ts +1 -1
  59. package/src/components/FiltersPane/FilterMultiSelect/FilterMultiSelect.tsx +14 -14
  60. package/src/components/FiltersPane/FilterMultiSelect/index.ts +1 -1
  61. package/src/components/FiltersPane/FilterSelect/FilterSelect.styles.ts +144 -144
  62. package/src/components/FiltersPane/FilterSelect/FilterSelect.tsx +397 -397
  63. package/src/components/FiltersPane/FilterSelect/index.ts +1 -1
  64. package/src/components/FiltersPane/FilterSelect/locales.ts +37 -37
  65. package/src/components/FiltersPane/FilterValueView/FilterValueView.styles.tsx +15 -15
  66. package/src/components/FiltersPane/FilterValueView/FilterValueView.tsx +186 -186
  67. package/src/components/FiltersPane/FilterValueView/index.tsx +1 -1
  68. package/src/components/FiltersPane/FilterWithDates/FilterWithDates.styles.ts +60 -60
  69. package/src/components/FiltersPane/FilterWithDates/FilterWithDates.tsx +222 -222
  70. package/src/components/FiltersPane/FilterWithDates/index.ts +1 -1
  71. package/src/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.styles.ts +17 -17
  72. package/src/components/FiltersPane/FilterWithPeriod/FilterWithPeriod.tsx +231 -231
  73. package/src/components/FiltersPane/FilterWithPeriod/index.ts +1 -1
  74. package/src/components/FiltersPane/FilterWrapper/FilterWrapper.styles.ts +110 -110
  75. package/src/components/FiltersPane/FilterWrapper/FilterWrapper.tsx +360 -360
  76. package/src/components/FiltersPane/FilterWrapper/index.ts +1 -1
  77. package/src/components/FiltersPane/FiltersPane.stories.tsx +308 -308
  78. package/src/components/FiltersPane/FiltersPane.styles.ts +71 -71
  79. package/src/components/FiltersPane/FiltersPane.tsx +193 -193
  80. package/src/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.styles.ts +109 -109
  81. package/src/components/FiltersPane/FiltersPaneSearch/FiltersPaneSearch.tsx +175 -175
  82. package/src/components/FiltersPane/FiltersPaneSearch/index.ts +1 -1
  83. package/src/components/FiltersPane/index.ts +20 -20
  84. package/src/components/FiltersPane/locales.ts +107 -107
  85. package/src/components/FiltersPane/types.ts +126 -126
  86. package/src/components/Flag/Flag.stories.tsx +29 -29
  87. package/src/components/Flag/Flag.styles.ts +18 -18
  88. package/src/components/Flag/Flag.tsx +28 -28
  89. package/src/components/Flag/augment.d.ts +1 -1
  90. package/src/components/Flag/index.ts +2 -2
  91. package/src/components/FlexibleTable/FlexibleTable.stories.tsx +86 -80
  92. package/src/components/FlexibleTable/FlexibleTable.styles.ts +131 -131
  93. package/src/components/FlexibleTable/FlexibleTable.tsx +243 -243
  94. package/src/components/FlexibleTable/TableRow.tsx +171 -171
  95. package/src/components/FlexibleTable/TableValue.tsx +83 -83
  96. package/src/components/FlexibleTable/fixture-test.ts +254 -254
  97. package/src/components/FlexibleTable/index.ts +3 -3
  98. package/src/components/FlexibleTable/types.ts +58 -58
  99. package/src/components/Icon/ComplexIconBoilerplate.tsx +17 -17
  100. package/src/components/Icon/Icon.stories.tsx +88 -88
  101. package/src/components/Icon/Icon.styles.ts +10 -10
  102. package/src/components/Icon/Icon.tsx +34 -34
  103. package/src/components/Icon/IconBoilerplate.tsx +42 -42
  104. package/src/components/Icon/complexIcons/augment.d.ts +1 -1
  105. package/src/components/Icon/complexIcons/avatarGreen.svg +57 -57
  106. package/src/components/Icon/complexIcons/icons.ts +7 -7
  107. package/src/components/Icon/complexIcons/index.ts +1 -1
  108. package/src/components/Icon/icons/icons.ts +838 -838
  109. package/src/components/Icon/icons/index.ts +1 -1
  110. package/src/components/Icon/index.ts +4 -4
  111. package/src/components/IncrementInput/ChangeButton.tsx +34 -34
  112. package/src/components/IncrementInput/IncrementInput.stories.tsx +34 -34
  113. package/src/components/IncrementInput/IncrementInput.styles.ts +77 -77
  114. package/src/components/IncrementInput/IncrementInput.tsx +95 -95
  115. package/src/components/IncrementInput/index.ts +2 -2
  116. package/src/components/Input/Input.stories.tsx +92 -92
  117. package/src/components/Input/Input.styles.ts +305 -305
  118. package/src/components/Input/Input.tsx +318 -318
  119. package/src/components/Input/index.ts +2 -2
  120. package/src/components/List/List.stories.tsx +62 -62
  121. package/src/components/List/List.styles.ts +52 -52
  122. package/src/components/List/List.tsx +82 -82
  123. package/src/components/List/index.ts +2 -2
  124. package/src/components/Modal/Modal.stories.tsx +113 -113
  125. package/src/components/Modal/Modal.styles.ts +308 -308
  126. package/src/components/Modal/Modal.tsx +210 -210
  127. package/src/components/Modal/index.ts +2 -2
  128. package/src/components/MoreMenu/MoreMenu.stories.tsx +46 -46
  129. package/src/components/MoreMenu/MoreMenu.styles.ts +70 -70
  130. package/src/components/MoreMenu/MoreMenu.tsx +102 -102
  131. package/src/components/MoreMenu/index.ts +2 -2
  132. package/src/components/MultiSelect/MultiSelect.stories.tsx +46 -46
  133. package/src/components/MultiSelect/MultiSelect.styles.ts +55 -55
  134. package/src/components/MultiSelect/MultiSelect.tsx +98 -98
  135. package/src/components/MultiSelect/MultiSelectInput/MultiSelectInput.styles.ts +73 -73
  136. package/src/components/MultiSelect/MultiSelectInput/MultiSelectInput.tsx +62 -62
  137. package/src/components/MultiSelect/MultiSelectInput/index.ts +1 -1
  138. package/src/components/MultiSelect/index.ts +3 -3
  139. package/src/components/MultiSelectList/MultiSelectList.styles.ts +125 -125
  140. package/src/components/MultiSelectList/MultiSelectList.tsx +519 -519
  141. package/src/components/MultiSelectList/index.ts +2 -2
  142. package/src/components/MultiSelectList/locales.ts +37 -37
  143. package/src/components/Notification/Notification.stories.tsx +51 -51
  144. package/src/components/Notification/Notification.styles.ts +50 -50
  145. package/src/components/Notification/Notification.tsx +84 -84
  146. package/src/components/Notification/index.ts +2 -2
  147. package/src/components/NumberInput/NumberInput.stories.tsx +36 -36
  148. package/src/components/NumberInput/NumberInput.tsx +154 -154
  149. package/src/components/NumberInput/helpers.ts +87 -87
  150. package/src/components/NumberInput/index.ts +1 -1
  151. package/src/components/PhoneInput/PhoneInput.stories.tsx +71 -71
  152. package/src/components/PhoneInput/PhoneInput.styles.ts +84 -84
  153. package/src/components/PhoneInput/PhoneInput.tsx +223 -223
  154. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.stories.tsx +21 -21
  155. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.styles.ts +100 -100
  156. package/src/components/PhoneInput/PhoneInputCountryList/PhoneInputCountryList.tsx +171 -171
  157. package/src/components/PhoneInput/PhoneInputCountryList/index.ts +2 -2
  158. package/src/components/PhoneInput/index.ts +6 -6
  159. package/src/components/PhoneInput/phone-info.ts +2167 -2167
  160. package/src/components/PhoneInput/types.ts +16 -16
  161. package/src/components/RadioButton/RadioButton.stories.tsx +46 -46
  162. package/src/components/RadioButton/RadioButton.styles.ts +37 -37
  163. package/src/components/RadioButton/RadioButton.tsx +56 -56
  164. package/src/components/RadioButton/index.ts +2 -2
  165. package/src/components/ScrollIntoViewIfNeeded/ScrollIntoViewIfNeeded.ts +66 -66
  166. package/src/components/ScrollIntoViewIfNeeded/index.ts +1 -1
  167. package/src/components/SearchInput/SearchInput.stories.tsx +24 -24
  168. package/src/components/SearchInput/SearchInput.styles.ts +50 -50
  169. package/src/components/SearchInput/SearchInput.tsx +63 -63
  170. package/src/components/SearchInput/index.ts +2 -2
  171. package/src/components/Select/Select.stories.tsx +258 -258
  172. package/src/components/Select/Select.styles.ts +85 -85
  173. package/src/components/Select/Select.tsx +510 -514
  174. package/src/components/Select/SelectList/SelectList.styles.ts +68 -68
  175. package/src/components/Select/SelectList/SelectList.tsx +139 -139
  176. package/src/components/Select/SelectList/index.ts +1 -1
  177. package/src/components/Select/helpers.ts +21 -21
  178. package/src/components/Select/index.ts +3 -3
  179. package/src/components/SmartInput/SmartInput.stories.tsx +63 -63
  180. package/src/components/SmartInput/SmartInput.tsx +180 -180
  181. package/src/components/SmartInput/helpers.ts +85 -85
  182. package/src/components/SmartInput/index.ts +1 -1
  183. package/src/components/Switch/Switch.stories.tsx +40 -40
  184. package/src/components/Switch/Switch.styles.ts +75 -75
  185. package/src/components/Switch/Switch.tsx +89 -89
  186. package/src/components/Switch/index.ts +2 -2
  187. package/src/components/TextArea/TextArea.stories.tsx +35 -35
  188. package/src/components/TextArea/TextArea.styles.ts +153 -153
  189. package/src/components/TextArea/TextArea.tsx +178 -178
  190. package/src/components/TextArea/index.ts +2 -2
  191. package/src/components/TextWithInfo/TextWithInfo.stories.tsx +53 -53
  192. package/src/components/TextWithInfo/TextWithInfo.styles.ts +60 -60
  193. package/src/components/TextWithInfo/TextWithInfo.tsx +67 -67
  194. package/src/components/TextWithInfo/index.ts +2 -2
  195. package/src/components/TextWithTooltip/TextWithTooltip.stories.tsx +58 -58
  196. package/src/components/TextWithTooltip/TextWithTooltip.styles.ts +19 -19
  197. package/src/components/TextWithTooltip/TextWithTooltip.tsx +163 -163
  198. package/src/components/TextWithTooltip/index.ts +2 -2
  199. package/src/components/ThemedPreloader/ThemedPreloader.stories.tsx +41 -41
  200. package/src/components/ThemedPreloader/ThemedPreloader.styles.ts +21 -21
  201. package/src/components/ThemedPreloader/ThemedPreloader.tsx +56 -56
  202. package/src/components/ThemedPreloader/components/DefaultPreloader/DefaultPreloader.tsx +34 -34
  203. package/src/components/ThemedPreloader/components/DefaultPreloader/index.ts +1 -1
  204. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.styles.ts +54 -54
  205. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.tsx +18 -18
  206. package/src/components/ThemedPreloader/components/DotsPreloader/index.ts +2 -2
  207. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.styles.ts +11 -11
  208. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.tsx +32 -32
  209. package/src/components/ThemedPreloader/components/SvgPreloader/index.ts +2 -2
  210. package/src/components/ThemedPreloader/components/index.ts +2 -2
  211. package/src/components/ThemedPreloader/index.ts +2 -2
  212. package/src/components/Toaster/Toaster.stories.tsx +34 -34
  213. package/src/components/Toaster/Toaster.styles.ts +59 -59
  214. package/src/components/Toaster/Toaster.tsx +113 -113
  215. package/src/components/Toaster/index.ts +2 -2
  216. package/src/components/Tooltip/Tooltip.stories.tsx +21 -21
  217. package/src/components/Tooltip/Tooltip.styles.ts +45 -45
  218. package/src/components/Tooltip/Tooltip.tsx +40 -40
  219. package/src/components/Tooltip/index.ts +3 -3
  220. package/src/components/Tooltip/types.ts +1 -1
  221. package/src/components/index.ts +36 -36
  222. package/src/helpers/colors.ts +2 -2
  223. package/src/helpers/dateHelpers/date-helpers.ts +9 -9
  224. package/src/helpers/index.ts +4 -4
  225. package/src/helpers/phone.ts +106 -106
  226. package/src/helpers/popper-helpers.ts +17 -17
  227. package/src/helpers/snippets.tsx +5 -5
  228. package/src/helpers/utils.ts +219 -219
  229. package/src/hooks/index.ts +6 -6
  230. package/src/hooks/use-did-mount-effect.ts +21 -21
  231. package/src/hooks/use-dropdown.ts +85 -85
  232. package/src/hooks/use-is-mounted.ts +15 -15
  233. package/src/hooks/use-on-click-outside.ts +92 -92
  234. package/src/hooks/use-theme.ts +36 -36
  235. package/src/hooks/use-tweak-styles.ts +14 -14
  236. package/src/index.ts +6 -6
  237. package/src/theme.ts +155 -155
  238. package/src/types.ts +106 -106
  239. 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,82 +1,82 @@
1
- import { FC, Fragment, ReactElement, ReactNode } from 'react';
2
- import clsx from 'clsx';
3
- import { useTheme } from '../../hooks';
4
- import { ICommonProps } from '../../types';
5
- import {
6
- isNotEmpty,
7
- getTestId,
8
- addDataTestId,
9
- addDataAttributes,
10
- } from '../../helpers';
11
- import { Icon, IIconType } from '../Icon';
12
-
13
- import { ListStyles, styles } from './List.styles';
14
-
15
- export interface IListItem {
16
- item: ReactNode;
17
- icon?: IIconType | ReactElement;
18
- disabled?: boolean;
19
- shouldDrawSpacerAbove?: boolean;
20
- shouldDrawSpacerBelow?: boolean;
21
- withIconGap?: boolean;
22
- testId?: string;
23
- onClick(): void;
24
- }
25
-
26
- export interface IListProps extends ICommonProps {
27
- tweakStyles?: ListStyles;
28
- items: IListItem[];
29
- testId?: string;
30
- onClick?(): void;
31
- }
32
-
33
- export const List: FC<IListProps> = ({
34
- items,
35
- testId,
36
- data,
37
- tweakStyles,
38
- onClick,
39
- }) => {
40
- const { classes } = useTheme('List', styles, tweakStyles);
41
-
42
- const handleItemClick = (item: IListItem) => {
43
- item.onClick();
44
- onClick?.();
45
- };
46
-
47
- return (
48
- <div
49
- className={classes.root}
50
- {...addDataTestId(testId)}
51
- {...addDataAttributes(data)}
52
- >
53
- {items.map((item, idx) => (
54
- <Fragment key={idx}>
55
- {item.shouldDrawSpacerAbove && <div className={classes.spacer} />}
56
- <div
57
- className={clsx(classes.item, {
58
- [classes.disabledItem]: item.disabled,
59
- [classes.withIconGap]: item.withIconGap,
60
- })}
61
- {...addDataTestId(item.testId ?? getTestId(testId, `item-${idx}`))}
62
- {...(item.disabled &&
63
- addDataAttributes({ disabled: item.disabled }))}
64
- onClick={item.disabled ? undefined : () => handleItemClick(item)}
65
- >
66
- {isNotEmpty(item.icon) && (
67
- <span className={classes.icon}>
68
- {typeof item.icon === 'string' ? (
69
- <Icon type={item.icon} />
70
- ) : (
71
- item.icon
72
- )}
73
- </span>
74
- )}
75
- <span className={classes.content}>{item.item}</span>
76
- </div>
77
- {item.shouldDrawSpacerBelow && <div className={classes.spacer} />}
78
- </Fragment>
79
- ))}
80
- </div>
81
- );
82
- };
1
+ import { FC, Fragment, ReactElement, ReactNode } from 'react';
2
+ import clsx from 'clsx';
3
+ import { useTheme } from '../../hooks';
4
+ import { ICommonProps } from '../../types';
5
+ import {
6
+ isNotEmpty,
7
+ getTestId,
8
+ addDataTestId,
9
+ addDataAttributes,
10
+ } from '../../helpers';
11
+ import { Icon, IIconType } from '../Icon';
12
+
13
+ import { ListStyles, styles } from './List.styles';
14
+
15
+ export interface IListItem {
16
+ item: ReactNode;
17
+ icon?: IIconType | ReactElement;
18
+ disabled?: boolean;
19
+ shouldDrawSpacerAbove?: boolean;
20
+ shouldDrawSpacerBelow?: boolean;
21
+ withIconGap?: boolean;
22
+ testId?: string;
23
+ onClick(): void;
24
+ }
25
+
26
+ export interface IListProps extends ICommonProps {
27
+ tweakStyles?: ListStyles;
28
+ items: IListItem[];
29
+ testId?: string;
30
+ onClick?(): void;
31
+ }
32
+
33
+ export const List: FC<IListProps> = ({
34
+ items,
35
+ testId,
36
+ data,
37
+ tweakStyles,
38
+ onClick,
39
+ }) => {
40
+ const { classes } = useTheme('List', styles, tweakStyles);
41
+
42
+ const handleItemClick = (item: IListItem) => {
43
+ item.onClick();
44
+ onClick?.();
45
+ };
46
+
47
+ return (
48
+ <div
49
+ className={classes.root}
50
+ {...addDataTestId(testId)}
51
+ {...addDataAttributes(data)}
52
+ >
53
+ {items.map((item, idx) => (
54
+ <Fragment key={idx}>
55
+ {item.shouldDrawSpacerAbove && <div className={classes.spacer} />}
56
+ <div
57
+ className={clsx(classes.item, {
58
+ [classes.disabledItem]: item.disabled,
59
+ [classes.withIconGap]: item.withIconGap,
60
+ })}
61
+ {...addDataTestId(item.testId ?? getTestId(testId, `item-${idx}`))}
62
+ {...(item.disabled &&
63
+ addDataAttributes({ disabled: item.disabled }))}
64
+ onClick={item.disabled ? undefined : () => handleItemClick(item)}
65
+ >
66
+ {isNotEmpty(item.icon) && (
67
+ <span className={classes.icon}>
68
+ {typeof item.icon === 'string' ? (
69
+ <Icon type={item.icon} />
70
+ ) : (
71
+ item.icon
72
+ )}
73
+ </span>
74
+ )}
75
+ <span className={classes.content}>{item.item}</span>
76
+ </div>
77
+ {item.shouldDrawSpacerBelow && <div className={classes.spacer} />}
78
+ </Fragment>
79
+ ))}
80
+ </div>
81
+ );
82
+ };
@@ -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,113 +1,113 @@
1
- import { ComponentStory } from '@storybook/react';
2
- import { FC, useState } from 'react';
3
- import { IModalProps, Modal } from './Modal';
4
- import { Button } from '../Button';
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> = ({
18
- size,
19
- textSize,
20
- ...args
21
- }) => {
22
- const [isModalOpen, setIsModalOpen] = useState(false);
23
- const [isSecondModalOpen, setIsSecondModalOpen] = useState(false);
24
-
25
- return (
26
- <div>
27
- <Button onClick={() => setIsModalOpen(true)}>Open</Button>
28
- <Button onClick={() => setIsSecondModalOpen(true)}>Open 2</Button>
29
-
30
- <Modal
31
- {...args}
32
- isOpen={isModalOpen}
33
- onClose={() => setIsModalOpen(false)}
34
- buttons={[
35
- <Button
36
- key="1"
37
- view="secondary"
38
- onClick={() => setIsModalOpen(false)}
39
- size={size === 's' ? 'm' : 'l'}
40
- >
41
- Отмена
42
- </Button>,
43
- <Button
44
- key="2"
45
- size={size === 's' ? 'm' : 'l'}
46
- onClick={() => {
47
- setIsModalOpen(false);
48
- setIsSecondModalOpen(true);
49
- }}
50
- >
51
- Применить
52
- </Button>,
53
- ]}
54
- >
55
- <div style={{ lineHeight: 1.6 }}>{texts[textSize]}</div>
56
- </Modal>
57
-
58
- <Modal
59
- {...args}
60
- isOpen={isSecondModalOpen}
61
- onClose={() => setIsSecondModalOpen(false)}
62
- >
63
- Text
64
- </Modal>
65
- </div>
66
- );
67
- };
68
-
69
- export default {
70
- title: 'Modal',
71
- component: Modal,
72
- argTypes: {
73
- buttonsAlign: {
74
- control: 'inline-radio',
75
- options: ['left', 'center', 'right'],
76
- },
77
- textSize: {
78
- control: 'inline-radio',
79
- options: ['small', 'medium', 'large'],
80
- },
81
- size: { control: 'inline-radio', options: ['s', 'm', 'l'] },
82
- position: {
83
- control: 'inline-radio',
84
- options: ['center', 'left', 'right', 'static'],
85
- },
86
- },
87
- };
88
-
89
- const Template: ComponentStory<typeof ModalWithCustomProps> = (args) => (
90
- <div
91
- style={{
92
- border: '1px dotted rgba(0,0,0,.2)',
93
- height: 1000, // чтобы был скролл на странице
94
- }}
95
- >
96
- <ModalWithCustomProps {...args} />
97
- </div>
98
- );
99
-
100
- export const Default = Template.bind({});
101
-
102
- Default.args = {
103
- title: 'Some modal title',
104
- size: 'm',
105
- textSize: 'small',
106
- buttonsAlign: 'right',
107
- shouldCloseOnEsc: true,
108
- hasOverlay: true,
109
- hasCloseButton: true,
110
- shouldCloseOnOverlayClick: true,
111
- shouldBlockScroll: true,
112
- isFooterSticky: false,
113
- };
1
+ import { ComponentStory } from '@storybook/react';
2
+ import { FC, useState } from 'react';
3
+ import { IModalProps, Modal } from './Modal';
4
+ import { Button } from '../Button';
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> = ({
18
+ size,
19
+ textSize,
20
+ ...args
21
+ }) => {
22
+ const [isModalOpen, setIsModalOpen] = useState(false);
23
+ const [isSecondModalOpen, setIsSecondModalOpen] = useState(false);
24
+
25
+ return (
26
+ <div>
27
+ <Button onClick={() => setIsModalOpen(true)}>Open</Button>
28
+ <Button onClick={() => setIsSecondModalOpen(true)}>Open 2</Button>
29
+
30
+ <Modal
31
+ {...args}
32
+ isOpen={isModalOpen}
33
+ onClose={() => setIsModalOpen(false)}
34
+ buttons={[
35
+ <Button
36
+ key="1"
37
+ view="secondary"
38
+ onClick={() => setIsModalOpen(false)}
39
+ size={size === 's' ? 'm' : 'l'}
40
+ >
41
+ Отмена
42
+ </Button>,
43
+ <Button
44
+ key="2"
45
+ size={size === 's' ? 'm' : 'l'}
46
+ onClick={() => {
47
+ setIsModalOpen(false);
48
+ setIsSecondModalOpen(true);
49
+ }}
50
+ >
51
+ Применить
52
+ </Button>,
53
+ ]}
54
+ >
55
+ <div style={{ lineHeight: 1.6 }}>{texts[textSize]}</div>
56
+ </Modal>
57
+
58
+ <Modal
59
+ {...args}
60
+ isOpen={isSecondModalOpen}
61
+ onClose={() => setIsSecondModalOpen(false)}
62
+ >
63
+ Text
64
+ </Modal>
65
+ </div>
66
+ );
67
+ };
68
+
69
+ export default {
70
+ title: 'Modal',
71
+ component: Modal,
72
+ argTypes: {
73
+ buttonsAlign: {
74
+ control: 'inline-radio',
75
+ options: ['left', 'center', 'right'],
76
+ },
77
+ textSize: {
78
+ control: 'inline-radio',
79
+ options: ['small', 'medium', 'large'],
80
+ },
81
+ size: { control: 'inline-radio', options: ['s', 'm', 'l'] },
82
+ position: {
83
+ control: 'inline-radio',
84
+ options: ['center', 'left', 'right', 'static'],
85
+ },
86
+ },
87
+ };
88
+
89
+ const Template: ComponentStory<typeof ModalWithCustomProps> = (args) => (
90
+ <div
91
+ style={{
92
+ border: '1px dotted rgba(0,0,0,.2)',
93
+ height: 1000, // чтобы был скролл на странице
94
+ }}
95
+ >
96
+ <ModalWithCustomProps {...args} />
97
+ </div>
98
+ );
99
+
100
+ export const Default = Template.bind({});
101
+
102
+ Default.args = {
103
+ title: 'Some modal title',
104
+ size: 'm',
105
+ textSize: 'small',
106
+ buttonsAlign: 'right',
107
+ shouldCloseOnEsc: true,
108
+ hasOverlay: true,
109
+ hasCloseButton: true,
110
+ shouldCloseOnOverlayClick: true,
111
+ shouldBlockScroll: true,
112
+ isFooterSticky: false,
113
+ };