@addev-be/ui 0.11.7 → 0.12.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 (186) 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/up.svg +1 -1
  21. package/assets/icons/user-tie.svg +1 -1
  22. package/assets/icons/x-bar.svg +3 -3
  23. package/dist/components/auth/LoginForm.js +0 -1
  24. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +10 -0
  25. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +173 -0
  26. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +13 -0
  27. package/dist/components/data/DataGrid/FilterValuesScroller.js +73 -0
  28. package/dist/components/data/DataGrid/VirtualScroller.d.ts +11 -0
  29. package/dist/components/data/DataGrid/VirtualScroller.js +41 -0
  30. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +12 -0
  31. package/dist/components/data/DataGrid/helpers/advancedRequests.js +53 -0
  32. package/dist/components/data/DataGrid/helpers.d.ts +28 -0
  33. package/dist/components/data/DataGrid/helpers.js +436 -0
  34. package/dist/config/types.d.ts +11 -0
  35. package/dist/config/types.js +2 -0
  36. package/dist/providers/AuthenticationProvider/index.d.ts +0 -1
  37. package/dist/providers/AuthenticationProvider/index.js +14 -28
  38. package/dist/services/advancedRequests.d.ts +1 -1
  39. package/dist/services/requests/userPermissions.d.ts +4 -0
  40. package/dist/services/requests/userPermissions.js +20 -0
  41. package/dist/services/sqlRequests.d.ts +1 -1
  42. package/package.json +1 -1
  43. package/src/Icons.tsx +128 -128
  44. package/src/components/auth/LoginForm.tsx +84 -84
  45. package/src/components/auth/LoginPage.tsx +32 -32
  46. package/src/components/auth/PasswordRecoveryForm.tsx +52 -52
  47. package/src/components/auth/PasswordResetForm.tsx +112 -112
  48. package/src/components/auth/index.ts +4 -4
  49. package/src/components/auth/styles.ts +14 -14
  50. package/src/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.ts +93 -93
  51. package/src/components/data/AdvancedRequestDataGrid/helpers/columns.tsx +262 -262
  52. package/src/components/data/AdvancedRequestDataGrid/helpers/index.ts +2 -2
  53. package/src/components/data/AdvancedRequestDataGrid/index.tsx +267 -267
  54. package/src/components/data/AdvancedRequestDataGrid/types.ts +47 -47
  55. package/src/components/data/DataGrid/DataGridCell.tsx +76 -76
  56. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +14 -14
  57. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  58. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +181 -181
  59. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  60. package/src/components/data/DataGrid/DataGridEditableCell.tsx +43 -43
  61. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +131 -131
  62. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +78 -78
  63. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +378 -378
  64. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  65. package/src/components/data/DataGrid/DataGridFooter.tsx +43 -43
  66. package/src/components/data/DataGrid/DataGridHeader.tsx +128 -128
  67. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +101 -101
  68. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +70 -70
  69. package/src/components/data/DataGrid/FilterModalContent/index.tsx +136 -136
  70. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  71. package/src/components/data/DataGrid/constants.ts +6 -6
  72. package/src/components/data/DataGrid/helpers/columns.tsx +319 -319
  73. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  74. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  75. package/src/components/data/DataGrid/hooks/index.ts +30 -30
  76. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +338 -338
  77. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +175 -175
  78. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  79. package/src/components/data/DataGrid/index.tsx +110 -110
  80. package/src/components/data/DataGrid/styles.ts +336 -336
  81. package/src/components/data/DataGrid/types.ts +283 -283
  82. package/src/components/data/SmartQueryDataGrid/helpers/columns.tsx +333 -0
  83. package/src/components/data/SmartQueryDataGrid/helpers/hooks.ts +41 -0
  84. package/src/components/data/SmartQueryDataGrid/helpers/index.ts +2 -0
  85. package/src/components/data/SmartQueryDataGrid/helpers/smartQueries.ts +17 -0
  86. package/src/components/data/SmartQueryDataGrid/hooks.ts +75 -0
  87. package/src/components/data/SmartQueryDataGrid/index.tsx +338 -0
  88. package/src/components/data/SmartQueryDataGrid/types.ts +45 -0
  89. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +306 -306
  90. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  91. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  92. package/src/components/data/SqlRequestDataGrid/index.tsx +387 -387
  93. package/src/components/data/SqlRequestDataGrid/types.ts +48 -48
  94. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +106 -106
  95. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  96. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  97. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  98. package/src/components/data/SqlRequestGrid/index.tsx +310 -310
  99. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  100. package/src/components/data/SqlRequestGrid/types.ts +53 -53
  101. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  102. package/src/components/data/VirtualScroller/index.tsx +89 -89
  103. package/src/components/data/VirtualScroller/styles.ts +58 -58
  104. package/src/components/data/VirtualScroller/types.ts +12 -12
  105. package/src/components/data/index.ts +21 -17
  106. package/src/components/forms/AutoTextArea.tsx +41 -41
  107. package/src/components/forms/Button.tsx +133 -133
  108. package/src/components/forms/IconButton.tsx +57 -57
  109. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  110. package/src/components/forms/Select.tsx +40 -40
  111. package/src/components/forms/VerticalLabel.tsx +20 -20
  112. package/src/components/forms/index.ts +6 -6
  113. package/src/components/forms/styles.ts +31 -31
  114. package/src/components/index.ts +6 -6
  115. package/src/components/layout/Dropdown/index.tsx +112 -112
  116. package/src/components/layout/Dropdown/styles.ts +45 -45
  117. package/src/components/layout/Loading/index.tsx +29 -29
  118. package/src/components/layout/Loading/styles.ts +29 -29
  119. package/src/components/layout/Modal/index.tsx +51 -51
  120. package/src/components/layout/Modal/styles.ts +121 -121
  121. package/src/components/layout/index.ts +3 -3
  122. package/src/components/search/HighlightedText.tsx +37 -37
  123. package/src/components/search/QuickSearchBar.tsx +86 -86
  124. package/src/components/search/QuickSearchResults.tsx +86 -86
  125. package/src/components/search/index.ts +9 -9
  126. package/src/components/search/styles.ts +96 -96
  127. package/src/components/search/types.ts +26 -26
  128. package/src/components/ui/Avatar/index.tsx +54 -54
  129. package/src/components/ui/Card/index.tsx +14 -14
  130. package/src/components/ui/Card/styles.ts +37 -37
  131. package/src/components/ui/ContextMenu/index.tsx +79 -79
  132. package/src/components/ui/ContextMenu/styles.ts +119 -119
  133. package/src/components/ui/Label.tsx +90 -90
  134. package/src/components/ui/Message/index.tsx +57 -57
  135. package/src/components/ui/Message/styles.ts +40 -40
  136. package/src/components/ui/index.ts +5 -5
  137. package/src/config/index.ts +14 -14
  138. package/src/helpers/dates.ts +17 -17
  139. package/src/helpers/getScrollbarSize.ts +14 -14
  140. package/src/helpers/index.ts +3 -3
  141. package/src/helpers/numbers.ts +26 -26
  142. package/src/helpers/text.ts +13 -13
  143. package/src/hooks/index.ts +3 -3
  144. package/src/hooks/useElementSize.ts +24 -24
  145. package/src/hooks/useShowArchived.ts +28 -28
  146. package/src/hooks/useWindowSize.ts +20 -20
  147. package/src/index.ts +9 -9
  148. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  149. package/src/providers/AuthenticationProvider/index.tsx +243 -243
  150. package/src/providers/LoadingProvider/index.tsx +47 -47
  151. package/src/providers/PortalsProvider/index.tsx +54 -54
  152. package/src/providers/PortalsProvider/styles.ts +31 -31
  153. package/src/providers/SettingsProvider/index.tsx +70 -70
  154. package/src/providers/ThemeProvider/ThemeProvider.ts +63 -63
  155. package/src/providers/ThemeProvider/defaultTheme.ts +457 -457
  156. package/src/providers/ThemeProvider/index.ts +4 -4
  157. package/src/providers/ThemeProvider/types.ts +131 -131
  158. package/src/providers/TrackingProvider/index.tsx +71 -71
  159. package/src/providers/UiProviders/index.tsx +68 -68
  160. package/src/providers/UiProviders/styles.ts +10 -10
  161. package/src/providers/hooks.ts +12 -12
  162. package/src/providers/index.ts +8 -8
  163. package/src/services/HttpService.ts +92 -92
  164. package/src/services/WebSocketService.ts +137 -137
  165. package/src/services/advancedRequests.ts +102 -102
  166. package/src/services/base.ts +23 -23
  167. package/src/services/globalSearch.ts +29 -29
  168. package/src/services/hooks.ts +44 -44
  169. package/src/services/index.ts +20 -19
  170. package/src/services/requests/auth.ts +44 -44
  171. package/src/services/requests/generic.ts +62 -62
  172. package/src/services/requests/tracking.ts +12 -12
  173. package/src/services/requests/userProfiles.ts +35 -35
  174. package/src/services/requests/users.ts +28 -28
  175. package/src/services/smartQueries.ts +122 -0
  176. package/src/services/sqlRequests.ts +111 -111
  177. package/src/services/types/auth.ts +131 -131
  178. package/src/services/types/base.ts +10 -10
  179. package/src/services/types/generic.ts +92 -92
  180. package/src/services/types/tracking.ts +39 -39
  181. package/src/services/types/userProfiles.ts +107 -107
  182. package/src/services/types/users.ts +106 -106
  183. package/src/styles/animations.scss +30 -30
  184. package/src/styles/index.scss +42 -42
  185. package/src/typings.d.ts +13 -13
  186. package/tsconfig.json +18 -18
