@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,112 +1,112 @@
1
- import { FC, ReactNode } from 'react';
2
- import { IMultiSelectListValues } from '../MultiSelectList';
3
- import { IFilterIntervalProps } from './FilterInterval';
4
- import { IFilterMultiSelectProps } from './FilterMultiSelect';
5
- import { IFilterSelectProps } from './FilterSelect';
6
- import { IFilterWithDatesProps } from './FilterWithDates';
7
- import { IFilterWithPeriodProps } from './FilterWithPeriod';
8
- import { IFilterLocaleKey, IPartialFilterLocale } from './locales';
9
-
10
- export const PERIODS = ['THIS_MONTH', 'LAST_MONTH', 'THIS_YEAR', 'LAST_YEAR', 'CUSTOM'] as const;
11
-
12
- export type IPeriodType = (typeof PERIODS)[number];
13
-
14
- export type IFilterMultiSelectValues<Option = string> = IMultiSelectListValues<Option>;
15
-
16
- export type IPeriodsList = Array<IPeriodType | [string, IPeriodGetter]>;
17
-
18
- export interface IFiltersPaneSearchPayload<Value> {
19
- value?: string;
20
- field?: Value;
21
- }
22
-
23
- export interface IFilterValueViewProps<Value> {
24
- value?: Value;
25
- filter: ConfigItem<Value>;
26
- }
27
-
28
- export interface IDatePeriod {
29
- from: Date | null;
30
- to: Date | null;
31
- }
32
-
33
- export interface IPeriod extends IDatePeriod {
34
- periodType: string;
35
- label?: string;
36
- }
37
-
38
- export type IPeriodGetter = () => IDatePeriod;
39
-
40
- export type IFilterWithDatesValue = IDatePeriod;
41
-
42
- export type MultiSelectOptionType<Value> = Value | undefined extends
43
- | IFilterMultiSelectValues<infer Option>
44
- | undefined
45
- ? Option
46
- : unknown;
47
-
48
- export interface IConfigItemBasicBase<Value> {
49
- name: string;
50
- isInline?: boolean;
51
- requiredFilledFilters?: string[];
52
- localeKey?: IFilterLocaleKey;
53
- locale?: IPartialFilterLocale;
54
- getSelectedValueView?: (v: Value) => ReactNode;
55
- }
56
-
57
- export type IIntervalConfigItem<Value> = IConfigItemBasicBase<Value> & {
58
- type: 'interval';
59
- } & Omit<IFilterIntervalProps, 'value' | 'onChange' | 'labelName'>;
60
-
61
- export interface IBooleanConfigItem<Value> extends IConfigItemBasicBase<Value> {
62
- type: 'boolean';
63
- }
64
-
65
- export type IMultiSelectConfigItem<Value> = IConfigItemBasicBase<Value> & {
66
- type: 'multiSelect';
67
- } & Omit<IFilterMultiSelectProps<Value, MultiSelectOptionType<Value>>, 'value' | 'onChange'>;
68
-
69
- export type ISelectConfigItem<Value> = IConfigItemBasicBase<Value> & {
70
- type: 'select';
71
- } & Omit<IFilterSelectProps<Value>, 'value' | 'onChange'>;
72
-
73
- // Дата без периодов
74
- export type IDateRangeWithoutPeriodConfigItem<Value> = IConfigItemBasicBase<Value> & {
75
- type: 'dateRangeWithoutPeriod';
76
- dateFormat?: string;
77
- } & Omit<IFilterWithDatesProps, 'value' | 'onChange' | 'onStartBtnSubmit' | 'onEndBtnSubmit'>;
78
-
79
- // Дата С ПЕРИОДАМИ
80
- export type IDateRangeConfigItem<Value> = IConfigItemBasicBase<Value> & {
81
- type: 'dateRange';
82
- dateFormat?: string;
83
- } & Omit<IFilterWithPeriodProps, 'value' | 'onChange' | 'setIsOpen'>;
84
-
85
- export type CustomComponent<Value> = FC<{
86
- value?: Value;
87
- onChange: (v?: Value) => void;
88
- onClose?: () => void;
89
- filter: ICustomConfigItem<Value>;
90
- localeKey?: IFilterLocaleKey;
91
- locale?: IPartialFilterLocale;
92
- }>;
93
-
94
- export interface ICustomConfigItem<Value> extends IConfigItemBasicBase<Value> {
95
- [key: string]: any;
96
- type: 'custom';
97
- component: CustomComponent<Value>;
98
- valueViewType?: 'range' | 'multiple';
99
- }
100
-
101
- export type ConfigItem<Value> =
102
- | ISelectConfigItem<Value>
103
- | IMultiSelectConfigItem<Value>
104
- | ICustomConfigItem<Value>
105
- | IDateRangeWithoutPeriodConfigItem<Value>
106
- | IDateRangeConfigItem<Value>
107
- | IIntervalConfigItem<Value>
108
- | IBooleanConfigItem<Value>;
109
-
110
- export type ConfigType<Values> = {
111
- [K in keyof Values]: ConfigItem<Values[K]>;
112
- };
1
+ import { FC, ReactNode } from 'react';
2
+ import { IMultiSelectListValues } from '../MultiSelectList';
3
+ import { IFilterIntervalProps } from './FilterInterval';
4
+ import { IFilterMultiSelectProps } from './FilterMultiSelect';
5
+ import { IFilterSelectProps } from './FilterSelect';
6
+ import { IFilterWithDatesProps } from './FilterWithDates';
7
+ import { IFilterWithPeriodProps } from './FilterWithPeriod';
8
+ import { IFilterLocaleKey, IPartialFilterLocale } from './locales';
9
+
10
+ export const PERIODS = ['THIS_MONTH', 'LAST_MONTH', 'THIS_YEAR', 'LAST_YEAR', 'CUSTOM'] as const;
11
+
12
+ export type IPeriodType = (typeof PERIODS)[number];
13
+
14
+ export type IFilterMultiSelectValues<Option = string> = IMultiSelectListValues<Option>;
15
+
16
+ export type IPeriodsList = Array<IPeriodType | [string, IPeriodGetter]>;
17
+
18
+ export interface IFiltersPaneSearchPayload<Value> {
19
+ value?: string;
20
+ field?: Value;
21
+ }
22
+
23
+ export interface IFilterValueViewProps<Value> {
24
+ value?: Value;
25
+ filter: ConfigItem<Value>;
26
+ }
27
+
28
+ export interface IDatePeriod {
29
+ from: Date | null;
30
+ to: Date | null;
31
+ }
32
+
33
+ export interface IPeriod extends IDatePeriod {
34
+ periodType: string;
35
+ label?: string;
36
+ }
37
+
38
+ export type IPeriodGetter = () => IDatePeriod;
39
+
40
+ export type IFilterWithDatesValue = IDatePeriod;
41
+
42
+ export type MultiSelectOptionType<Value> = Value | undefined extends
43
+ | IFilterMultiSelectValues<infer Option>
44
+ | undefined
45
+ ? Option
46
+ : unknown;
47
+
48
+ export interface IConfigItemBasicBase<Value> {
49
+ name: string;
50
+ isInline?: boolean;
51
+ requiredFilledFilters?: string[];
52
+ localeKey?: IFilterLocaleKey;
53
+ locale?: IPartialFilterLocale;
54
+ getSelectedValueView?: (v: Value) => ReactNode;
55
+ }
56
+
57
+ export type IIntervalConfigItem<Value> = IConfigItemBasicBase<Value> & {
58
+ type: 'interval';
59
+ } & Omit<IFilterIntervalProps, 'value' | 'onChange' | 'labelName'>;
60
+
61
+ export interface IBooleanConfigItem<Value> extends IConfigItemBasicBase<Value> {
62
+ type: 'boolean';
63
+ }
64
+
65
+ export type IMultiSelectConfigItem<Value> = IConfigItemBasicBase<Value> & {
66
+ type: 'multiSelect';
67
+ } & Omit<IFilterMultiSelectProps<Value, MultiSelectOptionType<Value>>, 'value' | 'onChange'>;
68
+
69
+ export type ISelectConfigItem<Value> = IConfigItemBasicBase<Value> & {
70
+ type: 'select';
71
+ } & Omit<IFilterSelectProps<Value>, 'value' | 'onChange'>;
72
+
73
+ // Дата без периодов
74
+ export type IDateRangeWithoutPeriodConfigItem<Value> = IConfigItemBasicBase<Value> & {
75
+ type: 'dateRangeWithoutPeriod';
76
+ dateFormat?: string;
77
+ } & Omit<IFilterWithDatesProps, 'value' | 'onChange' | 'onStartBtnSubmit' | 'onEndBtnSubmit'>;
78
+
79
+ // Дата С ПЕРИОДАМИ
80
+ export type IDateRangeConfigItem<Value> = IConfigItemBasicBase<Value> & {
81
+ type: 'dateRange';
82
+ dateFormat?: string;
83
+ } & Omit<IFilterWithPeriodProps, 'value' | 'onChange' | 'setIsOpen'>;
84
+
85
+ export type CustomComponent<Value> = FC<{
86
+ value?: Value;
87
+ onChange: (v?: Value) => void;
88
+ onClose?: () => void;
89
+ filter: ICustomConfigItem<Value>;
90
+ localeKey?: IFilterLocaleKey;
91
+ locale?: IPartialFilterLocale;
92
+ }>;
93
+
94
+ export interface ICustomConfigItem<Value> extends IConfigItemBasicBase<Value> {
95
+ [key: string]: any;
96
+ type: 'custom';
97
+ component: CustomComponent<Value>;
98
+ valueViewType?: 'range' | 'multiple';
99
+ }
100
+
101
+ export type ConfigItem<Value> =
102
+ | ISelectConfigItem<Value>
103
+ | IMultiSelectConfigItem<Value>
104
+ | ICustomConfigItem<Value>
105
+ | IDateRangeWithoutPeriodConfigItem<Value>
106
+ | IDateRangeConfigItem<Value>
107
+ | IIntervalConfigItem<Value>
108
+ | IBooleanConfigItem<Value>;
109
+
110
+ export type ConfigType<Values> = {
111
+ [K in keyof Values]: ConfigItem<Values[K]>;
112
+ };
@@ -1,29 +1,29 @@
1
- import { countries } from 'country-flag-icons';
2
- import { ComponentStory } from '@storybook/react';
3
- import { Flag } from './Flag';
4
-
5
- export default {
6
- title: 'Flag',
7
- component: Flag,
8
- argTypes: {
9
- countryCode: { control: 'select', options: countries },
10
- },
11
- };
12
-
13
- const Template: ComponentStory<typeof Flag> = (args) => (
14
- <div style={{ width: 60, height: 40 }}>
15
- <Flag {...args} />
16
- </div>
17
- );
18
-
19
- export const Default = Template.bind({});
20
-
21
- Default.args = {
22
- countryCode: 'ug',
23
- };
24
-
25
- Default.parameters = {
26
- controls: {
27
- exclude: ['data'],
28
- },
29
- };
1
+ import { countries } from 'country-flag-icons';
2
+ import { ComponentStory } from '@storybook/react';
3
+ import { Flag } from './Flag';
4
+
5
+ export default {
6
+ title: 'Flag',
7
+ component: Flag,
8
+ argTypes: {
9
+ countryCode: { control: 'select', options: countries },
10
+ },
11
+ };
12
+
13
+ const Template: ComponentStory<typeof Flag> = (args) => (
14
+ <div style={{ width: 60, height: 40 }}>
15
+ <Flag {...args} />
16
+ </div>
17
+ );
18
+
19
+ export const Default = Template.bind({});
20
+
21
+ Default.args = {
22
+ countryCode: 'ug',
23
+ };
24
+
25
+ Default.parameters = {
26
+ controls: {
27
+ exclude: ['data'],
28
+ },
29
+ };
@@ -1,18 +1,18 @@
1
- import { colors } from '../../theme';
2
- import { ComponentStyles } from '../../types';
3
-
4
- export const styles = {
5
- root: {
6
- // приходится хардкодить в компоненте, тк либа Flags выдает флаги с 2-3 пиксельным отступом снизу
7
- // если будет нужно, то можно вынести border на уровень пропсов
8
- border: [1, 'solid', colors.BORDER_MAIN],
9
- borderRadius: 2,
10
- },
11
-
12
- noFlag: {
13
- width: 20,
14
- color: colors.FONT_MEDIUM,
15
- },
16
- };
17
-
18
- export type FlagStyles = ComponentStyles<typeof styles>;
1
+ import { colors } from '../../theme';
2
+ import { ComponentStyles } from '../../types';
3
+
4
+ export const styles = {
5
+ root: {
6
+ // приходится хардкодить в компоненте, тк либа Flags выдает флаги с 2-3 пиксельным отступом снизу
7
+ // если будет нужно, то можно вынести border на уровень пропсов
8
+ border: [1, 'solid', colors.BORDER_MAIN],
9
+ borderRadius: 2,
10
+ },
11
+
12
+ noFlag: {
13
+ width: 20,
14
+ color: colors.FONT_MEDIUM,
15
+ },
16
+ };
17
+
18
+ export type FlagStyles = ComponentStyles<typeof styles>;
@@ -1,27 +1,27 @@
1
- import { FC } from 'react';
2
- import { hasFlag } from 'country-flag-icons';
3
- import Flags from 'country-flag-icons/react/3x2';
4
- import { useTheme } from '../../hooks';
5
- import { ICommonProps } from '../../types';
6
- import { Icon } from '../Icon';
7
- import { FlagStyles, styles } from './Flag.styles';
8
-
9
- export interface IFlagProps extends ICommonProps {
10
- tweakStyles?: FlagStyles;
11
- countryCode?: string;
12
- }
13
-
14
- export const Flag: FC<IFlagProps> = ({ countryCode = '', tweakStyles }) => {
15
- const { classes } = useTheme('Flag', styles, tweakStyles);
16
- const CC = countryCode.toUpperCase();
17
-
18
- const TheFlag = hasFlag(CC)
19
- ? Flags[CC as keyof typeof Flags]
20
- : () => (
21
- <div className={classes.noFlag}>
22
- <Icon type="minus" />
23
- </div>
24
- );
25
-
26
- return <TheFlag className={classes.root} />;
27
- };
1
+ import { FC } from 'react';
2
+ import { hasFlag } from 'country-flag-icons';
3
+ import Flags from 'country-flag-icons/react/3x2';
4
+ import { useTheme } from '../../hooks';
5
+ import { ICommonProps } from '../../types';
6
+ import { Icon } from '../Icon';
7
+ import { FlagStyles, styles } from './Flag.styles';
8
+
9
+ export interface IFlagProps extends ICommonProps {
10
+ tweakStyles?: FlagStyles;
11
+ countryCode?: string;
12
+ }
13
+
14
+ export const Flag: FC<IFlagProps> = ({ countryCode = '', tweakStyles }) => {
15
+ const { classes } = useTheme('Flag', styles, tweakStyles);
16
+ const CC = countryCode.toUpperCase();
17
+
18
+ const TheFlag = hasFlag(CC)
19
+ ? Flags[CC as keyof typeof Flags]
20
+ : () => (
21
+ <div className={classes.noFlag}>
22
+ <Icon type="minus" />
23
+ </div>
24
+ );
25
+
26
+ return <TheFlag className={classes.root} />;
27
+ };
@@ -1 +1 @@
1
- declare module 'country-flag-icons/react/3x2';
1
+ declare module 'country-flag-icons/react/3x2';
@@ -1,2 +1,2 @@
1
- export * from './Flag';
2
- export type { FlagStyles } from './Flag.styles';
1
+ export * from './Flag';
2
+ export type { FlagStyles } from './Flag.styles';
@@ -1,84 +1,84 @@
1
- import { FC } from 'react';
2
- import { ComponentStory } from '@storybook/react';
3
- import { FlexibleTable } from './FlexibleTable';
4
- import content from './fixture-test';
5
- import { FlexibleTableConfigType } from './types';
6
-
7
- export default {
8
- title: 'Table/FlexibleTable',
9
- component: FlexibleTable,
10
- };
11
-
12
- interface ITableContent {
13
- contractCode: string;
14
- validFrom: Date;
15
- validTo: Date;
16
- title: string;
17
- signDate: Date;
18
- partner: string;
19
- partnerDescription: string;
20
- parentContract: string;
21
- currency: string;
22
- status: string;
23
- }
24
-
25
- const Temp: FC<{ value: string | undefined }> = ({ value }) => <>{value}</>;
26
- const Temp1: FC<{ value: string }> = ({ value }) => <>{value}</>;
27
-
28
- const config: FlexibleTableConfigType<ITableContent> = {
29
- contractCode: {
30
- title: 'Contract Code',
31
- },
32
- title: {
33
- component: Temp,
34
- title: 'Title',
35
- minWidth: 320,
36
- },
37
- validFrom: {
38
- title: 'Valid From',
39
- },
40
- validTo: {
41
- title: 'Valid From',
42
- },
43
- signDate: {
44
- title: 'Sign Date',
45
- },
46
- partner: {
47
- component: Temp1,
48
- title: 'Partner',
49
- },
50
- };
51
-
52
- const Template: ComponentStory<typeof FlexibleTable<ITableContent>> = (args) => (
53
- <FlexibleTable<ITableContent>
54
- {...args}
55
- uniqueField="contractCode"
56
- expandableRowComponent={(item, _, close) =>
57
- item.contractCode === 'OB_UT_M119' ? (
58
- <div onClick={close}>всем привет :) {item.contractCode}</div>
59
- ) : null
60
- }
61
- content={content}
62
- config={config}
63
- />
64
- );
65
-
66
- export const Default = Template.bind({});
67
-
68
- Default.args = {
69
- isHorizontallyScrollable: true,
70
- isFirstColumnSticky: true,
71
- };
72
-
73
- Default.parameters = {
74
- controls: {
75
- exclude: [
76
- 'data',
77
- 'testId',
78
- 'onHeadClick',
79
- 'onRowClick',
80
- 'onRowHover',
81
- 'expandableRowComponent',
82
- ],
83
- },
84
- };
1
+ import { FC } from 'react';
2
+ import { ComponentStory } from '@storybook/react';
3
+ import { FlexibleTable } from './FlexibleTable';
4
+ import content from './fixture-test';
5
+ import { FlexibleTableConfigType } from './types';
6
+
7
+ export default {
8
+ title: 'Table/FlexibleTable',
9
+ component: FlexibleTable,
10
+ };
11
+
12
+ interface ITableContent {
13
+ contractCode: string;
14
+ validFrom: Date;
15
+ validTo: Date;
16
+ title: string;
17
+ signDate: Date;
18
+ partner: string;
19
+ partnerDescription: string;
20
+ parentContract: string;
21
+ currency: string;
22
+ status: string;
23
+ }
24
+
25
+ const Temp: FC<{ value: string | undefined }> = ({ value }) => <>{value}</>;
26
+ const Temp1: FC<{ value: string }> = ({ value }) => <>{value}</>;
27
+
28
+ const config: FlexibleTableConfigType<ITableContent> = {
29
+ contractCode: {
30
+ title: 'Contract Code',
31
+ },
32
+ title: {
33
+ component: Temp,
34
+ title: 'Title',
35
+ minWidth: 320,
36
+ },
37
+ validFrom: {
38
+ title: 'Valid From',
39
+ },
40
+ validTo: {
41
+ title: 'Valid From',
42
+ },
43
+ signDate: {
44
+ title: 'Sign Date',
45
+ },
46
+ partner: {
47
+ component: Temp1,
48
+ title: 'Partner',
49
+ },
50
+ };
51
+
52
+ const Template: ComponentStory<typeof FlexibleTable<ITableContent>> = (args) => (
53
+ <FlexibleTable<ITableContent>
54
+ {...args}
55
+ uniqueField="contractCode"
56
+ expandableRowComponent={(item, _, close) =>
57
+ item.contractCode === 'OB_UT_M119' ? (
58
+ <div onClick={close}>всем привет :) {item.contractCode}</div>
59
+ ) : null
60
+ }
61
+ content={content}
62
+ config={config}
63
+ />
64
+ );
65
+
66
+ export const Default = Template.bind({});
67
+
68
+ Default.args = {
69
+ isHorizontallyScrollable: true,
70
+ isFirstColumnSticky: true,
71
+ };
72
+
73
+ Default.parameters = {
74
+ controls: {
75
+ exclude: [
76
+ 'data',
77
+ 'testId',
78
+ 'onHeadClick',
79
+ 'onRowClick',
80
+ 'onRowHover',
81
+ 'expandableRowComponent',
82
+ ],
83
+ },
84
+ };