@addev-be/ui 0.19.0 → 0.19.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 (408) 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/trash-can.svg +1 -0
  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/Icons.d.ts +1 -9
  25. package/dist/Icons.js +1 -17
  26. package/dist/components/auth/LoginForm.js +1 -1
  27. package/dist/components/auth/PasswordRecoveryForm.js +1 -1
  28. package/dist/components/auth/PasswordResetForm.js +1 -1
  29. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +8 -9
  30. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +72 -21
  31. package/dist/components/data/AdvancedRequestDataGrid/index.js +2 -2
  32. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +1 -1
  33. package/dist/components/data/DataGrid/DataGridCell.js +5 -5
  34. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.d.ts +2 -2
  35. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.js +7 -1
  36. package/dist/components/data/DataGrid/DataGridColumnsModal/hooks.js +3 -3
  37. package/dist/components/data/DataGrid/DataGridColumnsModal/index.js +21 -16
  38. package/dist/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.js +1 -17
  39. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.d.ts +3 -4
  40. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.js +12 -11
  41. package/dist/components/data/DataGrid/DataGridFilterMenu/index.d.ts +4 -5
  42. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +40 -44
  43. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.js +1 -1
  44. package/dist/components/data/DataGrid/DataGridFooter.js +5 -5
  45. package/dist/components/data/DataGrid/DataGridHeader.js +6 -40
  46. package/dist/components/data/DataGrid/DataGridHeaderCell.d.ts +1 -1
  47. package/dist/components/data/DataGrid/DataGridHeaderCell.js +23 -11
  48. package/dist/components/data/DataGrid/DataGridRowTemplate.d.ts +1 -1
  49. package/dist/components/data/DataGrid/DataGridRowTemplate.js +9 -8
  50. package/dist/components/data/DataGrid/FilterModalContent/index.js +1 -1
  51. package/dist/components/data/DataGrid/helpers/columns.d.ts +12 -13
  52. package/dist/components/data/DataGrid/helpers/columns.js +130 -100
  53. package/dist/components/data/DataGrid/hooks/index.d.ts +3 -3
  54. package/dist/components/data/DataGrid/hooks/index.js +12 -8
  55. package/dist/components/data/DataGrid/hooks/useDataGrid.js +23 -71
  56. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +30 -25
  57. package/dist/components/data/DataGrid/index.js +3 -16
  58. package/dist/components/data/DataGrid/styles.d.ts +8 -13
  59. package/dist/components/data/DataGrid/styles.js +30 -58
  60. package/dist/components/data/DataGrid/types.d.ts +15 -81
  61. package/dist/components/data/SqlRequestDataGrid/helpers/columns.d.ts +17 -16
  62. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +84 -236
  63. package/dist/components/data/SqlRequestDataGrid/index.js +63 -77
  64. package/dist/components/data/SqlRequestDataGrid/types.d.ts +3 -13
  65. package/dist/components/data/SqlRequestDataGrid/types.js +0 -1
  66. package/dist/components/data/SqlRequestGrid/index.d.ts +1 -1
  67. package/dist/components/data/SqlRequestGrid/index.js +49 -139
  68. package/dist/components/data/SqlRequestGrid/styles.d.ts +12 -0
  69. package/dist/components/data/SqlRequestGrid/styles.js +20 -4
  70. package/dist/components/data/SqlRequestGrid/types.d.ts +4 -14
  71. package/dist/components/data/VirtualScroller/index.d.ts +3 -4
  72. package/dist/components/data/VirtualScroller/index.js +5 -15
  73. package/dist/components/data/VirtualScroller/styles.d.ts +2 -4
  74. package/dist/components/data/VirtualScroller/styles.js +6 -9
  75. package/dist/components/data/index.d.ts +2 -1
  76. package/dist/components/data/index.js +2 -1
  77. package/dist/components/forms/Button.d.ts +2 -9
  78. package/dist/components/forms/Button.js +7 -13
  79. package/dist/components/forms/IconButton.d.ts +1 -2
  80. package/dist/components/forms/IconButton.js +12 -12
  81. package/dist/components/forms/Select.d.ts +6 -5
  82. package/dist/components/forms/Select.js +5 -2
  83. package/dist/components/forms/index.d.ts +0 -3
  84. package/dist/components/forms/index.js +0 -3
  85. package/dist/components/layout/Dropdown/index.d.ts +0 -1
  86. package/dist/components/layout/Dropdown/index.js +3 -24
  87. package/dist/components/layout/index.d.ts +1 -4
  88. package/dist/components/layout/index.js +1 -4
  89. package/dist/components/search/QuickSearchBar.js +0 -6
  90. package/dist/components/ui/Card/styles.js +1 -1
  91. package/dist/components/ui/index.d.ts +0 -3
  92. package/dist/components/ui/index.js +0 -3
  93. package/dist/helpers/index.d.ts +0 -1
  94. package/dist/helpers/index.js +0 -1
  95. package/dist/helpers/numbers.d.ts +0 -3
  96. package/dist/helpers/numbers.js +1 -33
  97. package/dist/hooks/index.d.ts +0 -4
  98. package/dist/hooks/index.js +0 -4
  99. package/dist/index.d.ts +0 -1
  100. package/dist/index.js +0 -1
  101. package/dist/providers/AuthenticationProvider/index.js +3 -4
  102. package/dist/providers/PortalsProvider/styles.js +1 -1
  103. package/dist/providers/ThemeProvider/defaultTheme.js +0 -13
  104. package/dist/providers/ThemeProvider/types.d.ts +1 -2
  105. package/dist/providers/UiProviders/index.js +1 -2
  106. package/dist/providers/index.d.ts +0 -2
  107. package/dist/providers/index.js +0 -2
  108. package/dist/services/globalSearch.d.ts +1 -2
  109. package/dist/services/index.d.ts +0 -7
  110. package/dist/services/index.js +0 -20
  111. package/package.json +2 -2
  112. package/src/Icons.tsx +136 -134
  113. package/src/components/auth/LoginForm.tsx +84 -84
  114. package/src/components/auth/LoginPage.tsx +32 -32
  115. package/src/components/auth/PasswordRecoveryForm.tsx +52 -52
  116. package/src/components/auth/PasswordResetForm.tsx +112 -112
  117. package/src/components/auth/index.ts +4 -4
  118. package/src/components/auth/styles.ts +14 -14
  119. package/src/components/data/DataGrid/DataGridCell.tsx +77 -77
  120. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +9 -9
  121. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  122. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +182 -182
  123. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  124. package/src/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.tsx +38 -38
  125. package/src/components/data/DataGrid/DataGridEditableCell/DateEditableCell.tsx +39 -39
  126. package/src/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.tsx +68 -68
  127. package/src/components/data/DataGrid/DataGridEditableCell/TextEditableCell.tsx +38 -38
  128. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +106 -106
  129. package/src/components/data/DataGrid/DataGridEditableCell/styles.ts +35 -35
  130. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +19 -19
  131. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +131 -131
  132. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +81 -81
  133. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +376 -376
  134. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  135. package/src/components/data/DataGrid/DataGridFooter.tsx +45 -45
  136. package/src/components/data/DataGrid/DataGridHeader.tsx +185 -185
  137. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +111 -111
  138. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +82 -82
  139. package/src/components/data/DataGrid/FilterModalContent/index.tsx +136 -136
  140. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  141. package/src/components/data/DataGrid/constants.ts +6 -6
  142. package/src/components/data/DataGrid/helpers/columns.tsx +386 -386
  143. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  144. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  145. package/src/components/data/DataGrid/hooks/index.ts +29 -29
  146. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +381 -381
  147. package/src/components/data/DataGrid/hooks/useDataGridChangedRows.ts +97 -97
  148. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +174 -174
  149. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  150. package/src/components/data/DataGrid/hooks/useRefreshModal.tsx +48 -48
  151. package/src/components/data/DataGrid/index.tsx +112 -112
  152. package/src/components/data/DataGrid/styles.ts +380 -379
  153. package/src/components/data/DataGrid/types.ts +369 -369
  154. package/src/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.tsx +16 -16
  155. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +481 -481
  156. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  157. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  158. package/src/components/data/SqlRequestDataGrid/index.tsx +414 -414
  159. package/src/components/data/SqlRequestDataGrid/styles.ts +15 -15
  160. package/src/components/data/SqlRequestDataGrid/types.ts +74 -74
  161. package/src/components/data/SqlRequestForeignList/index.tsx +259 -259
  162. package/src/components/data/SqlRequestForeignList/styles.ts +43 -43
  163. package/src/components/data/SqlRequestForeignList/types.ts +34 -34
  164. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +110 -110
  165. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  166. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  167. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  168. package/src/components/data/SqlRequestGrid/index.tsx +316 -316
  169. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  170. package/src/components/data/SqlRequestGrid/types.ts +75 -75
  171. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  172. package/src/components/data/VirtualScroller/index.tsx +91 -91
  173. package/src/components/data/VirtualScroller/styles.ts +58 -58
  174. package/src/components/data/VirtualScroller/types.ts +12 -12
  175. package/src/components/data/index.ts +16 -16
  176. package/src/components/forms/AutoTextArea.tsx +41 -41
  177. package/src/components/forms/Button.tsx +133 -133
  178. package/src/components/forms/Form/Checkbox.tsx +12 -12
  179. package/src/components/forms/Form/FormGroup.tsx +31 -31
  180. package/src/components/forms/Form/Input.tsx +16 -16
  181. package/src/components/forms/Form/Row.tsx +32 -32
  182. package/src/components/forms/Form/Select.tsx +87 -81
  183. package/src/components/forms/Form/TextArea.tsx +17 -17
  184. package/src/components/forms/Form/index.tsx +45 -45
  185. package/src/components/forms/Form/styles.ts +184 -180
  186. package/src/components/forms/IconButton.tsx +57 -57
  187. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  188. package/src/components/forms/Select.tsx +35 -35
  189. package/src/components/forms/VerticalLabel.tsx +20 -20
  190. package/src/components/forms/index.ts +9 -9
  191. package/src/components/forms/styles.ts +29 -29
  192. package/src/components/index.ts +6 -6
  193. package/src/components/layout/Columns.ts +28 -24
  194. package/src/components/layout/Dropdown/index.tsx +113 -113
  195. package/src/components/layout/Dropdown/styles.ts +45 -45
  196. package/src/components/layout/Grid/index.tsx +8 -8
  197. package/src/components/layout/Grid/styles.ts +34 -34
  198. package/src/components/layout/Loading/index.tsx +29 -29
  199. package/src/components/layout/Loading/styles.ts +29 -29
  200. package/src/components/layout/Masonry/index.tsx +29 -29
  201. package/src/components/layout/Masonry/styles.ts +20 -20
  202. package/src/components/layout/Modal/index.tsx +51 -51
  203. package/src/components/layout/Modal/styles.ts +125 -125
  204. package/src/components/layout/index.ts +6 -6
  205. package/src/components/search/HighlightedText.tsx +41 -41
  206. package/src/components/search/QuickSearchBar.tsx +100 -100
  207. package/src/components/search/QuickSearchResults.tsx +86 -86
  208. package/src/components/search/index.ts +9 -9
  209. package/src/components/search/styles.ts +96 -96
  210. package/src/components/search/types.ts +29 -29
  211. package/src/components/ui/Avatar/index.tsx +54 -54
  212. package/src/components/ui/Card/index.tsx +14 -14
  213. package/src/components/ui/Card/styles.ts +37 -37
  214. package/src/components/ui/ContextMenu/index.tsx +79 -79
  215. package/src/components/ui/ContextMenu/styles.ts +119 -119
  216. package/src/components/ui/Ellipsis.tsx +34 -34
  217. package/src/components/ui/Label.tsx +90 -90
  218. package/src/components/ui/Message/index.tsx +57 -57
  219. package/src/components/ui/Message/styles.ts +40 -40
  220. package/src/components/ui/index.ts +6 -6
  221. package/src/config/index.ts +14 -14
  222. package/src/helpers/dates.ts +17 -17
  223. package/src/helpers/getScrollbarSize.ts +14 -14
  224. package/src/helpers/index.ts +5 -4
  225. package/src/helpers/numbers.ts +63 -63
  226. package/src/helpers/responsive.ts +83 -83
  227. package/src/helpers/styled/index.ts +1 -0
  228. package/src/helpers/styled/space.ts +55 -0
  229. package/src/helpers/text.ts +13 -13
  230. package/src/hooks/index.ts +7 -7
  231. package/src/hooks/useContainerMediaQuery.ts +7 -7
  232. package/src/hooks/useElementSize.ts +24 -24
  233. package/src/hooks/useMediaQuery.ts +9 -9
  234. package/src/hooks/useMediaQueryForWidth.ts +35 -35
  235. package/src/hooks/useMutableState.ts +19 -19
  236. package/src/hooks/useShowArchived.ts +28 -28
  237. package/src/hooks/useWindowSize.ts +20 -20
  238. package/src/index.ts +9 -9
  239. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  240. package/src/providers/AuthenticationProvider/index.tsx +303 -303
  241. package/src/providers/LoadingProvider/index.tsx +47 -47
  242. package/src/providers/PortalsProvider/index.tsx +54 -54
  243. package/src/providers/PortalsProvider/styles.ts +31 -31
  244. package/src/providers/SettingsProvider/index.tsx +70 -70
  245. package/src/providers/ThemeProvider/ThemeProvider.ts +63 -63
  246. package/src/providers/ThemeProvider/defaultTheme.ts +457 -457
  247. package/src/providers/ThemeProvider/helpers.ts +11 -11
  248. package/src/providers/ThemeProvider/index.ts +4 -4
  249. package/src/providers/ThemeProvider/types.ts +131 -131
  250. package/src/providers/TrackingProvider/index.tsx +71 -71
  251. package/src/providers/UiProviders/index.tsx +68 -68
  252. package/src/providers/UiProviders/styles.ts +10 -10
  253. package/src/providers/hooks.ts +12 -12
  254. package/src/providers/index.ts +8 -8
  255. package/src/services/HttpService.ts +92 -92
  256. package/src/services/WebSocketService.ts +155 -155
  257. package/src/services/advancedRequests.ts +102 -102
  258. package/src/services/base.ts +23 -23
  259. package/src/services/globalSearch.ts +32 -32
  260. package/src/services/hooks.ts +92 -92
  261. package/src/services/index.ts +21 -21
  262. package/src/services/requests/auth.ts +44 -44
  263. package/src/services/requests/generic.ts +62 -62
  264. package/src/services/requests/tracking.ts +12 -12
  265. package/src/services/requests/userProfiles.ts +35 -35
  266. package/src/services/requests/users.ts +28 -28
  267. package/src/services/smartQueries.ts +122 -122
  268. package/src/services/sqlRequests.ts +111 -111
  269. package/src/services/types/auth.ts +131 -131
  270. package/src/services/types/base.ts +10 -10
  271. package/src/services/types/generic.ts +96 -96
  272. package/src/services/types/tracking.ts +39 -39
  273. package/src/services/types/userProfiles.ts +107 -107
  274. package/src/services/types/users.ts +106 -106
  275. package/src/services/updateSqlRequests.ts +34 -34
  276. package/src/styles/animations.scss +30 -30
  277. package/src/styles/index.scss +42 -42
  278. package/src/typings.d.ts +19 -19
  279. package/tsconfig.json +18 -18
  280. package/tsconfig.tsbuildinfo +1 -1
  281. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +0 -10
  282. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +0 -173
  283. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.d.ts +0 -2
  284. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.js +0 -23
  285. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.d.ts +0 -2
  286. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.js +0 -27
  287. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.d.ts +0 -5
  288. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.js +0 -32
  289. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.d.ts +0 -2
  290. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.js +0 -23
  291. package/dist/components/data/DataGrid/DataGridEditableCell/index.d.ts +0 -2
  292. package/dist/components/data/DataGrid/DataGridEditableCell/index.js +0 -91
  293. package/dist/components/data/DataGrid/DataGridEditableCell/styles.d.ts +0 -3
  294. package/dist/components/data/DataGrid/DataGridEditableCell/styles.js +0 -17
  295. package/dist/components/data/DataGrid/DataGridEditableCell/types.d.ts +0 -11
  296. package/dist/components/data/DataGrid/DataGridEditableCell/types.js +0 -3
  297. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +0 -13
  298. package/dist/components/data/DataGrid/FilterValuesScroller.js +0 -73
  299. package/dist/components/data/DataGrid/VirtualScroller.d.ts +0 -11
  300. package/dist/components/data/DataGrid/VirtualScroller.js +0 -41
  301. package/dist/components/data/DataGrid/constants.d.ts +0 -6
  302. package/dist/components/data/DataGrid/constants.js +0 -9
  303. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +0 -12
  304. package/dist/components/data/DataGrid/helpers/advancedRequests.js +0 -53
  305. package/dist/components/data/DataGrid/helpers.d.ts +0 -28
  306. package/dist/components/data/DataGrid/helpers.js +0 -436
  307. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.d.ts +0 -9
  308. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.js +0 -71
  309. package/dist/components/data/SmartQueryDataGrid/helpers/columns.d.ts +0 -20
  310. package/dist/components/data/SmartQueryDataGrid/helpers/columns.js +0 -160
  311. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.d.ts +0 -5
  312. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.js +0 -41
  313. package/dist/components/data/SmartQueryDataGrid/helpers/index.d.ts +0 -2
  314. package/dist/components/data/SmartQueryDataGrid/helpers/index.js +0 -18
  315. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.d.ts +0 -3
  316. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.js +0 -15
  317. package/dist/components/data/SmartQueryDataGrid/hooks.d.ts +0 -9
  318. package/dist/components/data/SmartQueryDataGrid/hooks.js +0 -63
  319. package/dist/components/data/SmartQueryDataGrid/index.d.ts +0 -12
  320. package/dist/components/data/SmartQueryDataGrid/index.js +0 -242
  321. package/dist/components/data/SmartQueryDataGrid/types.d.ts +0 -22
  322. package/dist/components/data/SmartQueryDataGrid/types.js +0 -2
  323. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.d.ts +0 -2
  324. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.js +0 -19
  325. package/dist/components/data/SqlRequestDataGrid/styles.d.ts +0 -2
  326. package/dist/components/data/SqlRequestDataGrid/styles.js +0 -14
  327. package/dist/components/data/SqlRequestForeignList/index.d.ts +0 -4
  328. package/dist/components/data/SqlRequestForeignList/index.js +0 -131
  329. package/dist/components/data/SqlRequestForeignList/styles.d.ts +0 -9
  330. package/dist/components/data/SqlRequestForeignList/styles.js +0 -22
  331. package/dist/components/data/SqlRequestForeignList/types.d.ts +0 -22
  332. package/dist/components/data/SqlRequestForeignList/types.js +0 -3
  333. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.d.ts +0 -10
  334. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.js +0 -51
  335. package/dist/components/data/SqlRequestGrid/filters/styles.d.ts +0 -4
  336. package/dist/components/data/SqlRequestGrid/filters/styles.js +0 -17
  337. package/dist/components/forms/AutoTextArea.d.ts +0 -10
  338. package/dist/components/forms/AutoTextArea.js +0 -40
  339. package/dist/components/forms/Form/Checkbox.d.ts +0 -3
  340. package/dist/components/forms/Form/Checkbox.js +0 -33
  341. package/dist/components/forms/Form/FormGroup.d.ts +0 -9
  342. package/dist/components/forms/Form/FormGroup.js +0 -10
  343. package/dist/components/forms/Form/Input.d.ts +0 -3
  344. package/dist/components/forms/Form/Input.js +0 -32
  345. package/dist/components/forms/Form/InputWithLabel.d.ts +0 -2
  346. package/dist/components/forms/Form/InputWithLabel.js +0 -10
  347. package/dist/components/forms/Form/Select.d.ts +0 -17
  348. package/dist/components/forms/Form/Select.js +0 -46
  349. package/dist/components/forms/Form/TextArea.d.ts +0 -4
  350. package/dist/components/forms/Form/TextArea.js +0 -33
  351. package/dist/components/forms/Form/index.d.ts +0 -66
  352. package/dist/components/forms/Form/index.js +0 -24
  353. package/dist/components/forms/Form/styles.d.ts +0 -14
  354. package/dist/components/forms/Form/styles.js +0 -47
  355. package/dist/components/forms/Form/types.d.ts +0 -7
  356. package/dist/components/forms/Form/types.js +0 -2
  357. package/dist/components/layout/Columns.d.ts +0 -5
  358. package/dist/components/layout/Columns.js +0 -19
  359. package/dist/components/layout/Grid/index.d.ts +0 -6
  360. package/dist/components/layout/Grid/index.js +0 -6
  361. package/dist/components/layout/Grid/styles.d.ts +0 -14
  362. package/dist/components/layout/Grid/styles.js +0 -29
  363. package/dist/components/layout/Masonry/index.d.ts +0 -3
  364. package/dist/components/layout/Masonry/index.js +0 -20
  365. package/dist/components/layout/Masonry/styles.d.ts +0 -5
  366. package/dist/components/layout/Masonry/styles.js +0 -17
  367. package/dist/components/ui/Avatar/index.d.ts +0 -10
  368. package/dist/components/ui/Avatar/index.js +0 -52
  369. package/dist/components/ui/Avatar/styles.d.ts +0 -4
  370. package/dist/components/ui/Avatar/styles.js +0 -43
  371. package/dist/components/ui/Ellipsis.d.ts +0 -13
  372. package/dist/components/ui/Ellipsis.js +0 -28
  373. package/dist/components/ui/Label.d.ts +0 -9
  374. package/dist/components/ui/Label.js +0 -74
  375. package/dist/config/types.d.ts +0 -11
  376. package/dist/config/types.js +0 -2
  377. package/dist/helpers/responsive.d.ts +0 -37
  378. package/dist/helpers/responsive.js +0 -57
  379. package/dist/hooks/useContainerMediaQuery.d.ts +0 -17
  380. package/dist/hooks/useContainerMediaQuery.js +0 -10
  381. package/dist/hooks/useMediaQuery.d.ts +0 -17
  382. package/dist/hooks/useMediaQuery.js +0 -11
  383. package/dist/hooks/useMediaQueryForWidth.d.ts +0 -17
  384. package/dist/hooks/useMediaQueryForWidth.js +0 -26
  385. package/dist/hooks/useShowArchived.d.ts +0 -6
  386. package/dist/hooks/useShowArchived.js +0 -21
  387. package/dist/providers/ThemeProvider/helpers.d.ts +0 -3
  388. package/dist/providers/ThemeProvider/helpers.js +0 -13
  389. package/dist/providers/TrackingProvider/hooks.d.ts +0 -1
  390. package/dist/providers/TrackingProvider/hooks.js +0 -15
  391. package/dist/providers/TrackingProvider/index.d.ts +0 -8
  392. package/dist/providers/TrackingProvider/index.js +0 -41
  393. package/dist/services/requests/generic.d.ts +0 -29
  394. package/dist/services/requests/generic.js +0 -29
  395. package/dist/services/requests/tracking.d.ts +0 -18
  396. package/dist/services/requests/tracking.js +0 -8
  397. package/dist/services/requests/userPermissions.d.ts +0 -4
  398. package/dist/services/requests/userPermissions.js +0 -20
  399. package/dist/services/smartQueries.d.ts +0 -51
  400. package/dist/services/smartQueries.js +0 -10
  401. package/dist/services/smartRequests.d.ts +0 -0
  402. package/dist/services/smartRequests.js +0 -1
  403. package/dist/services/types/generic.d.ts +0 -44
  404. package/dist/services/types/generic.js +0 -79
  405. package/dist/services/types/tracking.d.ts +0 -24
  406. package/dist/services/types/tracking.js +0 -47
  407. package/dist/services/updateSqlRequests.d.ts +0 -24
  408. package/dist/services/updateSqlRequests.js +0 -7