@@ -0,0 +1,333 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ import {
4
+ ColumnDTO,
5
+ ColumnWithHavingDTO,
6
+ ConditionDTO,
7
+ } from '../../../../services/smartQueries';
8
+ import { SmartQueryDataGridColumn, SmartQueryDataGridColumns } from '../types';
9
+ import {
10
+ buildExcelFormat,
11
+ dateFilter,
12
+ numberFilter,
13
+ textFilter,
14
+ } from '../../DataGrid/helpers';
15
+ import { formatDate, formatDateTime } from '../../../../helpers/dates';
16
+ import {
17
+ formatMoney,
18
+ formatNumber,
19
+ formatNumberInvariant,
20
+ formatPercentage,
21
+ } from '../../../../helpers/numbers';
22
+
23
+ export const smartTextColumn = <R extends Record<string, any>>(
24
+ key: string,
25
+ title: string,
26
+ options?: Partial<SmartQueryDataGridColumn<R>>
27
+ ): SmartQueryDataGridColumns<R> => ({
28
+ [key]: {
29
+ name: title,
30
+ render: (row) => row[key] ?? '',
31
+ getter: (row) => row[key] ?? '',
32
+ sortGetter: (row) => row[key] ?? '',
33
+ filter: { ...textFilter(key), getter: (value) => value[key] ?? '' },
34
+ ...options,
35
+ footer: (rows) => `${rows[0][key]} éléments`,
36
+ },
37
+ });
38
+
39
+ /**
40
+ * Creates a column with a composed value from multiple fields,
41
+ * and filtered by a text filter on the first field
42
+ */
43
+ export const smartComposedColumn = <R extends Record<string, any>>(
44
+ key: string,
45
+ title: string,
46
+ fields: string[],
47
+ options?: Partial<SmartQueryDataGridColumn<R>>
48
+ ): SmartQueryDataGridColumns<R> => ({
49
+ [key]: {
50
+ field: {
51
+ fieldAlias: key,
52
+ operator: 'jsonObject',
53
+ operands: fields.flatMap((field) => [
54
+ { constantValue: field },
55
+ { fieldName: field },
56
+ ]),
57
+ },
58
+ name: title,
59
+ render: (row) => row[key] ?? '',
60
+ getter: (row) => row[key] ?? '',
61
+ sortGetter: (row) => row[key] ?? '',
62
+ filter: {
63
+ ...textFilter(fields[0]),
64
+ getter: (value) => value[fields[0]] ?? 0,
65
+ },
66
+ filterField: fields[0],
67
+ sortField: fields[0],
68
+ footer: (rows) => `${rows[0][key]} éléments`,
69
+ ...options,
70
+ },
71
+ });
72
+
73
+ export const smartMailColumn = <R extends Record<string, any>>(
74
+ key: string,
75
+ title: string,
76
+ options?: Partial<SmartQueryDataGridColumn<R>>
77
+ ): SmartQueryDataGridColumns<R> => ({
78
+ [key]: {
79
+ name: title,
80
+ render: (row) => <a href={`mailto:${row[key]}`}>{row[key] ?? ''}</a>,
81
+ getter: (row) => row[key] ?? '',
82
+ sortGetter: (row) => row[key] ?? '',
83
+ filter: { ...textFilter(key), getter: (value) => value[key] ?? '' },
84
+ footer: (rows) => `${rows[0][key]} éléments`,
85
+ ...options,
86
+ },
87
+ });
88
+
89
+ export const smartPhoneColumn = <R extends Record<string, any>>(
90
+ key: string,
91
+ title: string,
92
+ options?: Partial<SmartQueryDataGridColumn<R>>
93
+ ): SmartQueryDataGridColumns<R> => ({
94
+ [key]: {
95
+ name: title,
96
+ render: (row) => <a href={`tel:${row[key]}`}>{row[key] ?? ''}</a>,
97
+ getter: (row) => row[key] ?? '',
98
+ sortGetter: (row) => row[key] ?? '',
99
+ filter: { ...textFilter(key), getter: (value) => value[key] ?? '' },
100
+ footer: (rows) => `${rows[0][key]} éléments`,
101
+ ...options,
102
+ },
103
+ });
104
+
105
+ export const smartDateColumn = <R extends Record<string, any>>(
106
+ key: string,
107
+ title: string,
108
+ options?: Partial<SmartQueryDataGridColumn<R>>
109
+ ): SmartQueryDataGridColumns<R> => ({
110
+ [key]: {
111
+ name: title,
112
+ type: 'date',
113
+ render: (row) => formatDate(row[key]),
114
+ getter: (row) => row[key] ?? '',
115
+ sortGetter: (row) => row[key] ?? '',
116
+ excelFormatter: () => 'dd/mm/yyyy',
117
+ excelValue: (value) => formatDate(value, 'YYYY-MM-DD'),
118
+ filter: {
119
+ ...dateFilter(key),
120
+ getter: (value) => value[key] ?? '',
121
+ formatter: (value) => formatDate(value),
122
+ renderer: (value) => formatDate(value),
123
+ },
124
+ footer: (rows) => `${rows[0][key]} éléments`,
125
+ ...options,
126
+ },
127
+ });
128
+
129
+ export const smartDateTimeColumn = <R extends Record<string, any>>(
130
+ key: string,
131
+ title: string,
132
+ options?: Partial<SmartQueryDataGridColumn<R>>
133
+ ): SmartQueryDataGridColumns<R> => ({
134
+ [key]: {
135
+ name: title,
136
+ type: 'date',
137
+ render: (row) => formatDateTime(row[key]),
138
+ getter: (row) => row[key] ?? '',
139
+ sortGetter: (row) => row[key] ?? '',
140
+ excelFormatter: () => 'dd/mm/yyyy hh:mm:ss',
141
+ excelValue: (value) => formatDateTime(value, 'YYYY-MM-DD HH:mm:ss'),
142
+ filter: {
143
+ ...dateFilter(key),
144
+ getter: (value) => value[key] ?? '',
145
+ formatter: (value) => formatDateTime(value),
146
+ renderer: (value) => formatDateTime(value),
147
+ },
148
+ footer: (rows) => `${rows[0][key]} éléments`,
149
+ ...options,
150
+ },
151
+ });
152
+
153
+ export const smartMonthColumn = <R extends Record<string, any>>(
154
+ key: string,
155
+ title: string,
156
+ options?: Partial<SmartQueryDataGridColumn<R>>
157
+ ): SmartQueryDataGridColumns<R> => ({
158
+ [key]: {
159
+ name: title,
160
+ render: (row) => (row[key] ? `${row[key]} mois ` : ''),
161
+ getter: (row) => row[key] ?? '',
162
+ sortGetter: (row) => row[key] ?? '',
163
+ filter: { ...textFilter(key), getter: (value) => value[key] ?? '' },
164
+ footer: (rows) => `${rows[0][key]} éléments`,
165
+ ...options,
166
+ },
167
+ });
168
+
169
+ export const smartNumberColumn = <R extends Record<string, any>>(
170
+ key: string,
171
+ title: string,
172
+ decimals = 2,
173
+ options?: Partial<SmartQueryDataGridColumn<R>>
174
+ ): SmartQueryDataGridColumns<R> => ({
175
+ [key]: {
176
+ name: title,
177
+ type: 'number',
178
+ render: (row) => formatNumber(row[key], decimals) ?? '',
179
+ excelFormatter: () => buildExcelFormat(decimals),
180
+ excelValue: (value) => formatNumberInvariant(value, decimals),
181
+ getter: (row) => row[key] ?? '',
182
+ sortGetter: (row) => row[key] ?? 0,
183
+ filter: {
184
+ ...numberFilter(key),
185
+ getter: (value) => value[key] ?? 0,
186
+ renderer: (value) => formatNumber(value, decimals) ?? '',
187
+ },
188
+ footer: {
189
+ sum: null,
190
+ avg: null,
191
+ count: null,
192
+ max: null,
193
+ min: null,
194
+ },
195
+ ...options,
196
+ },
197
+ });
198
+
199
+ export const smartMoneyColumn = <R extends Record<string, any>>(
200
+ key: string,
201
+ title: string,
202
+ decimals = 2,
203
+ options?: Partial<SmartQueryDataGridColumn<R>>
204
+ ): SmartQueryDataGridColumns<R> => ({
205
+ [key]: {
206
+ name: title,
207
+ type: 'number',
208
+ render: (row) => formatMoney(row[key], decimals) ?? '',
209
+ excelFormatter: () => buildExcelFormat(decimals, ' €'),
210
+ excelValue: (value) => formatNumberInvariant(value, decimals),
211
+ getter: (row) => row[key] ?? '',
212
+ sortGetter: (row) => row[key] ?? 0,
213
+ filter: {
214
+ ...numberFilter(key),
215
+ getter: (value) => value[key] ?? 0,
216
+ renderer: (value) => formatMoney(value, decimals) ?? '',
217
+ },
218
+ footer: {
219
+ sum: null,
220
+ avg: null,
221
+ count: null,
222
+ max: null,
223
+ min: null,
224
+ },
225
+ ...options,
226
+ },
227
+ });
228
+
229
+ export const smartPercentageColumn = <R extends Record<string, any>>(
230
+ key: string,
231
+ title: string,
232
+ decimals = 2,
233
+ options?: Partial<SmartQueryDataGridColumn<R>>
234
+ ): SmartQueryDataGridColumns<R> => ({
235
+ [key]: {
236
+ name: title,
237
+ type: 'number',
238
+ render: (row) => formatPercentage(row[key]) ?? '',
239
+ excelFormatter: () => buildExcelFormat(decimals, '%'),
240
+ excelValue: (value) => formatNumberInvariant(value, decimals),
241
+ getter: (row) => row[key] ?? '',
242
+ sortGetter: (row) => row[key] ?? 0,
243
+ filter: {
244
+ ...numberFilter(key),
245
+ getter: (value) => value[key] ?? 0,
246
+ renderer: (value) => formatPercentage(value, decimals) ?? '',
247
+ },
248
+ ...options,
249
+ },
250
+ });
251
+
252
+ export const smartCheckboxColumn = <R extends Record<string, any>>(
253
+ key: string,
254
+ title: string,
255
+ options?: Partial<SmartQueryDataGridColumn<R>>
256
+ ): SmartQueryDataGridColumns<R> => ({
257
+ [key]: {
258
+ name: title,
259
+ render: (row) => {
260
+ const value = !!+(row[key] ?? 0);
261
+ return (
262
+ <>
263
+ <input type="checkbox" checked={value} readOnly />
264
+ <span>{value ? ' Oui' : ' Non'}</span>
265
+ </>
266
+ );
267
+ },
268
+ getter: (row) => row[key] ?? '',
269
+ sortGetter: (row) => row[key] ?? '',
270
+ filter: { ...numberFilter(key), getter: (value) => +(value[key] ?? 0) },
271
+ footer: (rows) => `${rows[0][key]} éléments`,
272
+ ...options,
273
+ },
274
+ });
275
+
276
+ export const smartColorColumn = <R extends Record<string, any>>(
277
+ key: string,
278
+ title: string,
279
+ options?: Partial<SmartQueryDataGridColumn<R>>
280
+ ): SmartQueryDataGridColumns<R> => ({
281
+ [key]: {
282
+ name: title,
283
+ render: (row) => (
284
+ <div
285
+ style={{ position: 'absolute', inset: 0, backgroundColor: row[key] }}
286
+ >
287
+ &nbsp;
288
+ </div>
289
+ ),
290
+ excelValue: () => '',
291
+ excelBackgroundColor: (value) => value,
292
+ getter: (row) => row[key] ?? '',
293
+ sortGetter: (row) => row[key] ?? '',
294
+ filter: {
295
+ ...textFilter(key),
296
+ getter: (value) => value[key] ?? '',
297
+ renderer: (value) => (
298
+ <div
299
+ style={{
300
+ backgroundColor: value,
301
+ width: 'var(--space-16)',
302
+ height: '1em',
303
+ }}
304
+ >
305
+ &nbsp;
306
+ </div>
307
+ ),
308
+ },
309
+ ...options,
310
+ },
311
+ });
312
+
313
+ export const getColumnsConditions = (columns: ColumnDTO[]): ConditionDTO[] =>
314
+ columns
315
+ .filter((column): column is ColumnWithHavingDTO => !!column.having)
316
+ .map((column) => ({
317
+ field: column.field,
318
+ operator: column.having?.operator ?? 'equals',
319
+ value: column.having?.value,
320
+ }));
321
+
322
+ export const getFooterColumn = (column: ColumnDTO): ColumnDTO =>
323
+ !column.footer
324
+ ? column
325
+ : {
326
+ ...column,
327
+ field: {
328
+ operator: column.footer,
329
+ operands: [{ fieldName: column.field.fieldName }],
330
+ fieldAlias: column.field.fieldAlias ?? column.field.fieldName,
331
+ },
332
+ groupBy: true,
333
+ };
@@ -0,0 +1,41 @@
1
+ import { ColumnDTO, ConditionDTO } from '../../../../services/smartQueries';
2
+
3
+ import { SmartQueryDataGridColumns } from '../types';
4
+ import { SmartQueries } from '../../../../services';
5
+ import { useMemo } from 'react';
6
+
7
+ export const useSmartColumnDTOs = <R>(
8
+ columns: SmartQueryDataGridColumns<R>,
9
+ conditions: Record<string, ConditionDTO> = {},
10
+ footers: Record<string, SmartQueries.FooterFunction> = {},
11
+ sorts: Record<string, SmartQueries.OrderByDirection> = {}
12
+ ) =>
13
+ useMemo(
14
+ () =>
15
+ Object.entries(columns).map<ColumnDTO>(([key, col]) => ({
16
+ key,
17
+ field: {
18
+ fieldName: col.field?.fieldName ?? key,
19
+ fieldAlias: col.field?.fieldAlias ?? key,
20
+ groupBy: col.field?.groupBy ?? false,
21
+ },
22
+ having: conditions[key],
23
+ footer: footers[key],
24
+ orderBy: sorts[key],
25
+ })),
26
+ [columns, conditions, footers, sorts]
27
+ );
28
+
29
+ export const useIdSmartColumnDTO = (smartColumns: SmartQueries.ColumnDTO[]) =>
30
+ useMemo(
31
+ () =>
32
+ smartColumns.find((col) => col.field.fieldName === 'id') ?? {
33
+ key: 'id',
34
+ field: {
35
+ fieldName: 'id',
36
+ fieldAlias: 'id',
37
+ groupBy: false,
38
+ },
39
+ },
40
+ [smartColumns]
41
+ );
@@ -0,0 +1,2 @@
1
+ export * from './smartQueries';
2
+ export * from './columns';
@@ -0,0 +1,17 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ import { castArray, mapValues } from 'lodash';
4
+
5
+ import { ConditionDTO } from '../../../../services/smartQueries';
6
+ import { SmartQueryDataGridFilters } from '../types';
7
+
8
+ export const convertSmartFiltersToConditions = (
9
+ filters: SmartQueryDataGridFilters
10
+ ): Record<string, ConditionDTO> =>
11
+ mapValues(filters, (filter, columnKey) => ({
12
+ field: { fieldName: columnKey },
13
+ operator: filter.operator as any,
14
+ value: ['inArray', 'inRange'].includes(filter.operator)
15
+ ? filter.values
16
+ : castArray<string | number | null>(filter.values)[0],
17
+ }));
@@ -0,0 +1,75 @@
1
+ import { useCallback, useMemo, useState } from 'react';
2
+
3
+ import { ColumnDTO } from '../../../services/smartQueries';
4
+ import { SmartQueries } from '../../../services';
5
+
6
+ export const useSmartQuery = (type: string, columns: ColumnDTO[]) => {
7
+ const [query, setQuery] = useState<SmartQueries.QueryDTO>({
8
+ type,
9
+ columns,
10
+ });
11
+
12
+ const havings = useMemo(
13
+ () =>
14
+ (query.columns ?? [])
15
+ .filter(
16
+ (column): column is SmartQueries.ColumnWithHavingDTO =>
17
+ !!column.having
18
+ )
19
+ .map((col) => col.having),
20
+ [query.columns]
21
+ );
22
+
23
+ const setHaving = useCallback(
24
+ (columnId: string, having: SmartQueries.HavingDTO) => {
25
+ setQuery((currentQuery) => ({
26
+ ...currentQuery,
27
+ columns: currentQuery.columns?.map((column) =>
28
+ column.key === columnId
29
+ ? {
30
+ ...column,
31
+ having,
32
+ }
33
+ : column
34
+ ),
35
+ }));
36
+ },
37
+ []
38
+ );
39
+
40
+ const footers = useMemo(
41
+ () =>
42
+ (query.columns ?? [])
43
+ .filter(
44
+ (column): column is SmartQueries.ColumnWithFooterDTO =>
45
+ !!column.footer
46
+ )
47
+ .map((col) => col.footer),
48
+ [query.columns]
49
+ );
50
+
51
+ const setFooter = useCallback(
52
+ (columnId: string, footer: SmartQueries.FooterFunction) => {
53
+ setQuery((currentQuery) => ({
54
+ ...currentQuery,
55
+ columns: currentQuery.columns?.map((column) =>
56
+ column.key === columnId
57
+ ? {
58
+ ...column,
59
+ footer,
60
+ }
61
+ : column
62
+ ),
63
+ }));
64
+ },
65
+ []
66
+ );
67
+
68
+ return {
69
+ query,
70
+ havings,
71
+ setHaving,
72
+ footers,
73
+ setFooter,
74
+ };
75
+ };