@addev-be/ui 0.15.0 → 0.16.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 (415) 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/Icons.d.ts +9 -1
  24. package/dist/Icons.js +17 -1
  25. package/dist/components/auth/LoginForm.js +1 -1
  26. package/dist/components/auth/PasswordRecoveryForm.js +1 -1
  27. package/dist/components/auth/PasswordResetForm.js +1 -1
  28. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +9 -8
  29. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +21 -72
  30. package/dist/components/data/AdvancedRequestDataGrid/index.js +2 -2
  31. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +1 -1
  32. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +10 -0
  33. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +173 -0
  34. package/dist/components/data/DataGrid/DataGridCell.js +5 -5
  35. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.d.ts +2 -2
  36. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.js +1 -7
  37. package/dist/components/data/DataGrid/DataGridColumnsModal/hooks.js +3 -3
  38. package/dist/components/data/DataGrid/DataGridColumnsModal/index.js +16 -21
  39. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.d.ts +2 -0
  40. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.js +23 -0
  41. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.d.ts +2 -0
  42. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.js +27 -0
  43. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.d.ts +5 -0
  44. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.js +32 -0
  45. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.d.ts +2 -0
  46. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.js +23 -0
  47. package/dist/components/data/DataGrid/DataGridEditableCell/index.d.ts +2 -0
  48. package/dist/components/data/DataGrid/DataGridEditableCell/index.js +91 -0
  49. package/dist/components/data/DataGrid/DataGridEditableCell/styles.d.ts +3 -0
  50. package/dist/components/data/DataGrid/DataGridEditableCell/styles.js +17 -0
  51. package/dist/components/data/DataGrid/DataGridEditableCell/types.d.ts +11 -0
  52. package/dist/components/data/DataGrid/DataGridEditableCell/types.js +3 -0
  53. package/dist/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.js +17 -1
  54. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.d.ts +4 -3
  55. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.js +11 -12
  56. package/dist/components/data/DataGrid/DataGridFilterMenu/index.d.ts +5 -4
  57. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +44 -40
  58. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.js +1 -1
  59. package/dist/components/data/DataGrid/DataGridFooter.js +5 -5
  60. package/dist/components/data/DataGrid/DataGridHeader.js +40 -6
  61. package/dist/components/data/DataGrid/DataGridHeaderCell.d.ts +1 -1
  62. package/dist/components/data/DataGrid/DataGridHeaderCell.js +11 -23
  63. package/dist/components/data/DataGrid/DataGridRowTemplate.d.ts +1 -1
  64. package/dist/components/data/DataGrid/DataGridRowTemplate.js +8 -9
  65. package/dist/components/data/DataGrid/FilterModalContent/index.js +1 -1
  66. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +13 -0
  67. package/dist/components/data/DataGrid/FilterValuesScroller.js +73 -0
  68. package/dist/components/data/DataGrid/VirtualScroller.d.ts +11 -0
  69. package/dist/components/data/DataGrid/VirtualScroller.js +41 -0
  70. package/dist/components/data/DataGrid/constants.d.ts +6 -0
  71. package/dist/components/data/DataGrid/constants.js +9 -0
  72. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +12 -0
  73. package/dist/components/data/DataGrid/helpers/advancedRequests.js +53 -0
  74. package/dist/components/data/DataGrid/helpers/columns.d.ts +13 -12
  75. package/dist/components/data/DataGrid/helpers/columns.js +100 -130
  76. package/dist/components/data/DataGrid/helpers.d.ts +28 -0
  77. package/dist/components/data/DataGrid/helpers.js +436 -0
  78. package/dist/components/data/DataGrid/hooks/index.d.ts +3 -3
  79. package/dist/components/data/DataGrid/hooks/index.js +8 -12
  80. package/dist/components/data/DataGrid/hooks/useDataGrid.js +71 -23
  81. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.d.ts +9 -0
  82. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.js +71 -0
  83. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +25 -30
  84. package/dist/components/data/DataGrid/index.js +16 -3
  85. package/dist/components/data/DataGrid/styles.d.ts +13 -8
  86. package/dist/components/data/DataGrid/styles.js +58 -30
  87. package/dist/components/data/DataGrid/types.d.ts +81 -15
  88. package/dist/components/data/SmartQueryDataGrid/helpers/columns.d.ts +20 -0
  89. package/dist/components/data/SmartQueryDataGrid/helpers/columns.js +160 -0
  90. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.d.ts +5 -0
  91. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.js +41 -0
  92. package/dist/components/data/SmartQueryDataGrid/helpers/index.js +18 -0
  93. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.d.ts +3 -0
  94. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.js +15 -0
  95. package/dist/components/data/SmartQueryDataGrid/hooks.d.ts +9 -0
  96. package/dist/components/data/SmartQueryDataGrid/hooks.js +63 -0
  97. package/dist/components/data/SmartQueryDataGrid/index.d.ts +12 -0
  98. package/dist/components/data/SmartQueryDataGrid/index.js +242 -0
  99. package/dist/components/data/SmartQueryDataGrid/types.d.ts +22 -0
  100. package/dist/components/data/SmartQueryDataGrid/types.js +2 -0
  101. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.d.ts +2 -0
  102. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.js +19 -0
  103. package/dist/components/data/SqlRequestDataGrid/helpers/columns.d.ts +16 -17
  104. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +236 -84
  105. package/dist/components/data/SqlRequestDataGrid/index.js +77 -63
  106. package/dist/components/data/SqlRequestDataGrid/styles.d.ts +2 -0
  107. package/dist/components/data/SqlRequestDataGrid/styles.js +14 -0
  108. package/dist/components/data/SqlRequestDataGrid/types.d.ts +13 -3
  109. package/dist/components/data/SqlRequestDataGrid/types.js +1 -0
  110. package/dist/components/data/SqlRequestForeignList/index.d.ts +4 -0
  111. package/dist/components/data/SqlRequestForeignList/index.js +131 -0
  112. package/dist/components/data/SqlRequestForeignList/styles.d.ts +9 -0
  113. package/dist/components/data/SqlRequestForeignList/styles.js +22 -0
  114. package/dist/components/data/SqlRequestForeignList/types.d.ts +22 -0
  115. package/dist/components/data/SqlRequestForeignList/types.js +3 -0
  116. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.d.ts +10 -0
  117. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.js +51 -0
  118. package/dist/components/data/SqlRequestGrid/filters/styles.d.ts +4 -0
  119. package/dist/components/data/SqlRequestGrid/filters/styles.js +17 -0
  120. package/dist/components/data/SqlRequestGrid/index.d.ts +1 -1
  121. package/dist/components/data/SqlRequestGrid/index.js +139 -49
  122. package/dist/components/data/SqlRequestGrid/styles.d.ts +0 -12
  123. package/dist/components/data/SqlRequestGrid/styles.js +4 -20
  124. package/dist/components/data/SqlRequestGrid/types.d.ts +14 -4
  125. package/dist/components/data/VirtualScroller/index.d.ts +4 -3
  126. package/dist/components/data/VirtualScroller/index.js +15 -5
  127. package/dist/components/data/VirtualScroller/styles.d.ts +4 -2
  128. package/dist/components/data/VirtualScroller/styles.js +9 -6
  129. package/dist/components/data/index.d.ts +1 -2
  130. package/dist/components/data/index.js +1 -2
  131. package/dist/components/forms/AutoTextArea.d.ts +10 -0
  132. package/dist/components/forms/AutoTextArea.js +40 -0
  133. package/dist/components/forms/Button.d.ts +9 -2
  134. package/dist/components/forms/Button.js +13 -7
  135. package/dist/components/forms/Form/Checkbox.d.ts +3 -0
  136. package/dist/components/forms/Form/Checkbox.js +33 -0
  137. package/dist/components/forms/Form/FormGroup.d.ts +9 -0
  138. package/dist/components/forms/Form/FormGroup.js +10 -0
  139. package/dist/components/forms/Form/Input.d.ts +3 -0
  140. package/dist/components/forms/Form/Input.js +32 -0
  141. package/dist/components/forms/Form/InputWithLabel.d.ts +2 -0
  142. package/dist/components/forms/Form/InputWithLabel.js +10 -0
  143. package/dist/components/forms/Form/Select.d.ts +17 -0
  144. package/dist/components/forms/Form/Select.js +46 -0
  145. package/dist/components/forms/Form/TextArea.d.ts +4 -0
  146. package/dist/components/forms/Form/TextArea.js +33 -0
  147. package/dist/components/forms/Form/index.d.ts +66 -0
  148. package/dist/components/forms/Form/index.js +24 -0
  149. package/dist/components/forms/Form/styles.d.ts +14 -0
  150. package/dist/components/forms/Form/styles.js +47 -0
  151. package/dist/components/forms/Form/types.d.ts +7 -0
  152. package/dist/components/forms/Form/types.js +2 -0
  153. package/dist/components/forms/IconButton.d.ts +2 -1
  154. package/dist/components/forms/IconButton.js +12 -12
  155. package/dist/components/forms/Select.d.ts +5 -6
  156. package/dist/components/forms/Select.js +2 -5
  157. package/dist/components/forms/index.d.ts +3 -0
  158. package/dist/components/forms/index.js +3 -0
  159. package/dist/components/layout/Columns.d.ts +5 -0
  160. package/dist/components/layout/Columns.js +19 -0
  161. package/dist/components/layout/Dropdown/index.d.ts +1 -0
  162. package/dist/components/layout/Dropdown/index.js +24 -3
  163. package/dist/components/layout/Grid/index.d.ts +6 -0
  164. package/dist/components/layout/Grid/index.js +6 -0
  165. package/dist/components/layout/Grid/styles.d.ts +14 -0
  166. package/dist/components/layout/Grid/styles.js +29 -0
  167. package/dist/components/layout/Masonry/index.d.ts +3 -0
  168. package/dist/components/layout/Masonry/index.js +20 -0
  169. package/dist/components/layout/Masonry/styles.d.ts +5 -0
  170. package/dist/components/layout/Masonry/styles.js +17 -0
  171. package/dist/components/layout/index.d.ts +4 -1
  172. package/dist/components/layout/index.js +4 -1
  173. package/dist/components/search/QuickSearchBar.js +6 -0
  174. package/dist/components/ui/Avatar/index.d.ts +10 -0
  175. package/dist/components/ui/Avatar/index.js +52 -0
  176. package/dist/components/ui/Avatar/styles.d.ts +4 -0
  177. package/dist/components/ui/Avatar/styles.js +43 -0
  178. package/dist/components/ui/Card/styles.js +1 -1
  179. package/dist/components/ui/Ellipsis.d.ts +13 -0
  180. package/dist/components/ui/Ellipsis.js +28 -0
  181. package/dist/components/ui/Label.d.ts +9 -0
  182. package/dist/components/ui/Label.js +74 -0
  183. package/dist/components/ui/index.d.ts +3 -0
  184. package/dist/components/ui/index.js +3 -0
  185. package/dist/config/types.d.ts +11 -0
  186. package/dist/config/types.js +2 -0
  187. package/dist/helpers/index.d.ts +1 -0
  188. package/dist/helpers/index.js +1 -0
  189. package/dist/helpers/numbers.d.ts +3 -0
  190. package/dist/helpers/numbers.js +33 -1
  191. package/dist/helpers/responsive.d.ts +37 -0
  192. package/dist/helpers/responsive.js +57 -0
  193. package/dist/hooks/index.d.ts +4 -0
  194. package/dist/hooks/index.js +4 -0
  195. package/dist/hooks/useContainerMediaQuery.d.ts +17 -0
  196. package/dist/hooks/useContainerMediaQuery.js +10 -0
  197. package/dist/hooks/useMediaQuery.d.ts +17 -0
  198. package/dist/hooks/useMediaQuery.js +11 -0
  199. package/dist/hooks/useMediaQueryForWidth.d.ts +17 -0
  200. package/dist/hooks/useMediaQueryForWidth.js +26 -0
  201. package/dist/hooks/useShowArchived.d.ts +6 -0
  202. package/dist/hooks/useShowArchived.js +21 -0
  203. package/dist/index.d.ts +1 -0
  204. package/dist/index.js +1 -0
  205. package/dist/providers/AuthenticationProvider/index.js +4 -3
  206. package/dist/providers/PortalsProvider/styles.js +1 -1
  207. package/dist/providers/ThemeProvider/defaultTheme.js +13 -0
  208. package/dist/providers/ThemeProvider/helpers.d.ts +3 -0
  209. package/dist/providers/ThemeProvider/helpers.js +13 -0
  210. package/dist/providers/ThemeProvider/types.d.ts +2 -1
  211. package/dist/providers/TrackingProvider/hooks.d.ts +1 -0
  212. package/dist/providers/TrackingProvider/hooks.js +15 -0
  213. package/dist/providers/TrackingProvider/index.d.ts +8 -0
  214. package/dist/providers/TrackingProvider/index.js +41 -0
  215. package/dist/providers/UiProviders/index.js +2 -1
  216. package/dist/providers/index.d.ts +2 -0
  217. package/dist/providers/index.js +2 -0
  218. package/dist/services/globalSearch.d.ts +2 -1
  219. package/dist/services/index.d.ts +7 -0
  220. package/dist/services/index.js +20 -0
  221. package/dist/services/requests/generic.d.ts +29 -0
  222. package/dist/services/requests/generic.js +29 -0
  223. package/dist/services/requests/tracking.d.ts +18 -0
  224. package/dist/services/requests/tracking.js +8 -0
  225. package/dist/services/requests/userPermissions.d.ts +4 -0
  226. package/dist/services/requests/userPermissions.js +20 -0
  227. package/dist/services/smartQueries.d.ts +51 -0
  228. package/dist/services/smartQueries.js +10 -0
  229. package/dist/services/smartRequests.d.ts +0 -0
  230. package/dist/services/smartRequests.js +1 -0
  231. package/dist/services/types/generic.d.ts +44 -0
  232. package/dist/services/types/generic.js +79 -0
  233. package/dist/services/types/tracking.d.ts +24 -0
  234. package/dist/services/types/tracking.js +47 -0
  235. package/dist/services/updateSqlRequests.d.ts +24 -0
  236. package/dist/services/updateSqlRequests.js +7 -0
  237. package/package.json +1 -1
  238. package/src/Icons.tsx +134 -134
  239. package/src/components/auth/LoginForm.tsx +84 -84
  240. package/src/components/auth/LoginPage.tsx +32 -32
  241. package/src/components/auth/PasswordRecoveryForm.tsx +52 -52
  242. package/src/components/auth/PasswordResetForm.tsx +112 -112
  243. package/src/components/auth/index.ts +4 -4
  244. package/src/components/auth/styles.ts +14 -14
  245. package/src/components/data/DataGrid/DataGridCell.tsx +77 -77
  246. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +9 -9
  247. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  248. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +182 -182
  249. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  250. package/src/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.tsx +38 -38
  251. package/src/components/data/DataGrid/DataGridEditableCell/DateEditableCell.tsx +39 -39
  252. package/src/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.tsx +68 -68
  253. package/src/components/data/DataGrid/DataGridEditableCell/TextEditableCell.tsx +38 -38
  254. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +108 -105
  255. package/src/components/data/DataGrid/DataGridEditableCell/styles.ts +35 -0
  256. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +19 -15
  257. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +131 -131
  258. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +81 -81
  259. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +376 -376
  260. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  261. package/src/components/data/DataGrid/DataGridFooter.tsx +45 -45
  262. package/src/components/data/DataGrid/DataGridHeader.tsx +173 -173
  263. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +111 -115
  264. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +80 -78
  265. package/src/components/data/DataGrid/FilterModalContent/index.tsx +136 -136
  266. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  267. package/src/components/data/DataGrid/constants.ts +6 -6
  268. package/src/components/data/DataGrid/helpers/columns.tsx +386 -384
  269. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  270. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  271. package/src/components/data/DataGrid/hooks/index.ts +29 -29
  272. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +377 -378
  273. package/src/components/data/DataGrid/hooks/useDataGridChangedRows.ts +56 -56
  274. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +174 -174
  275. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  276. package/src/components/data/DataGrid/index.tsx +110 -110
  277. package/src/components/data/DataGrid/styles.ts +371 -390
  278. package/src/components/data/DataGrid/types.ts +367 -367
  279. package/src/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.tsx +16 -16
  280. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +480 -407
  281. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  282. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  283. package/src/components/data/SqlRequestDataGrid/index.tsx +402 -402
  284. package/src/components/data/SqlRequestDataGrid/styles.ts +15 -15
  285. package/src/components/data/SqlRequestDataGrid/types.ts +74 -71
  286. package/src/components/data/SqlRequestForeignList/index.tsx +259 -201
  287. package/src/components/data/SqlRequestForeignList/styles.ts +43 -38
  288. package/src/components/data/SqlRequestForeignList/types.ts +34 -31
  289. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +110 -110
  290. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  291. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  292. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  293. package/src/components/data/SqlRequestGrid/index.tsx +316 -316
  294. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  295. package/src/components/data/SqlRequestGrid/types.ts +75 -75
  296. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  297. package/src/components/data/VirtualScroller/index.tsx +91 -89
  298. package/src/components/data/VirtualScroller/styles.ts +58 -58
  299. package/src/components/data/VirtualScroller/types.ts +12 -12
  300. package/src/components/data/index.ts +16 -23
  301. package/src/components/forms/AutoTextArea.tsx +41 -41
  302. package/src/components/forms/Button.tsx +133 -133
  303. package/src/components/forms/Form/Checkbox.tsx +13 -13
  304. package/src/components/forms/Form/FormGroup.tsx +27 -27
  305. package/src/components/forms/Form/Input.tsx +17 -13
  306. package/src/components/forms/Form/InputWithLabel.tsx +19 -18
  307. package/src/components/forms/Form/Select.tsx +82 -67
  308. package/src/components/forms/Form/TextArea.tsx +18 -13
  309. package/src/components/forms/Form/index.tsx +37 -37
  310. package/src/components/forms/Form/styles.ts +141 -101
  311. package/src/components/forms/Form/types.ts +8 -7
  312. package/src/components/forms/IconButton.tsx +57 -57
  313. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  314. package/src/components/forms/Select.tsx +35 -35
  315. package/src/components/forms/VerticalLabel.tsx +20 -20
  316. package/src/components/forms/index.ts +8 -8
  317. package/src/components/forms/styles.ts +31 -31
  318. package/src/components/index.ts +6 -6
  319. package/src/components/layout/Columns.ts +20 -20
  320. package/src/components/layout/Dropdown/index.tsx +113 -113
  321. package/src/components/layout/Dropdown/styles.ts +45 -45
  322. package/src/components/layout/Grid/index.tsx +8 -8
  323. package/src/components/layout/Grid/styles.ts +34 -34
  324. package/src/components/layout/Loading/index.tsx +29 -29
  325. package/src/components/layout/Loading/styles.ts +29 -29
  326. package/src/components/layout/Masonry/index.tsx +29 -29
  327. package/src/components/layout/Masonry/styles.ts +20 -20
  328. package/src/components/layout/Modal/index.tsx +51 -51
  329. package/src/components/layout/Modal/styles.ts +121 -121
  330. package/src/components/layout/index.ts +6 -6
  331. package/src/components/search/HighlightedText.tsx +37 -37
  332. package/src/components/search/QuickSearchBar.tsx +86 -86
  333. package/src/components/search/QuickSearchResults.tsx +86 -86
  334. package/src/components/search/index.ts +9 -9
  335. package/src/components/search/styles.ts +96 -96
  336. package/src/components/search/types.ts +26 -26
  337. package/src/components/ui/Avatar/index.tsx +54 -54
  338. package/src/components/ui/Card/index.tsx +14 -14
  339. package/src/components/ui/Card/styles.ts +37 -37
  340. package/src/components/ui/ContextMenu/index.tsx +79 -79
  341. package/src/components/ui/ContextMenu/styles.ts +119 -119
  342. package/src/components/ui/Ellipsis.tsx +34 -0
  343. package/src/components/ui/Label.tsx +90 -90
  344. package/src/components/ui/Message/index.tsx +57 -57
  345. package/src/components/ui/Message/styles.ts +40 -40
  346. package/src/components/ui/index.ts +6 -5
  347. package/src/config/index.ts +14 -14
  348. package/src/helpers/dates.ts +17 -17
  349. package/src/helpers/getScrollbarSize.ts +14 -14
  350. package/src/helpers/index.ts +4 -3
  351. package/src/helpers/numbers.ts +63 -63
  352. package/src/helpers/responsive.ts +83 -0
  353. package/src/helpers/text.ts +13 -13
  354. package/src/hooks/index.ts +6 -3
  355. package/src/hooks/useContainerMediaQuery.ts +7 -0
  356. package/src/hooks/useElementSize.ts +24 -24
  357. package/src/hooks/useMediaQuery.ts +9 -0
  358. package/src/hooks/useMediaQueryForWidth.ts +35 -0
  359. package/src/hooks/useShowArchived.ts +28 -28
  360. package/src/hooks/useWindowSize.ts +20 -20
  361. package/src/index.ts +9 -9
  362. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  363. package/src/providers/AuthenticationProvider/index.tsx +243 -243
  364. package/src/providers/LoadingProvider/index.tsx +47 -47
  365. package/src/providers/PortalsProvider/index.tsx +54 -54
  366. package/src/providers/PortalsProvider/styles.ts +31 -31
  367. package/src/providers/SettingsProvider/index.tsx +70 -70
  368. package/src/providers/ThemeProvider/ThemeProvider.ts +63 -63
  369. package/src/providers/ThemeProvider/defaultTheme.ts +457 -457
  370. package/src/providers/ThemeProvider/helpers.ts +11 -11
  371. package/src/providers/ThemeProvider/index.ts +4 -4
  372. package/src/providers/ThemeProvider/types.ts +131 -131
  373. package/src/providers/TrackingProvider/index.tsx +71 -71
  374. package/src/providers/UiProviders/index.tsx +68 -68
  375. package/src/providers/UiProviders/styles.ts +10 -10
  376. package/src/providers/hooks.ts +12 -12
  377. package/src/providers/index.ts +8 -8
  378. package/src/services/HttpService.ts +92 -92
  379. package/src/services/WebSocketService.ts +137 -137
  380. package/src/services/advancedRequests.ts +102 -102
  381. package/src/services/base.ts +23 -23
  382. package/src/services/globalSearch.ts +29 -29
  383. package/src/services/hooks.ts +44 -44
  384. package/src/services/index.ts +21 -21
  385. package/src/services/requests/auth.ts +44 -44
  386. package/src/services/requests/generic.ts +62 -62
  387. package/src/services/requests/tracking.ts +12 -12
  388. package/src/services/requests/userProfiles.ts +35 -35
  389. package/src/services/requests/users.ts +28 -28
  390. package/src/services/smartQueries.ts +122 -122
  391. package/src/services/sqlRequests.ts +111 -111
  392. package/src/services/types/auth.ts +131 -131
  393. package/src/services/types/base.ts +10 -10
  394. package/src/services/types/generic.ts +96 -96
  395. package/src/services/types/tracking.ts +39 -39
  396. package/src/services/types/userProfiles.ts +107 -107
  397. package/src/services/types/users.ts +106 -106
  398. package/src/services/updateSqlRequests.ts +34 -34
  399. package/src/styles/animations.scss +30 -30
  400. package/src/styles/index.scss +42 -42
  401. package/src/typings.d.ts +19 -13
  402. package/tsconfig.json +18 -18
  403. package/tsconfig.tsbuildinfo +1 -1
  404. package/src/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.ts +0 -93
  405. package/src/components/data/AdvancedRequestDataGrid/helpers/columns.tsx +0 -262
  406. package/src/components/data/AdvancedRequestDataGrid/helpers/index.ts +0 -2
  407. package/src/components/data/AdvancedRequestDataGrid/index.tsx +0 -267
  408. package/src/components/data/AdvancedRequestDataGrid/types.ts +0 -47
  409. package/src/components/data/SmartQueryDataGrid/helpers/columns.tsx +0 -333
  410. package/src/components/data/SmartQueryDataGrid/helpers/hooks.ts +0 -41
  411. package/src/components/data/SmartQueryDataGrid/helpers/smartQueries.ts +0 -17
  412. package/src/components/data/SmartQueryDataGrid/hooks.ts +0 -75
  413. package/src/components/data/SmartQueryDataGrid/index.tsx +0 -338
  414. package/src/components/data/SmartQueryDataGrid/types.ts +0 -45
  415. /package/{src/components/data/SmartQueryDataGrid/helpers/index.ts → dist/components/data/SmartQueryDataGrid/helpers/index.d.ts} +0 -0