@@ -1,369 +1,369 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
-
3
- import * as t from 'io-ts';
4
-
5
- import {
6
- CSSProperties,
7
- Context,
8
- Dispatch,
9
- FC,
10
- MouseEvent,
11
- MouseEventHandler,
12
- ReactNode,
13
- SetStateAction,
14
- } from 'react';
15
-
16
- import { DataGridEditableCellFC } from './DataGridEditableCell/types';
17
- import { ThemeColor } from '../../../providers/ThemeProvider/types';
18
-
19
- export type DataGridCellFCProps = {
20
- onDoubleClick?: MouseEventHandler;
21
- style?: CSSProperties;
22
- $color?: ThemeColor;
23
- $textAlign?: 'left' | 'right' | 'center';
24
- $userSelect?: boolean;
25
- };
26
-
27
- export type DataGridCellFC = FC<DataGridCellFCProps>;
28
-
29
- export type DataGridFooterPredefinedFunction =
30
- | 'average'
31
- | 'avg'
32
- | 'count'
33
- | 'max'
34
- | 'min'
35
- | 'sum';
36
- export type DataGridFooterFunction<R> = (
37
- allRows: R[],
38
- filteredRows: R[],
39
- selectedRows: R[]
40
- ) => ReactNode;
41
-
42
- type ExcelOptions = {
43
- formatter?: (value: any) => string;
44
- colorGetter?: (value: any) => string;
45
- valueGetter?: (value: any) => string;
46
- };
47
-
48
- type CommonGridColumnProps<R, T> = {
49
- key: string;
50
- component?: DataGridCellFC;
51
- color?: ThemeColor;
52
- excelOptions?: ExcelOptions;
53
- textAlign?: 'left' | 'right' | 'center';
54
- filter?: DataGridFilter;
55
- footer?:
56
- | DataGridFooterFunction<R>
57
- | Record<string, DataGridFooterFunction<R> | null>;
58
- name: ReactNode;
59
- order?: number;
60
- getter: (row: R) => T;
61
- render?: (row: R, column: DataGridColumn<R>) => ReactNode | string;
62
- resizable?: boolean;
63
- sortGetter?: (row: R) => string | number;
64
- width?: number;
65
- };
66
-
67
- export type EditableDataGridColumn<R, T> = CommonGridColumnProps<R, T> & {
68
- editable?: boolean;
69
- editComponent?: DataGridEditableCellFC<R, T>;
70
- itemToPartialRow?: (key: string, row: R, value: T) => Partial<R>;
71
- };
72
-
73
- export type DataGridTextColumn<R> = EditableDataGridColumn<R, string> & {
74
- type: 'text';
75
- };
76
-
77
- export type DataGridNumberColumn<R> = EditableDataGridColumn<R, number> & {
78
- type: 'number';
79
- decimals?: number;
80
- currency?: string | ((row: R) => string);
81
- };
82
-
83
- export type DataGridDateColumn<R> = EditableDataGridColumn<R, string> & {
84
- type: 'date';
85
- };
86
-
87
- export type DataGridCheckboxColumn<R> = EditableDataGridColumn<R, boolean> & {
88
- type: 'checkbox';
89
- };
90
-
91
- export type DataGridSelectColumn<R, T = any> = EditableDataGridColumn<
92
- R,
93
- T | null
94
- > & {
95
- type: 'select';
96
- items: T[];
97
- itemKey: (item: T) => string;
98
- itemLabel: (item: T) => string;
99
- };
100
-
101
- export type DataGridForeignListColumn<R> = EditableDataGridColumn<
102
- R,
103
- string | null
104
- > & {
105
- type: 'foreignList';
106
- };
107
-
108
- export type DataGridColorColumn<R> = EditableDataGridColumn<R, string> & {
109
- type: 'color';
110
- };
111
-
112
- export type DataGridColumn<R> =
113
- | DataGridTextColumn<R>
114
- | DataGridNumberColumn<R>
115
- | DataGridDateColumn<R>
116
- | DataGridCheckboxColumn<R>
117
- | DataGridSelectColumn<R>
118
- | DataGridForeignListColumn<R>
119
- | DataGridColorColumn<R>;
120
-
121
- export type DataGridColumnWithFilter<R> = DataGridColumn<R> & {
122
- filter: DataGridFilter;
123
- };
124
-
125
- export type DataGridColumns<R> = DataGridColumn<R>[];
126
-
127
- export type DataGridFilters = Record<
128
- string,
129
- DataGridFilter<DataGridFilterType>
130
- >;
131
-
132
- export type DataGridProps<R> = {
133
- name?: string;
134
- className?: string;
135
- rows: R[];
136
- setRows?: Dispatch<SetStateAction<R[]>>;
137
- columns: DataGridColumns<R>;
138
- rowKey: string;
139
- selectable?: boolean;
140
- userSelect?: boolean;
141
- editable?: boolean;
142
- onRowDoubleClick?: (row: R, e: MouseEvent) => void;
143
- onSelectionChange?: (keys: string[]) => void;
144
- onSelectedRowsChanged?: (rows: R[]) => void;
145
- getAllIds?: () => Promise<string[]>;
146
- onFiltersChanged?: (filters: DataGridFilters) => void;
147
- onSortsChanged?: (sorts: Record<string, DataGridSort>) => void;
148
- onVisibleRowsChange?: (startIndex: number, length: number) => void;
149
- onCellEdited?: (row: R, columnKey: string, value: any) => void;
150
- rowClassNameGetter?: (row: R | null) => {
151
- className?: string;
152
- style?: CSSProperties;
153
- };
154
- headerRowHeight?: number;
155
- rowHeight?: number;
156
- filter?: boolean;
157
- sort?: boolean;
158
- initialSorts?: Record<string, DataGridSort>;
159
- initialFooters?: Record<string, string>;
160
- onFootersChanged?: (footers: Record<string, string>) => void;
161
- filterValuesLoader?: (
162
- columnKey: string
163
- ) => Promise<(string | number | null)[]>;
164
- loadCopyRows?: () => Promise<R[]>;
165
- refresh?: () => void;
166
- headerColor?: ThemeColor;
167
- fixedColumnsCount?: number;
168
- onRowEdited?: (row: R, columnKey: keyof R, value: any) => void;
169
- onSaveClicked?: (
170
- addedRows: DataGridEditedRows<R>,
171
- editedRows: DataGridEditedRows<R>
172
- ) => Promise<string[]>;
173
- onAddClicked?: () => Promise<R>;
174
- };
175
-
176
- export type DataGridContextProps<R> = DataGridProps<R> & {
177
- setRows: Dispatch<SetStateAction<R[]>>;
178
- editingCell?: [number, number];
179
- setEditingCell: Dispatch<SetStateAction<[number, number]>>;
180
- sortedRows: R[];
181
- selectedRows: R[];
182
- selectedKeys: string[];
183
- setSelectedKeys: (selection: string[]) => void;
184
- sorts?: Record<string, DataGridSort>;
185
- setSorts: (sorts: Record<string, DataGridSort>) => void;
186
- filters?: DataGridFilters;
187
- setFilters: Dispatch<SetStateAction<DataGridFilters>>;
188
- footers?: Record<string, string>;
189
- setFooters: Dispatch<SetStateAction<Record<string, string>>>;
190
- footerFunctions?: Record<string, DataGridFooterFunction<R>>;
191
- visibleColumns: DataGridColumns<R>;
192
- copyTable: (
193
- includeHeaders?: boolean,
194
- includeFooters?: boolean
195
- ) => Promise<void>;
196
- setColumnWidth: (key: string, width: number) => void;
197
- saveSettings: (newSettings?: DataGridSettings) => void;
198
- settings: DataGridSettings;
199
- setSettings: Dispatch<SetStateAction<DataGridSettings>>;
200
- length: number;
201
- rowKeyGetter: (row: R) => string;
202
- gridTemplateColumns: string;
203
- resizingColumnKey: string | null;
204
- startResizing: (e: MouseEvent, columnKey: string) => void;
205
- moveResizing: (e: MouseEvent) => void;
206
- endResizing: () => void;
207
- toggleSelection: (key: string) => void;
208
-
209
- addedRows: DataGridEditedRows<R>;
210
- updatedRows: DataGridEditedRows<R>;
211
- editRow: (row: Partial<R>) => void;
212
- addRow: (row: R) => void;
213
- addRows: (rows: R[]) => void;
214
- updateRow: (row: Partial<R>) => void;
215
- clearChangedRows: (keys?: string[]) => void;
216
- };
217
-
218
- export type DataGridContext<R> = Context<DataGridContextProps<R>>;
219
-
220
- export const dataGridSettingCodec = t.partial(
221
- {
222
- width: t.number,
223
- order: t.number,
224
- },
225
- 'DataGridSetting'
226
- );
227
- export const dataGridSettingsCodec = t.record(
228
- t.string,
229
- dataGridSettingCodec,
230
- 'DataGridSettings'
231
- );
232
- export const dataGridSettingsByNameCodec = t.record(
233
- t.string,
234
- dataGridSettingsCodec,
235
- 'DataGridSettingsByName'
236
- );
237
-
238
- export type DataGridSetting = t.TypeOf<typeof dataGridSettingCodec>;
239
- export type DataGridSettings = t.TypeOf<typeof dataGridSettingsCodec>;
240
- export type DataGridSettingsByName = t.TypeOf<
241
- typeof dataGridSettingsByNameCodec
242
- >;
243
- export type DataGridSettingsTuple = [string, DataGridSetting];
244
- export type DataGridSettingsArray = DataGridSettingsTuple[];
245
- export type DataGridColumnKeyValuePair<R> = [string, DataGridColumn<R>];
246
-
247
- export type DataGridCellProps<R> = {
248
- row: R;
249
- rowIndex: number;
250
- columnKey: string;
251
- columnIndex: number;
252
- column: DataGridColumn<R>;
253
- context: DataGridContext<R>;
254
- className?: string;
255
- style?: CSSProperties;
256
- userSelect?: boolean;
257
- color?: ThemeColor;
258
- };
259
- export type EditableDataGridCellProps<R, T> = DataGridCellProps<R> & {
260
- column: EditableDataGridColumn<R, T>;
261
- };
262
-
263
- export type DataGridHeaderCellProps<R> = {
264
- columnKey: string;
265
- columnIndex: number;
266
- column: DataGridColumn<R>;
267
- context: DataGridContext<R>;
268
- onFilterButtonClicked?: (columnKey: string) => void;
269
- isFilterOpen?: boolean;
270
- color?: ThemeColor;
271
- };
272
-
273
- export type DataGridSort = 'asc' | 'desc';
274
-
275
- export type DataGridFilterPredicate<T> = (valueToVerify: T) => boolean;
276
- export type DataGridFilterPredicateBuilder<T> = (
277
- ...filterValues: T[]
278
- ) => DataGridFilterPredicate<T>;
279
-
280
- export type DataGridFilterOperators<K extends string, T> = {
281
- [key in K]: DataGridFilterPredicateBuilder<T>;
282
- };
283
-
284
- export type DataGridFilterPredicates = {
285
- date: DataGridFilterOperators<
286
- 'before' | 'after' | 'equals' | 'notEquals' | 'inRange' | 'inArray',
287
- string
288
- >;
289
- text: DataGridFilterOperators<
290
- | 'contains'
291
- | 'notContains'
292
- | 'equals'
293
- | 'notEquals'
294
- | 'startsWith'
295
- | 'endsWith'
296
- | 'inArray',
297
- string
298
- >;
299
- number: DataGridFilterOperators<
300
- | 'equals'
301
- | 'notEquals'
302
- | 'lessThan'
303
- | 'lessThanOrEqual'
304
- | 'greaterThan'
305
- | 'greaterThanOrEqual'
306
- | 'inRange'
307
- | 'inArray',
308
- number
309
- >;
310
- };
311
-
312
- export type DataGridFilterType = keyof DataGridFilterPredicates;
313
- export type DataGridFilterDataType<T extends DataGridFilterType> =
314
- DataGridFilterPredicates[T] extends DataGridFilterOperators<string, infer U>
315
- ? U
316
- : never;
317
-
318
- export type DataGridFilterGetter<T extends DataGridFilterType> = (
319
- value: any
320
- ) => DataGridFilterDataType<T> | null;
321
- export type DataGridFilterRenderer = (value: any) => ReactNode;
322
- export type DataGridFilterFormatter = (value: any) => string;
323
-
324
- export type DataGridFilterOperator<T extends DataGridFilterType> =
325
- DataGridFilterPredicates[T] extends DataGridFilterOperators<infer K, any>
326
- ? K
327
- : never;
328
-
329
- export type DataGridFilter<T extends string = DataGridFilterType> =
330
- T extends DataGridFilterType
331
- ? {
332
- type: T;
333
- operator: DataGridFilterOperator<T>;
334
- getter: DataGridFilterGetter<T>;
335
- renderer?: DataGridFilterRenderer;
336
- formatter?: DataGridFilterFormatter;
337
- values: (DataGridFilterDataType<T> | null)[];
338
- }
339
- : never;
340
-
341
- export type DataGridFilterGroup = {
342
- name: string;
343
- displayValue: DataGridFilterValue;
344
- values?: DataGridFilterValue[];
345
- groups?: DataGridFilterGroup[];
346
- };
347
-
348
- export type DataGridFilterValue = string | number | null;
349
-
350
- export type DataGridFilterCheckbox = {
351
- displayValue: ReactNode;
352
- title: string;
353
- values: DataGridFilterValue[];
354
- level: number;
355
- };
356
-
357
- export type DataGridRowTemplateProps<R> = {
358
- selected?: boolean;
359
- toggleSelection?: () => void;
360
- context: DataGridContext<R>;
361
- };
362
-
363
- export type DataGridRefProps<R> = {
364
- refresh: () => void;
365
- setSelectedKeys: (keys: string[]) => void;
366
- addRows: (rows: R[]) => void;
367
- };
368
-
369
- export type DataGridEditedRows<R> = Partial<R>[];
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ import * as t from 'io-ts';
4
+
5
+ import {
6
+ CSSProperties,
7
+ Context,
8
+ Dispatch,
9
+ FC,
10
+ MouseEvent,
11
+ MouseEventHandler,
12
+ ReactNode,
13
+ SetStateAction,
14
+ } from 'react';
15
+
16
+ import { DataGridEditableCellFC } from './DataGridEditableCell/types';
17
+ import { ThemeColor } from '../../../providers/ThemeProvider/types';
18
+
19
+ export type DataGridCellFCProps = {
20
+ onDoubleClick?: MouseEventHandler;
21
+ style?: CSSProperties;
22
+ $color?: ThemeColor;
23
+ $textAlign?: 'left' | 'right' | 'center';
24
+ $userSelect?: boolean;
25
+ };
26
+
27
+ export type DataGridCellFC = FC<DataGridCellFCProps>;
28
+
29
+ export type DataGridFooterPredefinedFunction =
30
+ | 'average'
31
+ | 'avg'
32
+ | 'count'
33
+ | 'max'
34
+ | 'min'
35
+ | 'sum';
36
+ export type DataGridFooterFunction<R> = (
37
+ allRows: R[],
38
+ filteredRows: R[],
39
+ selectedRows: R[]
40
+ ) => ReactNode;
41
+
42
+ type ExcelOptions = {
43
+ formatter?: (value: any) => string;
44
+ colorGetter?: (value: any) => string;
45
+ valueGetter?: (value: any) => string;
46
+ };
47
+
48
+ type CommonGridColumnProps<R, T> = {
49
+ key: string;
50
+ component?: DataGridCellFC;
51
+ color?: ThemeColor;
52
+ excelOptions?: ExcelOptions;
53
+ textAlign?: 'left' | 'right' | 'center';
54
+ filter?: DataGridFilter;
55
+ footer?:
56
+ | DataGridFooterFunction<R>
57
+ | Record<string, DataGridFooterFunction<R> | null>;
58
+ name: ReactNode;
59
+ order?: number;
60
+ getter: (row: R) => T;
61
+ render?: (row: R, column: DataGridColumn<R>) => ReactNode | string;
62
+ resizable?: boolean;
63
+ sortGetter?: (row: R) => string | number;
64
+ width?: number;
65
+ };
66
+
67
+ export type EditableDataGridColumn<R, T> = CommonGridColumnProps<R, T> & {
68
+ editable?: boolean;
69
+ editComponent?: DataGridEditableCellFC<R, T>;
70
+ itemToPartialRow?: (key: string, row: R, value: T) => Partial<R>;
71
+ };
72
+
73
+ export type DataGridTextColumn<R> = EditableDataGridColumn<R, string> & {
74
+ type: 'text';
75
+ };
76
+
77
+ export type DataGridNumberColumn<R> = EditableDataGridColumn<R, number> & {
78
+ type: 'number';
79
+ decimals?: number;
80
+ currency?: string | ((row: R) => string);
81
+ };
82
+
83
+ export type DataGridDateColumn<R> = EditableDataGridColumn<R, string> & {
84
+ type: 'date';
85
+ };
86
+
87
+ export type DataGridCheckboxColumn<R> = EditableDataGridColumn<R, boolean> & {
88
+ type: 'checkbox';
89
+ };
90
+
91
+ export type DataGridSelectColumn<R, T = any> = EditableDataGridColumn<
92
+ R,
93
+ T | null
94
+ > & {
95
+ type: 'select';
96
+ items: T[];
97
+ itemKey: (item: T) => string;
98
+ itemLabel: (item: T) => string;
99
+ };
100
+
101
+ export type DataGridForeignListColumn<R> = EditableDataGridColumn<
102
+ R,
103
+ string | null
104
+ > & {
105
+ type: 'foreignList';
106
+ };
107
+
108
+ export type DataGridColorColumn<R> = EditableDataGridColumn<R, string> & {
109
+ type: 'color';
110
+ };
111
+
112
+ export type DataGridColumn<R> =
113
+ | DataGridTextColumn<R>
114
+ | DataGridNumberColumn<R>
115
+ | DataGridDateColumn<R>
116
+ | DataGridCheckboxColumn<R>
117
+ | DataGridSelectColumn<R>
118
+ | DataGridForeignListColumn<R>
119
+ | DataGridColorColumn<R>;
120
+
121
+ export type DataGridColumnWithFilter<R> = DataGridColumn<R> & {
122
+ filter: DataGridFilter;
123
+ };
124
+
125
+ export type DataGridColumns<R> = DataGridColumn<R>[];
126
+
127
+ export type DataGridFilters = Record<
128
+ string,
129
+ DataGridFilter<DataGridFilterType>
130
+ >;
131
+
132
+ export type DataGridProps<R> = {
133
+ name?: string;
134
+ className?: string;
135
+ rows: R[];
136
+ setRows?: Dispatch<SetStateAction<R[]>>;
137
+ columns: DataGridColumns<R>;
138
+ rowKey: string;
139
+ selectable?: boolean;
140
+ userSelect?: boolean;
141
+ editable?: boolean;
142
+ onRowDoubleClick?: (row: R, e: MouseEvent) => void;
143
+ onSelectionChange?: (keys: string[]) => void;
144
+ onSelectedRowsChanged?: (rows: R[]) => void;
145
+ getAllIds?: () => Promise<string[]>;
146
+ onFiltersChanged?: (filters: DataGridFilters) => void;
147
+ onSortsChanged?: (sorts: Record<string, DataGridSort>) => void;
148
+ onVisibleRowsChange?: (startIndex: number, length: number) => void;
149
+ onCellEdited?: (row: R, columnKey: string, value: any) => void;
150
+ rowClassNameGetter?: (row: R | null) => {
151
+ className?: string;
152
+ style?: CSSProperties;
153
+ };
154
+ headerRowHeight?: number;
155
+ rowHeight?: number;
156
+ filter?: boolean;
157
+ sort?: boolean;
158
+ initialSorts?: Record<string, DataGridSort>;
159
+ initialFooters?: Record<string, string>;
160
+ onFootersChanged?: (footers: Record<string, string>) => void;
161
+ filterValuesLoader?: (
162
+ columnKey: string
163
+ ) => Promise<(string | number | null)[]>;
164
+ loadCopyRows?: () => Promise<R[]>;
165
+ refresh?: () => void;
166
+ headerColor?: ThemeColor;
167
+ fixedColumnsCount?: number;
168
+ onRowEdited?: (row: R, columnKey: keyof R, value: any) => void;
169
+ onSaveClicked?: (
170
+ addedRows: DataGridEditedRows<R>,
171
+ editedRows: DataGridEditedRows<R>
172
+ ) => Promise<string[]>;
173
+ onAddClicked?: () => Promise<R>;
174
+ };
175
+
176
+ export type DataGridContextProps<R> = DataGridProps<R> & {
177
+ setRows: Dispatch<SetStateAction<R[]>>;
178
+ editingCell?: [number, number];
179
+ setEditingCell: Dispatch<SetStateAction<[number, number]>>;
180
+ sortedRows: R[];
181
+ selectedRows: R[];
182
+ selectedKeys: string[];
183
+ setSelectedKeys: (selection: string[]) => void;
184
+ sorts?: Record<string, DataGridSort>;
185
+ setSorts: (sorts: Record<string, DataGridSort>) => void;
186
+ filters?: DataGridFilters;
187
+ setFilters: Dispatch<SetStateAction<DataGridFilters>>;
188
+ footers?: Record<string, string>;
189
+ setFooters: Dispatch<SetStateAction<Record<string, string>>>;
190
+ footerFunctions?: Record<string, DataGridFooterFunction<R>>;
191
+ visibleColumns: DataGridColumns<R>;
192
+ copyTable: (
193
+ includeHeaders?: boolean,
194
+ includeFooters?: boolean
195
+ ) => Promise<void>;
196
+ setColumnWidth: (key: string, width: number) => void;
197
+ saveSettings: (newSettings?: DataGridSettings) => void;
198
+ settings: DataGridSettings;
199
+ setSettings: Dispatch<SetStateAction<DataGridSettings>>;
200
+ length: number;
201
+ rowKeyGetter: (row: R) => string;
202
+ gridTemplateColumns: string;
203
+ resizingColumnKey: string | null;
204
+ startResizing: (e: MouseEvent, columnKey: string) => void;
205
+ moveResizing: (e: MouseEvent) => void;
206
+ endResizing: () => void;
207
+ toggleSelection: (key: string) => void;
208
+
209
+ addedRows: DataGridEditedRows<R>;
210
+ updatedRows: DataGridEditedRows<R>;
211
+ editRow: (row: Partial<R>) => void;
212
+ addRow: (row: R) => void;
213
+ addRows: (rows: R[]) => void;
214
+ updateRow: (row: Partial<R>) => void;
215
+ clearChangedRows: (keys?: string[]) => void;
216
+ };
217
+
218
+ export type DataGridContext<R> = Context<DataGridContextProps<R>>;
219
+
220
+ export const dataGridSettingCodec = t.partial(
221
+ {
222
+ width: t.number,
223
+ order: t.number,
224
+ },
225
+ 'DataGridSetting'
226
+ );
227
+ export const dataGridSettingsCodec = t.record(
228
+ t.string,
229
+ dataGridSettingCodec,
230
+ 'DataGridSettings'
231
+ );
232
+ export const dataGridSettingsByNameCodec = t.record(
233
+ t.string,
234
+ dataGridSettingsCodec,
235
+ 'DataGridSettingsByName'
236
+ );
237
+
238
+ export type DataGridSetting = t.TypeOf<typeof dataGridSettingCodec>;
239
+ export type DataGridSettings = t.TypeOf<typeof dataGridSettingsCodec>;
240
+ export type DataGridSettingsByName = t.TypeOf<
241
+ typeof dataGridSettingsByNameCodec
242
+ >;
243
+ export type DataGridSettingsTuple = [string, DataGridSetting];
244
+ export type DataGridSettingsArray = DataGridSettingsTuple[];
245
+ export type DataGridColumnKeyValuePair<R> = [string, DataGridColumn<R>];
246
+
247
+ export type DataGridCellProps<R> = {
248
+ row: R;
249
+ rowIndex: number;
250
+ columnKey: string;
251
+ columnIndex: number;
252
+ column: DataGridColumn<R>;
253
+ context: DataGridContext<R>;
254
+ className?: string;
255
+ style?: CSSProperties;
256
+ userSelect?: boolean;
257
+ color?: ThemeColor;
258
+ };
259
+ export type EditableDataGridCellProps<R, T> = DataGridCellProps<R> & {
260
+ column: EditableDataGridColumn<R, T>;
261
+ };
262
+
263
+ export type DataGridHeaderCellProps<R> = {
264
+ columnKey: string;
265
+ columnIndex: number;
266
+ column: DataGridColumn<R>;
267
+ context: DataGridContext<R>;
268
+ onFilterButtonClicked?: (columnKey: string) => void;
269
+ isFilterOpen?: boolean;
270
+ color?: ThemeColor;
271
+ };
272
+
273
+ export type DataGridSort = 'asc' | 'desc';
274
+
275
+ export type DataGridFilterPredicate<T> = (valueToVerify: T) => boolean;
276
+ export type DataGridFilterPredicateBuilder<T> = (
277
+ ...filterValues: T[]
278
+ ) => DataGridFilterPredicate<T>;
279
+
280
+ export type DataGridFilterOperators<K extends string, T> = {
281
+ [key in K]: DataGridFilterPredicateBuilder<T>;
282
+ };
283
+
284
+ export type DataGridFilterPredicates = {
285
+ date: DataGridFilterOperators<
286
+ 'before' | 'after' | 'equals' | 'notEquals' | 'inRange' | 'inArray',
287
+ string
288
+ >;
289
+ text: DataGridFilterOperators<
290
+ | 'contains'
291
+ | 'notContains'
292
+ | 'equals'
293
+ | 'notEquals'
294
+ | 'startsWith'
295
+ | 'endsWith'
296
+ | 'inArray',
297
+ string
298
+ >;
299
+ number: DataGridFilterOperators<
300
+ | 'equals'
301
+ | 'notEquals'
302
+ | 'lessThan'
303
+ | 'lessThanOrEqual'
304
+ | 'greaterThan'
305
+ | 'greaterThanOrEqual'
306
+ | 'inRange'
307
+ | 'inArray',
308
+ number
309
+ >;
310
+ };
311
+
312
+ export type DataGridFilterType = keyof DataGridFilterPredicates;
313
+ export type DataGridFilterDataType<T extends DataGridFilterType> =
314
+ DataGridFilterPredicates[T] extends DataGridFilterOperators<string, infer U>
315
+ ? U
316
+ : never;
317
+
318
+ export type DataGridFilterGetter<T extends DataGridFilterType> = (
319
+ value: any
320
+ ) => DataGridFilterDataType<T> | null;
321
+ export type DataGridFilterRenderer = (value: any) => ReactNode;
322
+ export type DataGridFilterFormatter = (value: any) => string;
323
+
324
+ export type DataGridFilterOperator<T extends DataGridFilterType> =
325
+ DataGridFilterPredicates[T] extends DataGridFilterOperators<infer K, any>
326
+ ? K
327
+ : never;
328
+
329
+ export type DataGridFilter<T extends string = DataGridFilterType> =
330
+ T extends DataGridFilterType
331
+ ? {
332
+ type: T;
333
+ operator: DataGridFilterOperator<T>;
334
+ getter: DataGridFilterGetter<T>;
335
+ renderer?: DataGridFilterRenderer;
336
+ formatter?: DataGridFilterFormatter;
337
+ values: (DataGridFilterDataType<T> | null)[];
338
+ }
339
+ : never;
340
+
341
+ export type DataGridFilterGroup = {
342
+ name: string;
343
+ displayValue: DataGridFilterValue;
344
+ values?: DataGridFilterValue[];
345
+ groups?: DataGridFilterGroup[];
346
+ };
347
+
348
+ export type DataGridFilterValue = string | number | null;
349
+
350
+ export type DataGridFilterCheckbox = {
351
+ displayValue: ReactNode;
352
+ title: string;
353
+ values: DataGridFilterValue[];
354
+ level: number;
355
+ };
356
+
357
+ export type DataGridRowTemplateProps<R> = {
358
+ selected?: boolean;
359
+ toggleSelection?: () => void;
360
+ context: DataGridContext<R>;
361
+ };
362
+
363
+ export type DataGridRefProps<R> = {
364
+ refresh: () => void;
365
+ setSelectedKeys: (keys: string[]) => void;
366
+ addRows: (rows: R[]) => void;
367
+ };
368
+
369
+ export type DataGridEditedRows<R> = Partial<R>[];