@addev-be/ui 2.4.0 → 2.4.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 (250) hide show
  1. package/assets/icons/arrow-down-1-9.svg +1 -1
  2. package/assets/icons/arrow-down-a-z.svg +1 -1
  3. package/assets/icons/arrow-up-z-a.svg +1 -1
  4. package/assets/icons/check.svg +1 -1
  5. package/assets/icons/circle-check.svg +1 -1
  6. package/assets/icons/down.svg +1 -1
  7. package/assets/icons/filter-full.svg +1 -1
  8. package/assets/icons/filter.svg +1 -1
  9. package/assets/icons/hashtag.svg +1 -1
  10. package/assets/icons/image-slash.svg +1 -1
  11. package/assets/icons/left.svg +1 -1
  12. package/assets/icons/magnifier.svg +1 -1
  13. package/assets/icons/phone.svg +1 -1
  14. package/assets/icons/right.svg +1 -1
  15. package/assets/icons/sort-calendar-ascending.svg +5 -5
  16. package/assets/icons/spinner-third.svg +1 -1
  17. package/assets/icons/table-columns.svg +1 -1
  18. package/assets/icons/table-footer-slash.svg +4 -4
  19. package/assets/icons/table-footer.svg +3 -3
  20. package/assets/icons/table.svg +1 -1
  21. package/assets/icons/up.svg +1 -1
  22. package/assets/icons/user-tie.svg +1 -1
  23. package/assets/icons/x-bar.svg +3 -3
  24. package/dist/components/data/DataGrid/hooks/useDataGrid.js +3 -0
  25. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.d.ts +1 -2
  26. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.js +3 -2
  27. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +3 -1
  28. package/dist/services/index.js +7 -17
  29. package/eslint.config.js +3 -3
  30. package/package.json +2 -2
  31. package/src/Icons.tsx +138 -138
  32. package/src/components/auth/LoginForm.tsx +86 -86
  33. package/src/components/auth/LoginPage.tsx +32 -32
  34. package/src/components/auth/PasswordRecoveryForm.tsx +53 -53
  35. package/src/components/auth/PasswordResetForm.tsx +112 -112
  36. package/src/components/auth/styles.ts +14 -14
  37. package/src/components/data/DataGrid/DataGridCell.tsx +81 -81
  38. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +9 -9
  39. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  40. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +182 -182
  41. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  42. package/src/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.tsx +37 -37
  43. package/src/components/data/DataGrid/DataGridEditableCell/DateEditableCell.tsx +38 -38
  44. package/src/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.tsx +71 -71
  45. package/src/components/data/DataGrid/DataGridEditableCell/TextEditableCell.tsx +37 -37
  46. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +106 -106
  47. package/src/components/data/DataGrid/DataGridEditableCell/styles.ts +35 -35
  48. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +18 -18
  49. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +129 -129
  50. package/src/components/data/DataGrid/DataGridFilterMenu/helpers.ts +23 -23
  51. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +81 -81
  52. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +370 -370
  53. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  54. package/src/components/data/DataGrid/DataGridFooter.tsx +45 -45
  55. package/src/components/data/DataGrid/DataGridHeader.tsx +74 -74
  56. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +112 -112
  57. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +83 -83
  58. package/src/components/data/DataGrid/DataGridToolbar.tsx +134 -134
  59. package/src/components/data/DataGrid/FilterModalContent/index.tsx +137 -137
  60. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  61. package/src/components/data/DataGrid/constants.ts +6 -6
  62. package/src/components/data/DataGrid/helpers/columns.tsx +452 -452
  63. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  64. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  65. package/src/components/data/DataGrid/hooks/index.ts +29 -29
  66. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +383 -380
  67. package/src/components/data/DataGrid/hooks/useDataGridChangedRows.ts +97 -97
  68. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +174 -174
  69. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  70. package/src/components/data/DataGrid/hooks/useRefreshModal.tsx +48 -48
  71. package/src/components/data/DataGrid/index.tsx +111 -111
  72. package/src/components/data/DataGrid/styles.ts +430 -430
  73. package/src/components/data/DataGrid/types.ts +380 -380
  74. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +526 -524
  75. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  76. package/src/components/data/SqlRequestDataGrid/helpers/rows.ts +24 -24
  77. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  78. package/src/components/data/SqlRequestDataGrid/index.tsx +417 -417
  79. package/src/components/data/SqlRequestDataGrid/styles.ts +15 -15
  80. package/src/components/data/SqlRequestDataGrid/types.ts +74 -74
  81. package/src/components/data/SqlRequestForeignList/index.tsx +254 -254
  82. package/src/components/data/SqlRequestForeignList/styles.ts +43 -43
  83. package/src/components/data/SqlRequestForeignList/types.ts +32 -32
  84. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +108 -108
  85. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  86. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  87. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  88. package/src/components/data/SqlRequestGrid/index.tsx +304 -304
  89. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  90. package/src/components/data/SqlRequestGrid/types.ts +73 -73
  91. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  92. package/src/components/data/VirtualScroller/index.tsx +89 -89
  93. package/src/components/data/VirtualScroller/styles.ts +57 -57
  94. package/src/components/data/VirtualScroller/types.ts +10 -10
  95. package/src/components/forms/AutoTextArea.tsx +48 -48
  96. package/src/components/forms/Button.tsx +132 -132
  97. package/src/components/forms/Form/Checkbox.tsx +12 -12
  98. package/src/components/forms/Form/CustomSelect.tsx +86 -86
  99. package/src/components/forms/Form/FormGroup.tsx +31 -31
  100. package/src/components/forms/Form/Input.tsx +16 -16
  101. package/src/components/forms/Form/Row.tsx +32 -32
  102. package/src/components/forms/Form/Select.tsx +82 -82
  103. package/src/components/forms/Form/TextArea.tsx +17 -17
  104. package/src/components/forms/Form/index.tsx +48 -48
  105. package/src/components/forms/Form/styles.ts +184 -184
  106. package/src/components/forms/IconButton.tsx +61 -61
  107. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  108. package/src/components/forms/NumberInput.tsx +53 -53
  109. package/src/components/forms/Select.tsx +34 -34
  110. package/src/components/forms/VerticalLabel.tsx +20 -20
  111. package/src/components/forms/styles.ts +42 -42
  112. package/src/components/layout/Columns.ts +28 -28
  113. package/src/components/layout/Dropdown/index.tsx +113 -113
  114. package/src/components/layout/Dropdown/styles.ts +53 -53
  115. package/src/components/layout/Flexbox.ts +21 -21
  116. package/src/components/layout/Grid/index.tsx +8 -8
  117. package/src/components/layout/Grid/styles.ts +34 -34
  118. package/src/components/layout/Loading/index.tsx +29 -29
  119. package/src/components/layout/Loading/styles.ts +29 -29
  120. package/src/components/layout/Masonry/index.tsx +29 -29
  121. package/src/components/layout/Masonry/styles.ts +20 -20
  122. package/src/components/layout/Modal/index.tsx +51 -51
  123. package/src/components/layout/Modal/styles.ts +125 -125
  124. package/src/components/search/HighlightedText.tsx +41 -41
  125. package/src/components/search/QuickSearchBar.tsx +99 -99
  126. package/src/components/search/QuickSearchResults.tsx +86 -86
  127. package/src/components/search/styles.ts +96 -96
  128. package/src/components/search/types.ts +29 -29
  129. package/src/components/ui/Avatar/index.tsx +54 -54
  130. package/src/components/ui/Avatar/styles.ts +61 -61
  131. package/src/components/ui/Card/index.tsx +14 -14
  132. package/src/components/ui/Card/styles.ts +37 -37
  133. package/src/components/ui/ContextMenu/index.tsx +79 -79
  134. package/src/components/ui/ContextMenu/styles.ts +119 -119
  135. package/src/components/ui/Ellipsis.tsx +33 -33
  136. package/src/components/ui/Label.tsx +93 -93
  137. package/src/components/ui/Message/index.tsx +57 -57
  138. package/src/components/ui/Message/styles.ts +44 -44
  139. package/src/components/ui/TabsView/TabsList.tsx +44 -44
  140. package/src/components/ui/TabsView/TabsView.tsx +38 -38
  141. package/src/components/ui/TabsView/index.ts +3 -3
  142. package/src/components/ui/TabsView/styles.ts +76 -76
  143. package/src/components/ui/TabsView/types.ts +15 -15
  144. package/src/config/index.ts +10 -10
  145. package/src/helpers/components.ts +9 -9
  146. package/src/helpers/dates.ts +17 -17
  147. package/src/helpers/getScrollbarSize.ts +14 -14
  148. package/src/helpers/numbers.ts +63 -63
  149. package/src/helpers/responsive.ts +83 -83
  150. package/src/helpers/styled/space.ts +114 -114
  151. package/src/helpers/styled/typography.ts +25 -25
  152. package/src/helpers/text.ts +13 -13
  153. package/src/helpers/types.ts +9 -9
  154. package/src/hooks/useContainerMediaQuery.ts +7 -7
  155. package/src/hooks/useElementSize.ts +24 -24
  156. package/src/hooks/useMediaQuery.ts +9 -9
  157. package/src/hooks/useMediaQueryForWidth.ts +35 -35
  158. package/src/hooks/useMutableState.ts +25 -25
  159. package/src/hooks/useShowArchived.ts +28 -28
  160. package/src/hooks/useWindowSize.ts +20 -20
  161. package/src/index.ts +102 -102
  162. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  163. package/src/providers/AuthenticationProvider/index.tsx +303 -303
  164. package/src/providers/LoadingProvider/index.tsx +47 -47
  165. package/src/providers/PortalsProvider/index.tsx +54 -54
  166. package/src/providers/PortalsProvider/styles.ts +31 -31
  167. package/src/providers/SettingsProvider/index.tsx +70 -70
  168. package/src/providers/ThemeProvider/defaultTheme.ts +470 -470
  169. package/src/providers/ThemeProvider/helpers.ts +84 -84
  170. package/src/providers/ThemeProvider/index.ts +66 -66
  171. package/src/providers/ThemeProvider/types.ts +134 -134
  172. package/src/providers/ToastProvider/index.tsx +93 -93
  173. package/src/providers/TrackingProvider/hooks.ts +14 -14
  174. package/src/providers/TrackingProvider/index.tsx +71 -71
  175. package/src/providers/UiProviders/index.tsx +76 -76
  176. package/src/providers/UiProviders/styles.ts +10 -10
  177. package/src/providers/hooks.ts +14 -14
  178. package/src/services/HttpService.ts +92 -92
  179. package/src/services/WebSocketService.ts +155 -155
  180. package/src/services/advancedRequests.ts +102 -102
  181. package/src/services/base.ts +23 -23
  182. package/src/services/globalSearch.ts +32 -32
  183. package/src/services/hooks.ts +92 -92
  184. package/src/services/requests/auth.ts +44 -44
  185. package/src/services/requests/generic.ts +62 -62
  186. package/src/services/requests/tracking.ts +12 -12
  187. package/src/services/requests/userProfiles.ts +35 -35
  188. package/src/services/requests/users.ts +28 -28
  189. package/src/services/smartQueries.ts +122 -122
  190. package/src/services/sqlRequests.ts +111 -111
  191. package/src/services/types/auth.ts +98 -98
  192. package/src/services/types/base.ts +10 -10
  193. package/src/services/types/generic.ts +82 -82
  194. package/src/services/types/tracking.ts +29 -29
  195. package/src/services/types/userProfiles.ts +79 -79
  196. package/src/services/types/users.ts +74 -74
  197. package/src/services/updateSqlRequests.ts +32 -32
  198. package/src/styles/animations.scss +30 -30
  199. package/src/styles/index.scss +42 -42
  200. package/src/types.ts +8 -8
  201. package/src/typings.d.ts +2 -2
  202. package/tsconfig.json +18 -18
  203. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.d.ts +0 -14
  204. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +0 -77
  205. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.d.ts +0 -22
  206. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +0 -105
  207. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.d.ts +0 -2
  208. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.js +0 -18
  209. package/dist/components/data/AdvancedRequestDataGrid/index.d.ts +0 -2
  210. package/dist/components/data/AdvancedRequestDataGrid/index.js +0 -215
  211. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +0 -21
  212. package/dist/components/data/AdvancedRequestDataGrid/types.js +0 -2
  213. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +0 -10
  214. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +0 -173
  215. package/dist/components/data/DataGrid/DataGridEditableCell.d.ts +0 -2
  216. package/dist/components/data/DataGrid/DataGridEditableCell.js +0 -27
  217. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +0 -13
  218. package/dist/components/data/DataGrid/FilterValuesScroller.js +0 -73
  219. package/dist/components/data/DataGrid/VirtualScroller.d.ts +0 -11
  220. package/dist/components/data/DataGrid/VirtualScroller.js +0 -41
  221. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +0 -12
  222. package/dist/components/data/DataGrid/helpers/advancedRequests.js +0 -53
  223. package/dist/components/data/DataGrid/helpers.d.ts +0 -28
  224. package/dist/components/data/DataGrid/helpers.js +0 -436
  225. package/dist/components/data/SmartQueryDataGrid/helpers/columns.d.ts +0 -20
  226. package/dist/components/data/SmartQueryDataGrid/helpers/columns.js +0 -160
  227. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.d.ts +0 -5
  228. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.js +0 -41
  229. package/dist/components/data/SmartQueryDataGrid/helpers/index.d.ts +0 -2
  230. package/dist/components/data/SmartQueryDataGrid/helpers/index.js +0 -18
  231. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.d.ts +0 -3
  232. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.js +0 -15
  233. package/dist/components/data/SmartQueryDataGrid/hooks.d.ts +0 -9
  234. package/dist/components/data/SmartQueryDataGrid/hooks.js +0 -63
  235. package/dist/components/data/SmartQueryDataGrid/index.d.ts +0 -12
  236. package/dist/components/data/SmartQueryDataGrid/index.js +0 -242
  237. package/dist/components/data/SmartQueryDataGrid/types.d.ts +0 -22
  238. package/dist/components/data/SmartQueryDataGrid/types.js +0 -2
  239. package/dist/components/forms/Form/InputWithLabel.d.ts +0 -2
  240. package/dist/components/forms/Form/InputWithLabel.js +0 -10
  241. package/dist/components/forms/Form/types.d.ts +0 -7
  242. package/dist/components/forms/Form/types.js +0 -2
  243. package/dist/config/types.d.ts +0 -11
  244. package/dist/config/types.js +0 -2
  245. package/dist/helpers/react.d.ts +0 -2
  246. package/dist/helpers/react.js +0 -8
  247. package/dist/helpers/styled/index.d.ts +0 -1
  248. package/dist/helpers/styled/index.js +0 -17
  249. package/dist/services/requests/userPermissions.d.ts +0 -4
  250. package/dist/services/requests/userPermissions.js +0 -20