@@ -1,15 +1,15 @@
1
- import styled from 'styled-components';
2
-
3
- export const SqlImageWrapper = styled.div`
4
- display: flex;
5
- justify-content: center;
6
- align-items: center;
7
- width: 100%;
8
- height: 100%;
9
- `;
10
-
11
- export const SqlImage = styled.img`
12
- max-width: 100%;
13
- height: 100%;
14
- object-fit: contain;
15
- `;
1
+ import styled from 'styled-components';
2
+
3
+ export const SqlImageWrapper = styled.div`
4
+ display: flex;
5
+ justify-content: center;
6
+ align-items: center;
7
+ width: 100%;
8
+ height: 100%;
9
+ `;
10
+
11
+ export const SqlImage = styled.img`
12
+ max-width: 100%;
13
+ height: 100%;
14
+ object-fit: contain;
15
+ `;
@@ -1,71 +1,74 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
-
3
- import {
4
- ConditionDTO,
5
- FieldDTO,
6
- OrderByDTO,
7
- SqlRequestRow,
8
- } from '../../../services/sqlRequests';
9
- import {
10
- DataGridCheckboxColumn,
11
- DataGridDateColumn,
12
- DataGridFilter,
13
- DataGridFilterType,
14
- DataGridNumberColumn,
15
- DataGridProps,
16
- DataGridTextColumn,
17
- EditableDataGridColumn,
18
- } from '../DataGrid/types';
19
-
20
- export type SqlRequestDataGridFilter<
21
- T extends DataGridFilterType = DataGridFilterType
22
- > = DataGridFilter<T> & {
23
- field?: FieldDTO;
24
- };
25
-
26
- export type SqlRequestDataGridFilters = Record<
27
- string,
28
- SqlRequestDataGridFilter
29
- >;
30
-
31
- export type SqlRequestDataGridCommonProps = {
32
- filter?: SqlRequestDataGridFilter;
33
- field?: FieldDTO;
34
- filterField?: string;
35
- sortField?: string;
36
- ignore?: boolean;
37
- };
38
-
39
- export type SqlRequestDataGridTextColumn<R> = DataGridTextColumn<R> &
40
- SqlRequestDataGridCommonProps;
41
- export type SqlRequestDataGridNumberColumn<R> = DataGridNumberColumn<R> &
42
- SqlRequestDataGridCommonProps;
43
- export type SqlRequestDataGridCheckboxColumn<R> = DataGridCheckboxColumn<R> &
44
- SqlRequestDataGridCommonProps;
45
- export type SqlRequestDataGridDateColumn<R> = DataGridDateColumn<R> &
46
- SqlRequestDataGridCommonProps;
47
- export type SqlRequestDataGridForeignListColumn<R, T> = {
48
- type: 'foreignList';
49
- } & EditableDataGridColumn<R, T> &
50
- SqlRequestDataGridCommonProps;
51
-
52
- export type SqlRequestDataGridColumn<R> =
53
- | SqlRequestDataGridTextColumn<R>
54
- | SqlRequestDataGridNumberColumn<R>
55
- | SqlRequestDataGridCheckboxColumn<R>
56
- | SqlRequestDataGridDateColumn<R>
57
- | SqlRequestDataGridForeignListColumn<R, any>;
58
-
59
- export type SqlRequestDataGridColumns<R> = SqlRequestDataGridColumn<R>[];
60
-
61
- export type SqlRequestDataGridProps<R> = Omit<
62
- DataGridProps<R>,
63
- 'rows' | 'columns'
64
- > & {
65
- columns: SqlRequestDataGridColumns<R>;
66
- hiddenColumns?: string[];
67
- type: string;
68
- orderBy?: OrderByDTO[];
69
- conditions?: ConditionDTO[];
70
- parser?: (row: SqlRequestRow<R>) => R;
71
- };
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ import {
4
+ ConditionDTO,
5
+ FieldDTO,
6
+ OrderByDTO,
7
+ SqlRequestRow,
8
+ } from '../../../services/sqlRequests';
9
+ import {
10
+ DataGridCheckboxColumn,
11
+ DataGridDateColumn,
12
+ DataGridFilter,
13
+ DataGridFilterType,
14
+ DataGridNumberColumn,
15
+ DataGridProps,
16
+ DataGridTextColumn,
17
+ EditableDataGridColumn,
18
+ } from '../DataGrid/types';
19
+
20
+ import { SqlRequestForeignListProps } from '../SqlRequestForeignList/types';
21
+
22
+ export type SqlRequestDataGridFilter<
23
+ T extends DataGridFilterType = DataGridFilterType
24
+ > = DataGridFilter<T> & {
25
+ field?: FieldDTO;
26
+ };
27
+
28
+ export type SqlRequestDataGridFilters = Record<
29
+ string,
30
+ SqlRequestDataGridFilter
31
+ >;
32
+
33
+ export type SqlRequestDataGridCommonProps = {
34
+ filter?: SqlRequestDataGridFilter;
35
+ field?: FieldDTO;
36
+ filterField?: string;
37
+ sortField?: string;
38
+ ignore?: boolean;
39
+ };
40
+
41
+ export type SqlRequestDataGridTextColumn<R> = DataGridTextColumn<R> &
42
+ SqlRequestDataGridCommonProps;
43
+ export type SqlRequestDataGridNumberColumn<R> = DataGridNumberColumn<R> &
44
+ SqlRequestDataGridCommonProps;
45
+ export type SqlRequestDataGridCheckboxColumn<R> = DataGridCheckboxColumn<R> &
46
+ SqlRequestDataGridCommonProps;
47
+ export type SqlRequestDataGridDateColumn<R> = DataGridDateColumn<R> &
48
+ SqlRequestDataGridCommonProps;
49
+ export type SqlRequestDataGridForeignListColumn<R, T> = {
50
+ type: 'foreignList';
51
+ } & SqlRequestForeignListProps<T> &
52
+ EditableDataGridColumn<R, T> &
53
+ SqlRequestDataGridCommonProps;
54
+
55
+ export type SqlRequestDataGridColumn<R> =
56
+ | SqlRequestDataGridTextColumn<R>
57
+ | SqlRequestDataGridNumberColumn<R>
58
+ | SqlRequestDataGridCheckboxColumn<R>
59
+ | SqlRequestDataGridDateColumn<R>
60
+ | SqlRequestDataGridForeignListColumn<R, any>;
61
+
62
+ export type SqlRequestDataGridColumns<R> = SqlRequestDataGridColumn<R>[];
63
+
64
+ export type SqlRequestDataGridProps<R> = Omit<
65
+ DataGridProps<R>,
66
+ 'rows' | 'columns'
67
+ > & {
68
+ columns: SqlRequestDataGridColumns<R>;
69
+ hiddenColumns?: string[];
70
+ type: string;
71
+ orderBy?: OrderByDTO[];
72
+ conditions?: ConditionDTO[];
73
+ parser?: (row: SqlRequestRow<R>) => R;
74
+ };
@@ -1,201 +1,259 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
-
3
- import {
4
- ForwardedRef,
5
- MouseEvent,
6
- forwardRef,
7
- useCallback,
8
- useEffect,
9
- useImperativeHandle,
10
- useMemo,
11
- useRef,
12
- useState,
13
- } from 'react';
14
- import {
15
- SqlRequestForeignListInput,
16
- SqlRequestForeignListItem,
17
- SqlRequestForeignListValue,
18
- } from './styles';
19
- import {
20
- SqlRequestForeignListItemProps,
21
- SqlRequestForeignListProps,
22
- } from './types';
23
-
24
- import { ChevronDownIcon } from '../../../Icons';
25
- import { Dropdown } from '../../layout';
26
- import { VirtualScrollerTemplateFC } from '../VirtualScroller/types';
27
- import { useSqlRequestHandler } from '../../../services';
28
-
29
- const DEFAULT_ROW_HEIGHT = 24;
30
-
31
- const createValueTemplate =
32
- <R extends Record<string, any>>(
33
- ValueTemplate: VirtualScrollerTemplateFC<
34
- R,
35
- SqlRequestForeignListItemProps<R>
36
- >,
37
- rowHeight = DEFAULT_ROW_HEIGHT
38
- ): VirtualScrollerTemplateFC<R, SqlRequestForeignListItemProps<R>> =>
39
- ({ item }) =>
40
- (
41
- <SqlRequestForeignListValue $rowHeight={rowHeight}>
42
- <ValueTemplate item={item} index={0} />
43
- </SqlRequestForeignListValue>
44
- );
45
-
46
- const createItemTemplate =
47
- <R extends Record<string, any>>(
48
- ItemTemplate: VirtualScrollerTemplateFC<
49
- R,
50
- SqlRequestForeignListItemProps<R>
51
- >,
52
- rowHeight = DEFAULT_ROW_HEIGHT
53
- ): VirtualScrollerTemplateFC<R, SqlRequestForeignListItemProps<R>> =>
54
- ({ item, index, onClick: onItemClick }) => {
55
- const onClick = useCallback(
56
- (
57
- e: MouseEvent<HTMLElement>,
58
- item: R | null,
59
- onItemClick?: (item: R | null) => void
60
- ) => {
61
- e.preventDefault();
62
- e.stopPropagation();
63
- onItemClick?.(item);
64
- },
65
- []
66
- );
67
-
68
- return (
69
- <SqlRequestForeignListItem
70
- $rowHeight={rowHeight}
71
- onClick={(e) => onClick(e, item, onItemClick)}
72
- >
73
- <ItemTemplate item={item} index={index} />
74
- </SqlRequestForeignListItem>
75
- );
76
- };
77
-
78
- export const SqlRequestForeignListInner = <T extends Record<string, any>>(
79
- {
80
- requestName,
81
- idColumn,
82
- columns = [],
83
- initialId,
84
- onItemChanged,
85
- onIdChanged,
86
- onClosed,
87
- onBlur,
88
- itemTemplate,
89
- valueTemplate,
90
- rowHeight = DEFAULT_ROW_HEIGHT,
91
- maxRows = 10,
92
- }: SqlRequestForeignListProps<T>,
93
- ref: ForwardedRef<HTMLDivElement>
94
- ) => {
95
- const [opened, setOpened] = useState(false);
96
- const [rect, setRect] = useState<DOMRect | null>(null);
97
- const [rows, setRows] = useState<T[]>([]);
98
- const [loaded, setLoaded] = useState(false);
99
- const [selectedItem, setSelectedItem] = useState<T | null>(null);
100
-
101
- // Create an internal ref for the component to use
102
- const internalRef = useRef<HTMLDivElement>(null);
103
-
104
- // Forward the ref while linking it to our internal ref
105
- useImperativeHandle(ref, () => internalRef.current!, []);
106
-
107
- const [sqlRequest] = useSqlRequestHandler<T>(requestName);
108
-
109
- const open = useCallback(() => {
110
- if (internalRef.current) {
111
- const parentRect = internalRef.current.getBoundingClientRect();
112
- setRect(new DOMRect(0, 0, parentRect.width, parentRect.height));
113
- setOpened(true);
114
- }
115
- }, []);
116
-
117
- const close = useCallback(() => {
118
- setOpened(false);
119
- onClosed?.();
120
- }, [onClosed]);
121
-
122
- const onItemClick = useCallback(
123
- (item: T | null) => {
124
- setSelectedItem(item);
125
- onItemChanged?.(item);
126
- onIdChanged?.(item?.[idColumn] ?? null);
127
- close();
128
- },
129
- [close, idColumn, onIdChanged, onItemChanged]
130
- );
131
-
132
- useEffect(() => {
133
- if (!loaded) {
134
- sqlRequest({
135
- columns: [idColumn, ...columns],
136
- // conditions,
137
- // orderBy,
138
- }).then((response) => {
139
- const data = (response.data ?? []) as T[];
140
- setRows(data);
141
- setSelectedItem(
142
- data.find((item) => String(item[idColumn]) === initialId) ?? null
143
- );
144
- setLoaded(true);
145
- });
146
- }
147
- }, [columns, idColumn, initialId, loaded, sqlRequest]);
148
-
149
- const ItemTemplate = useMemo(
150
- () =>
151
- createItemTemplate<T>(
152
- itemTemplate ??
153
- (({ item }) => <span>{item?.[columns[0]] ?? '(Aucun)'}</span>),
154
- rowHeight
155
- ),
156
- [columns, itemTemplate, rowHeight]
157
- );
158
- const ValueTemplate = useMemo(
159
- () =>
160
- createValueTemplate<T>(
161
- valueTemplate ??
162
- (({ item }) => <span>{item?.[columns[0]] ?? '(Aucun)'}</span>),
163
- rowHeight
164
- ),
165
- [columns, rowHeight, valueTemplate]
166
- );
167
-
168
- return (
169
- <>
170
- <SqlRequestForeignListInput
171
- tabIndex={0}
172
- ref={internalRef}
173
- onClick={open}
174
- onBlur={onBlur}
175
- >
176
- <ValueTemplate item={selectedItem} index={0} />
177
- <ChevronDownIcon />
178
- {opened && rect && (
179
- <Dropdown
180
- $height={[Math.min(maxRows, rows.length) * rowHeight, 600]}
181
- $width={rect.width}
182
- $sourceRect={rect}
183
- onClose={close}
184
- usePortal={false}
185
- >
186
- {rows.map((row, index) => (
187
- <ItemTemplate
188
- item={row}
189
- onClick={() => onItemClick(row)}
190
- key={index}
191
- index={index}
192
- />
193
- ))}
194
- </Dropdown>
195
- )}
196
- </SqlRequestForeignListInput>
197
- </>
198
- );
199
- };
200
-
201
- export const SqlRequestForeignList = forwardRef(SqlRequestForeignListInner);
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ import {
4
+ ConditionDTO,
5
+ OrderByDTO,
6
+ useSqlRequestHandler,
7
+ } from '../../../services';
8
+ import {
9
+ ForwardedRef,
10
+ MouseEvent,
11
+ forwardRef,
12
+ useCallback,
13
+ useEffect,
14
+ useImperativeHandle,
15
+ useMemo,
16
+ useRef,
17
+ useState,
18
+ } from 'react';
19
+ import {
20
+ SqlRequestForeignListInput,
21
+ SqlRequestForeignListItem,
22
+ SqlRequestForeignListValue,
23
+ } from './styles';
24
+ import {
25
+ SqlRequestForeignListItemProps,
26
+ SqlRequestForeignListProps,
27
+ } from './types';
28
+
29
+ import { ChevronDownIcon } from '../../../Icons';
30
+ import { Dropdown } from '../../layout';
31
+ import { VirtualScroller } from '../VirtualScroller';
32
+ import { VirtualScrollerTemplateFC } from '../VirtualScroller/types';
33
+ import { debounce } from 'lodash';
34
+
35
+ const DEFAULT_ROW_HEIGHT = 24;
36
+
37
+ const createValueTemplate =
38
+ <R extends Record<string, any>>(
39
+ ValueTemplate: VirtualScrollerTemplateFC<
40
+ R,
41
+ SqlRequestForeignListItemProps<R>
42
+ >,
43
+ rowHeight = DEFAULT_ROW_HEIGHT
44
+ ): VirtualScrollerTemplateFC<R, SqlRequestForeignListItemProps<R>> =>
45
+ ({ item }) =>
46
+ (
47
+ <SqlRequestForeignListValue $rowHeight={rowHeight}>
48
+ <ValueTemplate item={item} index={0} />
49
+ </SqlRequestForeignListValue>
50
+ );
51
+
52
+ const createItemTemplate =
53
+ <R extends Record<string, any>>(
54
+ ItemTemplate: VirtualScrollerTemplateFC<
55
+ R,
56
+ SqlRequestForeignListItemProps<R>
57
+ >,
58
+ rowHeight = DEFAULT_ROW_HEIGHT
59
+ ): VirtualScrollerTemplateFC<R, SqlRequestForeignListItemProps<R>> =>
60
+ ({ item, index, onClick: onItemClick }) => {
61
+ const onClick = useCallback(
62
+ (
63
+ e: MouseEvent<HTMLElement>,
64
+ item: R | null,
65
+ onItemClick?: (item: R | null) => void
66
+ ) => {
67
+ e.preventDefault();
68
+ e.stopPropagation();
69
+ onItemClick?.(item);
70
+ },
71
+ []
72
+ );
73
+
74
+ return (
75
+ <SqlRequestForeignListItem
76
+ $rowHeight={rowHeight}
77
+ onClick={(e) => onClick(e, item, onItemClick)}
78
+ >
79
+ <ItemTemplate item={item} index={index} />
80
+ </SqlRequestForeignListItem>
81
+ );
82
+ };
83
+
84
+ export const SqlRequestForeignListInner = <T extends Record<string, any>>(
85
+ {
86
+ requestName,
87
+ idColumn,
88
+ columns = [],
89
+ initialValue = null,
90
+ onItemChanged,
91
+ onIdChanged,
92
+ onClosed,
93
+ onBlur,
94
+ itemTemplate,
95
+ valueTemplate,
96
+ rowHeight = DEFAULT_ROW_HEIGHT,
97
+ maxRows = 10,
98
+ orderBy = [],
99
+ conditions = [],
100
+ }: SqlRequestForeignListProps<T>,
101
+ ref: ForwardedRef<HTMLDivElement>
102
+ ) => {
103
+ const [opened, setOpened] = useState(false);
104
+ const [rect, setRect] = useState<DOMRect | null>(null);
105
+
106
+ const currentRows = useRef<T[]>([]);
107
+ const [rows, setRows] = useState<T[]>([]);
108
+ const [start, setStart] = useState(0);
109
+ const [length, setLength] = useState(-1);
110
+ const [count, setCount] = useState(-1);
111
+ const [selectedItem, setSelectedItem] = useState<T | null>(initialValue);
112
+
113
+ // Create an internal ref for the component to use
114
+ const internalRef = useRef<HTMLDivElement>(null);
115
+
116
+ // Forward the ref while linking it to our internal ref
117
+ useImperativeHandle(ref, () => internalRef.current!, []);
118
+
119
+ const [sqlRequest] = useSqlRequestHandler<T>(requestName);
120
+
121
+ const open = useCallback(() => {
122
+ if (internalRef.current) {
123
+ const parentRect = internalRef.current.getBoundingClientRect();
124
+ setRect(new DOMRect(0, 0, parentRect.width, parentRect.height));
125
+ setOpened(true);
126
+ }
127
+ }, []);
128
+
129
+ const close = useCallback(() => {
130
+ setOpened(false);
131
+ onClosed?.();
132
+ }, [onClosed]);
133
+
134
+ const onClick = useCallback(
135
+ (item: T | null) => {
136
+ setSelectedItem(item);
137
+ onItemChanged?.(item);
138
+ onIdChanged?.(item?.[idColumn] ?? null);
139
+ close();
140
+ },
141
+ [close, idColumn, onIdChanged, onItemChanged]
142
+ );
143
+
144
+ const loadRows = useRef(
145
+ debounce(
146
+ (
147
+ columns: string[],
148
+ returnColumns: string[],
149
+ conditions: ConditionDTO[] = [],
150
+ orderBy: OrderByDTO[] = [],
151
+ start = 0,
152
+ length = 100,
153
+ getCount = false
154
+ ) => {
155
+ if (length > 0) {
156
+ sqlRequest({
157
+ columns: columns.includes('Id') ? columns : [...columns, 'Id'],
158
+ returnColumns: returnColumns.includes('Id')
159
+ ? returnColumns
160
+ : [...returnColumns, 'Id'],
161
+ conditions,
162
+ orderBy,
163
+ start,
164
+ length,
165
+ getCount,
166
+ }).then((response) => {
167
+ if (getCount) {
168
+ currentRows.current = Array(response.count).fill(null);
169
+ if (getCount) setCount(response.count ?? 0);
170
+ }
171
+ const data = response.data ?? [];
172
+ const parsedRows = data as T[];
173
+ currentRows.current.splice(start, length, ...parsedRows);
174
+ setRows([...currentRows.current]);
175
+ });
176
+ }
177
+ },
178
+ 100,
179
+ {
180
+ leading: true,
181
+ trailing: true,
182
+ }
183
+ )
184
+ );
185
+
186
+ useEffect(() => {
187
+ if (
188
+ (!rows.length && count < 0) ||
189
+ rows.slice(start, start + length).some((row) => row === null)
190
+ ) {
191
+ loadRows.current(
192
+ columns,
193
+ columns,
194
+ conditions,
195
+ orderBy,
196
+ start,
197
+ length,
198
+ count < 0
199
+ );
200
+ }
201
+ }, [start, length, count, conditions, rows, orderBy, columns]);
202
+
203
+ const onVisibleRowsChanged = useCallback(
204
+ (newStart: number, newLength: number) => {
205
+ if (newStart !== start || newLength !== length) {
206
+ setStart(newStart);
207
+ setLength(newLength);
208
+ }
209
+ },
210
+ [length, start]
211
+ );
212
+
213
+ const ItemTemplate = useMemo(
214
+ () => createItemTemplate<T>(itemTemplate, rowHeight),
215
+ [itemTemplate, rowHeight]
216
+ );
217
+ const ValueTemplate = useMemo(
218
+ () => createValueTemplate<T>(valueTemplate ?? itemTemplate, rowHeight),
219
+ [itemTemplate, rowHeight, valueTemplate]
220
+ );
221
+
222
+ return (
223
+ <>
224
+ <SqlRequestForeignListInput
225
+ tabIndex={0}
226
+ ref={internalRef}
227
+ onClick={open}
228
+ onBlur={onBlur}
229
+ >
230
+ <ValueTemplate item={selectedItem} index={0} />
231
+ <ChevronDownIcon />
232
+ {opened && rect && (
233
+ <Dropdown
234
+ $height={[Math.min(maxRows, rows.length) * rowHeight, 300]}
235
+ $width={rect.width}
236
+ $sourceRect={rect}
237
+ onClose={close}
238
+ usePortal={false}
239
+ >
240
+ <VirtualScroller
241
+ gridTemplateColumns={'1fr'}
242
+ items={rows}
243
+ itemTemplate={ItemTemplate}
244
+ rowHeightInPx={rowHeight}
245
+ itemProps={(item, index) => ({
246
+ item,
247
+ onClick,
248
+ index: index,
249
+ })}
250
+ onRangeChanged={onVisibleRowsChanged}
251
+ ></VirtualScroller>
252
+ </Dropdown>
253
+ )}
254
+ </SqlRequestForeignListInput>
255
+ </>
256
+ );
257
+ };
258
+
259
+ export const SqlRequestForeignList = forwardRef(SqlRequestForeignListInner);