@@ -1,81 +1,81 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
-
3
- import * as styles from './styles';
4
-
5
- import { MouseEvent, useCallback, useMemo } from 'react';
6
-
7
- import { DataGridCellProps } from './types';
8
- import { DataGridEditableCell } from './DataGridEditableCell';
9
- import { useDataGridContext } from './hooks';
10
-
11
- const defaultRender = (value: any) => (!value ? '' : String(value));
12
-
13
- export const DataGridCell = <R, T>({
14
- row,
15
- rowIndex,
16
- columnKey,
17
- columnIndex,
18
- column,
19
- context,
20
- style,
21
- }: DataGridCellProps<R, T>) => {
22
- const {
23
- name,
24
- editable,
25
- editingCell = [-1, -1],
26
- setEditingCell,
27
- onRowDoubleClick,
28
- userSelect,
29
- headerColor,
30
- } = useDataGridContext(context);
31
- const isEditable =
32
- !!editable &&
33
- 'editable' in column &&
34
- !!column.editable &&
35
- !!column.editComponent;
36
- const isEditing =
37
- isEditable && editingCell[0] === rowIndex && editingCell[1] === columnIndex;
38
- const DataGridCellComponent = column.component ?? styles.DataGridCell;
39
-
40
- const value = useMemo(() => column.getter(row), [column, row]);
41
-
42
- const onDoubleClick = useCallback(
43
- (e: MouseEvent) => {
44
- e.stopPropagation();
45
- e.preventDefault();
46
- if (isEditable) {
47
- setEditingCell([rowIndex, columnIndex]);
48
- } else onRowDoubleClick?.(row, e);
49
- },
50
- [columnIndex, isEditable, onRowDoubleClick, row, rowIndex, setEditingCell]
51
- );
52
-
53
- if (isEditing) {
54
- return (
55
- <DataGridEditableCell
56
- key={`${name}-${rowIndex}-${columnIndex}`}
57
- row={row}
58
- rowIndex={rowIndex}
59
- columnKey={columnKey}
60
- columnIndex={columnIndex}
61
- column={column as any}
62
- context={context}
63
- userSelect={userSelect}
64
- />
65
- );
66
- }
67
-
68
- return (
69
- <DataGridCellComponent
70
- key={`${name}-${rowIndex}-${columnIndex}`}
71
- onDoubleClick={onDoubleClick}
72
- style={style}
73
- $userSelect={userSelect}
74
- $color={column.color}
75
- $textAlign={column.textAlign}
76
- $headerColor={headerColor}
77
- >
78
- {(column.render ?? defaultRender)(value, row, column)}
79
- </DataGridCellComponent>
80
- );
81
- };
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ import * as styles from './styles';
4
+
5
+ import { MouseEvent, useCallback, useMemo } from 'react';
6
+
7
+ import { DataGridCellProps } from './types';
8
+ import { DataGridEditableCell } from './DataGridEditableCell';
9
+ import { useDataGridContext } from './hooks';
10
+
11
+ const defaultRender = (value: any) => (!value ? '' : String(value));
12
+
13
+ export const DataGridCell = <R, T>({
14
+ row,
15
+ rowIndex,
16
+ columnKey,
17
+ columnIndex,
18
+ column,
19
+ context,
20
+ style,
21
+ }: DataGridCellProps<R, T>) => {
22
+ const {
23
+ name,
24
+ editable,
25
+ editingCell = [-1, -1],
26
+ setEditingCell,
27
+ onRowDoubleClick,
28
+ userSelect,
29
+ headerColor,
30
+ } = useDataGridContext(context);
31
+ const isEditable =
32
+ !!editable &&
33
+ 'editable' in column &&
34
+ !!column.editable &&
35
+ !!column.editComponent;
36
+ const isEditing =
37
+ isEditable && editingCell[0] === rowIndex && editingCell[1] === columnIndex;
38
+ const DataGridCellComponent = column.component ?? styles.DataGridCell;
39
+
40
+ const value = useMemo(() => column.getter(row), [column, row]);
41
+
42
+ const onDoubleClick = useCallback(
43
+ (e: MouseEvent) => {
44
+ e.stopPropagation();
45
+ e.preventDefault();
46
+ if (isEditable) {
47
+ setEditingCell([rowIndex, columnIndex]);
48
+ } else onRowDoubleClick?.(row, e);
49
+ },
50
+ [columnIndex, isEditable, onRowDoubleClick, row, rowIndex, setEditingCell]
51
+ );
52
+
53
+ if (isEditing) {
54
+ return (
55
+ <DataGridEditableCell
56
+ key={`${name}-${rowIndex}-${columnIndex}`}
57
+ row={row}
58
+ rowIndex={rowIndex}
59
+ columnKey={columnKey}
60
+ columnIndex={columnIndex}
61
+ column={column as any}
62
+ context={context}
63
+ userSelect={userSelect}
64
+ />
65
+ );
66
+ }
67
+
68
+ return (
69
+ <DataGridCellComponent
70
+ key={`${name}-${rowIndex}-${columnIndex}`}
71
+ onDoubleClick={onDoubleClick}
72
+ style={style}
73
+ $userSelect={userSelect}
74
+ $color={column.color}
75
+ $textAlign={column.textAlign}
76
+ $headerColor={headerColor}
77
+ >
78
+ {(column.render ?? defaultRender)(value, row, column)}
79
+ </DataGridCellComponent>
80
+ );
81
+ };
@@ -1,9 +1,9 @@
1
- import { DataGridColumns } from '../types';
2
-
3
- export const normalizeColumnsOrders = <R>(
4
- columns: DataGridColumns<R>
5
- ): DataGridColumns<R> =>
6
- columns.map((column, index) => ({
7
- ...column,
8
- order: index,
9
- }));
1
+ import { DataGridColumns } from '../types';
2
+
3
+ export const normalizeColumnsOrders = <R>(
4
+ columns: DataGridColumns<R>
5
+ ): DataGridColumns<R> =>
6
+ columns.map((column, index) => ({
7
+ ...column,
8
+ order: index,
9
+ }));
@@ -1,59 +1,59 @@
1
- import { keyBy, mapValues } from 'lodash';
2
- import { useCallback, useContext, useMemo, useState } from 'react';
3
-
4
- import { Button } from '../../../forms/Button';
5
- import { DataGridColumnsEditor } from '.';
6
- import { DataGridContext } from '../types';
7
- import { Modal } from '../../../layout/Modal';
8
-
9
- export const useDataGridColumnsModal = <R,>(context: DataGridContext<R>) => {
10
- const [isVisible, setIsVisible] = useState(false);
11
- const { columns, setSettings, saveSettings } = useContext(context);
12
- const [currentColumns, setCurrentColumns] = useState(columns);
13
-
14
- const openModal = useCallback(() => {
15
- setCurrentColumns(columns);
16
- setIsVisible(true);
17
- }, [columns]);
18
- const closeModal = useCallback(() => {
19
- setIsVisible(false);
20
- }, []);
21
-
22
- const onApplyClicked = useCallback(() => {
23
- const newSettings = mapValues(keyBy(currentColumns, 'key'), (col) => ({
24
- order: col.order ?? 0,
25
- width: col.width ?? 150,
26
- }));
27
- setSettings(() => newSettings);
28
- saveSettings(newSettings);
29
- closeModal();
30
- }, [currentColumns, closeModal, saveSettings, setSettings]);
31
-
32
- const modal = useMemo(
33
- () =>
34
- isVisible ? (
35
- <Modal $width={600} $height={400}>
36
- <Modal.Header>Paramètres des colonnes</Modal.Header>
37
- <Modal.Content>
38
- <DataGridColumnsEditor
39
- columns={currentColumns}
40
- onColumnsChanged={setCurrentColumns}
41
- />
42
- </Modal.Content>
43
- <Modal.Footer>
44
- <Button onClick={closeModal}>Annuler</Button>
45
- <Button
46
- $color="primary"
47
- style={{ marginLeft: 'auto' }}
48
- onClick={onApplyClicked}
49
- >
50
- Appliquer
51
- </Button>
52
- </Modal.Footer>
53
- </Modal>
54
- ) : null,
55
- [closeModal, currentColumns, isVisible, onApplyClicked]
56
- );
57
-
58
- return { openModal, closeModal, modal };
59
- };
1
+ import { keyBy, mapValues } from 'lodash';
2
+ import { useCallback, useContext, useMemo, useState } from 'react';
3
+
4
+ import { Button } from '../../../forms/Button';
5
+ import { DataGridColumnsEditor } from '.';
6
+ import { DataGridContext } from '../types';
7
+ import { Modal } from '../../../layout/Modal';
8
+
9
+ export const useDataGridColumnsModal = <R,>(context: DataGridContext<R>) => {
10
+ const [isVisible, setIsVisible] = useState(false);
11
+ const { columns, setSettings, saveSettings } = useContext(context);
12
+ const [currentColumns, setCurrentColumns] = useState(columns);
13
+
14
+ const openModal = useCallback(() => {
15
+ setCurrentColumns(columns);
16
+ setIsVisible(true);
17
+ }, [columns]);
18
+ const closeModal = useCallback(() => {
19
+ setIsVisible(false);
20
+ }, []);
21
+
22
+ const onApplyClicked = useCallback(() => {
23
+ const newSettings = mapValues(keyBy(currentColumns, 'key'), (col) => ({
24
+ order: col.order ?? 0,
25
+ width: col.width ?? 150,
26
+ }));
27
+ setSettings(() => newSettings);
28
+ saveSettings(newSettings);
29
+ closeModal();
30
+ }, [currentColumns, closeModal, saveSettings, setSettings]);
31
+
32
+ const modal = useMemo(
33
+ () =>
34
+ isVisible ? (
35
+ <Modal $width={600} $height={400}>
36
+ <Modal.Header>Paramètres des colonnes</Modal.Header>
37
+ <Modal.Content>
38
+ <DataGridColumnsEditor
39
+ columns={currentColumns}
40
+ onColumnsChanged={setCurrentColumns}
41
+ />
42
+ </Modal.Content>
43
+ <Modal.Footer>
44
+ <Button onClick={closeModal}>Annuler</Button>
45
+ <Button
46
+ $color="primary"
47
+ style={{ marginLeft: 'auto' }}
48
+ onClick={onApplyClicked}
49
+ >
50
+ Appliquer
51
+ </Button>
52
+ </Modal.Footer>
53
+ </Modal>
54
+ ) : null,
55
+ [closeModal, currentColumns, isVisible, onApplyClicked]
56
+ );
57
+
58
+ return { openModal, closeModal, modal };
59
+ };
@@ -1,182 +1,182 @@
1
- import * as styles from './styles';
2
-
3
- import { DataGridColumn, DataGridColumns } from '../types';
4
- import { Dispatch, SetStateAction, useCallback } from 'react';
5
- import { DownIcon, LeftIcon, RightIcon, UpIcon } from '../../../../Icons';
6
-
7
- import { IconButton } from '../../../forms/IconButton';
8
- import _ from 'lodash';
9
- import { normalizeColumnsOrders } from './helpers';
10
- import { useVisibleAndHiddenColumns } from '../hooks';
11
-
12
- export const DataGridColumnItem = <R,>({
13
- columnIndex,
14
- columnKey,
15
- column,
16
- visible,
17
- onUpButtonClicked,
18
- onDownButtonClicked,
19
- onVisibleButtonClicked,
20
- }: {
21
- columnIndex: number;
22
- columnKey: string;
23
- column: DataGridColumn<R>;
24
- visible: boolean;
25
- onUpButtonClicked?: (index: number) => void;
26
- onDownButtonClicked?: (index: number) => void;
27
- onVisibleButtonClicked: (key: string) => void;
28
- }) => (
29
- <styles.ColumnItem $visible={visible}>
30
- {!visible && (
31
- <styles.Buttons $visible={false}>
32
- <IconButton
33
- size="small"
34
- icon={LeftIcon}
35
- onClick={() => onVisibleButtonClicked(columnKey)}
36
- />
37
- </styles.Buttons>
38
- )}
39
- <span>{column?.name}</span>
40
- {visible && (
41
- <styles.Buttons $visible>
42
- {onUpButtonClicked && (
43
- <IconButton
44
- size="small"
45
- icon={UpIcon}
46
- onClick={() => onUpButtonClicked(columnIndex)}
47
- />
48
- )}
49
- {onDownButtonClicked && (
50
- <IconButton
51
- size="small"
52
- icon={DownIcon}
53
- onClick={() => onDownButtonClicked(columnIndex)}
54
- />
55
- )}
56
- <IconButton
57
- size="small"
58
- icon={RightIcon}
59
- onClick={() => onVisibleButtonClicked(columnKey)}
60
- />
61
- </styles.Buttons>
62
- )}
63
- </styles.ColumnItem>
64
- );
65
-
66
- export const DataGridColumnsEditor = <R,>({
67
- columns,
68
- onColumnsChanged,
69
- }: {
70
- columns: DataGridColumns<R>;
71
- onColumnsChanged: Dispatch<SetStateAction<DataGridColumns<R>>>;
72
- }) => {
73
- console.log('DataGridColumnsEditor columns:', columns);
74
- const [visibleColumns, hiddenColumns] = useVisibleAndHiddenColumns(columns);
75
- const sortedVisibleColumnsEntries = normalizeColumnsOrders(
76
- _.sortBy(visibleColumns, (col) => col.order ?? 0)
77
- );
78
-
79
- const onUpButtonClicked = useCallback(
80
- (index: number) => {
81
- if (index > 0) {
82
- const newArray = normalizeColumnsOrders([
83
- ...sortedVisibleColumnsEntries.slice(0, index - 1),
84
- sortedVisibleColumnsEntries[index],
85
- sortedVisibleColumnsEntries[index - 1],
86
- ...sortedVisibleColumnsEntries.slice(index + 1),
87
- ]);
88
- onColumnsChanged(() => [...newArray, ...hiddenColumns]);
89
- }
90
- },
91
- [hiddenColumns, onColumnsChanged, sortedVisibleColumnsEntries]
92
- );
93
-
94
- const onDownButtonClicked = useCallback(
95
- (index: number) => {
96
- if (index < sortedVisibleColumnsEntries.length - 1) {
97
- const newArray = normalizeColumnsOrders([
98
- ...sortedVisibleColumnsEntries.slice(0, index),
99
- sortedVisibleColumnsEntries[index + 1],
100
- sortedVisibleColumnsEntries[index],
101
- ...sortedVisibleColumnsEntries.slice(index + 2),
102
- ]);
103
- onColumnsChanged(() => [...newArray, ...hiddenColumns]);
104
- }
105
- },
106
- [hiddenColumns, onColumnsChanged, sortedVisibleColumnsEntries]
107
- );
108
-
109
- const onHideButtonClicked = useCallback(
110
- (columnKey: string) => {
111
- onColumnsChanged((prev) =>
112
- prev.map((column) =>
113
- column.key === columnKey
114
- ? {
115
- ...column,
116
- order: -1,
117
- }
118
- : column
119
- )
120
- );
121
- },
122
- [onColumnsChanged]
123
- );
124
-
125
- const onShowButtonClicked = useCallback(
126
- (columnKey: string) => {
127
- onColumnsChanged((prev) =>
128
- prev.map((column) =>
129
- column.key === columnKey
130
- ? {
131
- ...column,
132
- order: Object.keys(prev).length,
133
- }
134
- : column
135
- )
136
- );
137
- },
138
- [onColumnsChanged]
139
- );
140
-
141
- return (
142
- <styles.Container>
143
- <styles.Panel>
144
- <styles.Title>Colonnes visibles</styles.Title>
145
- <styles.ColumnsList>
146
- {sortedVisibleColumnsEntries.map((column, index) => (
147
- <DataGridColumnItem
148
- key={column.key}
149
- columnKey={column.key}
150
- columnIndex={index}
151
- column={column}
152
- visible
153
- onUpButtonClicked={index > 0 ? onUpButtonClicked : undefined}
154
- onDownButtonClicked={
155
- index < sortedVisibleColumnsEntries.length - 1
156
- ? onDownButtonClicked
157
- : undefined
158
- }
159
- onVisibleButtonClicked={onHideButtonClicked}
160
- />
161
- ))}
162
- </styles.ColumnsList>
163
- </styles.Panel>
164
-
165
- <styles.Panel>
166
- <styles.Title>Colonnes masquées</styles.Title>
167
- <styles.ColumnsList>
168
- {hiddenColumns.map((column, index) => (
169
- <DataGridColumnItem
170
- key={column.key}
171
- columnKey={column.key}
172
- columnIndex={index}
173
- column={column}
174
- visible={false}
175
- onVisibleButtonClicked={onShowButtonClicked}
176
- />
177
- ))}
178
- </styles.ColumnsList>
179
- </styles.Panel>
180
- </styles.Container>
181
- );
182
- };
1
+ import * as styles from './styles';
2
+
3
+ import { DataGridColumn, DataGridColumns } from '../types';
4
+ import { Dispatch, SetStateAction, useCallback } from 'react';
5
+ import { DownIcon, LeftIcon, RightIcon, UpIcon } from '../../../../Icons';
6
+
7
+ import { IconButton } from '../../../forms/IconButton';
8
+ import _ from 'lodash';
9
+ import { normalizeColumnsOrders } from './helpers';
10
+ import { useVisibleAndHiddenColumns } from '../hooks';
11
+
12
+ export const DataGridColumnItem = <R,>({
13
+ columnIndex,
14
+ columnKey,
15
+ column,
16
+ visible,
17
+ onUpButtonClicked,
18
+ onDownButtonClicked,
19
+ onVisibleButtonClicked,
20
+ }: {
21
+ columnIndex: number;
22
+ columnKey: string;
23
+ column: DataGridColumn<R>;
24
+ visible: boolean;
25
+ onUpButtonClicked?: (index: number) => void;
26
+ onDownButtonClicked?: (index: number) => void;
27
+ onVisibleButtonClicked: (key: string) => void;
28
+ }) => (
29
+ <styles.ColumnItem $visible={visible}>
30
+ {!visible && (
31
+ <styles.Buttons $visible={false}>
32
+ <IconButton
33
+ size="small"
34
+ icon={LeftIcon}
35
+ onClick={() => onVisibleButtonClicked(columnKey)}
36
+ />
37
+ </styles.Buttons>
38
+ )}
39
+ <span>{column?.name}</span>
40
+ {visible && (
41
+ <styles.Buttons $visible>
42
+ {onUpButtonClicked && (
43
+ <IconButton
44
+ size="small"
45
+ icon={UpIcon}
46
+ onClick={() => onUpButtonClicked(columnIndex)}
47
+ />
48
+ )}
49
+ {onDownButtonClicked && (
50
+ <IconButton
51
+ size="small"
52
+ icon={DownIcon}
53
+ onClick={() => onDownButtonClicked(columnIndex)}
54
+ />
55
+ )}
56
+ <IconButton
57
+ size="small"
58
+ icon={RightIcon}
59
+ onClick={() => onVisibleButtonClicked(columnKey)}
60
+ />
61
+ </styles.Buttons>
62
+ )}
63
+ </styles.ColumnItem>
64
+ );
65
+
66
+ export const DataGridColumnsEditor = <R,>({
67
+ columns,
68
+ onColumnsChanged,
69
+ }: {
70
+ columns: DataGridColumns<R>;
71
+ onColumnsChanged: Dispatch<SetStateAction<DataGridColumns<R>>>;
72
+ }) => {
73
+ console.log('DataGridColumnsEditor columns:', columns);
74
+ const [visibleColumns, hiddenColumns] = useVisibleAndHiddenColumns(columns);
75
+ const sortedVisibleColumnsEntries = normalizeColumnsOrders(
76
+ _.sortBy(visibleColumns, (col) => col.order ?? 0)
77
+ );
78
+
79
+ const onUpButtonClicked = useCallback(
80
+ (index: number) => {
81
+ if (index > 0) {
82
+ const newArray = normalizeColumnsOrders([
83
+ ...sortedVisibleColumnsEntries.slice(0, index - 1),
84
+ sortedVisibleColumnsEntries[index],
85
+ sortedVisibleColumnsEntries[index - 1],
86
+ ...sortedVisibleColumnsEntries.slice(index + 1),
87
+ ]);
88
+ onColumnsChanged(() => [...newArray, ...hiddenColumns]);
89
+ }
90
+ },
91
+ [hiddenColumns, onColumnsChanged, sortedVisibleColumnsEntries]
92
+ );
93
+
94
+ const onDownButtonClicked = useCallback(
95
+ (index: number) => {
96
+ if (index < sortedVisibleColumnsEntries.length - 1) {
97
+ const newArray = normalizeColumnsOrders([
98
+ ...sortedVisibleColumnsEntries.slice(0, index),
99
+ sortedVisibleColumnsEntries[index + 1],
100
+ sortedVisibleColumnsEntries[index],
101
+ ...sortedVisibleColumnsEntries.slice(index + 2),
102
+ ]);
103
+ onColumnsChanged(() => [...newArray, ...hiddenColumns]);
104
+ }
105
+ },
106
+ [hiddenColumns, onColumnsChanged, sortedVisibleColumnsEntries]
107
+ );
108
+
109
+ const onHideButtonClicked = useCallback(
110
+ (columnKey: string) => {
111
+ onColumnsChanged((prev) =>
112
+ prev.map((column) =>
113
+ column.key === columnKey
114
+ ? {
115
+ ...column,
116
+ order: -1,
117
+ }
118
+ : column
119
+ )
120
+ );
121
+ },
122
+ [onColumnsChanged]
123
+ );
124
+
125
+ const onShowButtonClicked = useCallback(
126
+ (columnKey: string) => {
127
+ onColumnsChanged((prev) =>
128
+ prev.map((column) =>
129
+ column.key === columnKey
130
+ ? {
131
+ ...column,
132
+ order: Object.keys(prev).length,
133
+ }
134
+ : column
135
+ )
136
+ );
137
+ },
138
+ [onColumnsChanged]
139
+ );
140
+
141
+ return (
142
+ <styles.Container>
143
+ <styles.Panel>
144
+ <styles.Title>Colonnes visibles</styles.Title>
145
+ <styles.ColumnsList>
146
+ {sortedVisibleColumnsEntries.map((column, index) => (
147
+ <DataGridColumnItem
148
+ key={column.key}
149
+ columnKey={column.key}
150
+ columnIndex={index}
151
+ column={column}
152
+ visible
153
+ onUpButtonClicked={index > 0 ? onUpButtonClicked : undefined}
154
+ onDownButtonClicked={
155
+ index < sortedVisibleColumnsEntries.length - 1
156
+ ? onDownButtonClicked
157
+ : undefined
158
+ }
159
+ onVisibleButtonClicked={onHideButtonClicked}
160
+ />
161
+ ))}
162
+ </styles.ColumnsList>
163
+ </styles.Panel>
164
+
165
+ <styles.Panel>
166
+ <styles.Title>Colonnes masquées</styles.Title>
167
+ <styles.ColumnsList>
168
+ {hiddenColumns.map((column, index) => (
169
+ <DataGridColumnItem
170
+ key={column.key}
171
+ columnKey={column.key}
172
+ columnIndex={index}
173
+ column={column}
174
+ visible={false}
175
+ onVisibleButtonClicked={onShowButtonClicked}
176
+ />
177
+ ))}
178
+ </styles.ColumnsList>
179
+ </styles.Panel>
180
+ </styles.Container>
181
+ );
182
+ };